/* =========================================================
   GROWLEGAL - OBERON-style rebuild (from scratch, self-contained)
   Reference: OBERON Framer template. Monochrome warm-grey + orange,
   Swiss grid, mono/sans split, dithered terrain, +markers.
   ========================================================= */
:root{
  --bg:#efeee8; --panel:#ffffff; --ink:#15140f; --muted:#6c6a61; --soft:#9b988d;
  --orange:#ff5a00; --orange-ink:#c44400;
  --line:rgba(21,20,15,.12); --line2:rgba(21,20,15,.22);
  --dash:rgba(21,20,15,.18); --odash:rgba(255,90,0,.35);
  --sans:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --maxw:1320px; --gutter:clamp(18px,4vw,56px);
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);position:relative}

/* ---- mono utilities & labels ---- */
.mono{font-family:var(--mono)}
.ml{font-family:var(--mono);text-transform:uppercase;letter-spacing:.06em;font-size:12px;line-height:1.7}
.ml.dim{color:var(--muted)}
.lead-mono{font-family:var(--mono);text-transform:uppercase;font-size:12.5px;letter-spacing:.04em;line-height:1.85;color:var(--muted)}

/* ---- section number tag  [NN] LABEL ---- */
.tag{display:inline-flex;align-items:stretch;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.tag .n{background:var(--orange);color:#fff;padding:5px 9px;display:flex;align-items:center}
.tag .l{background:rgba(21,20,15,.06);color:var(--ink);padding:5px 13px;display:flex;align-items:center}

/* ---- headings (sans, medium, tight) ---- */
.h-hero{font-weight:500;font-size:clamp(44px,7vw,96px);line-height:.98;letter-spacing:-0.03em}
.h-xl{font-weight:500;font-size:clamp(40px,5.6vw,76px);line-height:1.0;letter-spacing:-0.025em}
.h-lg{font-weight:500;font-size:clamp(32px,4.2vw,56px);line-height:1.04;letter-spacing:-0.02em}
.body-sm{color:var(--muted);font-size:15px;line-height:1.55}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;height:56px;padding:0 28px;
  font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.1em;font-weight:600;
  border:1px solid var(--ink);background:transparent;color:var(--ink);transition:background .15s,color .15s,border-color .15s}
.btn:hover{background:var(--ink);color:#fff}
.btn.dark{background:var(--ink);color:#fff}
.btn.dark:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.btn.orange{background:var(--orange);border-color:var(--orange);color:#fff}
.btn.orange:hover{background:#e85200;border-color:#e85200}
.btn.sm{height:42px;padding:0 16px;font-size:11px}
.btn.full{width:100%}

/* ---- + cross markers ---- */
.plus{position:absolute;color:var(--orange);font-family:var(--mono);font-size:18px;line-height:1;transform:translate(-50%,-50%);z-index:3;pointer-events:none}
.plus.grey{color:var(--line2)}

/* white number box  .01 */
.numbox{display:inline-flex;align-items:center;justify-content:flex-start;background:#fff;border:1px solid var(--line);
  font-family:var(--mono);font-weight:600;font-size:20px;letter-spacing:.02em;padding:12px 16px;min-width:64px}
.numbox .dot{color:var(--orange);margin-right:1px}

/* pixel terrain image helper */
.terrain{image-rendering:pixelated;width:100%;display:block;opacity:.85}

/* ======================= NAV ======================= */
.nav{position:sticky;top:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--line)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);height:72px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-weight:700;letter-spacing:.04em;font-size:16px;text-transform:uppercase}
.brand .mk{width:20px;height:20px;background:var(--orange);position:relative;flex:0 0 20px}
.brand .mk::before{content:"";position:absolute;inset:5px;background:var(--bg)}
.nav-links{display:none;align-items:center;gap:26px}
.nav-links a{font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.06em;color:var(--muted)}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:inline-flex}
@media(min-width:900px){.nav-links{display:flex}}

/* ======================= HERO ======================= */
.hero{position:relative;border-bottom:1px solid var(--line);overflow:hidden}
.hero .wrap{padding-top:clamp(40px,7vw,86px);padding-bottom:0;min-height:clamp(540px,72vh,760px);display:flex;flex-direction:column}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:18px}
.hero-rt{font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.12em;color:var(--soft);text-align:right;line-height:1.8;display:none}
@media(min-width:760px){.hero-rt{display:block}}
.hero h1{margin:clamp(28px,5vw,54px) 0 0;max-width:15ch}
.hero-sub{margin-top:22px;max-width:52ch}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px}
/* orange glitch/pixel mark (right) */
.hero-mark{position:absolute;right:clamp(20px,7vw,120px);top:clamp(80px,14vw,150px);width:clamp(64px,9vw,120px);height:clamp(64px,9vw,120px);
  background:var(--orange);display:none}
