/* ==========================================================================
   PCH SERVICES — "GLEAM"  ·  bespoke concept v2 (Keymaker, 2026-06-18)
   Light & clarity. Bright, sunlit, crystalline coastal premium.
   Hand-built — NOT the template factory.
   Type: Brush Wedco = Aaron's real handwritten brand font (display H1/H2),
         Bricolage Grotesque (UI/card titles), Hanken Grotesk (body),
         Fraunces (italic accents).
   NOTE: Brush Wedco has NO punctuation glyphs — every h1/h2 must stay
   punctuation-free (letters, digits, space, & and ? only) or it tofus.
   ========================================================================== */

@font-face{font-family:'BrushWedco';src:url('fonts/brushwedco.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Bricolage';src:url('fonts/bricolage.woff2') format('woff2');font-weight:200 800;font-display:swap}
@font-face{font-family:'Hanken';src:url('fonts/hanken.woff2') format('woff2');font-weight:300 800;font-display:swap}
@font-face{font-family:'Fraunces';src:url('fonts/fraunces.woff2') format('woff2');font-weight:300 700;font-style:normal;font-display:swap}

:root{
  --paper:#F4FBFF;--paper-2:#E4F3FB;--paper-3:#D7ECF6;
  --ink:#06283A;--ink-soft:#33586B;--ink-dim:#5E7E8D;
  --aqua:#07B6D4;--aqua-bright:#22D3EE;--aqua-deep:#0A6E86;--aqua-ink:#064B5C;
  --sun:#FFC233;--sun-deep:#F59E0B;--coral:#FF6B53;--white:#fff;

  --grad-sunwater:linear-gradient(112deg,#07B6D4 0%,#3FD7C6 46%,#FFC233 100%);
  --grad-aqua:linear-gradient(135deg,#22D3EE 0%,#0A6E86 100%);
  --grad-cta:linear-gradient(120deg,#0A6E86 0%,#07B6D4 60%,#16B8A6 100%);
  --glass:rgba(255,255,255,.62);--glass-line:rgba(255,255,255,.7);

  --shadow-sm:0 2px 10px rgba(6,40,58,.07);--shadow:0 14px 40px -12px rgba(6,40,58,.20);
  --shadow-lg:0 40px 90px -28px rgba(6,40,58,.34);--shadow-aqua:0 22px 50px -18px rgba(7,182,212,.55);

  --r-sm:10px;--r:18px;--r-lg:28px;--r-xl:40px;--r-pill:999px;
  --maxw:1260px;--pad:clamp(1.25rem,5vw,3.25rem);--sectiony:clamp(4.5rem,9vw,8.5rem);

  --d-display:'BrushWedco','Bricolage',cursive;   /* Aaron's real brand script */
  --d-ui:'Bricolage','Hanken',system-ui,sans-serif;
  --d-body:'Hanken',system-ui,-apple-system,sans-serif;
  --d-accent:'Fraunces',Georgia,serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--d-body);background:var(--paper);color:var(--ink);font-size:1.0625rem;line-height:1.62;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--aqua);color:#fff}
:focus-visible{outline:3px solid var(--aqua-deep);outline-offset:3px;border-radius:4px}

/* H1/H2 = Aaron's handwritten Brush Wedco (natural weight, gentle positive tracking) */
h1,h2{font-family:var(--d-display);font-weight:400;line-height:1.04;letter-spacing:.012em;color:var(--ink)}
/* H3/H4 = crisp Bricolage so small titles stay legible */
h3,h4{font-family:var(--d-ui);font-weight:700;line-height:1.06;letter-spacing:-.02em;color:var(--ink)}
.accent{font-family:var(--d-accent);font-style:italic;font-weight:400}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.eyebrow{display:inline-flex;align-items:center;gap:.55em;font-family:var(--d-body);font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--aqua-deep)}
.eyebrow::before{content:"";width:1.8rem;height:2px;background:var(--grad-sunwater);border-radius:2px}

.btn{--bg:var(--grad-cta);display:inline-flex;align-items:center;gap:.6em;font-family:var(--d-body);font-weight:700;font-size:1.02rem;letter-spacing:-.01em;padding:1.05rem 1.9rem;border-radius:var(--r-pill);border:0;cursor:pointer;color:#fff;background:var(--bg);box-shadow:var(--shadow-aqua);transition:transform .25s cubic-bezier(.2,.8,.2,1),box-shadow .25s,filter .25s}
.btn:hover{transform:translateY(-3px);box-shadow:0 28px 60px -18px rgba(7,182,212,.7);filter:saturate(1.08)}
.btn:active{transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);box-shadow:none;border:1.5px solid rgba(6,40,58,.18)}
.btn--ghost:hover{border-color:var(--aqua-deep);color:var(--aqua-deep);box-shadow:none;transform:translateY(-2px)}
.btn--sun{--bg:linear-gradient(120deg,var(--sun),var(--sun-deep));color:#3a2600;box-shadow:0 22px 50px -18px rgba(245,158,11,.6)}
.btn svg{width:1.1em;height:1.1em}

/* ============================= HEADER ============================= */
.site-head{position:fixed;inset:0 0 auto 0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.1rem var(--pad);transition:background .3s,box-shadow .3s,padding .3s,backdrop-filter .3s}
.site-head.scrolled{background:rgba(244,251,255,.82);backdrop-filter:blur(16px) saturate(1.4);box-shadow:0 1px 0 rgba(6,40,58,.08),0 10px 30px -20px rgba(6,40,58,.4);padding-block:.7rem}
.brand{display:flex;align-items:center;gap:.7rem}
.brand__mark{position:relative;width:46px;height:46px;flex:none;border-radius:13px;background:var(--grad-sunwater);display:grid;place-items:center;box-shadow:var(--shadow-aqua);overflow:hidden}
.brand__mark::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 20% 10%,rgba(255,255,255,.65),transparent 55%)}
.brand__mark span{position:relative;z-index:1;font-family:var(--d-ui);color:#fff;font-weight:800;font-size:1.12rem;letter-spacing:-.04em;text-shadow:0 1px 2px rgba(6,40,58,.25)}
.brand__txt{line-height:1}
.brand__txt b{display:block;font-family:var(--d-display);font-weight:400;font-size:1.7rem;letter-spacing:.01em;color:var(--ink);margin-bottom:-.1rem}
.brand__txt small{display:block;font-family:var(--d-body);font-weight:600;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--aqua-deep)}
.nav{display:flex;align-items:center;gap:.4rem}
.nav a{font-family:var(--d-body);font-weight:600;font-size:.96rem;color:var(--ink);padding:.55rem .85rem;border-radius:var(--r-pill);transition:color .2s,background .2s}
.nav a:hover{color:var(--aqua-deep);background:rgba(7,182,212,.1)}
.head-cta{display:flex;align-items:center;gap:.9rem}
.head-phone{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--d-ui);font-weight:700;font-size:1.05rem;color:var(--ink);letter-spacing:-.02em}
.head-phone svg{width:1.05em;height:1.05em;color:var(--aqua-deep)}
.head-cta .btn{padding:.7rem 1.3rem;font-size:.95rem}

