/* ═══════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}
body{
  font-family:'DM Sans',system-ui,sans-serif;
  font-size:16px;line-height:1.7;
  background:var(--bg);color:var(--t);
  transition:background .3s,color .3s;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  -webkit-user-select:none;user-select:none;
  cursor:none;
}

/* ═══════════════════════════════════════
   TOKENS
═══════════════════════════════════════ */
:root{
  --g:#264F38;
  --g-dim:rgba(38,79,56,.12);
  --g-line:rgba(38,79,56,.2);
  --ink:#0A0C09;
  --bg:#FAFAF8;
  --bg2:#F3F2EE;
  --mid:#E8E7E2;
  --t:#0A0C09;
  --tm:#3A3D38;
  --ts:#6B7066;
  --tg:#A8AFA5;
  --br:rgba(10,12,9,.07);
  --br2:rgba(10,12,9,.04);
  --ease:cubic-bezier(.16,1,.3,1);
  --hh:64px;
  --grid-dark:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  --grid-size:72px 72px;
  --dots-dark:radial-gradient(circle,rgba(255,255,255,.09) 1px,transparent 1px);
}

/* ── DARK MODE OVERRIDES ── */
[data-theme="dark"]{
  --bg:#0F100E;
  --bg2:#131511;
  --mid:#1E2119;
  --t:#EDECEA;
  --tm:#C4CBC4;
  --ts:#7A877A;
  --tg:#4A554A;
  --br:rgba(255,255,255,.07);
  --br2:rgba(255,255,255,.03);
  --g-dim:rgba(38,79,56,.2);
  --g-line:rgba(38,79,56,.3);
}

/* ═══════════════════════════════════════
   NOISE GRAIN
═══════════════════════════════════════ */
html::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9000;opacity:.018;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E") repeat;
  background-size:300px;
}

/* ═══════════════════════════════════════
   CURSOR
═══════════════════════════════════════ */
#cur{
  position:fixed;width:6px;height:6px;background:var(--g);
  border-radius:50%;pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width .2s var(--ease),height .2s var(--ease),opacity .2s,background .2s;
}
#cur.h{
  width:28px;height:28px;background:transparent;
  border:1.5px solid var(--g);opacity:.55;
}
#cur.dark{background:#fff}
#cur.dark.h{border-color:rgba(255,255,255,.4);background:transparent}

/* ═══════════════════════════════════════
   HEADER
═══════════════════════════════════════ */
#hdr{
  position:fixed;top:0;left:0;right:0;z-index:800;
  height:var(--hh);
  display:grid;grid-template-columns:auto 1fr auto;align-items:center;
  padding:0 48px;
  border-bottom:1px solid transparent;
  transition:background .35s,border-color .35s,backdrop-filter .35s;
}
#hdr.s{
  background:rgba(250,250,248,.96);
  border-bottom-color:var(--br);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
}
[data-theme="dark"] #hdr.s{background:rgba(15,16,14,.96)}

.hdr-logo img{
  height:30px;width:auto;display:block;
  transition:filter .3s;
}
/* On dark hero, invert logo to white */
#hdr.dark-zone .hdr-logo img{filter:brightness(0) invert(1)}
#hdr.s .hdr-logo img{filter:none}

