/* Perfect Choice — website kit layout. Composes DS tokens + components. */
* { box-sizing: border-box; }
html, body { margin: 0; }
.pc-site {
  font-family: var(--font-body);
  color: var(--text-body);
  background: var(--color-bg);
  scroll-behavior: smooth;
}
html { scroll-behavior: smooth; }
.pc-container { width: 100%; max-width: var(--container-max); margin: 0 auto; padding-inline: var(--container-pad); }
.pc-sec { padding-block: var(--section-y); }
img { display: block; max-width: 100%; }

/* More presence for on-page content (kit-scoped) */
.pc-sec .pc-heading__title { font-size: clamp(2rem, 3.4vw, 2.875rem); }
.pc-sec .pc-heading__intro { font-size: var(--text-lg); }
.pc-services__grid .pc-service__title { font-size: var(--text-xl); }
.pc-services__grid .pc-service__desc { font-size: var(--text-base); }

/* ---------- Header ---------- */
.pc-hd { position: sticky; top: 0; z-index: 50; transition: background var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.pc-hd--solid { background: var(--surface-card); box-shadow: var(--shadow-sm); }
.pc-hd__inner { max-width: var(--container-wide); margin: 0 auto; padding: 14px clamp(1rem, 3vw, 2.5rem); display: flex; align-items: center; gap: 12px; }
.pc-hd__logo { text-decoration: none; flex: none; }
.pc-hd__nav { display: flex; align-items: center; gap: 1px; margin-left: auto; }
.pc-hd__link { font-size: var(--text-sm); font-weight: 600; color: rgba(255,255,255,.92); text-decoration: none; padding: 8px 6px; border-radius: var(--radius-sm); transition: color var(--dur-fast), background var(--dur-fast); white-space: nowrap; }
.pc-hd__link:hover { background: rgba(255,255,255,.14); }
.pc-hd__link.is-active { color: #fff; }
.pc-hd--solid .pc-hd__link { color: var(--text-body); }
.pc-hd--solid .pc-hd__link:hover { background: var(--surface-sunken); color: var(--brand); }
.pc-hd--solid .pc-hd__link.is-active { color: var(--brand); }
.pc-hd__actions { display: flex; align-items: center; gap: 12px; flex: none; margin-left: auto; }
.pc-hd__phone { display: inline-flex; align-items: center; gap: 8px; font-size: var(--text-sm); font-weight: 700; color: #fff; text-decoration: none; }
.pc-hd--solid .pc-hd__phone { color: var(--text-strong); }
.pc-hd__phone:hover { color: var(--brand); }
.pc-hd__burger { display: none; align-items: center; justify-content: center; width: 42px; height: 42px; border: 0; background: transparent; color: #fff; cursor: pointer; border-radius: var(--radius-sm); }
.pc-hd--solid .pc-hd__burger { color: var(--text-strong); }
.pc-hd__mobile { display: none; flex-direction: column; gap: 4px; background: var(--surface-card); padding: 12px var(--container-pad) 18px; box-shadow: var(--shadow-md); }
.pc-hd__mobile a { padding: 11px 8px; font-weight: 600; color: var(--text-strong); text-decoration: none; border-bottom: 1px solid var(--border-subtle); }
.pc-hd__mobile :last-child { margin-top: 10px; }

/* ---------- Hero ---------- */
.pc-hero { position: relative; margin-top: -76px; min-height: 88vh; display: flex; align-items: center; }
.pc-hero__media { position: absolute; inset: 0; overflow: hidden; }
.pc-hero__media img { width: 100%; height: 100%; object-fit: cover; }
.pc-hero__scrim { position: absolute; inset: 0; background: linear-gradient(100deg, rgba(8,28,50,.92) 0%, rgba(8,28,50,.78) 42%, rgba(10,42,71,.45) 100%); }
.pc-hero__inner { position: relative; width: 100%; max-width: var(--container-max); margin: 0 auto; padding: 120px var(--container-pad) 70px; }
.pc-hero__copy { max-width: 640px; }
.pc-hero__eyebrow { display: inline-flex; align-items: center; gap: 8px; font-size: var(--text-xs); font-weight: 700; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--pc-blue-300); background: rgba(4,155,220,.14); border: 1px solid rgba(4,155,220,.35); padding: 7px 14px; border-radius: var(--radius-pill); }
.pc-hero__title { font-family: var(--font-display); font-weight: 800; font-size: clamp(2.25rem, 8.5vw, 3.75rem); line-height: 1.05; letter-spacing: -0.025em; color: #fff; margin: 20px 0 0; }
.pc-hero__lead { font-size: var(--text-md); line-height: var(--leading-normal); color: rgba(233,240,247,.92); margin: 18px 0 0; max-width: 54ch; }
.pc-hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.pc-hero__trust { display: flex; flex-wrap: wrap; gap: 22px; margin-top: 28px; }
.pc-hero__trust span { display: inline-flex; align-items: center; gap: 8px; font-size: var(--text-sm); font-weight: 600; color: rgba(255,255,255,.9); }
.pc-hero__trust svg { color: var(--pc-blue-300); }

/* ---------- Services ---------- */
.pc-services__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; margin-top: 46px; }

/* ---------- About ---------- */
.pc-about { background: var(--surface-card); }
.pc-about__grid { display: grid; grid-template-columns: 0.85fr 1fr; gap: 56px; align-items: center; }
.pc-about__media { position: relative; }
.pc-about__media img { width: 100%; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); aspect-ratio: 4/5; object-fit: cover; }
.pc-about__badge { position: absolute; left: 18px; bottom: 18px; display: flex; align-items: center; gap: 12px; background: #fff; padding: 13px 18px; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); color: var(--brand); }
.pc-about__badge strong { display: block; font-family: var(--font-display); font-size: var(--text-base); color: var(--text-strong); }
.pc-about__badge span { font-size: var(--text-xs); color: var(--text-muted); }
.pc-about__p { font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-body); margin: 20px 0 0; max-width: 60ch; }
.pc-about__stats { display: flex; gap: 38px; margin: 28px 0; flex-wrap: wrap; }

/* ---------- Why (navy band) ---------- */
.pc-why { background: var(--surface-inverse); position: relative; }
.pc-why__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; margin-top: 44px; }
.pc-why__item h3 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: #fff; margin: 16px 0 8px; letter-spacing: -0.01em; }
.pc-why__item p { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--pc-navy-200); margin: 0; }
.pc-why__ico { display: inline-flex; align-items: center; justify-content: center; width: 52px; height: 52px; border-radius: var(--radius-md); background: rgba(4,155,220,.16); color: var(--pc-blue-300); border: 1px solid rgba(4,155,220,.3); }

