/* ============================================================
   C&C Roofing Solutions — home.css
   Bespoke, hand-built homepage system. "Northern Shield".
   Dark navy cinematic + brand orange. Built on styles.css tokens.
   ============================================================ */

/* ---- shared section scaffolding ---------------------------------- */
.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,64px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{margin-bottom:.35em}
.section-head .lede{color:var(--muted);max-width:62ch}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-head);font-size:.74rem;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.eyebrow::before{content:"";width:26px;height:2px;background:linear-gradient(90deg,var(--accent),transparent);border-radius:2px}
.eyebrow.center{justify-content:center}
.section-num{font-family:var(--font-head);font-size:.78rem;letter-spacing:.2em;color:var(--muted);opacity:.6}
.divider-rule{height:1px;border:0;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:0}

/* decorative oversized watermark wordmark behind sections */
.watermark{position:absolute;inset-inline:0;pointer-events:none;font-family:var(--font-head);font-weight:700;letter-spacing:-.04em;line-height:.8;
  font-size:clamp(5rem,20vw,18rem);color:transparent;-webkit-text-stroke:1px color-mix(in srgb,var(--accent) 16%,transparent);text-stroke:1px color-mix(in srgb,var(--accent) 16%,transparent);
  opacity:.5;user-select:none;z-index:0;white-space:nowrap;text-align:center}
.watermark--top{top:-.15em}
.watermark--mid{top:50%;translate:0 -50%}

/* gradient display type (kit) */
.grad-text{background:linear-gradient(100deg,var(--foreground) 0%,var(--accent) 55%,var(--accent2) 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}

/* ================================================================
   HERO
   ================================================================ */
.hero{min-height:100svh;display:flex;align-items:flex-end;padding-bottom:clamp(40px,6vw,72px)}
.hero__poster{background:#081120;background-image:linear-gradient(180deg,rgba(8,17,32,.62) 0%,rgba(8,17,32,.78) 55%,rgba(8,17,32,.96) 100%),url("../img/new-roof-installations-parry-sound-11.webp");
  background-size:cover;background-position:center 32%}
#hero-gl{z-index:-1;opacity:.9;mix-blend-mode:screen}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(120% 80% at 78% 8%,color-mix(in srgb,var(--accent) 20%,transparent),transparent 55%)}
.hero__content{width:100%;padding-block:0}
.hero__inner{max-width:920px}
.hero__badges{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:26px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;font-size:.8rem;font-weight:600;letter-spacing:.02em;
  padding:8px 14px;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--surface) 70%,transparent);
  border:1px solid var(--border);backdrop-filter:blur(8px);color:var(--foreground)}
.hero-badge svg{width:16px;height:16px;color:var(--accent)}
.hero h1{font-size:clamp(2.7rem,7.2vw,5.6rem);margin-bottom:.32em;text-shadow:0 2px 40px rgba(0,0,0,.4)}
.hero h1 .accent{color:var(--accent)}
.hero__lede{font-size:clamp(1.1rem,1.7vw,1.4rem);color:#dbe6f2;max-width:60ch;margin-bottom:32px}
.hero__cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero__phone{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-head);font-weight:600;font-size:1.05rem;color:var(--foreground)}
.hero__phone svg{width:22px;height:22px;color:var(--accent)}
.hero__phone small{display:block;font-family:var(--font-body);font-weight:500;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.hero__scroll{position:absolute;left:50%;bottom:18px;translate:-50% 0;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--muted);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;z-index:3}
.hero__scroll span{width:1px;height:42px;background:linear-gradient(var(--accent),transparent);position:relative;overflow:hidden}
.hero__scroll span::after{content:"";position:absolute;inset:0;background:var(--foreground);animation:scrolldrop 2.2s var(--ease-premium) infinite}
@keyframes scrolldrop{0%{transform:translateY(-100%)}60%,100%{transform:translateY(100%)}}
@media (prefers-reduced-motion:reduce){.hero__scroll span::after{animation:none}}

