/* ============================================================
   TOKENS
   ============================================================ */
:root{
  --bg:        oklch(98.5% 0.006 240);
  --surface:   oklch(100% 0 0);
  --ink:       oklch(22% 0.02 250);      /* off-black, not #000 */
  --ink-soft:  oklch(38% 0.02 250);
  --muted:     oklch(50% 0.018 250);
  --line:      oklch(90% 0.012 245);
  --line-soft: oklch(94% 0.008 245);

  --accent:        oklch(58% 0.17 235);   /* electric blue, sat < 80% */
  --accent-strong: oklch(50% 0.18 240);
  --accent-soft:   oklch(95% 0.04 235);
  --accent-ink:    oklch(30% 0.12 245);

  --ink-block: oklch(24% 0.03 250);       /* dark accent section */

  --maxw: 1320px;
  --pad: clamp(1.1rem, 4vw, 2.5rem);
  --r: 18px;
  --r-lg: 26px;

  --shadow-sm: 0 1px 2px oklch(40% 0.03 250 / .06), 0 4px 14px oklch(40% 0.03 250 / .05);
  --shadow-md: 0 8px 24px oklch(40% 0.04 250 / .10), 0 2px 6px oklch(40% 0.04 250 / .06);
  --shadow-lg: 0 28px 60px oklch(40% 0.06 250 / .16);

  --ease: cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"General Sans", system-ui, sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
svg{width:1.15em;height:1.15em;flex:0 0 auto} /* global icon fallback; scoped rules override */
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4{font-family:"Outfit",sans-serif;font-weight:800;line-height:1.02;letter-spacing:-0.04em;text-wrap:balance;color:var(--ink)}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:6px}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}

/* ============================================================
   GLOBAL CANVAS (particle field)
   ============================================================ */
#field{
  position:fixed;
  inset:0;
  width:100%;
  height:100%;
  z-index:0;
  pointer-events:none;
}
.page{position:relative;z-index:1}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:"Outfit",sans-serif;font-weight:700;font-size:1rem;
  letter-spacing:-0.01em;
  padding:.92rem 1.5rem;border-radius:999px;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  position:relative;overflow:hidden;will-change:transform;
}
.btn svg{width:1.1em;height:1.1em}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 10px 26px oklch(58% 0.17 235 / .38)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 38px oklch(58% 0.17 235 / .48);background:var(--accent-strong)}
.btn-ghost{background:var(--surface);color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{transform:translateY(-3px);border-color:var(--accent);color:var(--accent-strong);box-shadow:var(--shadow-sm)}
.btn-light{background:#fff;color:var(--accent-strong)}
.btn-light:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.btn-outline-light{border:1.5px solid oklch(100% 0 0 / .55);color:#fff}
.btn-outline-light:hover{transform:translateY(-3px);background:oklch(100% 0 0 / .12)}

/* ripple */
.ripple{position:absolute;border-radius:50%;background:oklch(100% 0 0 / .55);transform:translate(-50%,-50%) scale(0);pointer-events:none;animation:rip .6s var(--ease) forwards}
@keyframes rip{to{transform:translate(-50%,-50%) scale(18);opacity:0}}

/* ============================================================
   TOP UTILITY BAR
   ============================================================ */
.topbar{
  background:var(--ink-block);color:oklch(92% 0.01 245);
  font-size:.85rem;
  position:relative;z-index:60;
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;min-height:42px;padding-block:.4rem}
.topbar .pill{display:inline-flex;align-items:center;gap:.5rem}
.topbar .dot{width:7px;height:7px;border-radius:50%;background:oklch(75% 0.18 150);box-shadow:0 0 0 0 oklch(75% 0.18 150 / .6);animation:pulse 2.2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 oklch(75% 0.18 150 / .55)}70%{box-shadow:0 0 0 9px oklch(75% 0.18 150 / 0)}100%{box-shadow:0 0 0 0 oklch(75% 0.18 150 / 0)}}
.topbar a{font-weight:700;color:#fff;display:inline-flex;align-items:center;gap:.45rem;white-space:nowrap;font-size:1.05rem;letter-spacing:.01em}
.topbar a svg{width:18px;height:18px;flex:0 0 auto}
.topbar a:hover{color:oklch(80% 0.1 235)}
.topbar .sep{opacity:.4;margin-inline:.4rem}
@media(max-width:620px){.topbar .hide-sm{display:none}}

/* ============================================================
   HEADER / NAV
   ============================================================ */
header.nav{
  position:sticky;top:0;z-index:50;
  background:oklch(98.5% 0.006 240 / .82);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), box-shadow .3s var(--ease), background .3s var(--ease);
}
header.nav.scrolled{border-color:var(--line);box-shadow:var(--shadow-sm);background:oklch(99% 0.005 240 / .92)}
header.nav .wrap{display:flex;align-items:center;justify-content:space-between;min-height:72px;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.6rem;font-family:"Outfit",sans-serif;font-weight:800;font-size:1.18rem;letter-spacing:-0.03em}
.brand .mark{
  width:38px;height:38px;border-radius:11px;flex:none;
  background:linear-gradient(135deg,var(--accent),var(--accent-strong));
  display:grid;place-items:center;color:#fff;
  box-shadow:0 6px 16px oklch(58% 0.17 235 / .4);
}
.brand .mark svg{width:21px;height:21px}
.brand small{display:block;font-family:"General Sans";font-weight:500;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:1px}
.brand b{display:block;line-height:1}
nav.menu{display:flex;align-items:center;gap:.4rem}
nav.menu a.link{padding:.5rem .85rem;border-radius:99px;font-weight:600;font-size:.95rem;color:var(--ink-soft);transition:color .2s,background .2s}
nav.menu a.link:hover{color:var(--accent-strong);background:var(--accent-soft)}
.nav-cta{display:flex;align-items:center;gap:.7rem}
.menu-toggle{display:none}
@media(max-width:940px){
  nav.menu{display:none}
  .nav-cta .btn-ghost{display:none}
  .menu-toggle{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;border:1.5px solid var(--line);background:var(--surface)}
}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:80;display:none}
.drawer.open{display:block}
.drawer .scrim{position:absolute;inset:0;background:oklch(20% 0.02 250 / .45);backdrop-filter:blur(2px)}
.drawer .panel{position:absolute;top:0;right:0;width:min(82vw,340px);height:100%;background:var(--surface);padding:1.5rem;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:.4rem;transform:translateX(8px)}
.drawer .panel a{padding:.85rem 1rem;border-radius:12px;font-weight:600;font-size:1.05rem}
.drawer .panel a:hover{background:var(--accent-soft);color:var(--accent-strong)}
.drawer .panel .btn{margin-top:.6rem;justify-content:center}
.drawer .close{align-self:flex-end;width:42px;height:42px;border-radius:11px;border:1.5px solid var(--line);display:grid;place-items:center;margin-bottom:.5rem}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding-top:clamp(2.5rem,6vw,5rem);padding-bottom:clamp(3rem,7vw,6rem);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(1.5rem,4vw,4rem);align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:.55rem;background:var(--surface);border:1px solid var(--line);padding:.45rem .9rem .45rem .55rem;border-radius:99px;font-size:.82rem;font-weight:600;color:var(--ink-soft);box-shadow:var(--shadow-sm);margin-bottom:1.4rem}
.hero-badge .stars{display:inline-flex;gap:1px;color:oklch(78% 0.16 80)}
.hero-badge .stars svg{width:14px;height:14px}
.hero h1{font-size:clamp(2.55rem,6.4vw,5.7rem);font-weight:900;letter-spacing:-0.045em}
.hero h1 .rotwrap{display:inline-grid;vertical-align:bottom;position:relative;height:1.04em;overflow:hidden}
.hero h1 .rot{
  grid-area:1/1;
  background:linear-gradient(120deg,var(--accent),var(--accent-strong));
  color:transparent;-webkit-background-clip:text;background-clip:text; /* allowed only on the rotating word per energy; falls back to accent */
  color:var(--accent-strong);
  white-space:nowrap;
  display:block;
}
/* keep solid color, no gradient text per rules */
.hero h1 .rot{background:none;color:var(--accent-strong)}
.hero h1 .rot-slot{position:relative;display:inline-block;min-width:1ch}
.hero h1 .word{display:inline-block;position:absolute;left:0;top:0;white-space:nowrap;opacity:0;transform:translateY(0.5em) rotateX(-40deg);transform-origin:bottom;color:var(--accent-strong)}
.hero h1 .word.is-active{position:relative;opacity:1;transform:none}
.hero p.lede{font-size:clamp(1.05rem,1.6vw,1.22rem);color:var(--ink-soft);max-width:46ch;margin-top:1.5rem;line-height:1.55}
.hero .cta-row{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.hero .trust-mini{display:flex;align-items:center;gap:1.3rem;margin-top:2.3rem;flex-wrap:wrap;color:var(--muted);font-size:.9rem;font-weight:500}
.hero .trust-mini .tm{display:flex;align-items:center;gap:.45rem}
.hero .trust-mini svg{width:18px;height:18px;color:var(--accent)}

.hero-visual{position:relative}
.hero-visual .frame{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid var(--line);background:var(--surface);aspect-ratio:4/3.4}
.hero-visual .frame img{width:100%;height:100%;object-fit:cover}
.hero-visual .float-card{
  position:absolute;background:var(--surface);border:1px solid var(--line);
  border-radius:16px;padding:.85rem 1.05rem;box-shadow:var(--shadow-md);
  display:flex;align-items:center;gap:.7rem;will-change:transform;
}
.hero-visual .float-card .ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;flex:none}
.hero-visual .float-card .ic svg{width:20px;height:20px}
.hero-visual .float-card b{font-family:"Outfit";font-size:1.05rem;display:block;line-height:1.1}
.hero-visual .float-card span{font-size:.78rem;color:var(--muted)}
.fc-1{left:-14px;bottom:38px}
.fc-1 .ic{background:var(--accent-soft);color:var(--accent-strong)}
.fc-2{right:-10px;top:34px}
.fc-2 .ic{background:oklch(94% 0.06 150);color:oklch(45% 0.13 150)}
@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr}
  .hero-visual{order:-1;max-width:560px}
  .fc-1{left:0}
  .fc-2{right:0}
}
@media(max-width:420px){
  .hero-visual .float-card span{display:none}
  .fc-1,.fc-2{padding:.6rem .7rem}
}