/* ---------- Additional ---------- */
.pc-additional__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; margin-top: 40px; }
.pc-xcard { display: grid; grid-template-columns: 0.8fr 1fr; overflow: hidden; }
.pc-xcard__media { overflow: hidden; }
.pc-xcard__media img { width: 100%; height: 100%; object-fit: cover; min-height: 220px; }
.pc-xcard__body { padding: var(--space-6); display: flex; flex-direction: column; gap: 10px; }
.pc-xcard__ico { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: var(--radius-md); background: var(--surface-brand-soft); color: var(--brand); }
.pc-xcard__body h3 { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--text-strong); margin: 4px 0 0; letter-spacing: -0.015em; }
.pc-xcard__body p { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--text-muted); margin: 0; flex: 1; }
.pc-xcard__more { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: var(--text-sm); color: var(--brand); text-decoration: none; }
.pc-xcard__more:hover { color: var(--brand-hover); }

/* ---------- Contact (navy) ---------- */
.pc-contact { background: linear-gradient(180deg, var(--pc-navy-800), var(--pc-navy-900)); }
.pc-contact__grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 56px; align-items: start; }
.pc-contact__methods { list-style: none; padding: 0; margin: 30px 0 0; display: flex; flex-direction: column; gap: 12px; }
.pc-contact__methods a { display: flex; align-items: center; gap: 14px; text-decoration: none; color: #fff; padding: 12px 14px; border-radius: var(--radius-md); border: 1px solid rgba(255,255,255,.12); transition: background var(--dur-fast), border-color var(--dur-fast); }
.pc-contact__methods a:hover { background: rgba(255,255,255,.06); border-color: rgba(4,155,220,.5); }
.pc-contact__ico { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: var(--radius-sm); background: rgba(4,155,220,.18); color: var(--pc-blue-300); flex: none; }
.pc-contact__methods strong { display: block; font-size: var(--text-sm); }
.pc-contact__methods em { font-style: normal; font-size: var(--text-xs); color: var(--pc-navy-200); }
.pc-contact__addr { display: flex; align-items: center; gap: 9px; margin-top: 20px; color: var(--pc-navy-200); font-size: var(--text-sm); }
.pc-contact__addr svg { color: var(--pc-blue-300); }
.pc-contact__card { background: var(--surface-card); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); padding: var(--space-7); }
.pc-contact__formtitle { font-family: var(--font-display); font-size: var(--text-xl); font-weight: 700; color: var(--text-strong); margin: 0 0 20px; }
.pc-contact__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.pc-contact__card form { display: flex; flex-direction: column; gap: 16px; }
.pc-contact__fine { font-size: var(--text-xs); color: var(--text-subtle); margin: 0; text-align: center; }
.pc-contact__hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.pc-contact__done { text-align: center; padding: 22px 8px; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.pc-contact__check { display: inline-flex; align-items: center; justify-content: center; width: 72px; height: 72px; border-radius: 999px; background: var(--status-pass-bg); color: var(--status-pass); }
.pc-contact__done h3 { font-family: var(--font-display); font-size: var(--text-2xl); color: var(--text-strong); margin: 6px 0 0; }
.pc-contact__done p { color: var(--text-muted); max-width: 40ch; margin: 0 0 8px; line-height: var(--leading-normal); }

/* ---------- Footer ---------- */
.pc-ft { background: var(--pc-navy-900); color: var(--pc-navy-200); padding-top: var(--space-9); }
.pc-ft__top { display: grid; grid-template-columns: 1.6fr 1fr 1fr; gap: 40px; padding-bottom: var(--space-8); }
.pc-ft__brand p { font-size: var(--text-sm); line-height: var(--leading-normal); margin: 18px 0; max-width: 38ch; }
.pc-ft__contact { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.pc-ft__contact li { display: flex; align-items: center; gap: 10px; font-size: var(--text-sm); }
.pc-ft__contact svg { color: var(--pc-blue-300); flex: none; }
.pc-ft__contact a { color: var(--pc-navy-200); text-decoration: none; }
.pc-ft__contact a:hover { color: #fff; }
.pc-ft__col h4 { font-family: var(--font-display); color: #fff; font-size: var(--text-sm); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; margin: 0 0 16px; }
.pc-ft__col a { display: block; color: var(--pc-navy-200); text-decoration: none; font-size: var(--text-sm); padding: 6px 0; }
.pc-ft__col a:hover { color: var(--pc-blue-300); }
.pc-ft__bottom { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding: 22px var(--container-pad); border-top: 1px solid rgba(255,255,255,.1); font-size: var(--text-xs); color: var(--pc-navy-300); }

/* ---------- Responsive ---------- */
@media (max-width: 1000px) {
  .pc-services__grid { grid-template-columns: 1fr 1fr; }
  .pc-why__grid { grid-template-columns: 1fr 1fr; }
  .pc-about__grid, .pc-contact__grid, .pc-additional__grid { grid-template-columns: 1fr; gap: 36px; }
  .pc-xcard { grid-template-columns: 1fr; }
  .pc-xcard__media img { min-height: 200px; }
  .pc-ft__top { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 1180px) {
  .pc-hd__phone { display: none; }
}
@media (max-width: 860px) {
  .pc-hd__nav { display: none; }
  .pc-hd__burger { display: inline-flex; }
  .pc-hd--open .pc-hd__mobile, .pc-hd__mobile { display: flex; }
}
@media (max-width: 720px) {
  .pc-services__grid { grid-template-columns: 1fr; }
  .pc-why__grid { grid-template-columns: 1fr; }
  .pc-hero__inner { padding-top: 104px; padding-bottom: 56px; }
  .pc-hero { min-height: 78vh; }
  .pc-ft__top { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  /* Header: drop the CTA button (it's in the mobile menu) so logo + burger never collide */
  .pc-hd__actions .pc-btn { display: none; }
  .pc-hd__inner { gap: 8px; }
  .pc-hero__trust { gap: 10px 18px; }
  .pc-hero__cta { gap: 10px; }
  .pc-hero__cta .pc-btn { width: 100%; }
  /* Mobile menu: roomier touch targets */
  .pc-hd__mobile { gap: 0; padding-bottom: 16px; }
  .pc-hd__mobile a { padding: 14px 6px; }
  .pc-hd__mobile :last-child { margin-top: 14px; }
  /* Stack the name row; tighten stat gaps; trim card padding */
  .pc-contact__row { grid-template-columns: 1fr; }
  .pc-about__stats, .pc-loc-intro__stats { gap: 18px 26px; }
  .pc-contact__card { padding: var(--space-5); }
}

/* ===================== Interior pages ===================== */
/* Page hero (compact navy band) */
.pc-phero { position: relative; overflow: hidden; background: linear-gradient(105deg, var(--pc-navy-800), var(--pc-navy-700)); padding-block: clamp(48px, 7vw, 84px); }
.pc-phero__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .28; }
.pc-phero__scrim { position: absolute; inset: 0; background: linear-gradient(105deg, rgba(8,28,50,.92), rgba(14,42,71,.7)); }
.pc-phero__inner { position: relative; }
.pc-phero__eyebrow { display: inline-block; font-size: var(--text-xs); font-weight: 700; letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--pc-blue-300); }
.pc-phero__title { font-family: var(--font-display); font-weight: 800; font-size: var(--text-3xl); letter-spacing: -0.025em; color: #fff; margin: 12px 0 0; line-height: 1.06; }
.pc-phero__intro { font-size: var(--text-md); line-height: var(--leading-normal); color: rgba(233,240,247,.9); margin: 16px 0 0; max-width: 64ch; }

/* Pricing packages */
.pc-price__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 44px; align-items: start; }
.pc-card.pc-price { position: relative; overflow: visible; padding: var(--space-6) var(--space-5) var(--space-5); display: flex; flex-direction: column; }
.pc-price--featured { border: 2px solid var(--brand); box-shadow: var(--shadow-lg); }
.pc-price__flag { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--brand); color: #fff; font-size: var(--text-2xs); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; padding: 5px 13px; border-radius: var(--radius-pill); white-space: nowrap; }
.pc-price__head h3 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--text-strong); margin: 0; letter-spacing: -0.01em; }
.pc-price__sub { font-size: var(--text-xs); color: var(--text-subtle); font-weight: 600; }
.pc-price__rows { list-style: none; padding: 0; margin: 18px 0 0; display: flex; flex-direction: column; }
.pc-price__rows li { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 11px 0; border-top: 1px solid var(--border-subtle); }
.pc-price__rows li.is-best { border-top-color: var(--pc-blue-200); }
.pc-price__lbl { display: flex; align-items: center; gap: 7px; font-size: var(--text-sm); color: var(--text-body); flex-wrap: wrap; }
.pc-price__rows li.is-best .pc-price__lbl { color: var(--text-strong); font-weight: 600; }
.pc-price__rows li.is-best .pc-price__lbl svg { color: var(--status-pass); }
.pc-price__amt { font-family: var(--font-display); font-weight: 700; font-size: var(--text-md); color: var(--text-strong); flex: none; }
.pc-price__rows li.is-best .pc-price__amt { color: var(--brand); }
.pc-price__note { font-size: var(--text-xs); color: var(--text-muted); margin: 14px 0 0; font-style: italic; }
.pc-price__disclaimer { text-align: center; max-width: 64ch; margin: 36px auto 0; font-size: var(--text-sm); color: var(--text-muted); }
.pc-price__disclaimer a { color: var(--text-link); font-weight: 700; text-decoration: none; }

/* Add-ons */
.pc-addons { background: var(--surface-card); }
.pc-addons__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 40px; }
.pc-addon { display: flex; flex-direction: column; gap: 6px; }
.pc-addon__ico { display: inline-flex; align-items: center; justify-content: center; width: 48px; height: 48px; border-radius: var(--radius-md); background: var(--surface-brand-soft); color: var(--brand); margin-bottom: 8px; }
.pc-addon h3 { font-family: var(--font-display); font-size: var(--text-base); font-weight: 700; color: var(--text-strong); margin: 0; }
.pc-addon__price { font-family: var(--font-display); font-weight: 800; font-size: var(--text-xl); color: var(--brand); margin: 4px 0; letter-spacing: -0.02em; }
.pc-addon__tiers { list-style: none; padding: 0; margin: 8px 0; display: flex; flex-direction: column; gap: 0; }
.pc-addon__tiers li { display: flex; justify-content: space-between; gap: 10px; padding: 7px 0; border-top: 1px solid var(--border-subtle); font-size: var(--text-sm); color: var(--text-body); }
.pc-addon__tiers strong { font-family: var(--font-display); color: var(--text-strong); }
.pc-addon__note { font-size: var(--text-xs); color: var(--text-subtle); margin: auto 0 0; padding-top: 6px; }

/* Sample reports */
.pc-reports__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 44px; }
.pc-report { padding: var(--space-6); display: flex; flex-direction: column; gap: 10px; }
.pc-report__top { display: flex; align-items: center; justify-content: space-between; }
.pc-report__ico { display: inline-flex; align-items: center; justify-content: center; width: 50px; height: 50px; border-radius: var(--radius-md); background: var(--surface-brand-soft); color: var(--brand); }
.pc-report h3 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--text-strong); margin: 4px 0 0; letter-spacing: -0.01em; }
.pc-report p { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--text-muted); margin: 0; flex: 1; }
.pc-report__link { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: var(--text-sm); color: var(--brand); text-decoration: none; margin-top: 4px; }
.pc-report__link:hover { color: var(--brand-hover); }

