/*
Theme Name: Prestige Protected Child
Theme URI: https://eldarc18.sg-host.com
Description: Child theme of Twenty Twenty-Five for Prestige Protected — air duct, dryer vent & HVAC cleaning in North Carolina. Design system (theme.json tokens) + custom block styling. Built with native Gutenberg blocks and reusable patterns.
Author: LocalWiz
Template: twentytwentyfive
Version: 1.0.3
Requires at least: 6.6
Tested up to: 7.0
Requires PHP: 8.0
Text Domain: prestige-child
*/

/* ============================================================
   PRESTIGE PROTECTED — custom block styling
   Section helper classes are added via block "className".
   All colors pull from theme.json presets (--wp--preset--color--*).
   ============================================================ */

:root {
  --pp-shadow: 0 18px 40px -22px rgba(12, 43, 71, 0.45);
  --pp-shadow-sm: 0 8px 24px -16px rgba(12, 43, 71, 0.40);
  --pp-radius: 16px;
}

/* ---- Eyebrow label above headings ---- */
.pp-eyebrow {
  display: block;
  font-family: var(--wp--preset--font-family--heading);
  font-weight: 700;
  font-size: 0.8rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--wp--preset--color--secondary);
  margin: 0 0 0.35rem;
}
.pp-eyebrow.is-on-dark { color: var(--wp--preset--color--accent); }

/* ---- Section rhythm ---- */
.pp-section { padding-top: var(--wp--preset--spacing--60); padding-bottom: var(--wp--preset--spacing--60); }

/* ---- Remove white gap between sticky header and first section ---- */
.wp-site-blocks > main { margin-block-start: 0; }
.wp-site-blocks main > .wp-block-post-content > :first-child { margin-top: 0; }

/* ---- HERO ---- */
.pp-hero {
  color: #fff;
  background:
    radial-gradient(900px 520px at 88% 18%, rgba(21,184,208,0.28), transparent 60%),
    radial-gradient(760px 600px at 6% 92%, rgba(28,108,168,0.45), transparent 55%),
    var(--wp--preset--gradient--hero);
  border-radius: 0;
  overflow: hidden;
  padding-top: 4rem;
  padding-bottom: 3.5rem;
}
.pp-hero-cols { max-width: 1280px; }
.pp-hero-cols > .wp-block-column:first-child { padding-right: 1.5rem; }

/* hero bottom trust strip */
.pp-hero-trust {
  border-top: 1px solid rgba(255,255,255,0.18);
  padding-top: 1.6rem;
}
.pp-trust-item {
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  color: #fff;
  font-family: var(--wp--preset--font-family--heading);
  font-weight: 600;
  font-size: 0.95rem;
}
.pp-trust-item::before {
  content: "";
  flex: 0 0 auto;
  width: 1.25rem; height: 1.25rem;
  border-radius: 50%;
  background: var(--wp--preset--color--accent) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230C2B47' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/0.78rem no-repeat;
}
.pp-hero :is(h1, h2, h3, p) { color: #fff; }
.pp-hero .pp-hero-list li {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-weight: 600;
}
.pp-hero .pp-hero-list { padding-left: 0; }
.pp-hero .pp-hero-list li::before {
  content: "";
  flex: 0 0 auto;
  width: 1.4rem; height: 1.4rem;
  border-radius: 50%;
  background: var(--wp--preset--color--accent) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230C2B47' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/0.85rem no-repeat;
}
.pp-hero-card {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--pp-radius);
  backdrop-filter: blur(4px);
}

/* ---- Trust badge strip ---- */
.pp-badges img { max-height: 92px; width: auto; object-fit: contain; }
.pp-badges figure { margin: 0; }

/* ---- Generic card ---- */
.pp-card {
  background: var(--wp--preset--color--white);
  border: 1px solid var(--wp--preset--color--line);
  border-radius: var(--pp-radius);
  box-shadow: var(--pp-shadow-sm);
  height: 100%;
  transition: transform .2s ease, box-shadow .2s ease;
}
.pp-card:hover { transform: translateY(-4px); box-shadow: var(--pp-shadow); }
.pp-card .wp-block-heading { margin-top: 0; }