/* ============================================================
   KINETIC MARQUEE
   ============================================================ */
.marquee{background:var(--ink-block);color:#fff;padding:.95rem 0;overflow:hidden;position:relative}
.marquee .track{display:flex;gap:2.4rem;width:max-content;animation:scroll-x 28s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee .item{display:inline-flex;align-items:center;gap:.7rem;font-family:"Outfit";font-weight:700;font-size:1.05rem;letter-spacing:-0.02em;white-space:nowrap}
.marquee .item svg{width:16px;height:16px;color:var(--accent)}
@keyframes scroll-x{to{transform:translateX(-50%)}}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
section{position:relative;padding-block:clamp(3.4rem,7vw,6rem)}
.sec-head{max-width:680px;margin-bottom:clamp(2rem,4vw,3rem)}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-kicker{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;color:var(--accent-strong);background:var(--accent-soft);padding:.35rem .8rem;border-radius:99px;margin-bottom:1rem}
.sec-kicker svg{width:15px;height:15px}
.sec-head h2{font-size:clamp(2rem,4vw,3.2rem);font-weight:800}
.sec-head p{color:var(--ink-soft);font-size:1.08rem;margin-top:1rem;max-width:60ch}

/* reveal (content visible by default; transform-only enhancement) */
.reveal{opacity:1;transform:none}
.js .reveal{opacity:0;transform:translateY(28px)}
.js .reveal.in{opacity:1;transform:none;transition:opacity .7s var(--ease),transform .7s var(--ease)}

/* ============================================================
   VALUE / INTRO
   ============================================================ */
.value{}
.value-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.value h2{font-size:clamp(2rem,3.8vw,3rem)}
.value .sub{color:var(--ink-soft);margin-top:1.1rem;font-size:1.08rem;max-width:52ch}
.value ul{list-style:none;margin-top:1.8rem;display:grid;gap:.95rem}
.value li{display:flex;gap:.85rem;align-items:flex-start}
.value li .tick{width:26px;height:26px;border-radius:8px;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center;flex:none;margin-top:2px}
.value li .tick svg{width:15px;height:15px}
.value li b{font-family:"Outfit";font-weight:700;font-size:1.02rem}
.value li p{color:var(--muted);font-size:.95rem;margin-top:1px}
.value .save{margin-top:1.9rem;display:inline-flex;align-items:center;gap:1rem;background:var(--ink-block);color:#fff;border-radius:16px;padding:1rem 1.3rem}
.value .save .big{font-family:"Outfit";font-weight:900;font-size:2.6rem;line-height:1;color:oklch(80% 0.14 235)}
.value .save span{font-size:.92rem;color:oklch(85% 0.01 245);max-width:22ch}
.value .cta-row{margin-top:1.9rem}
.value-visual{position:relative}
.value-visual .stack{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:1rem}
.value-visual .stack img{border-radius:18px;box-shadow:var(--shadow-md);width:100%;height:100%;object-fit:cover;border:1px solid var(--line)}
.value-visual .stack .tall{grid-row:span 2;aspect-ratio:3/4.6}
.value-visual .stack .wide{aspect-ratio:4/3}
.value-visual .badge-25{
  position:absolute;right:-6px;top:-22px;width:104px;height:104px;border-radius:50%;
  background:var(--accent);color:#fff;display:grid;place-items:center;text-align:center;
  font-family:"Outfit";font-weight:800;box-shadow:0 14px 30px oklch(58% 0.17 235 / .45);
  transform:rotate(-8deg);
}
.value-visual .badge-25 b{font-size:1.9rem;line-height:.9;display:block}
.value-visual .badge-25 span{font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;display:block;margin-top:3px}
@media(max-width:880px){
  .value-grid{grid-template-columns:1fr}
  .value-visual{max-width:520px}
}

/* ============================================================
   SERVICES (asymmetric tilt cards + horizontal scroll)
   ============================================================ */
.services{background:linear-gradient(180deg,var(--bg),oklch(96.5% 0.01 240))}
.svc-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-bottom:2.2rem}
.svc-head .right{color:var(--muted);font-size:.9rem;display:flex;align-items:center;gap:.5rem}
.svc-head .right svg{width:18px;height:18px}

.svc-scroller{
  display:grid;grid-auto-flow:column;
  grid-auto-columns:minmax(290px,330px);
  gap:1.3rem;overflow-x:auto;padding:1rem .2rem 2rem;
  scroll-snap-type:x mandatory;
  scrollbar-width:thin;scrollbar-color:var(--accent) transparent;
}
.svc-scroller::-webkit-scrollbar{height:8px}
.svc-scroller::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px}
.svc-scroller::-webkit-scrollbar-thumb:hover{background:var(--accent)}

.svc-card{
  scroll-snap-align:start;position:relative;border-radius:var(--r-lg);overflow:hidden;
  background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);
  transition:box-shadow .35s var(--ease);
  transform-style:preserve-3d;will-change:transform;
}
.svc-card:hover{box-shadow:var(--shadow-lg)}
.svc-card .media{aspect-ratio:4/3.1;overflow:hidden;position:relative}
.svc-card .media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.svc-card:hover .media img{transform:scale(1.07)}
.svc-card .media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,oklch(22% 0.02 250 / .42))}
.svc-card .num{position:absolute;top:.9rem;left:.9rem;z-index:2;font-family:"Outfit";font-weight:800;font-size:.78rem;color:#fff;background:oklch(22% 0.02 250 / .5);backdrop-filter:blur(6px);padding:.25rem .6rem;border-radius:99px}
.svc-card .body{padding:1.25rem 1.3rem 1.45rem;transform:translateZ(30px)}
.svc-card h3{font-size:1.32rem;font-weight:800;display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.svc-card h3 .arrow{width:30px;height:30px;border-radius:50%;background:var(--accent-soft);color:var(--accent-strong);display:grid;place-items:center;flex:none;transition:transform .3s var(--ease),background .3s var(--ease)}
.svc-card h3 .arrow svg{width:15px;height:15px}
.svc-card:hover h3 .arrow{background:var(--accent);color:#fff;transform:translate(2px,-2px) rotate(-2deg)}
.svc-card p{color:var(--muted);font-size:.93rem;margin-top:.5rem;line-height:1.5}
.svc-hint{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.85rem;justify-content:center;margin-top:-.5rem}
.svc-hint svg{width:18px;height:18px;flex:0 0 auto}

/* ============================================================
   STATS (restrained, inline)
   ============================================================ */
.stats{background:var(--ink-block);color:#fff;border-radius:0}
.stats .wrap{display:grid;grid-template-columns:1.1fr 1fr 1fr 1fr;gap:2rem;align-items:center}
.stats .intro h3{color:#fff;font-size:1.5rem;font-weight:800}
.stats .intro p{color:oklch(80% 0.01 245);font-size:.95rem;margin-top:.5rem;max-width:30ch}
.stat .n{font-family:"Outfit";font-weight:900;font-size:clamp(2.2rem,4vw,3.1rem);letter-spacing:-0.04em;color:oklch(82% 0.13 235);line-height:1}
.stat .l{color:oklch(82% 0.01 245);font-size:.92rem;margin-top:.5rem}
@media(max-width:880px){.stats .wrap{grid-template-columns:1fr 1fr}.stats .intro{grid-column:1/-1}}
@media(max-width:440px){.stats .wrap{grid-template-columns:1fr}}

/* ============================================================
   BRAND LOGOS (kinetic marquee)
   ============================================================ */
.brands{text-align:center}
.brands h2{font-size:clamp(1.5rem,2.6vw,2rem);font-weight:700;color:var(--ink-soft)}
.logo-marquee{margin-top:2.2rem;position:relative;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.logo-marquee .track{display:flex;gap:3.6rem;width:max-content;align-items:center;animation:scroll-x 36s linear infinite}
.logo-marquee:hover .track{animation-play-state:paused}
.logo-marquee img{height:34px;width:auto;object-fit:contain;filter:grayscale(1);opacity:.6;transition:filter .3s,opacity .3s}
.logo-marquee img:hover{filter:grayscale(0);opacity:1}

/* ============================================================
   FORM
   ============================================================ */
.schedule{background:linear-gradient(160deg,var(--accent-soft),var(--bg))}
.sched-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.sched-left h2{font-size:clamp(2rem,3.6vw,2.9rem)}
.sched-left p{color:var(--ink-soft);margin-top:1.1rem;font-size:1.06rem;max-width:42ch}
.sched-left .feat{display:grid;gap:1.1rem;margin-top:2rem}
.sched-left .feat .f{display:flex;gap:.8rem;align-items:center}
.sched-left .feat .ic{width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;flex:none;color:var(--accent-strong)}
.sched-left .feat .ic svg{width:20px;height:20px}
.sched-left .feat b{font-family:"Outfit";font-size:1.02rem;display:block}
.sched-left .feat span{font-size:.9rem;color:var(--muted)}

.form-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.4rem,3vw,2.2rem);box-shadow:var(--shadow-lg)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem 1.2rem}
.field{display:flex;flex-direction:column;gap:.4rem}
.field.full{grid-column:1/-1}
.field label{font-weight:600;font-size:.88rem;color:var(--ink-soft)}
.field input,.field select{
  font-family:inherit;font-size:1rem;color:var(--ink);
  padding:.78rem .9rem;border-radius:12px;border:1.5px solid var(--line);
  background:var(--bg);transition:border-color .2s,box-shadow .2s,background .2s;
}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 4px oklch(58% 0.17 235 / .14)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%234a5568' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .9rem center;padding-right:2.4rem}
.form-card .submit-row{margin-top:1.5rem;display:flex;flex-direction:column;gap:.8rem}
.form-card .submit-row .btn{justify-content:center;width:100%;font-size:1.05rem;padding:1.05rem}
.form-note{font-size:.82rem;color:var(--muted);text-align:center}
.form-ok{display:none;background:oklch(94% 0.06 150);color:oklch(38% 0.12 150);border:1px solid oklch(85% 0.09 150);border-radius:12px;padding:.85rem 1rem;font-weight:600;font-size:.92rem;margin-bottom:1rem;align-items:center;gap:.5rem}
.form-ok.show{display:flex}
.form-ok svg{width:18px;height:18px;flex:none}
@media(max-width:840px){.sched-grid{grid-template-columns:1fr}}
@media(max-width:520px){.form-grid{grid-template-columns:1fr}}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews .rev-top{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:2.4rem}
.rev-rating{display:flex;align-items:center;gap:1rem}
.rev-rating .score{font-family:"Outfit";font-weight:900;font-size:3rem;line-height:1;color:var(--ink)}
.rev-rating .stars{color:oklch(78% 0.16 80);display:flex;gap:2px}
.rev-rating .stars svg{width:18px;height:18px}
.rev-rating small{display:block;color:var(--muted);font-size:.88rem;margin-top:3px}
.rev-rating .g{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;font-size:.92rem;color:var(--ink-soft)}
.rev-rating .g svg{width:18px;height:18px}
.rev-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem}
.rev-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:1rem;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.rev-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.rev-card .stars{color:oklch(78% 0.16 80);display:flex;gap:1px}
.rev-card .stars svg{width:16px;height:16px}
.rev-card p{color:var(--ink-soft);font-size:1rem;line-height:1.55;flex:1}
.rev-card .who{display:flex;align-items:center;gap:.75rem;border-top:1px solid var(--line-soft);padding-top:1rem}
.rev-card .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:"Outfit";font-weight:800;color:#fff;flex:none}
.rev-card .who b{font-size:.98rem;display:block;font-family:"Outfit"}
.rev-card .who span{font-size:.82rem;color:var(--muted)}
@media(max-width:840px){.rev-cards{grid-template-columns:1fr}}

/* ============================================================
   ARTICLES (varied bento)
   ============================================================ */
.articles{background:oklch(96.5% 0.01 240)}
.art-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;grid-template-rows:auto auto;gap:1.3rem}
.art{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:transform .3s var(--ease),box-shadow .3s var(--ease);display:flex;flex-direction:column}
.art:hover{transform:translateY(-5px);box-shadow:var(--shadow-md)}
.art .media{overflow:hidden;aspect-ratio:16/10}
.art .media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.art:hover .media img{transform:scale(1.06)}
.art .body{padding:1.2rem 1.3rem 1.4rem;display:flex;flex-direction:column;gap:.55rem;flex:1}
.art .tag{font-size:.76rem;font-weight:600;color:var(--accent-strong);text-transform:uppercase;letter-spacing:.06em}
.art h3{font-size:1.18rem;font-weight:700;letter-spacing:-0.03em}
.art p{color:var(--muted);font-size:.9rem;line-height:1.5}
.art .more{margin-top:auto;font-weight:600;font-size:.9rem;color:var(--accent-strong);display:inline-flex;align-items:center;gap:.4rem}
.art .more svg{width:15px;height:15px;transition:transform .3s var(--ease)}
.art:hover .more svg{transform:translateX(4px)}
.art.feature{grid-row:span 2}
.art.feature .media{aspect-ratio:auto;flex:1;min-height:200px}
.art.feature h3{font-size:1.7rem}
@media(max-width:900px){
  .art-grid{grid-template-columns:1fr 1fr}
  .art.feature{grid-column:1/-1;grid-row:auto}
  .art.feature .media{aspect-ratio:16/9}
}
@media(max-width:560px){.art-grid{grid-template-columns:1fr}}

/* ============================================================
   FINAL CTA (vivid color band)
   ============================================================ */
.final{background:linear-gradient(135deg,var(--accent),var(--accent-strong));color:#fff;text-align:center;overflow:hidden;position:relative}
.final::before,.final::after{content:"";position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;pointer-events:none}
.final::before{width:380px;height:380px;background:oklch(72% 0.16 200);top:-120px;left:-80px}
.final::after{width:420px;height:420px;background:oklch(55% 0.18 250);bottom:-160px;right:-90px}
.final .wrap{position:relative;z-index:2;max-width:780px}
.final h2{color:#fff;font-size:clamp(2.2rem,5vw,4rem);font-weight:900}
.final p{color:oklch(96% 0.03 235);font-size:1.15rem;margin-top:1.2rem;max-width:50ch;margin-inline:auto}
.final .cta-row{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap;margin-top:2.2rem}
.final .trust{margin-top:1.8rem;font-size:.92rem;color:oklch(94% 0.02 235);display:inline-flex;align-items:center;gap:.5rem}
.final .trust svg{width:17px;height:17px}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--ink-block);color:oklch(82% 0.01 245);padding-top:clamp(3rem,6vw,5rem);position:relative;z-index:1}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:2.5rem}
.foot-brand .brand{color:#fff;margin-bottom:1.1rem}
.foot-brand .brand small{color:oklch(70% 0.02 245)}
.foot-brand p{font-size:.92rem;line-height:1.7;max-width:30ch}
.foot-brand a{color:oklch(82% 0.1 235)}
.foot-contact{display:grid;gap:.6rem;margin-top:1.2rem;font-size:.92rem}
.foot-contact a,.foot-contact span{display:flex;gap:.6rem;align-items:flex-start}
.foot-contact svg{width:17px;height:17px;color:var(--accent);flex:none;margin-top:3px}
.socials{display:flex;gap:.7rem;margin-top:1.3rem}
.socials a{width:40px;height:40px;border-radius:11px;background:oklch(100% 0 0 / .08);display:grid;place-items:center;color:#fff;transition:background .25s,transform .25s}
.socials a:hover{background:var(--accent);transform:translateY(-3px)}
.socials svg{width:19px;height:19px}
footer h4{color:#fff;font-family:"Outfit";font-size:1rem;font-weight:700;margin-bottom:1.1rem;letter-spacing:0}
footer ul{list-style:none;display:grid;gap:.65rem}
footer ul a{font-size:.92rem;color:oklch(80% 0.01 245);transition:color .2s}
footer ul a:hover{color:#fff}
.foot-bottom{border-top:1px solid oklch(100% 0 0 / .1);margin-top:clamp(2.5rem,5vw,4rem);padding-block:1.5rem}
.foot-bottom .wrap{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:oklch(68% 0.01 245)}
.foot-bottom .areas{display:flex;gap:.5rem;flex-wrap:wrap}
.foot-bottom .areas span{font-size:.78rem}
@media(max-width:840px){.foot-grid{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1}}
@media(max-width:460px){.foot-grid{grid-template-columns:1fr}}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .marquee .track,.logo-marquee .track{animation:none}
  .js .reveal{opacity:1 !important;transform:none !important}
  .hero h1 .word{position:relative;opacity:1;transform:none}
  .hero h1 .word:not(.is-active){display:none}
}

/* ============ Generic pages, blog, prose (alta-v3 inner templates) ============ */
.wrap.narrow{max-width:820px}
.page-main{position:relative;z-index:1}
.page-hero{padding:92px 0 22px;background:linear-gradient(180deg,var(--surface),var(--bg));border-bottom:1px solid var(--line-soft)}
.page-hero .wrap{max-width:var(--maxw)}
.page-hero .eyebrow{color:var(--accent);font-weight:600;font-size:.95rem;margin:0 0 .5rem}
.page-hero h1{font-family:'Outfit',sans-serif;font-weight:800;letter-spacing:-.02em;line-height:1.05;font-size:clamp(2rem,1.4rem+3vw,3.6rem);color:var(--ink);margin:0;text-wrap:balance}
.page-hero p.lead{color:var(--muted);font-size:1.125rem;line-height:1.6;max-width:60ch;margin:.9rem 0 0}
.page-body{padding:48px 0 80px}
.entry{color:var(--ink);font-size:1.05rem;line-height:1.75}
.entry > *{max-width:72ch}
.entry h2{font-family:'Outfit',sans-serif;font-weight:700;letter-spacing:-.01em;font-size:1.7rem;margin:2.2rem 0 .8rem;color:var(--ink)}
.entry h3{font-weight:700;font-size:1.3rem;margin:1.8rem 0 .6rem;color:var(--ink)}
.entry p{margin:0 0 1.1rem;color:var(--ink-soft,var(--ink))}
.entry a{color:var(--accent);text-decoration:underline;text-underline-offset:2px}
.entry ul,.entry ol{margin:0 0 1.1rem 1.2rem;color:var(--ink-soft,var(--ink))}
.entry li{margin:.35rem 0}
.entry img{max-width:100%;height:auto;border-radius:var(--r)}
.entry figure{margin:1.4rem 0}
.entry blockquote{border-left:3px solid var(--accent);margin:1.4rem 0;padding:.4rem 0 .4rem 1.2rem;color:var(--muted);font-style:italic}
.entry table{width:100%;border-collapse:collapse;margin:1.2rem 0}
.entry th,.entry td{border:1px solid var(--line);padding:.6rem .8rem;text-align:left}

/* Blog index grid */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px;padding:48px 0 80px}
.post-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg,18px);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.post-card .thumb{aspect-ratio:16/10;background:var(--line-soft);overflow:hidden}
.post-card .thumb img{width:100%;height:100%;object-fit:cover}
.post-card .pc-body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:.5rem;flex:1}
.post-card h2{font-family:'Outfit',sans-serif;font-size:1.2rem;font-weight:700;line-height:1.25;margin:0}
.post-card h2 a{color:var(--ink);text-decoration:none}
.post-card h2 a:hover{color:var(--accent)}
.post-card .meta{font-size:.85rem;color:var(--muted)}
.post-card .excerpt{color:var(--muted);font-size:.95rem;line-height:1.55;margin:0}
.post-card .more{margin-top:auto;color:var(--accent);font-weight:600;font-size:.92rem;text-decoration:none}
.pagination{display:flex;gap:.5rem;justify-content:center;align-items:center;padding:0 0 80px;flex-wrap:wrap}
.pagination .page-numbers{display:inline-flex;min-width:42px;height:42px;align-items:center;justify-content:center;gap:.35rem;padding:0 .8rem;border:1px solid var(--line);border-radius:999px;color:var(--ink);text-decoration:none;font-weight:600;transition:border-color .18s var(--ease),background .18s var(--ease),color .18s var(--ease)}
.pagination .page-numbers:hover{border-color:var(--accent);color:var(--accent-strong)}
.pagination .page-numbers.current{background:var(--accent);color:#fff;border-color:var(--accent)}
.pagination .page-numbers svg{width:16px;height:16px}
.pagination .prev,.pagination .next{padding:0 1.05rem}
.pagination .is-disabled{opacity:.4;pointer-events:none}
@media(max-width:560px){.pagination .prev span,.pagination .next span{display:none}.pagination .prev,.pagination .next{padding:0;min-width:42px}}
.single-meta{display:flex;gap:1rem;align-items:center;color:var(--muted);font-size:.95rem;margin:.6rem 0 0}
.single-feat{margin:0 0 28px;border-radius:var(--r-lg,18px);overflow:hidden;max-width:var(--maxw)}
.single-feat img{width:100%;height:auto;display:block}
.post-cta{margin:48px 0 0;padding:32px;border-radius:var(--r-lg,18px);background:var(--ink-block,#0f1b2d);color:#fff;display:flex;flex-wrap:wrap;gap:1rem;align-items:center;justify-content:space-between}
.post-cta h3{font-family:'Outfit',sans-serif;font-size:1.4rem;margin:0;color:#fff}
@media(max-width:640px){.page-hero{padding:96px 0 20px}}

/* ============ Override Elementor per-page body background (#54595F) ============
   Elementor (active for plugin parity) emits body.elementor-page-{id}{background:#54595F}
   which overrides the homepage6 light bg on inner pages. Force the design bg back. */
html body { background: var(--bg) !important; color: var(--ink); }

/* ============ Header dropdown submenus (Services / About) ============ */
nav.menu{display:flex;align-items:center;gap:.25rem}
.menu-item{position:relative;display:flex;align-items:center}
.menu-item .link{display:inline-flex;align-items:center;gap:.28rem}
.menu-item .caret{width:14px;height:14px;transition:transform .25s var(--ease);opacity:.7}
.menu-item.has-sub:hover .caret,.menu-item.has-sub:focus-within .caret{transform:rotate(180deg)}
/* hover bridge so the gap between link and panel doesn't drop the menu */
.menu-item.has-sub::after{content:"";position:absolute;top:100%;left:0;right:0;height:.65rem}
.submenu{
  position:absolute;top:calc(100% + .55rem);left:50%;transform:translateX(-50%) translateY(8px);
  min-width:248px;background:var(--surface);border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow-lg);padding:.5rem;
  display:flex;flex-direction:column;gap:1px;z-index:120;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s;
}
.menu-item.has-sub:hover .submenu,
.menu-item.has-sub:focus-within .submenu{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.submenu a{display:block;padding:.32rem .7rem;border-radius:7px;font-size:.9rem;line-height:1.25;font-weight:500;color:var(--ink-soft);white-space:nowrap;transition:background .18s var(--ease),color .18s var(--ease)}
.submenu a:hover{background:var(--accent-soft);color:var(--accent-strong)}
.submenu .submenu-all{margin-top:.25rem;border-top:1px solid var(--line);border-radius:0 0 10px 10px;color:var(--accent-strong);font-weight:700}
@media(max-width:980px){ nav.menu{display:none} }

/* ============ Mobile drawer accordion submenus ============ */
.drawer details{border:none}
.drawer details > summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;padding:.65rem .2rem;font-weight:600;color:var(--ink)}
.drawer details > summary::-webkit-details-marker{display:none}
.drawer details > summary .caret{width:18px;height:18px;transition:transform .25s var(--ease);opacity:.6}
.drawer details[open] > summary .caret{transform:rotate(180deg)}
.drawer .submenu-mobile{display:flex;flex-direction:column;padding:.2rem 0 .5rem .6rem;border-left:2px solid var(--line);margin-left:.2rem}
.drawer .submenu-mobile a{padding:.32rem .4rem;font-size:.95rem;color:var(--ink-soft)}
.drawer .submenu-mobile a:hover{color:var(--accent-strong);background:transparent}

/* ============ Locations mega-menu ============ */
.submenu.submenu--mega{
  left:auto; right:0; transform:translateY(8px);
  width:min(660px,88vw); min-width:0; padding:.75rem;
}
.menu-item.has-mega:hover .submenu--mega,
.menu-item.has-mega:focus-within .submenu--mega{transform:translateY(0)}
.mega-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:0 2px;max-height:62vh;overflow:auto;
}
.mega-grid a{padding:.26rem .6rem;border-radius:7px;font-size:.88rem;line-height:1.2;font-weight:500;color:var(--ink-soft);white-space:nowrap}
.mega-grid a:hover{background:var(--accent-soft);color:var(--accent-strong)}
.submenu--mega .submenu-all{margin-top:.4rem}

/* ============================================================
   SERVICE PAGE TEMPLATE (full-width, rich)
   ============================================================ */
.svc-main{position:relative;z-index:1}
.svc-hero{padding:120px 0 56px;background:linear-gradient(180deg,var(--surface),var(--bg))}
.svc-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.svc-hero-copy .eyebrow{color:var(--accent);font-weight:700;margin:1rem 0 .4rem;font-size:.95rem;letter-spacing:.01em}
.svc-hero-copy h1{font-size:clamp(2.3rem,1.6rem+3vw,4rem);line-height:1.04;color:var(--ink);margin:0}
.svc-lead{font-size:1.18rem;line-height:1.6;color:var(--muted);max-width:54ch;margin:1.1rem 0 1.6rem}
.svc-hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1.4rem}
.svc-hero-trust{list-style:none;display:flex;flex-wrap:wrap;gap:1.3rem;padding:0;margin:0}
.svc-hero-trust li{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;font-size:.92rem;color:var(--ink-soft)}
.svc-hero-trust svg{width:18px;height:18px;color:var(--accent)}
.svc-hero-media{position:relative}
.svc-hero-media img{width:100%;aspect-ratio:5/4;object-fit:cover;border-radius:var(--r-lg,26px);box-shadow:var(--shadow-lg)}
.svc-hero-chip{position:absolute;left:-10px;bottom:-18px;background:var(--surface);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-md);padding:.8rem 1.1rem;display:flex;flex-direction:column}
.svc-hero-chip strong{font-family:'Outfit',sans-serif;font-size:1.3rem;color:var(--accent-strong)}
.svc-hero-chip span{font-size:.78rem;color:var(--muted)}

.svc-features{padding:18px 0 10px}
.svc-features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.svc-feature{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem 1.3rem;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.svc-feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.svc-feature .ic{display:grid;place-items:center;width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent-strong);margin-bottom:.8rem}
.svc-feature .ic svg{width:22px;height:22px}
.svc-feature h3{font-size:1.05rem;margin:0 0 .35rem;color:var(--ink)}
.svc-feature p{font-size:.92rem;color:var(--muted);line-height:1.5;margin:0}

.svc-body{padding:30px 0 24px}
.svc-body-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.svc-content{font-size:1.05rem}
.svc-content h2{font-family:'Outfit',sans-serif;font-size:1.9rem;margin:0 0 1rem;color:var(--ink)}
.svc-content h3{font-size:1.3rem;margin:1.8rem 0 .6rem;color:var(--ink)}
.svc-content p{margin:0 0 1.1rem;color:var(--ink-soft);line-height:1.75}
.svc-aside{position:sticky;top:96px;display:flex;flex-direction:column;gap:18px}
.svc-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.5rem;box-shadow:var(--shadow-sm)}
.svc-quote-card{background:linear-gradient(160deg,var(--accent-soft),var(--surface));border-color:var(--accent-soft)}
.svc-quote-card h3{font-size:1.25rem;margin:0 0 .4rem;color:var(--ink)}
.svc-quote-card p{font-size:.92rem;color:var(--muted);margin:0 0 1rem;line-height:1.5}
.svc-quote-card .btn{width:100%;justify-content:center}
.svc-call{display:block;text-align:center;margin-top:.7rem;font-weight:600;color:var(--accent-strong);font-size:.92rem}
.svc-card h4{font-size:1rem;margin:0 0 .6rem;color:var(--ink);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;color:var(--muted)}
.svc-related-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column}
.svc-related-list a{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--line-soft);font-weight:600;color:var(--ink-soft);font-size:.95rem}
.svc-related-list li:last-child a{border-bottom:none}
.svc-related-list a:hover{color:var(--accent-strong)}
.svc-related-list svg{width:16px;height:16px;opacity:.6}