/* What's inside */
.pc-inside { background: var(--surface-card); }
.pc-inside__grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: 52px; align-items: center; }
.pc-inside__list { list-style: none; padding: 0; margin: 24px 0 0; display: flex; flex-direction: column; gap: 12px; }
.pc-inside__list li { display: flex; align-items: center; gap: 12px; font-size: var(--text-base); color: var(--text-body); }
.pc-inside__ck { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 999px; background: var(--status-pass-bg); color: var(--status-pass); flex: none; }
.pc-preview { overflow: hidden; }
.pc-preview__bar { display: flex; align-items: center; gap: 7px; padding: 12px 16px; background: var(--surface-sunken); border-bottom: 1px solid var(--border-subtle); }
.pc-preview__dot { width: 10px; height: 10px; border-radius: 999px; background: var(--border-strong); }
.pc-preview__file { margin-left: 10px; font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-muted); }
.pc-preview__body { padding: var(--space-5); }
.pc-preview__meta { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 18px; padding-bottom: 16px; margin-bottom: 8px; border-bottom: 1px solid var(--border-subtle); }
.pc-preview__meta em { display: block; font-style: normal; font-size: var(--text-2xs); letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-subtle); }
.pc-preview__meta strong { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--text-strong); font-weight: 600; }
.pc-preview__rows { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; }
.pc-preview__rows li { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 10px 0; border-top: 1px solid var(--border-subtle); }
.pc-preview__rows li:first-child { border-top: 0; }
.pc-preview__rows span { font-size: var(--text-sm); font-weight: 600; color: var(--text-body); }