/* ---- Value cards (Excellence Meets Air) ---- */
.pp-values .wp-block-column { display: flex; }
.pp-value-card {
  background: var(--wp--preset--color--white);
  border: 1px solid var(--wp--preset--color--line);
  border-top: 4px solid var(--wp--preset--color--accent);
  border-radius: var(--pp-radius);
  box-shadow: var(--pp-shadow-sm);
  width: 100%;
  transition: transform .2s ease, box-shadow .2s ease;
}
.pp-value-card:hover { transform: translateY(-4px); box-shadow: var(--pp-shadow); }
.pp-value-card .wp-block-heading {
  margin: 0.4rem 0 0.3rem;
  font-size: 1.2rem;
  overflow-wrap: normal;
  word-break: keep-all;
  hyphens: none;
}
.pp-value-card p { margin: 0; }
/* About-with-image row */
.pp-about-media img { border-radius: var(--pp-radius); box-shadow: var(--pp-shadow); }
.pp-stats { gap: 2rem; }
.pp-stat-num { font-family: var(--wp--preset--font-family--heading); font-weight: 800; font-size: 2rem; color: var(--wp--preset--color--secondary); line-height: 1; }
.pp-stat-label { font-size: 0.85rem; color: var(--wp--preset--color--muted); }

/* ---- Service cards: accent top + icon chip ---- */
.pp-service-card { border-top: 4px solid var(--wp--preset--color--accent); }
.pp-icon-chip {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 12px;
  background: var(--wp--preset--color--light);
  color: var(--wp--preset--color--secondary);
  margin-bottom: 0.5rem;
}
.pp-icon-chip svg { width: 30px; height: 30px; }

/* ---- Numbered "why us" steps ---- */
.pp-num {
  font-family: var(--wp--preset--font-family--heading);
  font-weight: 800;
  font-size: 2.4rem;
  line-height: 1;
  color: var(--wp--preset--color--accent);
}

/* ---- 4-step process ---- */
.pp-step-badge {
  width: 64px; height: 64px;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto;
  border-radius: 50%;
  background: var(--wp--preset--color--primary);
  color: #fff;
  font-family: var(--wp--preset--font-family--heading);
  font-weight: 800;
  font-size: 1.4rem;
}