/* hero stat ribbon */
.hero__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;margin-top:clamp(36px,5vw,56px);
  background:var(--border);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}
.hero__stat{background:color-mix(in srgb,var(--bg-deep,#081120) 86%,transparent);padding:20px 22px}
.hero__stat b{display:block;font-family:var(--font-head);font-size:clamp(1.5rem,3vw,2.2rem);line-height:1;color:var(--foreground)}
.hero__stat b .unit{color:var(--accent);font-size:.7em}
.hero__stat span{font-size:.82rem;color:var(--muted)}
@media (max-width:760px){.hero__stats{grid-template-columns:repeat(2,1fr)}}

/* ================================================================
   TRUST MARQUEE
   ================================================================ */
.trust{padding:0;border-block:1px solid var(--border);background:var(--bg-deep,#081120)}
.marquee{overflow:hidden;position:relative;padding:20px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;gap:54px;width:max-content;align-items:center;animation:marquee-scroll 38s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marquee-scroll{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee__track{animation:none}}
.marquee__item{display:inline-flex;align-items:center;gap:12px;color:var(--muted);font-family:var(--font-head);font-weight:600;font-size:1.02rem;letter-spacing:.02em;white-space:nowrap}
.marquee__item svg{width:24px;height:24px;color:var(--accent);flex:none}
.marquee__dot{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.6}

/* ================================================================
   SERVICES
   ================================================================ */
.services{position:relative;overflow:hidden}
.services__grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;position:relative;z-index:1}
.svc{grid-column:span 4;position:relative;display:flex;flex-direction:column;gap:14px;padding:30px 28px 28px;
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  transition:transform .4s var(--ease-premium),border-color .4s,background .4s}
.svc::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 60%,transparent),transparent);opacity:0;transition:opacity .4s}
.svc::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 50% 0%,color-mix(in srgb,var(--accent) 12%,transparent),transparent 70%);opacity:0;transition:opacity .45s;pointer-events:none}
.svc:hover{transform:translateY(-6px);border-color:color-mix(in srgb,var(--accent) 45%,var(--border))}
.svc:hover::before,.svc:hover::after{opacity:1}
.svc--wide{grid-column:span 8}
.svc--feature{grid-column:span 4;grid-row:span 2;background:linear-gradient(165deg,color-mix(in srgb,var(--secondary) 40%,var(--surface)),var(--surface));justify-content:space-between}
.svc__icon{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 12%,transparent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent)}
.svc__icon svg{width:28px;height:28px;color:var(--accent)}
.svc h3{font-size:1.22rem;margin:0}
.svc p{color:var(--muted);font-size:.95rem;margin:0}
.svc__link{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-family:var(--font-head);font-weight:600;font-size:.9rem;color:var(--foreground);transition:gap .3s,color .3s}
.svc__link svg{width:16px;height:16px;transition:transform .3s}
.svc:hover .svc__link{color:var(--accent);gap:12px}
.svc:hover .svc__link svg{transform:translateX(3px)}
.svc--feature .svc__art{position:relative;height:140px;margin:6px -28px -28px;border-top:1px solid var(--border);
  background:linear-gradient(180deg,transparent,rgba(8,17,32,.4)),url("../img/expert-roofing-crew-parry-sound-1-9.webp");background-size:cover;background-position:center}
@media (max-width:960px){.svc,.svc--wide,.svc--feature{grid-column:span 6}.svc--feature{grid-row:auto}}
@media (max-width:620px){.svc,.svc--wide,.svc--feature{grid-column:span 12}}

/* ================================================================
   WHY US  (split illustration panels)
   ================================================================ */