.svc-stats{background:linear-gradient(160deg,var(--navy-900,#0d1b30),var(--ink-block));color:#fff;padding-block:clamp(2.6rem,4vw,3.6rem)}
.svc-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:0;text-align:center;max-width:1080px;margin-inline:auto}
.svc-stats-grid > div{position:relative;padding:.25rem 1.5rem;display:flex;flex-direction:column;align-items:center;justify-content:center}
.svc-stats-grid > div + div::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);height:56px;width:1px;background:linear-gradient(180deg,transparent,oklch(100% 0 0 / .18),transparent)}
.svc-stats strong{display:block;font-family:'Outfit',sans-serif;font-weight:800;font-size:clamp(2.4rem,1.6rem+2.4vw,3.4rem);line-height:1;letter-spacing:-.03em;background:linear-gradient(180deg,#fff,oklch(85% 0.06 235));-webkit-background-clip:text;background-clip:text;color:transparent}
.svc-stats span{display:block;margin-top:.6rem;color:oklch(78% 0.03 245);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600}

.svc-related{padding:64px 0 24px}
.svc-related h2{font-family:'Outfit',sans-serif;font-size:1.9rem;margin:0 0 1.5rem;color:var(--ink)}
.svc-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.svc-related-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:1.3rem 1.5rem;font-family:'Outfit',sans-serif;font-weight:700;font-size:1.1rem;color:var(--ink);box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease)}
.svc-related-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent);color:var(--accent-strong)}
.svc-related-card svg{width:20px;height:20px;flex:0 0 auto}