/* ============================= HERO + CAROUSEL ============================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;isolation:isolate;overflow:hidden}
.hero__carousel{position:absolute;inset:0;z-index:-3}
.hero__slide{position:absolute;inset:0;opacity:0;transition:opacity 1.3s ease;transform:scale(1.04)}
.hero__slide img{width:100%;height:100%;object-fit:cover;object-position:62% center}
.hero__slide.active{opacity:1;animation:kenburns 7s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.08)}to{transform:scale(1.0)}}
/* light, bright wash — never a heavy dark scrim; keep the beach popping */
.hero__scrim{position:absolute;inset:0;z-index:-2;background:linear-gradient(86deg,rgba(244,251,255,.94) 0%,rgba(244,251,255,.55) 30%,rgba(244,251,255,.05) 55%,transparent 72%),linear-gradient(0deg,rgba(6,40,58,.34),transparent 38%)}
.hero__inner{width:100%;max-width:var(--maxw);margin-inline:auto;padding:8rem var(--pad) clamp(3rem,6vw,5.5rem)}
.hero__copy{max-width:44rem}
.hero h1{font-size:clamp(3.6rem,9.5vw,7.4rem);line-height:.96;letter-spacing:.005em;margin:.6rem 0 0}
.hero h1 .accent{background:linear-gradient(100deg,#07B6D4 0%,#3FD7C6 32%,#FFC233 55%,#3FD7C6 80%,#07B6D4 100%);background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 7s ease-in-out infinite}
@keyframes shimmer{0%,100%{background-position:0 0}50%{background-position:100% 0}}
.hero__lead{font-size:clamp(1.1rem,1.7vw,1.4rem);color:var(--ink-soft);max-width:34rem;margin:1.4rem 0 0;font-weight:450}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2.1rem}
.hero__trust{display:inline-flex;align-items:center;gap:1.1rem;margin-top:2.4rem;padding:.75rem 1.15rem .75rem .85rem;background:var(--glass);backdrop-filter:blur(14px) saturate(1.5);border:1px solid var(--glass-line);border-radius:var(--r-pill);box-shadow:var(--shadow);font-family:var(--d-body)}
.hero__trust .stars{color:var(--sun-deep);letter-spacing:.06em;font-size:1.05rem}
.hero__trust b{font-weight:800}
.hero__trust .sep{width:1px;height:1.6rem;background:rgba(6,40,58,.14)}
.hero__trust small{font-size:.82rem;color:var(--ink-soft);font-weight:600;line-height:1.25}
.hero__dots{position:absolute;right:var(--pad);bottom:1.6rem;z-index:3;display:flex;gap:.5rem}
.hero__dots button{width:11px;height:11px;border-radius:var(--r-pill);border:0;padding:0;background:rgba(255,255,255,.55);cursor:pointer;box-shadow:0 1px 5px rgba(6,40,58,.35);transition:width .35s,background .35s}
.hero__dots button.active{background:#fff;width:30px}
.hero__dots button:hover{background:#fff}
.scroll-cue{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.4rem;color:var(--ink-dim);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;z-index:1;font-family:var(--d-body)}
.scroll-cue span{width:1.5px;height:34px;background:linear-gradient(var(--aqua-deep),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

.strip{background:var(--ink);color:var(--paper);overflow:hidden;padding:.95rem 0;font-family:var(--d-ui);font-weight:600}
.strip__track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:marq 32s linear infinite}
.strip__track span{display:inline-flex;align-items:center;font-size:1.02rem;letter-spacing:-.01em;padding:0 1.4rem}
.strip__track span::before{content:"✦";color:var(--sun);margin-right:1.4rem;font-size:.8rem}
@keyframes marq{to{transform:translateX(-50%)}}

/* ============================= SECTION SHELL ============================= */
.section{padding-block:var(--sectiony)}
.section--tint{background:linear-gradient(180deg,var(--paper) 0%,var(--paper-2) 100%)}
.s-head{max-width:44rem}
.s-head.center{margin-inline:auto;text-align:center}
.s-head h2{font-size:clamp(2.4rem,5vw,4rem);margin:.5rem 0 0}
.s-head p{color:var(--ink-soft);font-size:1.12rem;margin-top:1rem}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ============================= DIFFERENCE (real photos, no gimmick) ===== */
.diff-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.diff-copy h2{font-size:clamp(2.4rem,5vw,4rem)}
.diff-copy .big{font-family:var(--d-accent);font-style:italic;font-size:clamp(1.3rem,2vw,1.75rem);color:var(--aqua-deep);line-height:1.32;margin:1.2rem 0 0}
.diff-copy ul{list-style:none;margin:1.6rem 0 0;display:grid;gap:.8rem}
.diff-copy li{display:flex;gap:.7rem;align-items:flex-start;font-weight:500;color:var(--ink-soft);font-size:1.04rem}
.diff-copy li svg{flex:none;width:1.5rem;height:1.5rem;color:var(--aqua);margin-top:.05rem}
.diff-media{position:relative}
.diff-media__main{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.diff-media__main img{width:100%;height:100%;object-fit:cover}
.diff-media__inset{position:absolute;left:-1.6rem;bottom:-1.6rem;width:46%;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-lg);border:5px solid var(--paper);aspect-ratio:4/3}
.diff-media__inset img{width:100%;height:100%;object-fit:cover}
.diff-badge{position:absolute;top:1.1rem;right:1.1rem;z-index:2;display:inline-flex;align-items:center;gap:.5rem;background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--glass-line);border-radius:var(--r-pill);padding:.5rem .95rem;font-family:var(--d-body);font-weight:700;font-size:.82rem;color:var(--aqua-deep);box-shadow:var(--shadow)}
.diff-badge svg{width:1.05em;height:1.05em}

/* ============================= SERVICES ============================= */
.svc-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(1rem,1.6vw,1.4rem);margin-top:clamp(2.5rem,4vw,3.5rem)}
.svc{position:relative;background:#fff;border:1px solid var(--paper-3);border-radius:var(--r-lg);padding:1.9rem 1.7rem;overflow:hidden;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,border-color .35s}
.svc:nth-child(1){grid-column:span 4}
.svc:nth-child(2){grid-column:span 2}
.svc:nth-child(3){grid-column:span 2}
.svc:nth-child(4){grid-column:span 2}
.svc:nth-child(5){grid-column:span 2}
.svc::before{content:"";position:absolute;inset:0;background:var(--grad-sunwater);opacity:0;transition:opacity .35s;z-index:0}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc:hover::before{opacity:.06}
.svc>*{position:relative;z-index:1}
.svc__ic{width:54px;height:54px;border-radius:15px;background:var(--paper-2);display:grid;place-items:center;color:var(--aqua-deep);margin-bottom:1.2rem;transition:background .35s,color .35s}
.svc:hover .svc__ic{background:var(--grad-sunwater);color:#fff}
.svc__ic svg{width:28px;height:28px}
.svc h3{font-size:1.4rem}
.svc:nth-child(1) h3{font-size:1.85rem}
.svc p{color:var(--ink-soft);margin-top:.55rem;font-size:.98rem;line-height:1.55}
.svc__more{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-family:var(--d-body);font-weight:700;color:var(--aqua-deep);font-size:.92rem}
.svc__more svg{width:1em;height:1em;transition:transform .25s}
.svc:hover .svc__more svg{transform:translateX(4px)}
.svc--feat{display:grid;grid-template-columns:1.1fr 1fr;gap:1.5rem;align-items:center}
.svc--feat .svc__media{align-self:stretch;border-radius:var(--r);overflow:hidden;min-height:230px;box-shadow:var(--shadow)}
.svc--feat .svc__media img{width:100%;height:100%;object-fit:cover}

/* ============================= SOLAR MOMENT ============================= */
.solar{position:relative;background:var(--ink);color:var(--paper);border-radius:clamp(var(--r),3vw,var(--r-xl));overflow:hidden;isolation:isolate}
.solar__bg{position:absolute;inset:0;z-index:-1}
.solar__bg img{width:100%;height:100%;object-fit:cover;opacity:.5}
.solar__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(6,40,58,.95) 0%,rgba(6,40,58,.7) 42%,rgba(6,40,58,.25) 100%)}
.solar__inner{display:grid;grid-template-columns:1.2fr .9fr;gap:clamp(2rem,5vw,4rem);align-items:center;padding:clamp(2.6rem,5vw,4.5rem)}
.solar h2{color:#fff;font-size:clamp(2.2rem,4.4vw,3.6rem)}
.solar .eyebrow{color:var(--sun)}
.solar .eyebrow::before{background:var(--sun)}
.solar p{color:rgba(244,251,255,.82);margin-top:1.1rem;font-size:1.1rem;max-width:34rem}
.solar__stat{text-align:center;padding:2.2rem 1.5rem;border-radius:var(--r-lg);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(6px)}
.solar__kick{font-family:var(--d-body);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;color:var(--sun)}
.solar__num{font-family:var(--d-accent);font-style:italic;font-weight:600;font-size:clamp(4rem,9vw,6.5rem);line-height:.9;background:var(--grad-sunwater);-webkit-background-clip:text;background-clip:text;color:transparent}
.solar__num small{font-size:.42em;vertical-align:.5em;-webkit-text-fill-color:var(--sun)}
.solar__cap{font-family:var(--d-body);font-weight:700;letter-spacing:.02em;margin-top:.6rem;color:#fff}
.solar__bar{height:9px;border-radius:var(--r-pill);background:rgba(255,255,255,.14);margin-top:1.5rem;overflow:hidden}
.solar__bar i{display:block;height:100%;width:0;border-radius:inherit;background:var(--grad-sunwater);transition:width 1.6s cubic-bezier(.2,.8,.2,1)}
.solar__bar.in i{width:78%}
.solar__sub{display:flex;justify-content:space-between;font-family:var(--d-body);font-size:.74rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:rgba(244,251,255,.6);margin-top:.55rem}
.solar__src{font-size:.74rem;color:rgba(244,251,255,.6);font-style:italic;margin-top:1.3rem}

/* ============== REVIEWS — 3D rotating ring carousel ============== */
.rev-ring-stage{position:relative;height:clamp(440px,50vw,580px);perspective:1800px;perspective-origin:50% 44%;margin-top:clamp(1.5rem,3vw,2.5rem)}
.rev-ring{position:absolute;left:50%;top:50%;transform-style:preserve-3d;transition:transform .9s cubic-bezier(.33,.92,.3,1);will-change:transform}
.rev-ring.dragging{transition:none}
.rev{position:absolute;left:0;top:0;overflow:hidden;background:#fff;border:1px solid var(--paper-3);border-radius:var(--r-lg);padding:1.7rem 1.6rem;box-shadow:var(--shadow-sm);backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;flex-direction:column;justify-content:center;opacity:.45;transition:opacity .6s,box-shadow .6s,border-color .6s;cursor:grab}
.rev.is-front{opacity:1;box-shadow:var(--shadow-lg);border-color:var(--aqua)}
.rev-ring.dragging .rev{cursor:grabbing}
.rev::before{content:"\201C";position:absolute;top:.3rem;right:1.1rem;font-family:var(--d-accent);font-style:italic;font-size:4.5rem;line-height:1;color:var(--aqua);opacity:.16}
.rev .stars{color:var(--sun-deep);font-size:.95rem;letter-spacing:.08em}
.rev p{margin:.6rem 0 1rem;color:var(--ink);font-size:.97rem;line-height:1.45}
.rev__by{display:flex;align-items:center;gap:.7rem}
.rev__av{width:40px;height:40px;border-radius:50%;background:var(--grad-aqua);color:#fff;display:grid;place-items:center;font-family:var(--d-ui);font-weight:800;font-size:1.05rem;flex:none}
.rev__by b{display:block;font-family:var(--d-body);font-weight:700;font-size:.95rem}
.rev__by small{color:var(--ink-dim);font-size:.8rem}
.rev-ctrl{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.4rem}
.rev-ctrl button{width:48px;height:48px;border-radius:50%;border:1.5px solid var(--paper-3);background:#fff;color:var(--aqua-deep);cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-sm);transition:transform .2s,background .2s,color .2s}
.rev-ctrl button:hover{background:var(--grad-sunwater);color:#fff;border-color:transparent;transform:translateY(-2px)}
.rev-ctrl button svg{width:22px;height:22px}
.rev-hint{font-family:var(--d-body);font-size:.8rem;font-weight:600;letter-spacing:.04em;color:var(--ink-dim);text-align:center;margin-top:.8rem}
@media (prefers-reduced-motion:reduce){
  .rev-ring-stage{height:auto;perspective:none;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
  .rev-ring{position:static;transform:none!important;display:contents}
  .rev{position:static;opacity:1;transform:none!important;height:auto!important;width:auto!important;margin:0!important}
  .rev-ctrl,.rev-hint{display:none}
}

/* ============================= AREAS RIBBON ============================= */
.areas{padding-block:clamp(3rem,5vw,4.5rem);text-align:center}
.areas .eyebrow{justify-content:center}
.areas h2{font-size:clamp(1.9rem,3.4vw,2.8rem);margin-top:.5rem}
.area-ribbon{margin-top:2rem;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.area-ribbon__track{display:flex;gap:0;width:max-content;animation:marq 38s linear infinite}
.area-ribbon:hover .area-ribbon__track{animation-play-state:paused}
.area-ribbon__track span{display:inline-flex;align-items:center;font-family:var(--d-ui);font-weight:700;font-size:clamp(1.6rem,3vw,2.6rem);letter-spacing:-.03em;color:var(--ink);padding:0 1.3rem;opacity:.42;transition:opacity .3s}
.area-ribbon__track span::after{content:"•";color:var(--aqua);margin-left:1.3rem;opacity:.6}
.area-ribbon__track span:hover{opacity:1}

/* ============================= CTA BAND ============================= */
.cta{position:relative;overflow:hidden;color:#fff;text-align:center;padding-block:clamp(4rem,7vw,6.5rem);background:var(--grad-cta)}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 120% at 85% -10%,rgba(255,194,51,.5),transparent 60%),radial-gradient(50% 100% at 10% 120%,rgba(34,211,238,.5),transparent 60%)}
.cta>*{position:relative}
.cta h2{color:#fff;font-size:clamp(2.6rem,6vw,4.6rem);max-width:18ch;margin-inline:auto}
.cta p{color:rgba(255,255,255,.92);font-size:1.2rem;margin:1.1rem auto 0;max-width:40ch}
.cta__row{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2.3rem}
.cta .btn--ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.cta .btn--ghost:hover{background:rgba(255,255,255,.12);border-color:#fff;color:#fff}

/* ============================= FOOTER ============================= */
.foot{background:var(--ink);color:rgba(244,251,255,.72);padding-block:clamp(3.5rem,5vw,5rem)}
.foot__top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem}
.foot .brand__txt b{color:#fff}
.foot__bl b{display:block;color:#fff;font-family:var(--d-ui);font-weight:700;font-size:1.05rem;margin-bottom:1rem;letter-spacing:-.02em}
.foot__bl a,.foot__bl p{display:block;color:rgba(244,251,255,.72);padding:.25rem 0;font-size:.96rem}
.foot__bl a:hover{color:var(--aqua-bright)}
.foot__intro p{margin:1.1rem 0;max-width:32ch;font-size:.96rem}
.foot__phone{font-family:var(--d-ui);font-weight:700;font-size:1.5rem;color:#fff!important;letter-spacing:-.02em}
.foot__bot{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;margin-top:3rem;padding-top:1.6rem;border-top:1px solid rgba(255,255,255,.12);font-size:.82rem;color:rgba(244,251,255,.5)}

.concept{position:fixed;z-index:90;left:50%;bottom:1rem;transform:translateX(-50%);background:rgba(6,40,58,.9);color:#fff;backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.18);padding:.5rem 1rem;border-radius:var(--r-pill);font-family:var(--d-body);font-weight:600;font-size:.78rem;box-shadow:var(--shadow);display:flex;gap:.6rem;align-items:center}
.concept b{color:var(--sun)}

/* ============================= RESPONSIVE ============================= */
@media (max-width:1000px){
  .nav,.head-phone{display:none}
  .svc-grid{grid-template-columns:repeat(4,1fr)}
  .svc:nth-child(1){grid-column:span 4}.svc:nth-child(n+2){grid-column:span 2}
  .svc--feat{grid-template-columns:1fr}
  .solar__inner,.diff-grid,.foot__top{grid-template-columns:1fr}
  .diff-media{max-width:30rem;margin-inline:auto}
  .rev-grid{columns:2}
}
@media (max-width:640px){
  .svc-grid{grid-template-columns:1fr}.svc:nth-child(n){grid-column:auto}
  .rev-grid{columns:1}
  .hero__inner{padding-top:7rem}
  .hero__trust{flex-wrap:wrap;gap:.7rem}
  .head-cta .btn{padding:.6rem 1rem}
  .hero__dots{bottom:auto;top:5.2rem}
  .concept{font-size:.7rem;bottom:.6rem}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .hero__slide{transition:none}.strip__track,.area-ribbon__track{animation:none}
}