.why{position:relative}
.why__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,72px);align-items:center}
@media (max-width:900px){.why__grid{grid-template-columns:1fr}}
.why__list{display:flex;flex-direction:column;gap:6px}
.why-item{display:grid;grid-template-columns:auto 1fr;gap:20px;padding:22px 0;border-bottom:1px solid var(--border);align-items:start}
.why-item:last-child{border-bottom:0}
.why-item__ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--secondary) 50%,transparent);border:1px solid var(--border);flex:none}
.why-item__ic svg{width:24px;height:24px;color:var(--accent)}
.why-item h3{font-size:1.12rem;margin:0 0 6px}
.why-item p{color:var(--muted);font-size:.94rem;margin:0}
.why__visual{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);aspect-ratio:4/5;
  background:linear-gradient(180deg,rgba(8,17,32,.15),rgba(8,17,32,.75)),url("../img/new-roof-installations-parry-sound-11.webp");background-size:cover;background-position:center}
.why__visual-tag{position:absolute;left:20px;bottom:20px;right:20px;padding:18px 20px;border-radius:14px;
  background:color-mix(in srgb,var(--bg-deep,#081120) 70%,transparent);backdrop-filter:blur(10px);border:1px solid var(--border)}
.why__visual-tag b{font-family:var(--font-head);font-size:1.05rem;color:var(--foreground)}
.why__visual-tag span{display:block;color:var(--muted);font-size:.85rem;margin-top:3px}
.why__visual-badge{position:absolute;top:18px;right:18px;display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-pill);
  background:var(--accent);color:var(--onPrimary);font-family:var(--font-head);font-weight:700;font-size:.82rem}
.why__visual-badge svg{width:16px;height:16px}

/* ================================================================
   SIGNATURE — ROOF SYSTEM CUTAWAY
   ================================================================ */
.cutaway{position:relative;background:var(--bg-deep,#081120);overflow:hidden}
.cutaway__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,4vw,60px);align-items:center}
@media (max-width:920px){.cutaway__grid{grid-template-columns:1fr}}
.cutaway__steps{display:flex;flex-direction:column;gap:12px}
.cstep{position:relative;display:grid;grid-template-columns:auto 1fr;gap:18px;padding:22px 22px 22px 20px;border-radius:var(--radius);
  border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 55%,transparent);cursor:pointer;
  transition:border-color .4s var(--ease-premium),background .4s,transform .4s}
.cstep:hover{transform:translateX(4px)}
.cstep.is-active{border-color:color-mix(in srgb,var(--accent) 60%,var(--border));background:var(--surface)}
.cstep.is-active::before{content:"";position:absolute;left:0;top:14px;bottom:14px;width:3px;border-radius:3px;background:var(--accent)}
.cstep__n{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;font-size:1.1rem;
  background:color-mix(in srgb,var(--accent) 14%,transparent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);color:var(--accent);transition:background .4s,color .4s}
.cstep.is-active .cstep__n{background:var(--accent);color:var(--onPrimary)}
.cstep h3{font-size:1.16rem;margin:0 0 5px}
.cstep p{color:var(--muted);font-size:.92rem;margin:0}
.cutaway__stage{position:relative;border-radius:var(--radius);border:1px solid var(--border);background:
  radial-gradient(120% 90% at 50% 0%,color-mix(in srgb,var(--secondary) 30%,var(--bg-deep,#081120)),var(--bg-deep,#081120));
  padding:24px;overflow:hidden;min-height:380px}
.cutaway__stage svg{width:100%;height:auto;display:block}
.layer{opacity:.18;transition:opacity .6s var(--ease-premium),transform .6s var(--ease-premium)}
.layer.is-on{opacity:1}
.layer-label{font-family:var(--font-body);font-size:11px;font-weight:600;fill:var(--muted);letter-spacing:.04em}
.layer-label.is-on{fill:var(--foreground)}
.cutaway__caption{margin-top:16px;display:flex;align-items:center;gap:14px;color:var(--muted);font-size:.9rem}
.cutaway__caption b{color:var(--accent);font-family:var(--font-head)}
.cutaway__progress{display:flex;gap:6px;margin-top:8px}
.cutaway__progress i{height:4px;flex:1;border-radius:4px;background:var(--border);overflow:hidden;position:relative}
.cutaway__progress i.is-on::after{content:"";position:absolute;inset:0;background:var(--accent)}

/* ================================================================
   MATERIALS
   ================================================================ */
.materials__head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.mat-tabs{display:flex;flex-wrap:wrap;gap:10px;margin:28px 0 30px}
.mat-tab{font-family:var(--font-head);font-weight:600;font-size:.9rem;padding:10px 18px;border-radius:var(--radius-pill);
  border:1px solid var(--border);background:transparent;color:var(--muted);cursor:pointer;transition:all .3s}
.mat-tab:hover{color:var(--foreground)}
.mat-tab.is-active{background:var(--accent);color:var(--onPrimary);border-color:var(--accent)}
.mat-panels{position:relative}
.mat-panel{display:none;grid-template-columns:1fr 1fr;gap:30px;align-items:center}
.mat-panel.is-active{display:grid;animation:fadeup .5s var(--ease-premium)}
@keyframes fadeup{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@media (max-width:820px){.mat-panel.is-active{grid-template-columns:1fr}}
.mat-panel__body h3{font-size:1.6rem}
.mat-panel__body p{color:var(--muted)}
.mat-spec{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.mat-spec span{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;color:var(--foreground);
  padding:7px 13px;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--surface) 70%,transparent);border:1px solid var(--border)}
.mat-spec span svg{width:14px;height:14px;color:var(--accent)}
.mat-panel__art{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);aspect-ratio:4/3;display:grid;place-items:center;
  background:linear-gradient(160deg,color-mix(in srgb,var(--secondary) 45%,var(--surface)),var(--surface))}
.mat-panel__art svg{width:62%;height:auto;color:var(--accent);opacity:.92}
.mat-panel__art.has-photo{background-image:linear-gradient(180deg,transparent,rgba(8,17,32,.5)),url("../img/premium-roofing-materials-parry-sound-1-20.webp");background-size:cover;background-position:center}

/* ================================================================
   COTTAGE / ISLAND SPECIALTY
   ================================================================ */
.specialty{position:relative;overflow:hidden}
.specialty__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
@media (max-width:900px){.specialty__grid{grid-template-columns:1fr}}
.specialty__art{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);aspect-ratio:5/4;
  background:linear-gradient(180deg,rgba(8,17,32,.15),rgba(8,17,32,.6)),url("../img/expert-roofing-crew-parry-sound-1-9.webp");background-size:cover;background-position:center}
.specialty__wave{position:absolute;left:0;right:0;bottom:0;height:60px;color:var(--accent2);opacity:.5}
.specialty__points{display:flex;flex-direction:column;gap:18px;margin-top:24px}
.spt{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:start}
.spt__ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent2) 14%,transparent);border:1px solid color-mix(in srgb,var(--accent2) 30%,transparent);flex:none}
.spt__ic svg{width:21px;height:21px;color:var(--accent2)}
.spt h4{margin:0 0 3px;font-family:var(--font-head);font-size:1.04rem}
.spt p{margin:0;color:var(--muted);font-size:.92rem}