.svc-faq{padding:48px 0 64px}
.svc-faq h2{font-family:'Outfit',sans-serif;font-size:1.9rem;margin:0 0 1.5rem;color:var(--ink)}
.faq-list{display:flex;flex-direction:column;gap:12px}

@media(max-width:980px){
  .svc-hero-grid{grid-template-columns:1fr}
  .svc-hero-media{order:-1}
  .svc-features-grid{grid-template-columns:repeat(2,1fr)}
  .svc-body-grid{grid-template-columns:1fr}
  .svc-aside{position:static}
  .svc-stats-grid{grid-template-columns:repeat(2,1fr);gap:36px 0}
  .svc-stats-grid > div + div::before{display:none}
  .svc-related-grid{grid-template-columns:1fr}
}
@media(max-width:520px){ .svc-features-grid{grid-template-columns:1fr} }

/* ============ About brands strip ============ */
.about-brands{padding:48px 0 8px}
.about-brands-label{text-align:center;color:var(--muted);font-weight:600;letter-spacing:.04em;margin:0 0 1.8rem;font-size:.95rem}
.about-logos{display:grid;grid-template-columns:repeat(5,1fr);gap:2rem 2.5rem;align-items:center;justify-items:center;max-width:980px;margin:0 auto}
.about-logos img{max-height:46px;width:auto;filter:grayscale(1);opacity:.6;transition:filter .25s var(--ease),opacity .25s var(--ease)}
.about-logos img:hover{filter:grayscale(0);opacity:1}
@media(max-width:760px){ .about-logos{grid-template-columns:repeat(3,1fr);gap:1.6rem} }