/* CTA band */
.pc-ctaband { background: linear-gradient(180deg, var(--pc-navy-800), var(--pc-navy-900)); }
.pc-ctaband__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: center; padding-block: var(--section-y); }
.pc-ctaband__head h2 { font-family: var(--font-display); font-weight: 800; font-size: var(--text-2xl); letter-spacing: -0.02em; color: #fff; margin: 0; }
.pc-ctaband__head p { font-size: var(--text-md); color: var(--pc-navy-200); margin: 12px 0 22px; line-height: var(--leading-normal); }
.pc-ctaband__ways { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.pc-ctaband__ways a { display: flex; align-items: center; gap: 14px; text-decoration: none; color: #fff; padding: 14px 16px; border-radius: var(--radius-md); border: 1px solid rgba(255,255,255,.12); transition: background var(--dur-fast), border-color var(--dur-fast); }
.pc-ctaband__ways a:hover { background: rgba(255,255,255,.06); border-color: rgba(4,155,220,.5); }
.pc-ctaband__ico { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: var(--radius-sm); background: rgba(4,155,220,.18); color: var(--pc-blue-300); flex: none; }
.pc-ctaband__ways strong { display: block; font-size: var(--text-sm); }
.pc-ctaband__ways em { font-style: normal; font-size: var(--text-xs); color: var(--pc-navy-200); }

@media (max-width: 1000px) {
  .pc-price__grid { grid-template-columns: 1fr 1fr; }
  .pc-addons__grid { grid-template-columns: 1fr 1fr; }
  .pc-reports__grid { grid-template-columns: 1fr; }
  .pc-inside__grid, .pc-ctaband__inner { grid-template-columns: 1fr; gap: 32px; }
}
@media (max-width: 720px) {
  .pc-price__grid, .pc-addons__grid { grid-template-columns: 1fr; }
  .pc-phero__title { font-size: var(--text-2xl); }
}

/* ===================== Service Areas dropdown (nav) ===================== */
.pc-areas { position: relative; }
.pc-areas__btn { display: inline-flex; align-items: center; gap: 5px; border: 0; background: transparent; cursor: pointer; font-family: var(--font-body); }
.pc-areas__caret { transition: transform var(--dur-fast) var(--ease-out); }
.pc-areas__btn.is-open .pc-areas__caret { transform: rotate(90deg); }
.pc-areas__menu { position: absolute; top: calc(100% + 10px); left: 50%; transform: translateX(-50%); width: 320px; background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); padding: 10px; z-index: 60; display: flex; flex-direction: column; gap: 2px; }
.pc-areas__county { display: flex; align-items: center; gap: 12px; padding: 11px 12px; border-radius: var(--radius-md); text-decoration: none; color: var(--text-strong); transition: background var(--dur-fast); }
.pc-areas__county:hover { background: var(--surface-brand-soft); }
.pc-areas__ico { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: var(--radius-sm); background: var(--surface-brand-soft); color: var(--brand); flex: none; }
.pc-areas__county:hover .pc-areas__ico { background: var(--brand); color: #fff; }
.pc-areas__county strong { display: block; font-size: var(--text-sm); }
.pc-areas__county em { font-style: normal; font-size: var(--text-xs); color: var(--text-muted); }
.pc-areas__all { display: flex; align-items: center; justify-content: center; gap: 7px; margin-top: 6px; padding: 11px; border-top: 1px solid var(--border-subtle); color: var(--brand); font-weight: 700; font-size: var(--text-sm); text-decoration: none; }
.pc-areas__all:hover { color: var(--brand-hover); }

/* ===================== Commercial feature strip (in Services) ===================== */
.pc-commercial { display: grid; grid-template-columns: 1fr 1.3fr; gap: 0; margin-top: 26px; background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); overflow: hidden; }
.pc-commercial__media { overflow: hidden; min-height: 240px; }
.pc-commercial__media img { width: 100%; height: 100%; object-fit: cover; }
.pc-commercial__body { padding: var(--space-7); display: flex; flex-direction: column; gap: 12px; align-items: flex-start; justify-content: center; }
.pc-commercial__ico { display: inline-flex; align-items: center; justify-content: center; width: 50px; height: 50px; border-radius: var(--radius-md); background: var(--surface-brand-soft); color: var(--brand); }
.pc-commercial__body h3 { font-family: var(--font-display); font-size: var(--text-2xl); font-weight: 700; color: var(--text-strong); margin: 4px 0 0; letter-spacing: -0.02em; }
.pc-commercial__body p { font-size: var(--text-base); line-height: var(--leading-normal); color: var(--text-muted); margin: 0; max-width: 56ch; }

/* ===================== Service Areas section (search-first) ===================== */
.pc-areas-sec { background: var(--surface-card); }
.pc-areas-sec__search { position: relative; max-width: 540px; margin: 36px auto 0; display: flex; align-items: center; }
.pc-areas-sec__searchico { position: absolute; left: 18px; color: var(--text-subtle); display: flex; pointer-events: none; }
.pc-areas-sec__search input { width: 100%; font-family: var(--font-body); font-size: var(--text-md); color: var(--text-strong); background: var(--surface-card); border: 2px solid var(--border-default); border-radius: var(--radius-pill); padding: 15px 48px 15px 50px; box-shadow: var(--shadow-sm); transition: border-color var(--dur-fast), box-shadow var(--dur-fast); }
.pc-areas-sec__search input::placeholder { color: var(--text-subtle); }
.pc-areas-sec__search input:focus { outline: none; border-color: var(--brand); box-shadow: var(--focus-ring); }
.pc-areas-sec__clear { position: absolute; right: 14px; width: 28px; height: 28px; border: 0; border-radius: 999px; background: var(--surface-sunken); color: var(--text-muted); cursor: pointer; font-size: 13px; display: flex; align-items: center; justify-content: center; }
.pc-areas-sec__clear:hover { background: var(--border-default); color: var(--text-strong); }

/* County cards (default state) */
.pc-areas-sec__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 40px; }
.pc-areas-card { padding: var(--space-6); display: flex; flex-direction: column; scroll-margin-top: 90px; }
.pc-areas-card__head { display: flex; align-items: center; gap: 13px; padding-bottom: 18px; margin-bottom: 16px; border-bottom: 1px solid var(--border-subtle); }
.pc-areas-card__ico { display: inline-flex; align-items: center; justify-content: center; width: 46px; height: 46px; border-radius: var(--radius-md); background: var(--surface-brand-soft); color: var(--brand); flex: none; }
.pc-areas-card__head h3 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--text-strong); margin: 0; letter-spacing: -0.01em; }
.pc-areas-card__count { font-size: var(--text-xs); color: var(--text-subtle); font-weight: 600; }
.pc-areas-card__towns { list-style: none; padding: 0; margin: 0 0 18px; display: grid; grid-template-columns: 1fr 1fr; gap: 4px 12px; flex: 1; }
.pc-areas-card__towns a { display: block; padding: 6px 0; font-size: var(--text-sm); color: var(--text-body); text-decoration: none; transition: color var(--dur-fast); }
.pc-areas-card__towns a:hover { color: var(--brand); }
.pc-areas-card__all { display: inline-flex; align-items: center; gap: 7px; font-weight: 700; font-size: var(--text-sm); color: var(--brand); text-decoration: none; margin-top: auto; }
.pc-areas-card__all:hover { color: var(--brand-hover); }
.pc-areas-card__all svg { transition: transform var(--dur-fast); }
.pc-areas-card__all:hover svg { transform: translateX(3px); }