/* ================================================================
   STATS BAND
   ================================================================ */
.statsband{background:linear-gradient(120deg,var(--secondary),var(--bg-deep,#081120));border-block:1px solid var(--border);position:relative;overflow:hidden}
.statsband__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;position:relative;z-index:1}
@media (max-width:720px){.statsband__grid{grid-template-columns:repeat(2,1fr)}}
.statc{text-align:center}
.statc b{display:block;font-family:var(--font-head);font-weight:700;font-size:clamp(2.4rem,5vw,3.4rem);line-height:1;color:var(--foreground)}
.statc b .unit{color:var(--accent)}
.statc span{display:block;margin-top:8px;color:#cdd9e6;font-size:.92rem;letter-spacing:.02em}
.statsband__svg{position:absolute;inset:0;width:100%;height:100%;opacity:.08;color:var(--foreground)}

/* ================================================================
   SERVICE AREA
   ================================================================ */
.area__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:center}
@media (max-width:880px){.area__grid{grid-template-columns:1fr}}
.area__map{position:relative;border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;aspect-ratio:1/1;
  background:radial-gradient(100% 100% at 50% 30%,color-mix(in srgb,var(--secondary) 40%,var(--bg-deep,#081120)),var(--bg-deep,#081120))}
.area__map svg{position:absolute;inset:0;width:100%;height:100%}
.area__pin{fill:var(--accent)}
.area__ripple{fill:none;stroke:var(--accent);stroke-width:1;opacity:.5;transform-origin:center;animation:ripple 3s ease-out infinite}
@keyframes ripple{0%{transform:scale(.4);opacity:.6}100%{transform:scale(1.6);opacity:0}}
@media (prefers-reduced-motion:reduce){.area__ripple{animation:none}}
.area__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.area-chip{display:inline-flex;align-items:center;gap:8px;font-size:.88rem;font-weight:500;color:var(--foreground);
  padding:9px 16px;border-radius:var(--radius-pill);background:var(--surface);border:1px solid var(--border);transition:all .3s}
.area-chip:hover{border-color:var(--accent);color:var(--accent)}
.area-chip svg{width:14px;height:14px;color:var(--accent)}

/* ================================================================
   TESTIMONIALS
   ================================================================ */
.reviews{position:relative;overflow:hidden}
.reviews__rating{display:flex;align-items:center;gap:16px;margin-bottom:8px}
.stars{display:inline-flex;gap:3px}
.stars svg{width:20px;height:20px;color:var(--accent)}
.reviews__rating b{font-family:var(--font-head);font-size:1.7rem}
.reviews__rating span{color:var(--muted);font-size:.9rem}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:36px}
@media (max-width:920px){.reviews__grid{grid-template-columns:1fr 1fr}}
@media (max-width:620px){.reviews__grid{grid-template-columns:1fr}}
.review{display:flex;flex-direction:column;gap:16px;padding:28px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);position:relative;overflow:hidden}
.review::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 50%,transparent),transparent)}
.review__quote{position:absolute;top:18px;right:20px;width:42px;height:42px;color:var(--accent);opacity:.16}
.review p{color:#dbe6f2;font-size:.96rem;line-height:1.6;margin:0;position:relative;z-index:1}
.review__who{display:flex;align-items:center;gap:12px;margin-top:auto}
.review__av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;color:var(--onPrimary);background:var(--accent);flex:none}
.review__who b{font-family:var(--font-head);font-size:.98rem;display:block}
.review__who span{color:var(--muted);font-size:.8rem}
.review--span2{grid-column:span 2}
@media (max-width:620px){.review--span2{grid-column:span 1}}

/* ================================================================
   FAQ
   ================================================================ */
.faq__grid{display:grid;grid-template-columns:.7fr 1.3fr;gap:clamp(28px,5vw,60px);align-items:start}
@media (max-width:860px){.faq__grid{grid-template-columns:1fr}}
.faq__list details{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);margin-bottom:12px;overflow:hidden;transition:border-color .3s}
.faq__list details[open]{border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}
.faq__list summary{list-style:none;cursor:pointer;padding:20px 22px;display:flex;align-items:center;justify-content:space-between;gap:18px;
  font-family:var(--font-head);font-weight:600;font-size:1.04rem;color:var(--foreground)}