.hero-mark::before{content:"";position:absolute;inset:22%;background:var(--bg)}
.hero-mark::after{content:"";position:absolute;right:-8px;bottom:-8px;width:36%;height:36%;background:var(--orange);box-shadow:-14px -14px 0 -4px var(--orange)}
@media(min-width:900px){.hero-mark{display:block}}
/* terrain strip riding hero bottom */
.hero-terrain{margin-top:auto;width:100%;overflow:hidden;height:clamp(70px,12vw,130px);display:flex;align-items:flex-end}
.hero-terrain img{width:100%;height:100%;object-fit:cover;object-position:bottom;image-rendering:pixelated;opacity:.8}
/* hero stat bar */
.hero-stats{border-top:1px solid var(--line);display:grid;grid-template-columns:1fr;position:relative;z-index:2;background:var(--bg)}
.hero-stats .st{padding:18px var(--gutter);border-bottom:1px solid var(--line);font-family:var(--mono);text-transform:uppercase;font-size:11.5px;letter-spacing:.05em;color:var(--muted);line-height:1.6}
.hero-stats .st b{color:var(--ink);font-weight:600}
.hero-stats .st.cta{display:flex;align-items:center;justify-content:space-between}
@media(min-width:760px){
  .hero-stats{grid-template-columns:repeat(4,1fr)}
  .hero-stats .st{border-bottom:0;border-right:1px solid var(--line);padding:20px 26px}
  .hero-stats .st:last-child{border-right:0}
}

/* ======================= TRUSTED BY ======================= */
.trusted{border-bottom:1px solid var(--line)}
.trusted .wrap{display:flex;align-items:center;gap:clamp(20px,5vw,60px);flex-wrap:wrap;padding-top:18px;padding-bottom:18px}
.trusted .lbl{font-family:var(--mono);text-transform:uppercase;font-size:11.5px;letter-spacing:.08em;color:var(--muted);white-space:nowrap}
.trusted .marks{display:flex;align-items:center;gap:clamp(22px,4vw,52px);flex-wrap:wrap}
.trusted .marks span{font-weight:600;font-size:16px;letter-spacing:-0.01em;color:var(--ink);opacity:.8}

/* ======================= SECTION SHELL ======================= */
.sec{border-bottom:1px solid var(--line);position:relative}
.sec .wrap{padding-top:clamp(48px,6vw,88px);padding-bottom:clamp(48px,6vw,88px)}
.sec-head{display:flex;flex-direction:column;gap:18px;margin-bottom:clamp(36px,5vw,64px)}
.sec-head .tag{align-self:flex-start}
/* vertical dashed guide */
.guide{position:absolute;top:0;bottom:0;border-left:1px dashed var(--dash);pointer-events:none;z-index:1}
.guide.o{border-left-color:var(--odash)}