/* ============================================================
   SERVICES HUB (/our-services/)
   ============================================================ */
.hub-hero{padding:120px 0 40px;text-align:center;background:linear-gradient(180deg,var(--surface),var(--bg))}
.hub-hero .hero-badge{margin:0 auto 1.1rem}
.hub-hero .eyebrow{color:var(--accent);font-weight:700;font-size:.95rem;margin:0 0 .4rem}
.hub-hero h1{font-size:clamp(2.3rem,1.6rem+3vw,4rem);line-height:1.04;color:var(--ink);margin:0 auto;max-width:16ch}
.hub-lead{font-size:1.18rem;line-height:1.6;color:var(--muted);max-width:60ch;margin:1.1rem auto 1.6rem}
.hub-hero .svc-hero-cta{justify-content:center}
.hub-grid-sec{padding:24px 0 16px}
.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.hub-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg,22px);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .28s var(--ease),box-shadow .28s var(--ease),border-color .28s var(--ease)}
.hub-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.hub-card-media{aspect-ratio:16/10;overflow:hidden}
.hub-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.hub-card:hover .hub-card-media img{transform:scale(1.06)}
.hub-card-body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.hub-card-body h3{font-family:'Outfit',sans-serif;font-size:1.3rem;color:var(--ink);margin:0 0 .45rem}
.hub-card-body p{font-size:.95rem;color:var(--muted);line-height:1.55;margin:0 0 1rem}
.hub-card-link{margin-top:auto;display:inline-flex;align-items:center;gap:.4rem;font-weight:700;color:var(--accent-strong);font-size:.95rem}
.hub-card-link svg{width:18px;height:18px;transition:transform .25s var(--ease)}
.hub-card:hover .hub-card-link svg{transform:translateX(4px)}
@media(max-width:980px){ .hub-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:600px){ .hub-grid{grid-template-columns:1fr} }