.hdr-nav{
  display:flex;align-items:center;justify-content:center;gap:0;
}
.nav-item{position:relative}
.nav-a{
  font-size:13px;font-weight:400;
  color:rgba(255,255,255,.5);
  padding:8px 16px;border-radius:6px;
  transition:color .15s,background .15s;
  white-space:nowrap;cursor:pointer;
  display:flex;align-items:center;gap:4px;
}
#hdr.s .nav-a{color:var(--ts)}
.nav-a:hover{color:#fff}
#hdr.s .nav-a:hover{color:var(--t);background:rgba(10,12,9,.04)}
[data-theme="dark"] #hdr.s .nav-a{color:var(--ts)}
[data-theme="dark"] #hdr.s .nav-a:hover{color:var(--t);background:rgba(255,255,255,.06)}

/* Dropdown */
.drop{
  position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(-4px);
  background:#fff;border:1px solid var(--br);border-radius:12px;
  box-shadow:0 8px 40px rgba(10,12,9,.10),0 1px 4px rgba(10,12,9,.05);
  padding:6px;min-width:420px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .18s var(--ease),transform .18s var(--ease),visibility .18s;
}
[data-theme="dark"] .drop{background:#1A1E18;box-shadow:0 8px 40px rgba(0,0,0,.4)}
.nav-item:hover .drop{
  opacity:1;visibility:visible;pointer-events:all;
  transform:translateX(-50%) translateY(0);
}
.drop.narrow{min-width:240px}
.drop-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.drop.narrow .drop-grid{grid-template-columns:1fr}
.drop-item{
  padding:10px 12px;border-radius:8px;cursor:pointer;
  transition:background .12s;
}
.drop-item:hover{background:#FAFAF8}
[data-theme="dark"] .drop-item:hover{background:rgba(255,255,255,.06)}
.drop-label{font-size:13px;font-weight:600;color:#0A0C09;margin-bottom:2px}
[data-theme="dark"] .drop-label{color:#EDECEA}
.drop-sub{font-size:11.5px;color:var(--ts);line-height:1.45}
.drop-footer{
  padding:10px 12px;margin-top:4px;
  border-top:1px solid var(--br);
  font-size:12px;font-weight:600;color:var(--g);
  display:flex;align-items:center;justify-content:space-between;cursor:pointer;
}
.nav-chevron{
  width:10px;height:10px;stroke:currentColor;fill:none;stroke-width:2;
  transition:transform .2s;
}
.nav-item:hover .nav-chevron{transform:rotate(180deg)}

.hdr-right{display:flex;align-items:center;gap:10px}
.theme-btn{
  width:32px;height:32px;border-radius:7px;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;
  border:1px solid rgba(255,255,255,.15);
  background:rgba(255,255,255,.08);
  transition:background .2s,border-color .2s;
}
#hdr.s .theme-btn{border-color:var(--br);background:var(--bg2)}
.theme-btn:hover{background:rgba(255,255,255,.18)}
#hdr.s .theme-btn:hover{background:var(--mid)}
.i-sun{display:block}.i-moon{display:none}
[data-theme="dark"] .i-sun{display:none}[data-theme="dark"] .i-moon{display:block}
.theme-btn svg{display:block;color:rgba(255,255,255,.6);transition:color .2s}
#hdr.s .theme-btn svg{color:var(--ts)}
.theme-btn:hover svg{color:#fff}
#hdr.s .theme-btn:hover svg{color:var(--t)}

.hdr-cta{
  font-size:12.5px;font-weight:600;letter-spacing:.01em;
  color:var(--ink);background:#fff;
  padding:8px 18px;border-radius:100px;
  transition:all .2s;white-space:nowrap;
  box-shadow:0 1px 4px rgba(10,12,9,.08);
}
#hdr.s .hdr-cta{background:var(--g);color:#fff;box-shadow:0 2px 10px rgba(38,79,56,.25)}
.hdr-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(10,12,9,.15)}
#hdr.s .hdr-cta:hover{box-shadow:0 6px 20px rgba(38,79,56,.35)}

.hbg{
  display:none;width:34px;height:34px;border-radius:7px;
  border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.08);
  flex-direction:column;align-items:center;justify-content:center;gap:4.5px;
}
#hdr.s .hbg{border-color:var(--br);background:var(--bg2)}
.hbg span{display:block;width:16px;height:1.5px;background:#fff;transition:all .25s}
#hdr.s .hbg span{background:var(--t)}
.hbg.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hbg.open span:nth-child(2){opacity:0}
.hbg.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

#mob{
  position:fixed;top:var(--hh);left:0;right:0;bottom:0;z-index:790;
  background:var(--bg);transform:translateX(100%);
  transition:transform .35s var(--ease);
  overflow-y:auto;padding:20px 28px 60px;display:none;
}
#mob.open{transform:translateX(0)}
.mob-a{display:block;font-size:15px;font-weight:500;color:var(--t);padding:15px 0;border-bottom:1px solid var(--br);cursor:pointer}
.mob-cta{display:block;text-align:center;margin-top:28px;font-size:14px;font-weight:600;color:#fff;background:var(--g);padding:14px;border-radius:100px;cursor:pointer}

/* ═══════════════════════════════════════
   SHARED LAYOUT
═══════════════════════════════════════ */
.wrap{max-width:1160px;margin:0 auto;padding:0 48px}
.sec{padding:112px 0}
.sec-label{
  font-size:11px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--tg);
  display:block;margin-bottom:28px;
}
.sec-label.center{text-align:center}

/* ── SCROLL REVEAL ── */
.r{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.r2{opacity:0;transform:translateY(24px);transition:opacity .8s .12s var(--ease),transform .8s .12s var(--ease)}
.r3{opacity:0;transform:translateY(24px);transition:opacity .8s .24s var(--ease),transform .8s .24s var(--ease)}
.r4{opacity:0;transform:translateY(24px);transition:opacity .8s .36s var(--ease),transform .8s .36s var(--ease)}
.r.in,.r2.in,.r3.in,.r4.in{opacity:1;transform:none}
/* Stagger grid children */
.stag > *{opacity:0;transform:translateY(20px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.stag > *:nth-child(1){transition-delay:.04s}
.stag > *:nth-child(2){transition-delay:.14s}
.stag > *:nth-child(3){transition-delay:.24s}
.stag > *:nth-child(4){transition-delay:.34s}
.stag > *:nth-child(5){transition-delay:.44s}
.stag > *:nth-child(6){transition-delay:.54s}
.stag > *:nth-child(7){transition-delay:.64s}
.stag > *:nth-child(8){transition-delay:.74s}
.stag.in > *{opacity:1;transform:none}
/* Slide in from sides */
.slide-l{opacity:0;transform:translateX(-28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.slide-r{opacity:0;transform:translateX(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.slide-l.in,.slide-r.in{opacity:1;transform:none}

/* ── HERO ENTRANCE ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-22px)}to{opacity:1;transform:none}}
@keyframes glowFloat{0%,100%{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}
@keyframes gridFloat{0%,100%{opacity:1}50%{opacity:.7}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(45,155,90,.6)}60%{box-shadow:0 0 0 9px rgba(45,155,90,0)}100%{box-shadow:0 0 0 0 rgba(45,155,90,0)}}
@keyframes mqs{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes indS{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes iconDraw{from{stroke-dashoffset:200}to{stroke-dashoffset:0}}
@keyframes countPop{0%{transform:scale(1)}40%{transform:scale(1.08)}70%{transform:scale(.97)}100%{transform:scale(1)}}
@keyframes ringPulse{0%{box-shadow:0 0 0 0 rgba(38,79,56,.5)}70%{box-shadow:0 0 0 16px rgba(38,79,56,0)}100%{box-shadow:0 0 0 0 rgba(38,79,56,0)}}
@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes shimmer{0%{background-position:200% center}100%{background-position:-200% center}}

.h-over{animation:slideInLeft .9s .1s var(--ease) both}
.h-h1{animation:fadeUp 1s .28s var(--ease) both}
.h-row{animation:fadeUp .9s .5s var(--ease) both}
.h-stats{animation:fadeUp .9s .68s var(--ease) both}
.h-glow{animation:glowFloat 7s ease-in-out infinite}
.h-grid{animation:gridFloat 12s ease-in-out infinite}

/* Ghost grid — ONLY used on dark sections */
.dark-grid::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:var(--grid-dark),var(--dots-dark);
  background-size:var(--grid-size),var(--grid-size);
}
.dark-grid > *{position:relative;z-index:1}

/* Subtle glow — used on select light sections only */
.has-glow{position:relative}
.has-glow::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(ellipse 55% 60% at 8% 30%,rgba(38,79,56,.055) 0%,transparent 70%);
}
.has-glow.glow-r::after{
  background:radial-gradient(ellipse 55% 60% at 92% 30%,rgba(38,79,56,.055) 0%,transparent 70%);
}
.has-glow > *{position:relative;z-index:1}

/* ═══════════════════════════════════════
   HERO
═══════════════════════════════════════ */
#hero{
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  background:#0A0C09;
  position:relative;overflow:hidden;
  padding-bottom:88px;padding-top:var(--hh);
}
/* Hero grid layers */
.h-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.036) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.036) 1px,transparent 1px);
  background-size:72px 72px;
}
.h-dots{
  position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(255,255,255,.12) 1px,transparent 1px);
  background-size:72px 72px;
}
.h-glow{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 70% 60% at 65% 35%,rgba(38,79,56,.32) 0%,transparent 68%),
    radial-gradient(ellipse 40% 45% at 12% 78%,rgba(38,79,56,.14) 0%,transparent 60%);
}
.h-vign{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 120% 100% at 50% 50%,transparent 35%,rgba(0,0,0,.65) 100%);
}
.h-inner{
  position:relative;z-index:1;
  max-width:1160px;margin:0 auto;width:100%;padding:0 48px;
}
.h-over{
  display:inline-flex;align-items:center;gap:9px;
  font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.3);margin-bottom:36px;
}
.h-pulse{
  width:6px;height:6px;border-radius:50%;background:#2D9B5A;
  animation:pulse 2.4s ease infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(45,155,90,.6)}
  60%{box-shadow:0 0 0 9px rgba(45,155,90,0)}
  100%{box-shadow:0 0 0 0 rgba(45,155,90,0)}
}
.h-h1{
  font-size:clamp(58px,8vw,110px);
  font-weight:700;letter-spacing:-.042em;line-height:.93;
  color:#F5F4F0;margin-bottom:48px;max-width:960px;
}
.h-h1 .soft{
  display:block;font-weight:300;font-style:italic;
  color:rgba(245,244,240,.22);
}
.h-h1 .green{color:#2D9B5A}
.h-row{
  display:flex;align-items:flex-end;
  justify-content:space-between;gap:60px;flex-wrap:wrap;
}
.h-sub{
  font-size:16px;line-height:1.82;
  color:rgba(245,244,240,.38);max-width:400px;
}
.h-actions{display:flex;flex-direction:column;align-items:flex-end;gap:12px;flex-shrink:0}
.btn-main{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13.5px;font-weight:600;letter-spacing:.01em;
  color:#fff;background:var(--g);
  padding:13px 28px;border-radius:100px;
  transition:all .25s var(--ease);
  box-shadow:0 2px 12px rgba(38,79,56,.35);
}
.btn-main:hover{background:#1e3f2d;transform:translateY(-2px);box-shadow:0 8px 28px rgba(38,79,56,.45)}
.h-link{
  font-size:13px;color:rgba(245,244,240,.28);
  display:inline-flex;align-items:center;gap:5px;
  transition:color .2s;cursor:pointer;
}
.h-link:hover{color:rgba(245,244,240,.55)}
.h-stats{
  display:flex;gap:52px;flex-wrap:wrap;
  margin-top:72px;padding-top:40px;
  border-top:1px solid rgba(255,255,255,.07);
}
.hs{display:flex;flex-direction:column;gap:6px}
.hs-n{
  font-size:32px;font-weight:700;letter-spacing:-.045em;
  color:#F5F4F0;line-height:1;
}
.hs-n em{color:#2D9B5A;font-style:normal}
.hs-l{font-size:11.5px;color:rgba(245,244,240,.28);letter-spacing:.02em}

/* ═══════════════════════════════════════
   MARQUEE
═══════════════════════════════════════ */
.mq{
  overflow:hidden;background:var(--bg2);
  border-top:1px solid var(--br);border-bottom:1px solid var(--br);
  padding:12px 0;position:relative;z-index:1;
}
.mq-track{display:flex;white-space:nowrap;animation:mqs 38s linear infinite}
@keyframes mqs{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mq-item{
  display:inline-flex;align-items:center;gap:20px;
  font-size:12.5px;font-weight:400;color:var(--ts);
  padding:0 20px;white-space:nowrap;
}
.mq-dot{width:3px;height:3px;border-radius:50%;background:var(--g);opacity:.6;flex-shrink:0}

/* ═══════════════════════════════════════
   PROBLEM
═══════════════════════════════════════ */
#problem{background:var(--bg)}
.prob-top{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;margin-bottom:80px;
}
.prob-h{
  font-size:clamp(36px,4.5vw,58px);font-weight:700;
  letter-spacing:-.04em;line-height:.98;color:var(--t);
}
.prob-h em{font-weight:300;font-style:italic;color:var(--tg);display:block}
.prob-right{padding-top:8px}
.prob-body{font-size:16px;line-height:1.85;color:var(--ts);margin-bottom:28px;}
.btn-ghost{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13px;font-weight:500;color:var(--g);
  padding:10px 0;border-bottom:1px solid var(--g-line);
  transition:gap .2s,border-color .2s;cursor:pointer;
}
.btn-ghost:hover{gap:12px;border-color:var(--g)}
.prob-cols{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--br);
}
.prob-col{
  padding:44px 0 44px 44px;
  border-right:1px solid var(--br);
  position:relative;
}
.prob-col:first-child{padding-left:0}
.prob-col:last-child{border-right:none}
/* animated top accent line */
.prob-col::before{
  content:'';position:absolute;top:-1px;left:0;right:0;height:2px;
  background:var(--g);transform:scaleX(0);transform-origin:left;
  transition:transform .5s var(--ease);
}
.prob-col:hover::before{transform:scaleX(1)}
/* SVG icon box */
.prob-ico-box{
  width:54px;height:54px;border-radius:14px;
  background:rgba(38,79,56,.07);border:1px solid rgba(38,79,56,.14);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:24px;position:relative;
  transition:background .3s var(--ease),transform .3s var(--ease),box-shadow .3s;
}
.prob-col:hover .prob-ico-box{
  background:rgba(38,79,56,.13);
  transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(38,79,56,.15);
}
.prob-ico-box svg{
  width:24px;height:24px;stroke:var(--g);fill:none;
  stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:200;stroke-dashoffset:200;
  transition:stroke-dashoffset .9s var(--ease);
}
.prob-col.drawn .prob-ico-box svg{stroke-dashoffset:0}
.prob-title{
  font-size:15px;font-weight:700;color:var(--t);
  margin-bottom:10px;letter-spacing:-.015em;line-height:1.3;
}
.prob-desc{font-size:13.5px;color:var(--ts);line-height:1.78}
.prob-stat{
  display:inline-flex;align-items:center;gap:6px;margin-top:18px;
  font-size:11.5px;font-weight:600;color:var(--g);
  background:rgba(38,79,56,.08);padding:5px 12px;border-radius:100px;
  transition:background .2s;
}
.prob-col:hover .prob-stat{background:rgba(38,79,56,.14)}

/* ═══════════════════════════════════════
   SERVICES
═══════════════════════════════════════ */
#services{background:var(--bg)}
.svc-top{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:end;margin-bottom:72px;
}
.svc-h{
  font-size:clamp(36px,4.5vw,58px);font-weight:700;
  letter-spacing:-.04em;line-height:.98;color:var(--t);
}
.svc-h em{font-weight:300;font-style:italic;color:var(--tg);display:block}
.svc-body{font-size:15px;color:var(--ts);line-height:1.82;max-width:360px}

/* 3 big services — no cards, columns with dividers */
.svc-big{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--br);
  border-bottom:1px solid var(--br);
  margin-bottom:1px;
}
.svc-item{
  padding:44px 40px 44px 0;
  border-right:1px solid var(--br);cursor:pointer;
  transition:background .15s;
}
.svc-item:last-child{border-right:none;padding-right:0;padding-left:40px}
.svc-item:nth-child(2){padding-left:40px}
.svc-item:hover{background:rgba(10,12,9,.02)}
.svc-num{
  font-size:11px;font-weight:600;letter-spacing:.1em;color:var(--tg);
  margin-bottom:28px;display:flex;align-items:center;gap:10px;
}
.svc-num::after{content:'';flex:1;height:1px;background:var(--br)}
.svc-name{
  font-size:20px;font-weight:700;letter-spacing:-.02em;
  color:var(--t);margin-bottom:12px;line-height:1.15;
}
.svc-desc{font-size:14px;color:var(--ts);line-height:1.78;margin-bottom:20px}
.svc-link{
  font-size:12.5px;font-weight:600;color:var(--g);
  display:inline-flex;align-items:center;gap:5px;
  transition:gap .2s;cursor:pointer;
}
.svc-item:hover .svc-link{gap:9px}

/* 3 small services — compact row */
.svc-small{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--br);
}
.svc-sm{
  padding:22px 28px;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  border-right:1px solid var(--br);transition:background .15s;
}
.svc-sm:last-child{border-right:none}
.svc-sm:hover{background:rgba(10,12,9,.02)}
.svc-sm-l{}
.svc-sm-name{font-size:14px;font-weight:600;color:var(--t);margin-bottom:2px}
.svc-sm-sub{font-size:12px;color:var(--ts)}
.svc-arr{font-size:14px;color:var(--tg);transition:color .2s,transform .2s;flex-shrink:0}
.svc-sm:hover .svc-arr{color:var(--g);transform:translateX(3px)}

/* ═══════════════════════════════════════
   PROCESS
═══════════════════════════════════════ */
#process{background:var(--bg2)}
.proc-h{
  font-size:clamp(36px,4.5vw,58px);font-weight:700;
  letter-spacing:-.04em;line-height:.98;color:var(--t);
  margin-bottom:72px;
}
.proc-h em{font-weight:300;font-style:italic;color:var(--tg);display:block}
/* Palantia-style: numbers + type, no cards */
.proc-steps{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--br);
}
.proc-step{
  padding:44px 36px 0 0;
  border-right:1px solid var(--br);
}
.proc-step:last-child{border-right:none;padding-right:0;padding-left:36px}
.proc-step:nth-child(2),.proc-step:nth-child(3){padding-left:36px}
.proc-n{
  font-size:clamp(52px,5vw,72px);font-weight:700;
  letter-spacing:-.06em;line-height:1;
  color:var(--mid);margin-bottom:28px;
}
.proc-title{
  font-size:16px;font-weight:700;color:var(--t);
  margin-bottom:10px;letter-spacing:-.015em;
}
.proc-desc{font-size:13.5px;color:var(--ts);line-height:1.8}