.faq__list summary::-webkit-details-marker{display:none}
.faq__icon{width:26px;height:26px;flex:none;position:relative}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;background:var(--accent);border-radius:2px;transition:transform .35s var(--ease-premium)}
.faq__icon::before{top:50%;left:4px;right:4px;height:2px;translate:0 -50%}
.faq__icon::after{left:50%;top:4px;bottom:4px;width:2px;translate:-50% 0}
.faq__list details[open] .faq__icon::after{transform:rotate(90deg);opacity:0}
.faq__list details p{margin:0;padding:0 22px 22px;color:var(--muted);font-size:.95rem;line-height:1.65}
.faq__aside{position:sticky;top:100px;padding:30px;border-radius:var(--radius);background:linear-gradient(165deg,color-mix(in srgb,var(--secondary) 45%,var(--surface)),var(--surface));border:1px solid var(--border)}
.faq__aside h3{font-size:1.3rem}
.faq__aside p{color:var(--muted);font-size:.94rem}

/* ================================================================
   CONTACT
   ================================================================ */
.contact{position:relative;overflow:hidden;background:var(--bg-deep,#081120)}
.contact__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(30px,5vw,64px);align-items:start}
@media (max-width:900px){.contact__grid{grid-template-columns:1fr}}
.contact__info h2{font-size:clamp(2rem,4vw,3rem)}
.contact__info .lede{color:var(--muted)}
.contact__lines{display:flex;flex-direction:column;gap:14px;margin-top:28px}
.cline{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;padding:16px 18px;border-radius:var(--radius-sm);
  background:var(--surface);border:1px solid var(--border);transition:border-color .3s}
.cline:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}
.cline__ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 12%,transparent);border:1px solid color-mix(in srgb,var(--accent) 26%,transparent);flex:none}
.cline__ic svg{width:20px;height:20px;color:var(--accent)}
.cline span{display:block;font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.cline b{font-family:var(--font-head);font-size:1.06rem;color:var(--foreground)}
.contact__form{padding:clamp(26px,4vw,38px);border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);position:relative}
.contact__form::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:var(--radius) var(--radius) 0 0}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid .field--full{grid-column:1/-1}
@media (max-width:520px){.form-grid{grid-template-columns:1fr}}
.field select{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;color:var(--foreground);font:inherit;cursor:pointer}
.field select:focus{outline:none;border-color:var(--primary)}
.form__foot{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:8px}
.form__note{font-size:.82rem;color:var(--muted)}