/* ============ About-child photo gallery (Recent Jobs) ============ */
.ac-gallery-sec{padding:24px 0 8px}
.ac-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.ac-gallery img{width:100%!important;height:auto;aspect-ratio:4/3;object-fit:cover;border-radius:12px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),box-shadow .25s var(--ease);margin:0!important}
.ac-gallery img:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
@media(max-width:900px){ .ac-gallery{grid-template-columns:repeat(3,1fr)} }
@media(max-width:560px){ .ac-gallery{grid-template-columns:repeat(2,1fr)} }
/* inline content images (Careers etc.) */
.svc-content img{border-radius:var(--r);box-shadow:var(--shadow-sm);margin:1rem 0;max-width:100%;height:auto}

/* ============================================================
   STATS 2 — light "by the numbers" cards (replaces dark band)
   ============================================================ */
.stats2{padding:clamp(44px,6vw,76px) 0}
.stats2-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;max-width:1160px;margin-inline:auto}
.stat2-card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg,22px);padding:2rem 1.5rem 1.8rem;text-align:center;box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .28s var(--ease),box-shadow .28s var(--ease),border-color .28s var(--ease)}
.stat2-card::before{content:"";position:absolute;top:-40px;right:-40px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,var(--accent-soft),transparent 70%);opacity:.8;pointer-events:none}
.stat2-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--accent)}
.stat2-ic{position:relative;display:inline-grid;place-items:center;width:54px;height:54px;border-radius:16px;background:linear-gradient(150deg,var(--accent),var(--accent-strong));color:#fff;margin-bottom:1.1rem;box-shadow:0 8px 20px oklch(58% 0.17 235 / .3)}
.stat2-ic svg{width:26px;height:26px}
.stat2-num{position:relative;display:block;font-family:'Outfit',sans-serif;font-weight:800;font-size:clamp(2.3rem,1.6rem+2vw,3.2rem);line-height:1;color:var(--ink);letter-spacing:-.03em}
.stat2-label{position:relative;display:block;margin-top:.55rem;color:var(--muted);font-weight:600;font-size:.92rem;letter-spacing:.01em}
@media(max-width:900px){ .stats2-grid{grid-template-columns:repeat(2,1fr)} }
@media(max-width:480px){ .stats2-grid{grid-template-columns:1fr} }

/* ============ Location: nearby cities grid ============ */
.loc-near-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:10px}
.loc-near{display:flex;align-items:center;gap:.55rem;padding:.8rem 1rem;background:var(--surface);border:1px solid var(--line);border-radius:12px;font-weight:600;font-size:.95rem;color:var(--ink-soft);box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease)}
.loc-near:hover{transform:translateY(-2px);border-color:var(--accent);color:var(--accent-strong)}
.loc-near svg{width:17px;height:17px;color:var(--accent);flex:0 0 auto}