/* Search results */
.pc-areas-sec__results { margin-top: 28px; min-height: 120px; }
.pc-areas-sec__count { text-align: center; font-size: var(--text-sm); color: var(--text-muted); margin: 0 0 18px; }
.pc-areas-sec__chips { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.pc-areas-sec__chips a { display: inline-flex; align-items: center; gap: 8px; padding: 9px 16px; border-radius: var(--radius-pill); border: 1px solid var(--border-default); font-size: var(--text-sm); font-weight: 600; color: var(--text-strong); text-decoration: none; transition: all var(--dur-fast); }
.pc-areas-sec__chips a:hover { border-color: var(--brand); background: var(--surface-brand-soft); }
.pc-areas-sec__chips svg { color: var(--brand); flex: none; }
.pc-areas-sec__chips em { font-style: normal; font-size: var(--text-2xs); color: var(--text-subtle); font-weight: 500; }
.pc-areas-sec__empty { text-align: center; padding: 30px 0; color: var(--text-muted); }
.pc-areas-sec__empty p { margin: 0 0 6px; }
.pc-areas-sec__empty a { color: var(--text-link); font-weight: 700; text-decoration: none; }

.pc-areas-sec__note { text-align: center; margin: 36px auto 0; font-size: var(--text-sm); color: var(--text-muted); }
.pc-areas-sec__note a { color: var(--text-link); font-weight: 700; text-decoration: none; }

/* ===================== Location page ===================== */
.pc-loc-intro__grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 52px; align-items: center; }
.pc-loc-intro__p { font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-body); margin: 18px 0 0; max-width: 60ch; }
.pc-loc-intro__stats { display: flex; gap: 36px; margin-top: 26px; flex-wrap: wrap; }
.pc-loc-intro__media img { width: 100%; border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); aspect-ratio: 4/5; object-fit: cover; }
.pc-loc-nearby { background: var(--surface-card); }
.pc-loc-nearby__list { list-style: none; padding: 0; margin: 36px 0 0; display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.pc-loc-nearby__list a { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; border-radius: var(--radius-pill); border: 1px solid var(--border-default); font-size: var(--text-sm); font-weight: 600; color: var(--text-body); text-decoration: none; transition: all var(--dur-fast); }
.pc-loc-nearby__list a:hover { border-color: var(--brand); color: var(--brand); background: var(--surface-brand-soft); }
.pc-loc-nearby__list svg { color: var(--brand); }
.pc-loc-nearby__all { border-color: var(--brand) !important; color: var(--brand) !important; }

@media (max-width: 1000px) {
  .pc-commercial { grid-template-columns: 1fr; }
  .pc-areas-sec__grid { grid-template-columns: 1fr; gap: 28px; }
  .pc-loc-intro__grid { grid-template-columns: 1fr; gap: 32px; }
  .pc-loc-intro__media { order: -1; }
}

/* ===================== Location page — SEO depth ===================== */
.pc-breadcrumb { background: var(--surface-card); border-bottom: 1px solid var(--border-subtle); }
.pc-breadcrumb .pc-container { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding-block: 14px; font-size: var(--text-xs); }
.pc-breadcrumb a { color: var(--text-muted); text-decoration: none; }
.pc-breadcrumb a:hover { color: var(--brand); }
.pc-breadcrumb span { color: var(--border-strong); }
.pc-breadcrumb em { font-style: normal; color: var(--text-strong); font-weight: 600; }

.pc-loc-intro__cta { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 26px; }
.pc-loc-intro__media { position: relative; }
.pc-loc-intro__badge { position: absolute; left: 18px; bottom: 18px; display: flex; align-items: center; gap: 12px; background: #fff; padding: 13px 18px; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); color: var(--brand); }
.pc-loc-intro__badge strong { display: block; font-family: var(--font-display); font-size: var(--text-base); color: var(--text-strong); }
.pc-loc-intro__badge span { font-size: var(--text-xs); color: var(--text-muted); }

.pc-coverage { background: var(--surface-card); }
.pc-coverage__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 44px; }
.pc-coverage__card { display: flex; flex-direction: column; gap: 8px; }
.pc-coverage__ck { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: var(--radius-md); background: var(--status-pass-bg); color: var(--status-pass); margin-bottom: 6px; }
.pc-coverage__card h3 { font-family: var(--font-display); font-size: var(--text-md); font-weight: 700; color: var(--text-strong); margin: 0; letter-spacing: -0.01em; }
.pc-coverage__card p { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--text-muted); margin: 0; }