/* ================================================================
   FOOTER (rich)
   ================================================================ */
.site-footer{background:var(--bg-deep,#081120)}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:46px;border-bottom:1px solid var(--border)}
@media (max-width:880px){.footer-top{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer-top{grid-template-columns:1fr}}
.footer-brand__logo{height:38px;width:auto;margin-bottom:18px}
.footer-brand p{color:var(--muted);font-size:.92rem;max-width:34ch}
.footer-certs{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.footer-certs span{font-size:.72rem;color:var(--muted);padding:6px 11px;border:1px solid var(--border);border-radius:var(--radius-pill)}
.footer-col h4{font-family:var(--font-head);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin:0 0 16px}
.footer-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:#cdd9e6;font-size:.92rem}
.footer-col a:hover{color:var(--accent)}
.footer-cta{display:inline-flex;align-items:center;gap:10px;margin-top:8px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding-top:26px}
.footer-bottom p{margin:0;color:var(--muted);font-size:.84rem}
.footer-bottom a{color:var(--muted)}

/* ---- reveal helper variants ---- */
[data-reveal]{opacity:0}
html.qa [data-reveal],html.no-js [data-reveal]{opacity:1 !important}

/* ---- small print / utility ---- */
.tag-amber{color:var(--accent)}
.nowrap{white-space:nowrap}
.mt-0{margin-top:0}
.center{text-align:center}

/* ================================================================
   INNER PAGES
   ================================================================ */
.page-hero{position:relative;overflow:hidden;padding:clamp(120px,16vh,180px) 0 clamp(48px,7vw,80px);
  background:radial-gradient(120% 90% at 80% 0%,color-mix(in srgb,var(--secondary) 42%,var(--bg-deep,#081120)),var(--bg-deep,#081120))}
.page-hero::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(60% 50% at 85% 10%,color-mix(in srgb,var(--accent) 14%,transparent),transparent 60%)}
.page-hero .container{position:relative;z-index:1}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:.82rem;color:var(--muted);margin-bottom:20px;flex-wrap:wrap}
.breadcrumb a{color:var(--muted)}.breadcrumb a:hover{color:var(--accent)}
.breadcrumb svg{width:13px;height:13px;opacity:.6}
.page-hero h1{font-size:clamp(2.2rem,5.5vw,4rem);max-width:18ch}
.page-hero .lede{max-width:60ch;color:#dbe6f2;font-size:clamp(1.05rem,1.5vw,1.25rem)}
.page-hero__cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:30px}

.prose{max-width:760px}
.prose h2{margin-top:1.4em;font-size:clamp(1.6rem,3vw,2.2rem)}
.prose h3{margin-top:1.2em}
.prose p,.prose li{color:#cdd9e6}
.prose ul{padding-left:0;list-style:none;display:flex;flex-direction:column;gap:12px;margin:1.2em 0}
.prose ul li{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start}
.prose ul li::before{content:"";width:22px;height:22px;margin-top:2px;border-radius:6px;background:color-mix(in srgb,var(--accent) 14%,transparent);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fe7f00' stroke-width='3'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");
  background-size:15px;background-position:center;background-repeat:no-repeat;border:1px solid color-mix(in srgb,var(--accent) 26%,transparent)}

/* quick-answer / key-facts (AEO) */
.quick-answer{display:grid;grid-template-columns:1.3fr .7fr;gap:24px;margin:8px 0 12px;padding:0}
@media (max-width:820px){.quick-answer{grid-template-columns:1fr}}
.quick-answer__box{padding:26px 28px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent)}
.quick-answer__box h2{margin:0 0 10px;font-size:1.2rem}
.quick-answer__box p{margin:0;color:#cdd9e6}
.keyfacts{padding:24px;border-radius:var(--radius);background:color-mix(in srgb,var(--secondary) 30%,var(--surface));border:1px solid var(--border)}
.keyfacts h3{font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 14px}
.keyfacts dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:10px 14px}
.keyfacts dt{color:var(--muted);font-size:.86rem}
.keyfacts dd{margin:0;font-family:var(--font-head);font-weight:600;font-size:.92rem;text-align:right}

.inner-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:8px}
.feature-card{padding:26px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border);transition:transform .35s var(--ease-premium),border-color .35s}
.feature-card:hover{transform:translateY(-5px);border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}
.feature-card .svc__icon{margin-bottom:14px}
.feature-card h3{font-size:1.12rem;margin:0 0 8px}
.feature-card p{color:var(--muted);font-size:.93rem;margin:0}

.cta-band{margin:0;padding:clamp(48px,7vw,80px) 0;background:linear-gradient(120deg,var(--secondary),var(--bg-deep,#081120));border-block:1px solid var(--border);text-align:center}
.cta-band h2{font-size:clamp(1.8rem,4vw,2.8rem);max-width:20ch;margin-inline:auto}
.cta-band p{color:#cdd9e6;max-width:52ch;margin:0 auto 28px}
.cta-band__row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,60px);align-items:center}
@media (max-width:860px){.split{grid-template-columns:1fr}}
.split__art{border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;aspect-ratio:4/3;
  background:linear-gradient(160deg,color-mix(in srgb,var(--secondary) 40%,var(--surface)),var(--surface));display:grid;place-items:center}
.split__art svg{width:55%;color:var(--accent);opacity:.9}
.split__art.has-photo{background-size:cover;background-position:center}

.steps-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:10px}
@media (max-width:760px){.steps-row{grid-template-columns:1fr}}
.step-card{position:relative;padding:30px 26px;border-radius:var(--radius);background:var(--surface);border:1px solid var(--border)}
.step-card__n{font-family:var(--font-head);font-weight:700;font-size:2.4rem;color:color-mix(in srgb,var(--accent) 70%,transparent);line-height:1}
.step-card h3{margin:12px 0 8px}
.step-card p{color:var(--muted);font-size:.93rem;margin:0}