/* ======================= AREAS (What we can automate) ======================= */
.areas-grid{display:grid;grid-template-columns:1fr;gap:0}
.area{display:grid;grid-template-columns:1fr;border-top:1px dashed var(--dash);padding:26px 0}
.area .ic{width:72px;height:72px;border:1px solid var(--line);display:grid;place-items:center;background:#fff;margin-bottom:26px;position:relative}
.area .ic .sq{width:22px;height:22px;background:var(--orange)}
.area-title{font-family:var(--mono);text-transform:uppercase;font-size:14px;letter-spacing:.04em;font-weight:600;line-height:1.4}
.area-desc{color:var(--muted);font-size:15px;line-height:1.55;margin-top:14px}
.areas-foot{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-top:30px;flex-wrap:wrap}
.muchmore{font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.06em;color:var(--muted);display:inline-flex;align-items:center;gap:8px}
.muchmore .p{color:var(--orange)}
.area-intro{max-width:30ch}
@media(min-width:900px){
  .areas-wrap{display:grid;grid-template-columns:0.9fr 1.4fr;gap:clamp(30px,4vw,64px)}
  .areas-grid{grid-template-columns:1fr 1fr;border-left:1px dashed var(--dash);border-top:1px dashed var(--dash)}
  .area{grid-template-columns:1fr 1fr;border-top:0;border-bottom:1px dashed var(--dash);border-right:1px dashed var(--dash);padding:30px;align-items:start;gap:18px}
  .area .txt-right{padding-top:0}
  .area .ic{margin-bottom:0}
}

/* ======================= PROCESS (How it works) ======================= */
.proc{display:grid;grid-template-columns:1fr;gap:0}
.proc-intro{font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.05em;color:var(--muted);line-height:1.85;padding:24px 0;border-top:1px solid var(--line)}
.step{border-top:1px solid var(--line);padding:24px 0 30px;position:relative}
.step .numbox{margin-bottom:34px}
.step .st-title{font-family:var(--mono);text-transform:uppercase;font-size:13.5px;letter-spacing:.03em;font-weight:600;line-height:1.45;min-height:2.9em}
.step .st-flow{font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.1em;color:var(--soft);margin:22px 0 10px}
.step .st-ic{height:54px;display:flex;align-items:center;color:var(--ink)}
.step .st-ic svg{width:42px;height:42px}
.step .st-desc{color:var(--muted);font-size:14.5px;line-height:1.5;margin-top:24px;max-width:30ch}
@media(min-width:860px){
  .proc{grid-template-columns:0.8fr repeat(4,1fr)}
  .proc-intro{border-top:0;padding:90px 24px 0 0;align-self:start}
  .step{border-top:0;border-left:1px solid var(--line);padding:0 0 30px 26px}
  .step:first-of-type{border-left:0}
}

/* ======================= VALUE (Why choose us) - staggered ======================= */
.value-wrap{position:relative;min-height:520px}
.value-head{position:relative;z-index:3}
.val-grid{position:relative;z-index:3;display:grid;grid-template-columns:1fr 1fr;gap:30px 26px;margin-top:34px}
.val-item .numbox{margin-bottom:120px}
.val-item:nth-child(2) .numbox,.val-item:nth-child(4) .numbox{margin-bottom:40px} /* stagger */
.val-title{font-family:var(--mono);text-transform:uppercase;font-size:14px;letter-spacing:.03em;font-weight:600;line-height:1.5}
.value-terrain{position:absolute;left:0;right:0;bottom:30px;z-index:0;height:200px;overflow:hidden;display:flex;align-items:flex-end;opacity:.7}
.value-terrain img{width:100%;height:200px;object-fit:cover;object-position:bottom;image-rendering:pixelated}
.value-quote{position:relative;z-index:3;margin-top:40px;max-width:34ch}
.value-quote .who{display:flex;align-items:center;gap:10px;font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.06em;color:var(--soft)}
.value-quote .who .av{width:32px;height:32px;background:var(--line2);filter:grayscale(1)}
.value-quote p{font-family:var(--mono);text-transform:uppercase;font-size:12.5px;letter-spacing:.04em;line-height:1.8;margin-top:14px}
@media(min-width:860px){
  .val-grid{grid-template-columns:repeat(4,1fr);gap:0 0}
  .val-item{border-left:1px dashed var(--dash);padding:0 18px;min-height:430px;position:relative}
  .val-item:first-child{border-left:0}
  .val-item .numbox{margin-bottom:160px}
  .val-item:nth-child(2) .numbox,.val-item:nth-child(4) .numbox{margin-bottom:60px}
}

/* ======================= STACK (Integrations) ======================= */
.stack-wrap{position:relative;min-height:460px;display:grid;place-items:center}
.constellation{position:relative;width:min(720px,92%);aspect-ratio:16/10}
.constellation svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.node{position:absolute;transform:translate(-50%,-50%);font-family:var(--mono);font-size:13px;font-weight:600;display:flex;align-items:center;gap:7px;color:var(--ink);white-space:nowrap}
.node .dotmk{width:9px;height:9px;border-radius:50%;background:var(--ink)}
.core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:96px;height:96px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;z-index:2}
.core .mk{width:34px;height:34px;background:var(--orange);position:relative}
.core .mk::before{content:"";position:absolute;inset:9px;background:#fff}
.core .bracket{position:absolute;width:18px;height:18px;border:2px solid var(--orange)}
.core .b1{top:-7px;left:-7px;border-right:0;border-bottom:0}
.core .b2{top:-7px;right:-7px;border-left:0;border-bottom:0}
.core .b3{bottom:-7px;left:-7px;border-right:0;border-top:0}
.core .b4{bottom:-7px;right:-7px;border-left:0;border-top:0}
.stack-cap{font-family:var(--mono);text-transform:uppercase;font-size:12.5px;letter-spacing:.05em;line-height:1.8;color:var(--ink);max-width:30ch;margin-top:24px}
@media(max-width:680px){.constellation .node{font-size:11px}}

/* ======================= FAQ (Help) ======================= */
.faq-wrap{display:grid;grid-template-columns:1fr;gap:0}
.faq-side{position:relative;z-index:2}
.faq-side .who{display:flex;align-items:center;gap:10px;font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.06em;color:var(--soft);margin-top:30px}
.faq-side .who .av{width:30px;height:30px;background:var(--line2);filter:grayscale(1)}
.faq-side .tl{font-family:var(--mono);text-transform:uppercase;font-size:12.5px;letter-spacing:.05em;line-height:1.8;margin-top:14px}
.faq-grid{display:grid;grid-template-columns:1fr;border-top:1px dashed var(--dash)}
.faq-q{border-bottom:1px dashed var(--dash);padding:26px 8px;display:flex;justify-content:space-between;gap:18px;align-items:flex-start;cursor:pointer}
.faq-q h4{font-weight:500;font-size:clamp(17px,1.4vw,20px);line-height:1.3;letter-spacing:-0.01em;max-width:26ch}
.faq-q .pm{color:var(--orange);font-family:var(--mono);font-size:22px;line-height:1}
.faq-q .ans{display:none}
.faq-ask{display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;margin-top:26px}
.faq-ask .q{font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.05em;color:var(--muted);line-height:1.6}
@media(min-width:900px){
  .faq-wrap{grid-template-columns:0.85fr 2fr;gap:clamp(28px,4vw,60px)}
  .faq-grid{grid-template-columns:1fr 1fr;border-left:1px dashed var(--dash)}
  .faq-q{border-right:1px dashed var(--dash);min-height:150px}
}

/* ======================= CONTACTS / FOOTER ======================= */
.contacts{position:relative;border-top:1px solid var(--line);overflow:hidden}
.contacts .wrap{padding-top:clamp(40px,5vw,70px)}
.contacts-top{display:grid;grid-template-columns:1fr;gap:14px;font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.05em;color:var(--ink)}
.contacts-top .row{display:flex;gap:26px;flex-wrap:wrap;color:var(--muted)}
.contacts-top .row a:hover{color:var(--ink)}
.contacts-head{position:relative;margin:clamp(28px,5vw,46px) 0}
.contacts-head h2{position:relative;z-index:2;max-width:14ch}
.contacts-terrain{position:absolute;left:calc(var(--gutter)*-1);right:calc(var(--gutter)*-1);top:50%;transform:translateY(-50%);z-index:0;height:200px;overflow:hidden;display:flex;align-items:center;opacity:.55}
.contacts-terrain img{width:100%;height:200px;object-fit:cover;image-rendering:pixelated}
.foot-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px 24px;border-top:1px solid var(--line);padding:36px 0}
.foot-col h5{font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.08em;color:var(--soft);margin:0 0 14px}
.foot-col a,.foot-col span{display:block;font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.04em;color:var(--muted);padding:5px 0}
.foot-col a:hover{color:var(--ink)}
.foot-form{display:grid;gap:14px}
.foot-form .fld label{font-family:var(--mono);text-transform:uppercase;font-size:10.5px;letter-spacing:.08em;color:var(--soft)}
.foot-form .fld input{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line2);padding:8px 0;font-family:var(--mono);text-transform:uppercase;font-size:13px;color:var(--ink);letter-spacing:.03em}
.foot-form .fld input::placeholder{color:var(--ink)}
.foot-form .fld input:focus{outline:none;border-bottom-color:var(--orange)}
.foot-bottom{border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;padding:22px 0 40px;font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.05em;color:var(--soft)}
.foot-bottom .brand{font-size:14px;color:var(--ink)}
@media(min-width:860px){
  .foot-grid{grid-template-columns:1fr 1fr 1fr 1.4fr;gap:24px}
  .foot-form{grid-template-columns:1fr 1fr;gap:18px}
  .foot-form .lets{grid-column:1/-1}
}