/* ---- CTA band ---- */
.pp-cta-band { background: var(--wp--preset--gradient--cta); color: #fff; border-radius: var(--pp-radius); }
.pp-cta-band :is(h1,h2,h3,p){ color:#fff; }

/* ---- Testimonials ---- */
.pp-review-card { background: var(--wp--preset--color--white); border:1px solid var(--wp--preset--color--line); border-radius: var(--pp-radius); box-shadow: var(--pp-shadow-sm); height:100%; }
.pp-stars { color: var(--wp--preset--color--cta); letter-spacing:2px; font-size:1.1rem; }
.pp-review-name { font-weight:700; color: var(--wp--preset--color--primary); }
.pp-review-loc { color: var(--wp--preset--color--muted); font-size:0.9rem; }

/* ---- Service areas chips ---- */
.pp-areas .wp-block-button__link {
  background: var(--wp--preset--color--light);
  color: var(--wp--preset--color--primary);
  border: 1px solid var(--wp--preset--color--line);
  font-weight: 600;
}
.pp-areas .wp-block-button__link:hover { background: var(--wp--preset--color--primary); color:#fff; }

/* ---- Buttons: secondary outline variant ---- */
.wp-block-button.is-style-outline .wp-block-button__link {
  border: 2px solid currentColor;
  background: transparent;
}
.pp-hero .wp-block-button.is-style-outline .wp-block-button__link { color:#fff; }

/* ---- Section heading helper ---- */
.pp-heading-tight { margin-top: 0.25rem; }

/* ---- Header (dark, premium — reference style) ---- */
.pp-header {
  position: sticky; top: 0; z-index: 50;
  padding-top: 0.6rem; padding-bottom: 0.6rem;
  border-bottom: 3px solid var(--wp--preset--color--accent);
  box-shadow: 0 8px 24px -14px rgba(0,0,0,.55);
}
.pp-header .wp-block-site-logo { display: flex; align-items: center; }
.pp-header .wp-block-site-logo img {
  background: #fff; padding: 6px 12px; border-radius: 10px;
}
.pp-header .wp-block-navigation {
  font-family: var(--wp--preset--font-family--heading);
}
.pp-header .wp-block-navigation a,
.pp-header .wp-block-navigation .wp-block-navigation-item__content {
  color: #fff; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.045em; font-size: 0.82rem; text-decoration: none;
}
.pp-header .wp-block-navigation a:hover,
.pp-header .wp-block-navigation .wp-block-navigation-item__content:hover {
  color: var(--wp--preset--color--accent);
}
.pp-header .wp-block-navigation .wp-block-navigation__submenu-icon { color: #fff; }
/* dropdown panel */
.pp-header .wp-block-navigation .wp-block-navigation__submenu-container {
  background: #0a2540; border: 1px solid rgba(255,255,255,0.14);
  border-radius: 10px; padding: 0.35rem 0; box-shadow: var(--pp-shadow);
}
.pp-header .wp-block-navigation__submenu-container a,
.pp-header .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
  text-transform: none; letter-spacing: 0; font-size: 0.85rem;
}
/* CTA pill */
.pp-header-cta .wp-block-button__link {
  background: var(--wp--preset--color--cta); color: var(--wp--preset--color--primary);
  padding: 0.62rem 1.3rem; border-radius: 999px; font-weight: 700;
}
.pp-header-cta .wp-block-button__link:hover { filter: brightness(1.06); }
.pp-nav-wrap { gap: 1.5rem; }
/* mobile overlay menu */
.pp-header .wp-block-navigation__responsive-container.is-menu-open {
  background: var(--wp--preset--color--primary);
}
.pp-header .wp-block-navigation__responsive-container-open svg { fill: #fff; }

/* ---- Footer ---- */
.pp-footer :is(h3,h4) { color: #fff; }
.pp-footer a { color: #cfe0ef; text-decoration: none; }
.pp-footer a:hover { color: #fff; }
.pp-footer-list { list-style: none; padding-left: 0; margin: 0; }
.pp-footer-list li { margin-bottom: 0.4rem; }

/* ---- Inner-page banner ---- */
.pp-page-hero {
  background:
    radial-gradient(700px 380px at 85% 15%, rgba(21,184,208,0.25), transparent 60%),
    var(--wp--preset--gradient--hero);
}
.pp-page-hero .wp-block-post-title { color: #fff; margin: 0; }
.pp-page-hero-sub { color: rgba(255,255,255,0.85); margin: 0.5rem 0 0; font-family: var(--wp--preset--font-family--heading); font-weight: 600; letter-spacing: 0.02em; }

/* ---- Contact info list ---- */
.pp-contact-item { display: flex; gap: 0.75rem; align-items: flex-start; margin-bottom: 1rem; }
.pp-contact-item .pp-icon-chip { width: 44px; height: 44px; flex: 0 0 auto; }
.pp-contact-item .pp-icon-chip svg { width: 22px; height: 22px; }
.pp-map iframe { width: 100%; border: 0; border-radius: var(--pp-radius); display: block; }
.pp-form-wrap .wpcf7 input:not([type=submit]), .pp-form-wrap .wpcf7 textarea, .pp-form-wrap .wpcf7 select {
  width: 100%; padding: 0.7rem 0.9rem; border: 1px solid var(--wp--preset--color--line);
  border-radius: 10px; font: inherit; margin-top: 0.25rem; background: #fff;
}
.pp-form-wrap .wpcf7 label { display: block; font-weight: 600; margin-bottom: 0.6rem; color: var(--wp--preset--color--primary); font-family: var(--wp--preset--font-family--heading); font-size: 0.9rem; }
.pp-form-wrap .wpcf7 input[type=submit] {
  background: var(--wp--preset--color--cta); color: var(--wp--preset--color--primary);
  border: 0; border-radius: 10px; padding: 0.85rem 1.75rem; font-weight: 700; cursor: pointer;
  font-family: var(--wp--preset--font-family--heading); margin-top: 0.5rem;
}

/* ---- Gallery + video ---- */
.pp-gallery img { border-radius: 12px; }
.wp-block-video video { width: 100%; border-radius: 14px; display: block; }

/* ---- Mobile polish ---- */
@media (max-width: 781px) {
  .pp-hero-card { margin-top: 1.5rem; }
  .pp-num { font-size: 2rem; }
  .pp-header .wp-block-navigation { justify-content: center; }
}

/* ---- Testimonials: section subtitle ---- */
.pp-section-sub {
  max-width: 620px; margin: 0.5rem auto 0; color: var(--wp--preset--color--muted);
  font-size: 1.05rem; line-height: 1.6;
}

/* ---- Google-style review cards ---- */
.pp-greviews {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem;
  margin: 2.5rem auto 0; max-width: var(--wp--style--global--wide-size, 1200px);
}
.pp-greview {
  background: var(--wp--preset--color--white, #fff);
  border: 1px solid var(--wp--preset--color--line, #e3eaf0);
  border-radius: var(--pp-radius); box-shadow: var(--pp-shadow-sm);
  padding: 1.5rem 1.5rem 1.6rem; display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
}
.pp-greview:hover { transform: translateY(-4px); box-shadow: var(--pp-shadow); }
.pp-greview-head { display: flex; align-items: center; gap: 0.85rem; }
.pp-grev-av {
  position: relative; flex: 0 0 auto; width: 46px; height: 46px; border-radius: 50%;
  color: #fff; font-weight: 700; font-size: 1.25rem; line-height: 46px; text-align: center;
  font-family: var(--wp--preset--font-family--heading, sans-serif);
}
.pp-grev-gwrap {
  position: absolute; right: -3px; bottom: -3px; width: 20px; height: 20px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.25);
  display: flex; align-items: center; justify-content: center;
}
.pp-grev-g { width: 13px; height: 13px; display: block; }
.pp-grev-meta { display: flex; flex-direction: column; line-height: 1.25; }
.pp-grev-name { font-weight: 700; color: var(--wp--preset--color--primary, #0C2B47); font-size: 1rem; }
.pp-grev-date { color: var(--wp--preset--color--muted, #6b7a87); font-size: 0.85rem; }
.pp-grev-stars { display: flex; align-items: center; gap: 0.25rem; margin: 0.85rem 0 0.6rem; color: #FBBC04; font-size: 1.05rem; letter-spacing: 1px; }
.pp-grev-verif { display: inline-flex; margin-left: 0.35rem; }
.pp-grev-verif svg { width: 15px; height: 15px; display: block; }
.pp-grev-text { color: var(--wp--preset--color--ink, #14222E); font-size: 0.95rem; line-height: 1.62; margin: 0; }

/* ---- Testimonial videos ---- */
.pp-video-heading { margin-top: 3rem; }
.pp-video-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem;
  margin: 1.5rem auto 0; max-width: var(--wp--style--global--wide-size, 1200px);
}
.pp-video-grid figure.wp-block-video { margin: 0; }
.pp-video-grid video {
  width: 100%; aspect-ratio: 9 / 16; object-fit: cover; background: #000;
  border-radius: 14px; display: block; box-shadow: var(--pp-shadow-sm);
}

/* ---- Testimonials responsive ---- */
@media (max-width: 1024px) {
  .pp-greviews { grid-template-columns: repeat(2, 1fr); }
  .pp-video-grid { grid-template-columns: repeat(3, 1fr); gap: 1rem; }
}
@media (max-width: 781px) {
  .pp-greviews { grid-template-columns: 1fr; }
  .pp-video-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
}
@media (max-width: 480px) {
  .pp-video-grid { grid-template-columns: 1fr; }
}

/* ---- Service-area maps (2 side by side) ---- */
.pp-maps-2up {
  display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem;
  margin: 2rem auto 0; max-width: var(--wp--style--global--wide-size, 1200px);
}
.pp-maps-2up iframe {
  width: 100%; height: 420px; border: 0; border-radius: var(--pp-radius);
  display: block; box-shadow: var(--pp-shadow-sm);
}
@media (max-width: 781px) {
  .pp-maps-2up { grid-template-columns: 1fr; }
  .pp-maps-2up iframe { height: 320px; }
}

/* ===== Mobile header fix (CTA + logo alignment) — added 2026-06-09 ===== */
@media (max-width: 781px) {
  .pp-header > .wp-block-group.alignwide { flex-wrap: nowrap; gap: 0.5rem; align-items: center; }
  .pp-header .wp-block-site-logo,
  .pp-header .wp-block-site-logo img { width: 140px !important; max-width: 140px; }
  .pp-nav-wrap { flex-wrap: nowrap !important; gap: 0.5rem !important; align-items: center; }
  /* override earlier centering so the menu toggle sits right, no overlap */
  .pp-header .wp-block-navigation { justify-content: flex-end !important; flex: 0 0 auto; }
  .pp-header-cta { margin: 0; }
  .pp-header-cta .wp-block-button__link {
    white-space: nowrap;
    padding: 0.55rem 0.9rem;
    font-size: 0.82rem;
    line-height: 1.1;
    min-height: 40px;
    display: inline-flex; align-items: center;
  }
  .pp-header .wp-block-navigation__responsive-container-open { margin-left: 0.15rem; padding: 0.25rem; }
}
@media (max-width: 400px) {
  .pp-header .wp-block-site-logo,
  .pp-header .wp-block-site-logo img { width: 116px !important; max-width: 116px; }
  .pp-header-cta .wp-block-button__link { padding: 0.5rem 0.7rem; font-size: 0.74rem; }
}