/* ============ Location testimonial quote ============ */
.loc-quote{margin:2rem 0 0;padding:1.6rem 1.8rem;background:var(--accent-soft);border-radius:var(--r);border:1px solid var(--line)}
.loc-quote svg{width:30px;height:30px;color:var(--accent);opacity:.5}
.loc-quote blockquote{margin:.4rem 0 .6rem;font-size:1.15rem;line-height:1.6;color:var(--ink);font-weight:500}
.loc-quote figcaption{color:var(--accent-strong);font-weight:700;font-size:.92rem}

/* ============ Google reviews animated badge ============ */
.greviews-wrap{display:flex;justify-content:center;padding:14px 0 40px}
.greviews{position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:1.1rem;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:1rem 1.7rem;box-shadow:var(--shadow-md);transition:transform .28s var(--ease),box-shadow .28s var(--ease)}
.greviews:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.greviews-g{flex:0 0 auto;display:grid;place-items:center}
.greviews-g svg{width:38px;height:38px}
.greviews-body{display:flex;flex-direction:column;gap:3px;text-align:left}
.greviews-top{font-size:.7rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);font-weight:700}
.greviews-rating{display:inline-flex;align-items:center;gap:.55rem}
.greviews-rating b{font-family:'Outfit',sans-serif;font-weight:800;font-size:1.55rem;line-height:1;color:var(--ink)}
.greviews-stars{display:inline-flex;gap:2px;color:#fbbc05}
.gstar{width:18px;height:18px}
.greviews-sub{font-size:.82rem;color:var(--muted)}
.greviews-shimmer{position:absolute;inset:0;background:linear-gradient(110deg,transparent 35%,oklch(100% 0 0 / .65) 50%,transparent 65%);transform:translateX(-130%);pointer-events:none}
/* hidden initial states only when JS is on (graceful no-JS fallback) */
html.js .gstar{transform:scale(0) rotate(-30deg);opacity:0}
.greviews.in .gstar{animation:gstarpop .5s var(--ease) forwards;animation-delay:var(--d)}
.greviews.in .greviews-shimmer{animation:gshimmer 1.15s ease .35s 1}
@keyframes gstarpop{0%{transform:scale(0) rotate(-30deg);opacity:0}60%{transform:scale(1.28) rotate(7deg);opacity:1}100%{transform:scale(1) rotate(0);opacity:1}}
@keyframes gshimmer{to{transform:translateX(130%)}}
@media(prefers-reduced-motion:reduce){html.js .gstar{transform:none;opacity:1}.greviews.in .gstar,.greviews.in .greviews-shimmer{animation:none}}

/* ============================================================
   SEO SIDE PANEL (global slide-out: TOC + extra content + links)
   ============================================================ */
.seo-tab{position:fixed;right:0;top:42%;z-index:70;display:flex;flex-direction:column;align-items:center;gap:8px;background:linear-gradient(160deg,var(--accent),var(--accent-strong));color:#fff;border:none;border-radius:14px 0 0 14px;padding:14px 9px 16px;box-shadow:-6px 8px 24px oklch(58% .17 235 / .35);cursor:pointer;transition:padding-right .2s var(--ease),box-shadow .2s var(--ease)}
.seo-tab:hover{padding-right:13px;box-shadow:-8px 10px 30px oklch(58% .17 235 / .45)}
.seo-tab svg{width:20px;height:20px}
.seo-tab span{writing-mode:vertical-rl;transform:rotate(180deg);font-family:'Outfit',sans-serif;font-weight:700;font-size:.74rem;letter-spacing:.06em}
@media(max-width:600px){.seo-tab span{display:none}.seo-tab{top:auto;bottom:90px;border-radius:14px 0 0 14px;padding:12px}}

.seo-panel{position:fixed;inset:0;z-index:130;visibility:hidden;opacity:0;transition:opacity .3s var(--ease),visibility .3s}
.seo-panel.open{visibility:visible;opacity:1}
.seo-panel-scrim{position:absolute;inset:0;background:oklch(20% .02 250 / .45);backdrop-filter:blur(2px)}
.seo-panel-inner{position:absolute;top:0;right:0;height:100%;width:min(90vw,372px);background:var(--surface);box-shadow:var(--shadow-lg);padding:1.8rem 1.6rem 2.2rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem;transform:translateX(100%);transition:transform .38s var(--ease)}
.seo-panel.open .seo-panel-inner{transform:none}
.seo-panel-close{align-self:flex-end;width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:var(--bg);display:grid;place-items:center;color:var(--ink);cursor:pointer;margin:-.4rem -.4rem .2rem 0}
.seo-panel-close:hover{border-color:var(--accent);color:var(--accent-strong)}
.seo-panel-h{font-family:'Outfit',sans-serif;font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin:0 0 .7rem;font-weight:700}
.seo-toc{display:flex;flex-direction:column}
.seo-toc a{display:block;padding:.42rem 0;color:var(--ink-soft);font-weight:600;font-size:.95rem;border-bottom:1px solid var(--line-soft);transition:color .18s var(--ease),padding-left .18s var(--ease)}
.seo-toc a:last-child{border-bottom:none}
.seo-toc a.lvl3{padding-left:.9rem;font-weight:500;font-size:.9rem;color:var(--muted)}
.seo-toc a:hover{color:var(--accent-strong);padding-left:.3rem}
.seo-extra{font-size:.95rem;color:var(--ink-soft);line-height:1.6}
.seo-extra a{color:var(--accent-strong);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.seo-extra ul{margin:.3rem 0 .3rem 1rem}
.seo-quick{display:flex;flex-direction:column;gap:6px}
.seo-quick a{display:block;padding:.6rem .9rem;border-radius:11px;background:var(--accent-soft);color:var(--accent-strong);font-weight:600;font-size:.92rem;transition:transform .18s var(--ease)}
.seo-quick a:hover{transform:translateX(3px)}
/* anchor offset so TOC jumps clear the sticky nav */
.svc-content :is(h2,h3),.entry :is(h2,h3),.page-body :is(h2,h3){scroll-margin-top:96px}

/* ============================================================
   COMMENTS (DM styled)
   ============================================================ */
.dm-comments{padding:8px 0 8px}
.dm-comments .wrap.narrow{max-width:880px}
.dm-comments-title{font-family:'Outfit',sans-serif;font-weight:800;font-size:clamp(1.5rem,1.1rem+1.4vw,2rem);color:var(--ink);margin:0 0 1.6rem}
.dm-comment-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:1rem}
.dm-comment-list .children{list-style:none;margin:1rem 0 0;padding:0 0 0 clamp(1rem,4vw,2.6rem);display:flex;flex-direction:column;gap:1rem}
.dm-comment{display:flex;gap:1rem;background:var(--bg);border:1px solid var(--line-soft);border-radius:16px;padding:1.3rem 1.4rem}
.dm-cm-staff>.dm-comment{background:linear-gradient(180deg,oklch(96% .03 250),oklch(98% .015 250));border-color:oklch(88% .05 250);border-left:4px solid var(--accent-strong)}
.dm-cm-av{flex:0 0 auto;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;color:#fff;font-family:'Outfit',sans-serif;font-weight:700;font-size:1.15rem}
.dm-cm-main{min-width:0}
.dm-cm-head{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.dm-cm-name{font-family:'Outfit',sans-serif;font-weight:700;font-size:1.05rem;color:var(--ink)}
.dm-cm-badge{font-family:'Outfit',sans-serif;font-weight:700;font-size:.66rem;letter-spacing:.08em;color:#fff;background:var(--ink);padding:.18rem .5rem;border-radius:6px}
.dm-cm-date{color:var(--muted);font-size:.9rem;margin:.15rem 0 .6rem}
.dm-cm-text{color:var(--ink-soft);line-height:1.6}
.dm-cm-text p{margin:0 0 .6rem}.dm-cm-text p:last-child{margin:0}
/* comment form */
.dm-comment-form{margin-top:2.4rem}
.dm-cf-title{font-family:'Outfit',sans-serif;font-weight:800;font-size:1.3rem;color:var(--ink);margin:0 0 1rem}
.dm-comment-form input[type=text],.dm-comment-form input[type=email],.dm-comment-form input[type=url],.dm-comment-form textarea{width:100%;padding:.8rem .9rem;border:1px solid var(--line);border-radius:11px;background:var(--surface);font:inherit;color:var(--ink)}
.dm-comment-form label{display:block;font-weight:600;font-size:.92rem;margin:0 0 .35rem;color:var(--ink-soft)}
.dm-comment-form p{margin:0 0 1rem}
.dm-comment-form .form-submit{margin-top:.4rem}

/* ============================================================
   Real SVG logos (header color / footer white)
   ============================================================ */
.brand--logo{display:inline-flex;align-items:center;gap:0;padding:0}
.brand--logo img{display:block;width:auto}
#nav .brand--logo img{height:52px}                 /* header — color lockup */
#nav.scrolled .brand--logo img{height:46px;transition:height .25s ease}
footer .brand--logo img{height:74px}               /* footer — white logo, larger */
.drawer .brand--logo img{height:46px}
@media(max-width:640px){#nav .brand--logo img{height:42px}footer .brand--logo img{height:60px}}

/* ============================================================
   ESTIMATE FORM WIZARD
   ============================================================ */
.wizard .wiz-prog{display:flex;list-style:none;margin:0 0 1.4rem;padding:0;gap:.4rem;counter-reset:none}
.wizard .wiz-prog li{flex:1;display:flex;align-items:center;gap:.5rem;font-family:'Outfit',sans-serif;font-weight:600;font-size:.85rem;color:var(--muted);position:relative;padding-bottom:.7rem;border-bottom:3px solid var(--line-soft);transition:color .2s var(--ease),border-color .2s var(--ease)}
.wizard .wiz-prog li span{display:grid;place-items:center;width:26px;height:26px;border-radius:50%;background:var(--line-soft);color:var(--muted);font-size:.82rem;flex:0 0 auto;transition:background .2s var(--ease),color .2s var(--ease)}
.wizard .wiz-prog li.is-active{color:var(--ink);border-color:var(--accent)}
.wizard .wiz-prog li.is-active span{background:var(--accent);color:#fff}
.wizard .wiz-prog li.is-done{color:var(--accent-strong);border-color:var(--accent)}
.wizard .wiz-prog li.is-done span{background:var(--accent-strong);color:#fff}
.wizard .wiz-step{display:none;animation:wiz-in .35s var(--ease)}
.wizard .wiz-step.is-active{display:block}
@keyframes wiz-in{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:none}}
.wizard [hidden]{display:none!important}
.wizard .wiz-nav{display:flex;align-items:center;gap:.7rem;margin-top:1.3rem}
.wizard .wiz-nav .wiz-spacer{flex:1}
.wizard .wiz-nav .btn-ghost{padding-inline:1rem}
@media(max-width:560px){.wizard .wiz-prog li{font-size:0}.wizard .wiz-prog li span{font-size:.82rem}}

/* free-quote: how-it-works numbered steps + section head */
.hiw .sec-head{margin-bottom:1.8rem}
.hiw .sec-head .eyebrow{color:var(--accent);font-weight:600;margin:0 0 .3rem}
.hiw .sec-head h2{margin:0}
.hiw-num{font-family:'Outfit',sans-serif;font-weight:800;font-size:1.4rem;color:#fff}

/* contact page map */
.contact-map-sec{padding:8px 0 0}
.contact-map{border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-md,0 10px 30px rgba(20,30,55,.06))}
.contact-map iframe{display:block;width:100%}
a.svc-feature{text-decoration:none}