.pc-locctx__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 40px; }
.pc-locctx__card { display: flex; flex-direction: column; gap: 10px; }
.pc-locctx__ico { display: inline-flex; align-items: center; justify-content: center; width: 50px; height: 50px; border-radius: var(--radius-md); background: var(--surface-brand-soft); color: var(--brand); }
.pc-locctx__card h3 { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; color: var(--text-strong); margin: 0; letter-spacing: -0.01em; }
.pc-locctx__card p { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--text-muted); margin: 0; }

/* FAQ accordion */
.pc-faq__wrap { max-width: 820px; }
.pc-faq__list { margin-top: 36px; display: flex; flex-direction: column; gap: 12px; }
.pc-faq__item { background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); overflow: hidden; transition: border-color var(--dur-fast), box-shadow var(--dur-fast); }
.pc-faq__item.is-open { border-color: var(--border-default); box-shadow: var(--shadow-sm); }
.pc-faq__q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 18px 20px; background: transparent; border: 0; cursor: pointer; text-align: left; font-family: var(--font-display); font-weight: 600; font-size: var(--text-md); color: var(--text-strong); }
.pc-faq__chev { font-family: var(--font-body); font-size: var(--text-xl); color: var(--brand); flex: none; line-height: 1; }
.pc-faq__a { overflow: hidden; transition: max-height var(--dur-base) var(--ease-out); }
.pc-faq__a p { margin: 0; padding: 0 20px 20px; font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-body); }