/* reveal helper for FAQ (progressive enhancement, JS toggles .open) */
.faq-q.open .ans{display:block;margin-top:14px;color:var(--muted);font-size:14px;line-height:1.55;font-family:var(--sans);text-transform:none;letter-spacing:0;max-width:40ch}
.faq-q.open .pm{transform:rotate(45deg)}

/* =========================================================
   REFINEMENTS - white background, breathing room, hero video
   ========================================================= */
:root{ --bg:#ffffff; --line:rgba(21,20,15,.10); }
body{background:#fff}

/* --- more air everywhere --- */
.nav-in{height:80px}
.sec .wrap{padding-top:clamp(80px,10vw,150px);padding-bottom:clamp(80px,10vw,150px)}
.sec-head{margin-bottom:clamp(52px,7vw,100px);gap:24px}
.trusted .wrap{padding-top:26px;padding-bottom:26px}
.body-sm,.area-desc,.st-desc{line-height:1.7}

/* --- HERO: two columns (copy | framed video), generous spacing --- */
.hero .wrap{padding-top:clamp(52px,8vw,100px);min-height:auto;padding-bottom:0}
.hero-grid{display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,80px);align-items:center;
  margin:clamp(40px,6vw,72px) 0 clamp(52px,8vw,92px)}
.hero-left h1{margin-top:0}
.hero-left .hero-sub{margin-top:28px;max-width:46ch}
.hero-left .hero-cta{margin-top:40px}
.hero-media{position:relative;border:1px solid var(--line2);overflow:hidden;aspect-ratio:4/3;background:#0c0c0c}
.hero-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transform:scale(1.18);transform-origin:top left}  /* crops bottom-right Gemini logo */
.hero-media .br{position:absolute;width:20px;height:20px;border:2px solid var(--orange);z-index:2}
.hero-media .br.b1{top:9px;left:9px;border-right:0;border-bottom:0}
.hero-media .br.b2{top:9px;right:9px;border-left:0;border-bottom:0}
.hero-media .br.b3{bottom:9px;left:9px;border-right:0;border-top:0}
.hero-media .br.b4{bottom:9px;right:9px;border-left:0;border-top:0}
.hero-media .cap{position:absolute;left:12px;bottom:12px;z-index:2;font-family:var(--mono);
  text-transform:uppercase;font-size:10px;letter-spacing:.1em;color:#fff;background:rgba(0,0,0,.45);padding:6px 10px}
.hero-stats{border-top:1px solid var(--line)}
.hero-stats .st{padding:24px 30px}
@media(min-width:920px){ .hero-grid{grid-template-columns:1.12fr .88fr} }
@media(prefers-reduced-motion:reduce){ .hero-media video{display:none} }

/* --- lighter dither terrain on white --- */
.value-terrain img,.contacts-terrain img{opacity:.26}
.contacts-terrain{height:170px}.contacts-terrain img{height:170px}

/* --- number boxes lift slightly off white --- */
.numbox{box-shadow:0 2px 0 var(--line)}

/* --- roomier grids / cells --- */
.area{padding:38px !important}
@media(min-width:900px){.area{padding:44px !important}}
.faq-q{padding:36px 12px;min-height:190px}
.foot-grid{padding:60px 0}
.step{padding-bottom:40px}
@media(min-width:860px){.step{padding:0 0 40px 30px}}
.areas-foot{margin-top:40px}
.stack-wrap{min-height:520px}
.contacts .wrap{padding-top:clamp(48px,6vw,80px)}
.contacts-head{margin:clamp(40px,6vw,72px) 0}

/* =========================================================
   HERO v2 - FULL-BLEED VIDEO (overrides the two-column hero)
   ========================================================= */
.hero{position:relative;min-height:clamp(580px,92vh,880px);overflow:hidden;background:#0a0a0a;color:#fff;display:flex;flex-direction:column;border-bottom:1px solid var(--line)}
.hero .vid{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero .vid video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.2);transform-origin:top left}
.hero .scrim{position:absolute;inset:0;z-index:1;pointer-events:none;background:
  linear-gradient(90deg,rgba(8,8,8,.92) 0%,rgba(8,8,8,.66) 40%,rgba(8,8,8,.22) 72%,rgba(8,8,8,.5) 100%),
  linear-gradient(0deg,rgba(8,8,8,.9) 0%,rgba(8,8,8,.10) 40%,transparent 62%)}
.hero .wrap{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:center;
  padding-top:clamp(56px,9vw,96px);padding-bottom:clamp(40px,6vw,68px);min-height:auto}
.hero .hero-top{position:absolute;top:clamp(28px,5vw,52px);left:var(--gutter);right:var(--gutter);display:flex;justify-content:space-between;align-items:flex-start}
.hero .hero-copy{max-width:900px}
.hero h1{color:#fff;margin-top:0;max-width:16ch}
.hero .hero-sub{color:rgba(255,255,255,.82);margin-top:28px;max-width:50ch}
.hero .hero-cta{margin-top:40px}
.hero .tag .l{background:rgba(255,255,255,.14);color:#fff}
.hero .hero-rt{color:rgba(255,255,255,.6)}
.hero .guide{border-left-color:rgba(255,255,255,.16)}
.hero .hero-cta .btn:not(.orange){border-color:rgba(255,255,255,.5);color:#fff;background:transparent}
.hero .hero-cta .btn:not(.orange):hover{background:#fff;color:var(--ink);border-color:#fff}
.hero-stats{position:relative;z-index:2;background:transparent;border-top:1px solid rgba(255,255,255,.2)}
.hero-stats .st{color:rgba(255,255,255,.66);border-color:rgba(255,255,255,.14)}
.hero-stats .st b{color:#fff}
.hero-stats .st.cta{color:rgba(255,255,255,.66)}
@media(min-width:760px){.hero-stats .st{border-right:1px solid rgba(255,255,255,.14)}.hero-stats .st:last-child{border-right:0}}
@media(prefers-reduced-motion:reduce){.hero .vid video{display:none}}

/* =========================================================
   MORE BREATHING SPACE (global spacing pass)
   ========================================================= */
:root{ --gutter:clamp(20px,4.5vw,72px); }
.nav-in{height:86px}
.sec .wrap{padding-top:clamp(104px,13vw,210px);padding-bottom:clamp(104px,13vw,210px)}
.sec-head{margin-bottom:clamp(70px,9vw,140px);gap:30px}
.trusted .wrap{padding-top:36px;padding-bottom:36px;gap:clamp(26px,5vw,76px)}

/* hero copy a touch more air */
.hero .hero-sub{margin-top:34px}
.hero .hero-cta{margin-top:50px;gap:16px}
.hero-stats .st{padding:30px 34px}

/* AREAS */
.areas-wrap{gap:clamp(44px,5vw,100px)}
.area{padding:44px !important}
@media(min-width:900px){.area{padding:56px !important;gap:28px}}
.area-desc{margin-top:18px}
.areas-foot{margin-top:64px}

/* PROCESS */
.step .numbox{margin-bottom:50px}
.step .st-flow{margin:32px 0 14px}
.step .st-desc{margin-top:40px}
@media(min-width:860px){.step{padding:0 0 50px 42px}.proc-intro{padding:116px 40px 0 0}}

/* VALUE */
.value-quote{margin-top:60px}
@media(min-width:860px){
  .val-item{min-height:520px;padding:0 28px}
  .val-item .numbox{margin-bottom:210px}
  .val-item:nth-child(2) .numbox,.val-item:nth-child(4) .numbox{margin-bottom:80px}
}

/* INTEGRATIONS */
.stack-wrap{min-height:620px}
.stack-cap{margin-top:44px}

/* FAQ */
.faq-wrap{gap:clamp(40px,5vw,88px)}
.faq-q{padding:48px 16px;min-height:240px}

/* CONTACTS / FOOTER */
.contacts .wrap{padding-top:clamp(64px,7vw,108px)}
.contacts-head{margin:clamp(60px,8vw,120px) 0}
.foot-grid{padding:84px 0;gap:44px 32px}
.foot-bottom{padding:32px 0 60px}

/* =========================================================
   REAL LOGO + HERO COPY FLUSH-LEFT WITH LOGO
   ========================================================= */
.brand img{height:30px;width:auto;display:block}
.brand .mk{display:none}
/* pin hero content to the same left edge as the logo:
   the hero is a flex column, so the wrap's auto-margins shrink it to content width
   and center it - width:100% makes it span the centered max-width like the nav. */
.hero .wrap{align-items:flex-start;width:100%}
.hero .hero-copy{margin-left:0;align-self:flex-start}

/* =========================================================
   SCROLL-REVEAL MOTION (Framer-style appear: fade + rise)
   ========================================================= */
.reveal{opacity:0;transform:translateY(22px);
  transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1);
  transition-delay:var(--d,0ms);will-change:opacity,transform}
.reveal.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}}

/* =========================================================
   NAV - OBERON minimal (logo left · black square menu button)
   ========================================================= */
.nav{z-index:120}
.nav-in{justify-content:space-between}
.nav .nav-links,.nav .nav-cta{display:none !important}   /* links live in the overlay now */
.nav-right{display:flex;align-items:center;gap:clamp(12px,1.5vw,20px)}
.nav-call{display:inline-flex;align-items:center;height:46px;padding:0 20px;border:1px solid var(--ink);
  font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.1em;font-weight:600;color:var(--ink);
  transition:background .15s,color .15s}
.nav-call:hover{background:var(--ink);color:#fff}
.menu-btn{width:50px;height:50px;background:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:0;cursor:pointer;flex:0 0 50px}
.menu-btn span{display:block;width:22px;height:2px;background:#fff;transition:transform .3s ease,opacity .2s ease}
body.menu-open .menu-btn span:nth-child(1){transform:translateY(4px) rotate(45deg)}
body.menu-open .menu-btn span:nth-child(2){transform:translateY(-4px) rotate(-45deg)}
@media(max-width:560px){.nav-call{display:none}}

/* ---- full-screen menu overlay ---- */
.menu-overlay{position:fixed;inset:0;z-index:115;background:#0a0a0a;color:#fff;
  display:flex;flex-direction:column;justify-content:center;
  padding:96px var(--gutter) 48px;opacity:0;visibility:hidden;transform:translateY(-14px);
  transition:opacity .42s ease,transform .42s ease,visibility 0s linear .42s;overflow:auto}
body.menu-open .menu-overlay{opacity:1;visibility:visible;transform:none;transition:opacity .42s ease,transform .42s ease}
body.menu-open{overflow:hidden}
.menu-overlay .m-inner{max-width:var(--maxw);margin:0 auto;width:100%}
.menu-overlay .m-tag{font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.18em;color:rgba(255,255,255,.45);margin-bottom:28px}
.m-links{display:flex;flex-direction:column}
.m-link{display:flex;align-items:baseline;gap:20px;padding:clamp(10px,1.6vw,18px) 0;border-bottom:1px solid rgba(255,255,255,.12);
  font-weight:500;font-size:clamp(30px,5.5vw,68px);line-height:1.04;letter-spacing:-0.025em;color:#fff;transition:color .15s,padding-left .2s}
.m-link:hover{color:var(--orange);padding-left:10px}
.m-link .idx{font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.06em;color:var(--orange);flex:0 0 auto}
.m-foot{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-top:clamp(34px,5vw,56px)}
.m-foot .m-mail{font-family:var(--mono);text-transform:uppercase;font-size:12px;letter-spacing:.06em;color:rgba(255,255,255,.6)}
.m-foot .m-mail:hover{color:#fff}