/* ═══════════════════════════════════════
   WORK (dark)
═══════════════════════════════════════ */
#work{
  background:#0A0C09;
  position:relative;overflow:hidden;
}
.work-h{
  font-size:clamp(36px,4.5vw,58px);font-weight:700;
  letter-spacing:-.04em;line-height:.98;color:#F5F4F0;
  margin-bottom:56px;
}
.work-h em{font-weight:300;font-style:italic;color:rgba(245,244,240,.2)}
.feat{
  display:grid;grid-template-columns:1.1fr 1fr;
  border:1px solid rgba(255,255,255,.07);
  margin-bottom:1px;
}
.feat-l{
  padding:56px 52px;
  border-right:1px solid rgba(255,255,255,.07);
  background:rgba(255,255,255,.025);
}
.feat-r{
  padding:56px 52px;
  display:flex;flex-direction:column;justify-content:center;
}
.feat-kick{
  font-size:10px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:#2D9B5A;margin-bottom:20px;
}
.feat-title{
  font-size:clamp(26px,3vw,38px);font-weight:700;
  letter-spacing:-.035em;color:#F5F4F0;
  margin-bottom:14px;line-height:1.06;
}
.feat-desc{font-size:15px;color:rgba(245,244,240,.35);line-height:1.85;margin-bottom:28px}
.feat-tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:32px}
.feat-tag{
  font-size:11px;color:rgba(245,244,240,.28);
  border:1px solid rgba(255,255,255,.08);
  padding:5px 12px;border-radius:100px;
}
.feat-btn{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13px;font-weight:600;color:#fff;background:var(--g);
  padding:11px 22px;border-radius:100px;
  align-self:flex-start;transition:all .2s;
}
.feat-btn:hover{background:#1e3f2d;transform:translateY(-1px)}
.stat-list{display:flex;flex-direction:column}
.stat-row{
  display:flex;justify-content:space-between;align-items:flex-end;
  padding:22px 0;border-bottom:1px solid rgba(255,255,255,.05);
}
.stat-row:last-child{border-bottom:none}
.stat-label{
  font-size:11px;font-weight:500;letter-spacing:.06em;
  text-transform:uppercase;color:rgba(245,244,240,.2);
}
.stat-val{
  font-size:28px;font-weight:700;
  letter-spacing:-.045em;color:#F5F4F0;line-height:1;
}
.stat-val.g{color:#2D9B5A}
.stat-sub{font-size:11px;color:rgba(245,244,240,.2);margin-top:2px;text-align:right}
.work-mini{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid rgba(255,255,255,.07);
  border-top:none;
}
.wm{
  padding:36px 36px;cursor:pointer;
  border-right:1px solid rgba(255,255,255,.07);
  transition:background .2s;
}
.wm:last-child{border-right:none}
.wm:hover{background:rgba(255,255,255,.03)}
.wm-kick{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(245,244,240,.2);margin-bottom:12px}
.wm-title{font-size:17px;font-weight:700;color:#F5F4F0;margin-bottom:8px;letter-spacing:-.02em}
.wm-desc{font-size:13px;color:rgba(245,244,240,.3);line-height:1.75;margin-bottom:20px}
.wm-stat-n{font-size:20px;font-weight:700;color:#2D9B5A;letter-spacing:-.04em;line-height:1;margin-bottom:3px}
.wm-stat-l{font-size:11px;color:rgba(245,244,240,.2)}

/* ═══════════════════════════════════════
   INDUSTRY SLIDER
═══════════════════════════════════════ */
#industries{background:var(--bg)}
.ind-h{
  font-size:clamp(36px,4.5vw,58px);font-weight:700;
  letter-spacing:-.04em;line-height:.98;color:var(--t);
  margin-bottom:52px;
}
.ind-h em{font-weight:300;font-style:italic;color:var(--tg);display:block}
.ind-slider-wrap{
  overflow:hidden;margin:0 -48px;padding:4px 0 72px;
  -webkit-mask-image:linear-gradient(90deg,transparent 0%,#000 6%,#000 94%,transparent 100%);
  mask-image:linear-gradient(90deg,transparent 0%,#000 6%,#000 94%,transparent 100%);
}
.ind-slider{display:flex;gap:1px;width:max-content;animation:indS 36s linear infinite}
.ind-slider:hover{animation-play-state:paused}
@keyframes indS{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ind-card{
  width:272px;flex-shrink:0;padding:32px 28px;
  background:var(--bg2);
  border:1px solid var(--br);
  cursor:pointer;
  transition:background .18s,border-color .18s;
}
.ind-card:hover{background:#fff;border-color:rgba(38,79,56,.18)}
.ind-name{font-size:15px;font-weight:700;color:var(--t);margin-bottom:8px;letter-spacing:-.015em}
.ind-sub{font-size:13px;color:var(--ts);line-height:1.72;margin-bottom:16px}
.ind-arr{font-size:12px;font-weight:600;color:var(--g)}

/* ═══════════════════════════════════════
   MIGRATIONS
═══════════════════════════════════════ */
#migrations{background:var(--bg2)}
.mig-h{
  font-size:clamp(36px,4.5vw,58px);font-weight:700;
  letter-spacing:-.04em;line-height:.98;color:var(--t);
  margin-bottom:52px;
}
.mig-h em{font-weight:300;font-style:italic;color:var(--tg);display:block}
.plat-grid{
  display:grid;grid-template-columns:repeat(8,1fr);
  border:1px solid var(--br);
}
.plat{
  padding:24px 16px;background:var(--bg);cursor:pointer;
  transition:background .15s;text-align:center;
  border-right:1px solid var(--br);
}
.plat:last-child{border-right:none}
.plat:hover{background:#fff}
.plat-name{font-size:12.5px;font-weight:600;color:var(--t);margin-bottom:3px}
.plat-sub{font-size:10px;color:var(--tg)}
.plat.hi{background:rgba(38,79,56,.06)}
.plat.hi:hover{background:rgba(38,79,56,.1)}
.plat.hi .plat-name{color:var(--g)}
.plat.hi .plat-sub{color:var(--g);opacity:.7}

/* ═══════════════════════════════════════
   FAQ
═══════════════════════════════════════ */
#faq{background:var(--bg)}
.faq-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:80px;align-items:start;
}
.faq-h{
  font-size:clamp(36px,4.5vw,58px);font-weight:700;
  letter-spacing:-.04em;line-height:.98;color:var(--t);
  position:sticky;top:calc(var(--hh) + 40px);
}
.faq-h em{font-weight:300;font-style:italic;color:var(--tg);display:block}
.faq-list{display:flex;flex-direction:column;border-top:1px solid var(--br)}
.faq-item{border-bottom:1px solid var(--br)}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:22px 0;font-size:15px;font-weight:500;color:var(--t);
  text-align:left;cursor:pointer;transition:color .15s;
  background:none;
}
.faq-q:hover{color:var(--g)}
.faq-item.open .faq-q{color:var(--g)}
.faq-q svg{
  width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;
  flex-shrink:0;transition:transform .25s var(--ease);
}
.faq-item.open .faq-q svg{transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .35s var(--ease);
  font-size:14px;color:var(--ts);line-height:1.85;
}
.faq-item.open .faq-a{max-height:240px;padding-bottom:22px}

/* ═══════════════════════════════════════
   GHL STRIP — dark, distinct from Book
═══════════════════════════════════════ */
#ghl{background:var(--g);position:relative;overflow:hidden}
#ghl::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:64px 64px;
}
#ghl::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 100% at 85% 50%,rgba(255,255,255,.07) 0%,transparent 65%);
}
.ghl-layout{
  display:grid;grid-template-columns:1fr auto;
  gap:64px;align-items:center;
  position:relative;z-index:1;
}
.ghl-left{}
.ghl-badge{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.5);margin-bottom:18px;
}
.ghl-dot{width:5px;height:5px;border-radius:50%;background:#fff;opacity:.7}
.ghl-h{
  font-size:clamp(24px,2.8vw,38px);font-weight:700;
  letter-spacing:-.035em;line-height:1.05;color:#fff;margin-bottom:10px;
}
.ghl-h em{font-weight:300;font-style:italic;color:rgba(255,255,255,.45)}
.ghl-sub{font-size:14.5px;color:rgba(255,255,255,.5);max-width:480px;line-height:1.8}
.ghl-right{
  display:flex;flex-direction:column;align-items:flex-start;gap:12px;flex-shrink:0;
}
.btn-ghl{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13.5px;font-weight:600;color:var(--g);
  background:#fff;
  padding:13px 28px;border-radius:100px;white-space:nowrap;
  box-shadow:0 2px 16px rgba(0,0,0,.2);
  transition:all .25s var(--ease);
}
.btn-ghl:hover{background:#F5F4F0;transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.25)}
.ghl-note{font-size:11.5px;color:rgba(255,255,255,.3);line-height:1.6;max-width:200px}

/* ═══════════════════════════════════════
   BOOK — dark, immersive, calendar
═══════════════════════════════════════ */
#book{background:#0A0C09;position:relative;overflow:hidden;border-top:1px solid rgba(38,79,56,.4)}
#book::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),
    radial-gradient(circle,rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:72px 72px,72px 72px,72px 72px;
}
#book::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 80% 55% at 50% -10%,rgba(38,79,56,.28) 0%,transparent 65%);
}
.book-inner{position:relative;z-index:1;max-width:820px;margin:0 auto}
.book-head{text-align:center;margin-bottom:52px}
.book-head .sec-label{
  color:rgba(245,244,240,.28);display:inline-flex;align-items:center;gap:8px;
}
.book-head .sec-label::before{content:'';width:16px;height:1px;background:rgba(245,244,240,.2)}
.book-h{
  font-size:clamp(32px,4.5vw,52px);font-weight:700;
  letter-spacing:-.04em;line-height:.98;color:#F5F4F0;margin-bottom:14px;
}
.book-h em{font-weight:300;font-style:italic;color:rgba(245,244,240,.22)}
.book-sub{
  font-size:15px;color:rgba(245,244,240,.32);
  line-height:1.82;max-width:440px;margin:0 auto;
}
.book-cal-frame{
  position:relative;
  background:rgba(255,255,255,.028);
  border:1px solid rgba(255,255,255,.08);
  border-top:1px solid rgba(255,255,255,.12);
  border-radius:3px;overflow:hidden;
  box-shadow:0 0 0 1px rgba(38,79,56,.18),0 40px 100px rgba(0,0,0,.55);
  transition:box-shadow .4s;
}
.book-cal-frame:hover{
  box-shadow:0 0 0 1px rgba(38,79,56,.3),0 50px 120px rgba(0,0,0,.6);
}
.book-cal-bar{
  padding:14px 24px;
  background:rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;gap:10px;
}
.book-cal-dots{display:flex;gap:6px}
.book-cal-dots span{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.1)}
.book-cal-dots span:nth-child(1){background:rgba(255,100,100,.35)}
.book-cal-dots span:nth-child(2){background:rgba(255,200,80,.3)}
.book-cal-dots span:nth-child(3){background:rgba(45,155,90,.35)}
.book-cal-bar-title{
  flex:1;text-align:center;
  font-size:11px;font-weight:500;letter-spacing:.08em;
  color:rgba(245,244,240,.2);text-transform:uppercase;
}
.book-cal-frame iframe{width:100%;min-height:680px;border:none;display:block}
.book-trust{
  display:flex;align-items:center;justify-content:center;
  gap:40px;margin-top:32px;flex-wrap:wrap;
}
.book-trust-item{
  display:flex;align-items:center;gap:8px;
  font-size:12px;color:rgba(245,244,240,.22);
}
.book-trust-item svg{
  width:13px;height:13px;stroke:#2D9B5A;fill:none;
  stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;
}

/* ═══════════════════════════════════════
   FOOTER
═══════════════════════════════════════ */
footer{background:#080A07;padding:64px 0 32px;border-top:1px solid rgba(255,255,255,.04)}
.ft-top{
  display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;
  gap:48px;padding-bottom:48px;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.ft-logo img{
  height:26px;width:auto;display:block;
  filter:brightness(0) invert(1);opacity:.55;
  margin-bottom:14px;
}
.ft-desc{font-size:13px;color:rgba(245,244,240,.18);line-height:1.88;max-width:210px;margin-bottom:20px}
.ft-cta-link{
  font-size:12.5px;font-weight:600;color:rgba(245,244,240,.35);
  display:inline-flex;align-items:center;gap:5px;
  transition:color .2s;cursor:pointer;
  border-bottom:1px solid rgba(245,244,240,.12);
  padding-bottom:2px;
}
.ft-cta-link:hover{color:rgba(245,244,240,.6);border-color:rgba(245,244,240,.3)}
.ft-cat{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(245,244,240,.18);margin-bottom:18px}
.ft-list li{margin-bottom:10px}
.ft-list a{font-size:13px;color:rgba(245,244,240,.2);transition:color .2s;cursor:pointer}
.ft-list a:hover{color:rgba(245,244,240,.5)}
.ft-bot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:24px;flex-wrap:wrap;gap:10px;
}
.ft-bot span{font-size:11px;color:rgba(245,244,240,.12)}

/* ═══════════════════════════════════════
   FLOATING CTA
═══════════════════════════════════════ */
#float-cta{
  position:fixed;bottom:28px;right:28px;z-index:700;
  display:inline-flex;align-items:center;gap:8px;
  font-size:13px;font-weight:600;color:#fff;background:var(--g);
  padding:11px 22px;border-radius:100px;
  box-shadow:0 4px 24px rgba(38,79,56,.45);
  opacity:0;transform:translateY(10px);pointer-events:none;
  transition:opacity .3s var(--ease),transform .3s var(--ease);
  cursor:pointer;
}
#float-cta.show{opacity:1;transform:translateY(0);pointer-events:all}
#float-cta:hover{background:#1e3f2d;transform:translateY(-2px)!important}
.fpulse{width:6px;height:6px;border-radius:50%;background:#2D9B5A;animation:pulse 2s ease infinite;flex-shrink:0}

/* Proc step number reveal */
.proc-step .proc-n{
  opacity:0;transform:translateY(12px) scale(.92);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
  display:block;
}
.proc-step .proc-title,.proc-step .proc-desc{
  opacity:0;transform:translateY(10px);
  transition:opacity .6s .15s var(--ease),transform .6s .15s var(--ease);
}
.proc-step.in .proc-n{opacity:1;transform:none}
.proc-step.in .proc-title,.proc-step.in .proc-desc{opacity:1;transform:none}
/* Plat cells */
.plat{opacity:0;transform:scale(.94);transition:opacity .35s var(--ease),transform .35s var(--ease),background .15s}
.plat.in{opacity:1;transform:scale(1)}


@media(max-width:1024px){
  #hdr{padding:0 24px}
  .hdr-nav{display:none}
  .hbg{display:flex}
  #mob{display:block}
  .wrap{padding:0 24px}
  .h-inner{padding:0 24px}
  .h-h1{font-size:clamp(48px,10vw,78px)}
  .h-row{flex-direction:column;align-items:flex-start}
  .h-actions{align-items:flex-start}
  .prob-top{grid-template-columns:1fr;gap:32px}
  .prob-cols{grid-template-columns:1fr;border-top:none}
  .prob-col{padding:32px 0!important;border-right:none;border-bottom:1px solid var(--br)}
  .prob-col:last-child{border-bottom:none}
  .svc-top{grid-template-columns:1fr;gap:24px}
  .svc-big{grid-template-columns:1fr}
  .svc-item{padding:32px 0!important;border-right:none;border-bottom:1px solid var(--br)}
  .svc-item:last-child{border-bottom:none}
  .svc-small{grid-template-columns:1fr}
  .svc-sm{border-right:none;border-bottom:1px solid var(--br)}
  .svc-sm:last-child{border-bottom:none}
  .proc-steps{grid-template-columns:1fr 1fr}
  .proc-step{padding:36px 0!important;border-right:none;border-bottom:1px solid var(--br)}
  .feat{grid-template-columns:1fr}
  .feat-l{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}
  .work-mini{grid-template-columns:1fr}
  .wm{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}
  .plat-grid{grid-template-columns:repeat(4,1fr)}
  .faq-wrap{grid-template-columns:1fr}
  .faq-h{position:static;margin-bottom:40px}
  .ghl-layout{grid-template-columns:1fr;gap:32px}
  .ghl-right{align-items:flex-start}
  .ft-top{grid-template-columns:1fr 1fr;gap:32px}
  #float-cta{bottom:16px;right:16px}
  .ind-slider-wrap{margin:0 -24px}
}
@media(max-width:600px){
  .h-stats{gap:28px}
  .proc-steps{grid-template-columns:1fr}
  .plat-grid{grid-template-columns:repeat(2,1fr)}
  .ft-top{grid-template-columns:1fr}
  footer{padding:48px 0 24px}
}

/* ═══════════════════════════════════════
   INNER PAGE HERO (shorter — not full-vh)
═══════════════════════════════════════ */
.inner-hero{
  background:#0A0C09;
  position:relative;overflow:hidden;
  padding:calc(var(--hh) + 80px) 0 80px;
}
.inner-hero .h-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.036) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.036) 1px,transparent 1px);
  background-size:72px 72px;
}
.inner-hero .h-glow{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 70% 60% at 65% 35%,rgba(38,79,56,.22) 0%,transparent 68%);
}
.inner-hero .h-vign{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 120% 100% at 50% 50%,transparent 35%,rgba(0,0,0,.5) 100%);
}
.inner-hero .wrap{position:relative;z-index:1}
.ih-over{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.28);margin-bottom:22px;
}
.ih-h{
  font-size:clamp(42px,6vw,80px);
  font-weight:700;letter-spacing:-.042em;line-height:.95;
  color:#F5F4F0;margin-bottom:22px;max-width:800px;
}
.ih-h em{font-weight:300;font-style:italic;color:rgba(245,244,240,.22);display:block}
.ih-h .green{color:#2D9B5A}
.ih-sub{
  font-size:17px;color:rgba(245,244,240,.38);
  line-height:1.82;max-width:540px;margin-bottom:32px;
}
.ih-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}