@media (max-width: 1000px) {
  .pc-coverage__grid, .pc-locctx__grid { grid-template-columns: 1fr; }
}

/* Static location pages: native <details> FAQ + JS-toggle mobile menu */
details.pc-faq__item > summary.pc-faq__q { list-style: none; }
details.pc-faq__item > summary.pc-faq__q::-webkit-details-marker { display: none; }
details.pc-faq__item[open] { border-color: var(--border-default); box-shadow: var(--shadow-sm); }
details.pc-faq__item .pc-faq__a { max-height: none; }
.pc-faq__chev::before { content: "+"; }
details.pc-faq__item[open] .pc-faq__chev::before { content: "\2013"; }

/* ===== Static-page component CSS (normally injected by React at runtime) ===== */
.pc-btn{--_pad:0 20px;--_h:44px;--_fs:15px;display:inline-flex;align-items:center;justify-content:center;gap:9px;height:var(--_h);padding:var(--_pad);font-family:var(--font-body);font-size:var(--_fs);font-weight:700;letter-spacing:-0.01em;border-radius:var(--radius-pill);border:2px solid transparent;cursor:pointer;text-decoration:none;white-space:nowrap;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);}
.pc-btn:active{transform:translateY(1px);}
.pc-btn:focus-visible{outline:none;box-shadow:var(--focus-ring);}
.pc-btn[disabled]{opacity:.5;cursor:not-allowed;transform:none;}
.pc-btn--sm{--_h:36px;--_pad:0 15px;--_fs:14px;}
.pc-btn--lg{--_h:54px;--_pad:0 30px;--_fs:17px;}
.pc-btn--block{display:flex;width:100%;}
.pc-btn--primary{background:var(--brand);color:var(--brand-contrast);border-color:var(--pc-blue-800);box-shadow:var(--shadow-sm);}
.pc-btn--primary:hover:not([disabled]){background:var(--brand-hover);border-color:var(--pc-blue-900);box-shadow:var(--shadow-brand);}
.pc-btn--accent{background:var(--accent);color:var(--pc-navy-800);border-color:var(--accent-hover);box-shadow:var(--shadow-sm);}
.pc-btn--accent:hover:not([disabled]){background:var(--accent-hover);border-color:var(--pc-amber-600);color:#fff;}
.pc-btn--secondary{background:transparent;color:var(--text-strong);border-color:var(--border-strong);}
.pc-btn--secondary:hover:not([disabled]){border-color:var(--pc-navy-800);background:var(--surface-sunken);}
.pc-btn--ghost{background:transparent;color:var(--brand);}
.pc-btn--ghost:hover:not([disabled]){background:var(--surface-brand-soft);}
.pc-btn--inverse{background:#fff;color:var(--pc-navy-800);border-color:rgba(14,42,71,.12);}
.pc-btn--inverse:hover:not([disabled]){background:var(--pc-blue-50);border-color:var(--pc-blue-200);}
.pc-field{display:flex;flex-direction:column;gap:7px;font-family:var(--font-body);width:100%;}
.pc-field__label{font-size:var(--text-sm);font-weight:600;color:var(--text-strong);}
.pc-field__req{color:var(--status-defect);margin-left:2px;}
.pc-input,.pc-textarea{width:100%;font-family:var(--font-body);font-size:var(--text-base);color:var(--text-strong);background:var(--surface-card);border:2px solid var(--border-default);border-radius:var(--radius-md);padding:12px 14px;transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);box-sizing:border-box;}
.pc-input::placeholder,.pc-textarea::placeholder{color:var(--text-subtle);}
.pc-input:hover,.pc-textarea:hover{border-color:var(--border-strong);}
.pc-input:focus,.pc-textarea:focus{outline:none;border-color:var(--brand);box-shadow:var(--focus-ring);}
.pc-textarea{resize:vertical;min-height:108px;line-height:var(--leading-normal);}