/* Breadcrumb */
.breadcrumb{
  display:flex;align-items:center;gap:7px;
  font-size:12px;color:rgba(245,244,240,.2);margin-bottom:32px;
}
.breadcrumb a{color:rgba(245,244,240,.2);transition:color .2s}
.breadcrumb a:hover{color:rgba(245,244,240,.5)}
.breadcrumb span{color:rgba(245,244,240,.12)}

/* ─ Page sections ─ */
.page-sec{padding:96px 0}
.page-sec.alt{background:var(--bg2)}
.page-sec.dark{background:#0A0C09;color:#F5F4F0}

.pg-h{
  font-size:clamp(32px,4vw,52px);font-weight:700;
  letter-spacing:-.04em;line-height:.98;color:var(--t);
}
.pg-h em{font-weight:300;font-style:italic;color:var(--tg);display:block}
.pg-h.light{color:#F5F4F0}
.pg-h.light em{color:rgba(245,244,240,.22)}

/* ─ Two-col layout ─ */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:start}
.two-col.center{align-items:center}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;border-top:1px solid var(--br)}
.four-col{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;border-top:1px solid var(--br)}

/* ─ Feature card (icon + title + desc) ─ */
.fc-box{
  padding:36px 28px;border-bottom:1px solid var(--br);
  transition:background .15s;cursor:default;
}
.three-col .fc-box{border-right:1px solid var(--br);border-bottom:none}
.three-col .fc-box:last-child{border-right:none}
.fc-ico{
  width:48px;height:48px;border-radius:12px;
  background:rgba(38,79,56,.08);border:1px solid rgba(38,79,56,.14);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;
  transition:background .2s,transform .2s;
}
.fc-box:hover .fc-ico{background:rgba(38,79,56,.14);transform:translateY(-2px)}
.fc-ico svg{width:22px;height:22px;stroke:var(--g);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.fc-title{font-size:15px;font-weight:700;color:var(--t);margin-bottom:8px;letter-spacing:-.015em}
.fc-desc{font-size:13.5px;color:var(--ts);line-height:1.78}

/* ─ List with checks ─ */
.check-list{display:flex;flex-direction:column;gap:14px}
.check-list li{
  display:flex;align-items:flex-start;gap:12px;
  font-size:14.5px;color:var(--ts);line-height:1.7;
}
.check-list li::before{
  content:'';flex-shrink:0;width:18px;height:18px;border-radius:50%;
  background:rgba(38,79,56,.1);border:1px solid rgba(38,79,56,.2);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpolyline points='2,6 5,9 10,3' stroke='%23264F38' stroke-width='1.7' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center;background-size:12px;
  margin-top:3px;
}

/* ─ Stat bar ─ */
.stat-bar{
  display:flex;gap:0;border:1px solid var(--br);
  margin:48px 0;
}
.sb-item{
  flex:1;padding:28px 24px;border-right:1px solid var(--br);
  text-align:center;
}
.sb-item:last-child{border-right:none}
.sb-n{font-size:36px;font-weight:700;letter-spacing:-.05em;color:var(--g);line-height:1}
.sb-l{font-size:12px;color:var(--ts);margin-top:6px}

/* CTA block */
.cta-block{
  background:var(--g);padding:64px 48px;
  position:relative;overflow:hidden;
  text-align:center;
}
.cta-block::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  background-size:64px 64px;
}
.cta-block > *{position:relative;z-index:1}
.cta-block .pg-h{color:#fff}
.cta-block .pg-h em{color:rgba(255,255,255,.4)}
.cta-block p{color:rgba(255,255,255,.55);font-size:16px;line-height:1.8;margin:16px 0 32px;max-width:480px;margin-left:auto;margin-right:auto}
.btn-white{
  display:inline-flex;align-items:center;gap:8px;
  font-size:13.5px;font-weight:600;color:var(--g);background:#fff;
  padding:13px 28px;border-radius:100px;
  transition:all .25s var(--ease);
  box-shadow:0 2px 16px rgba(0,0,0,.2);
}
.btn-white:hover{background:#F5F4F0;transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.25)}

@media(max-width:1024px){
  .two-col{grid-template-columns:1fr;gap:40px}
  .three-col{grid-template-columns:1fr}
  .three-col .fc-box{border-right:none;border-bottom:1px solid var(--br)}
  .four-col{grid-template-columns:1fr 1fr}
  .stat-bar{flex-wrap:wrap}
  .sb-item{border-bottom:1px solid var(--br);min-width:50%}
  .cta-block{padding:48px 24px}
}
@media(max-width:600px){
  .four-col{grid-template-columns:1fr}
  .ih-h{font-size:clamp(38px,10vw,58px)}
}
