/* ============================================================
   VERNIAS - Editorial design system
   Warm paper · deep pine · ink · General Sans / Instrument Serif / Geist Mono
   ============================================================ */
:root{
  --paper:#F6F4EF;        /* warm off-white base   */
  --paper-2:#FBFAF7;      /* lifted surface        */
  --surface:#FFFFFF;
  --ink:#16191B;          /* near-black ink        */
  --ink-2:#3B4145;        /* primary body          */
  --ink-3:#6E767B;        /* muted                 */
  --line:#E4DFD5;         /* warm hairline         */
  --line-2:#D6CFC1;       /* stronger hairline     */
  --accent:#0E5A41;       /* deep pine             */
  --accent-2:#0A4733;     /* darker hover          */
  --accent-tint:rgba(14,90,65,0.08);
  --accent-bright:#13a172;/* live / status only    */
  --amber:#B47314;
  --danger:#b4452f;
  --maxw:1220px;
  --r:12px;
  --ease:cubic-bezier(.2,.6,.2,1);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;color-scheme:light}
body{
  font-family:"General Sans",system-ui,-apple-system,sans-serif;
  background:var(--paper);color:var(--ink-2);line-height:1.6;
  overflow-x:hidden;max-width:100vw;
}
body.nav-open{overflow:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
input,select,textarea,button{font-family:inherit;font-size:inherit;color:inherit}
::selection{background:var(--accent-tint);color:var(--accent-2)}

/* ---------- utilities ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.serif{font-family:"Instrument Serif",Georgia,serif;font-weight:400}
.em{font-family:"Instrument Serif",Georgia,serif;font-style:italic;font-weight:400;color:var(--accent);font-size:1.06em;letter-spacing:0}
.mono{font-family:"Geist Mono",ui-monospace,monospace}
.accent{color:var(--accent)}

.eyebrow{
  font-family:"Geist Mono",monospace;font-size:.72rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);
  display:inline-flex;align-items:center;gap:.7rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block;flex:none}
.eyebrow.center{justify-content:center}

/* ---------- buttons & links ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;font-weight:600;font-size:.95rem;
  padding:.85rem 1.35rem;border-radius:10px;border:1px solid transparent;cursor:pointer;line-height:1;
  transition:transform .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease),color .25s var(--ease);
}
.btn svg{width:15px;height:15px;flex:none;transition:transform .25s var(--ease)}
.btn-primary{background:var(--accent);color:var(--paper);box-shadow:0 1px 2px rgba(14,90,65,.25)}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 8px 22px rgba(14,90,65,.22)}
.btn-primary:hover svg{transform:translateX(3px)}
.btn-outline{background:transparent;border-color:var(--line-2);color:var(--ink)}
.btn-outline:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn-sm{padding:.6rem 1rem;font-size:.9rem}
.btn-lg{padding:1rem 1.6rem;font-size:1rem}
.btn-block{width:100%;justify-content:center}

.link{display:inline-flex;align-items:center;gap:.5rem;color:var(--ink);font-weight:600;font-size:.95rem;position:relative}
.link svg{width:15px;height:15px;transition:transform .25s var(--ease)}
.link::after{content:"";position:absolute;left:0;bottom:-3px;height:1px;width:100%;background:var(--ink);transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.link:hover::after{transform:scaleX(1)}
.link:hover svg{transform:translateX(3px)}
.link.muted{color:var(--ink-2)}.link.muted::after{background:var(--ink-2)}

/* ---------- reveal motion ---------- */
[data-reveal]{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none}
  *{scroll-behavior:auto!important}
}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;
  background:rgba(246,244,239,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.nav.scrolled{border-color:var(--line);background:rgba(246,244,239,.88)}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:0 28px;height:68px;display:flex;align-items:center;justify-content:space-between;gap:1.5rem}
.brand{display:flex;align-items:center;gap:.55rem;font-size:1.16rem;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.brand-mark{width:26px;height:25px;object-fit:contain}
.nav-links{display:flex;gap:.4rem;align-items:center}
.nav-links>li>a,.drop-toggle{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem .8rem;border-radius:8px;
  color:var(--ink-2);font-size:.92rem;font-weight:500;background:none;border:none;cursor:pointer;transition:color .2s,background .2s}
.nav-links>li>a:hover,.drop-toggle:hover,.nav-links>li>a.active{color:var(--ink)}
.drop-toggle svg{width:11px;height:11px;transition:transform .25s var(--ease)}
.has-drop.open .drop-toggle svg{transform:rotate(180deg)}
.has-drop{position:relative}
.drop-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:248px;background:var(--surface);
  border:1px solid var(--line);border-radius:12px;padding:8px;box-shadow:0 12px 34px rgba(20,24,26,.1);
  opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .2s,transform .2s,visibility .2s}
.has-drop.open .drop-menu{opacity:1;visibility:visible;transform:none}
.drop-menu a{display:flex;align-items:center;gap:.7rem;padding:.6rem .7rem;border-radius:8px;font-size:.9rem;color:var(--ink-2);transition:background .15s,color .15s}
.drop-menu a:hover{background:var(--paper);color:var(--ink)}
.drop-menu a.active{color:var(--accent);background:var(--accent-tint)}
.drop-menu a .mk{width:10px;height:2px;border-radius:2px;background:var(--accent);flex:none}
.nav-cta{display:flex;align-items:center;gap:1rem}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.nav-burger span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-burger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.active span:nth-child(2){opacity:0}
.nav-burger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:880px){
  .nav-burger{display:flex}
  .nav-cta{display:none}
  .nav-links{position:fixed;inset:68px 0 auto 0;flex-direction:column;align-items:stretch;gap:.2rem;
    background:var(--paper);border-bottom:1px solid var(--line);padding:16px 20px 24px;
    transform:translateY(-130%);transition:transform .35s var(--ease);box-shadow:0 20px 40px rgba(20,24,26,.08)}
  .nav-links.open{transform:none}
  .nav-links>li>a,.drop-toggle{width:100%;padding:.8rem .4rem;font-size:1rem}
  .drop-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:0 0 .4rem 1rem;
    min-width:0;background:none;display:none}
  .has-drop.open .drop-menu{display:block}
}

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{padding:100px 0 96px;position:relative;overflow:hidden;display:block;min-height:0;background:none}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
.hero h1{font-size:clamp(2.7rem,5.6vw,4.9rem);line-height:1.015;letter-spacing:-.025em;color:var(--ink);font-weight:600;margin:1.5rem 0 0}
.hero .sub{font-size:1.16rem;color:var(--ink-2);max-width:34rem;margin:1.7rem 0 0}
.hero-actions{display:flex;gap:1.1rem;align-items:center;margin-top:2.4rem;flex-wrap:wrap}
.trust{margin-top:3.2rem;display:flex;align-items:center;gap:1.1rem;color:var(--ink-3);font-size:.82rem;flex-wrap:wrap}
.trust .mono{font-size:.74rem;letter-spacing:.04em}
.hero-glow{position:absolute;top:-12%;right:-8%;width:540px;height:540px;border-radius:50%;
  background:radial-gradient(circle,var(--accent-tint),transparent 68%);pointer-events:none;z-index:-1;filter:none;opacity:1}
@media(max-width:880px){
  .hero{padding:120px 0 64px}
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .hero .stage{order:2}
}

/* ---------- interior page hero ---------- */
.page-hero{padding:150px 0 64px;position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.page-hero .hero-glow{top:-30%}
.page-hero-inner{max-width:46rem}
.page-hero h1{font-size:clamp(2.6rem,5vw,4.4rem);line-height:1.04;letter-spacing:-.025em;color:var(--ink);font-weight:600;margin:1.4rem 0 0}
.page-hero p{font-size:1.16rem;color:var(--ink-2);margin:1.5rem 0 0;max-width:38rem}
.page-hero .hero-actions{margin-top:2.2rem}

/* ============================================================
   PRODUCT FRAME + MOCKUPS (reusable)
   ============================================================ */
.stage{perspective:1600px}
.frame{background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden;
  box-shadow:0 2px 4px rgba(20,24,26,.03),0 14px 30px rgba(20,24,26,.06),0 44px 88px rgba(20,24,26,.09);
  will-change:transform;transition:transform .4s var(--ease)}
.frame-bar{height:46px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:1.2rem;padding:0 16px;background:var(--paper-2)}
.frame-brand{font-size:.84rem;font-weight:600;color:var(--ink);display:flex;align-items:center;gap:.45rem}
.frame-brand .dot{width:7px;height:7px;border-radius:50%;background:var(--accent)}
.frame-tabs{display:flex;gap:1.1rem;font-size:.78rem;color:var(--ink-3)}
.frame-tabs .on{color:var(--ink);position:relative}
.frame-tabs .on::after{content:"";position:absolute;left:0;right:0;bottom:-15px;height:2px;background:var(--accent)}
.frame-right{margin-left:auto;display:flex;align-items:center;gap:.6rem}
.avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#cfe5da,#0E5A41)}
.frame-body{padding:20px}
.hero-shot{display:block;width:100%;height:auto}
#home #tiltFrame{box-shadow:0 4px 10px rgba(20,24,26,.06),0 24px 50px rgba(20,24,26,.13),0 70px 130px rgba(20,24,26,.22)}
@media(min-width:881px){
  #home .hero-grid{grid-template-columns:.92fr 1.22fr}
  #home #tiltFrame{transform:rotateY(-24deg) rotateX(3deg) scale(1.14);transform-origin:center}
  .hero:not(#home){padding-top:160px}  /* industries pages: more breathing room below the menu (home stays 100px) */
}

/* dashboard */
.db-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:18px;gap:1rem}
.db-head h4{font-size:1.05rem;color:var(--ink);font-weight:600;letter-spacing:-.01em}
.db-head .when{font-size:.72rem;color:var(--ink-3)}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden;margin-bottom:18px}
.kpis.three{grid-template-columns:repeat(3,1fr)}
.kpi{background:var(--surface);padding:12px 13px}
.kpi .lbl{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.kpi .val{font-size:1.15rem;color:var(--ink);font-weight:500;margin-top:5px;font-family:"Geist Mono",monospace;letter-spacing:-.02em}
.kpi .delta{font-size:.68rem;margin-top:3px;font-family:"Geist Mono",monospace}
.up{color:var(--accent-bright)}.down{color:var(--danger)}
.chart{display:flex;align-items:flex-end;gap:7px;height:74px;padding:0 2px;border-bottom:1px solid var(--line);margin-bottom:16px}
.bar{flex:1;background:var(--line-2);border-radius:3px 3px 0 0}
.bar.hi{background:var(--accent)}
.tbl{width:100%;border-collapse:collapse;font-size:.78rem}
.tbl th{text-align:left;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-weight:500;padding:0 0 9px}
.tbl td{padding:9px 0;border-top:1px solid var(--line);color:var(--ink-2)}
.tbl td.co{color:var(--ink);font-weight:500}
.tbl td.num,.tbl th.r{text-align:right}
.tbl td.num{font-family:"Geist Mono",monospace;letter-spacing:-.02em}
.pill{display:inline-flex;align-items:center;gap:.35rem;font-size:.68rem;font-weight:500;padding:.18rem .5rem;border-radius:999px}
.pill::before{content:"";width:5px;height:5px;border-radius:50%}
.pill.ok{background:rgba(19,161,114,.1);color:var(--accent)}.pill.ok::before{background:var(--accent-bright)}
.pill.watch{background:rgba(180,115,20,.1);color:var(--amber)}.pill.watch::before{background:var(--amber)}

/* memo / AI */
.memo{display:grid;grid-template-columns:148px 1fr;min-height:330px}
.memo .rail{border-right:1px solid var(--line);padding:16px 14px;background:var(--paper-2)}
.memo .rail .h{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:11px}
.memo .src{display:flex;align-items:center;gap:.5rem;font-size:.76rem;color:var(--ink-2);padding:6px 0}
.memo .src .tick{width:15px;height:15px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-size:.6rem;flex:none}
.memo .src.run .tick{background:var(--paper);border:1.5px solid var(--accent);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.memo .doc{padding:20px 22px}
.memo .status{display:inline-flex;align-items:center;gap:.45rem;font-size:.68rem;font-family:"Geist Mono",monospace;color:var(--accent);margin-bottom:14px}
.memo .status .live{width:6px;height:6px;border-radius:50%;background:var(--accent-bright);animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
.memo .doc h5{font-size:1rem;color:var(--ink);font-weight:600;margin-bottom:10px}
.ln{height:9px;border-radius:4px;background:var(--line);margin:8px 0}
.callout{margin-top:16px;border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:8px;padding:12px 14px;background:var(--paper-2)}
.callout .cl{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.callout .row{display:flex;justify-content:space-between;gap:1rem;font-size:.8rem;margin-top:7px;color:var(--ink)}
.callout .row .mono{color:var(--accent)}
.cursor{display:inline-block;width:2px;height:1em;background:var(--accent);vertical-align:-2px;animation:blink 1s step-end infinite}
@keyframes blink{50%{opacity:0}}

/* ============================================================
   STRIP (asset classes)
   ============================================================ */
.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper-2)}
.strip-in{display:flex;align-items:center;justify-content:space-between;gap:2rem;padding:26px 0;flex-wrap:wrap}
.strip .lead{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);font-family:"Geist Mono",monospace;white-space:nowrap}
.strip ul{display:flex;gap:2.2rem;flex-wrap:wrap}
.strip li{font-size:1rem;color:var(--ink);font-weight:500}
@media(max-width:760px){.strip ul{gap:1.2rem}.strip li{font-size:.9rem}}

/* ============================================================
   SECTION SYSTEM
   ============================================================ */
section.block{padding:clamp(90px,12vh,150px) 0}
section.block.tight{padding-top:0}
.sec-head{max-width:44rem}
.sec-head.center{margin:0 auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head h2{font-size:clamp(2rem,3.8vw,3.2rem);line-height:1.08;letter-spacing:-.022em;color:var(--ink);font-weight:600;margin:1.2rem 0 0}
.sec-head p{font-size:1.1rem;color:var(--ink-2);margin-top:1.2rem}

/* ---------- industries (editorial cards) ---------- */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:54px;border-top:1px solid var(--line-2);border-left:1px solid var(--line)}
.ind-card{border-right:1px solid var(--line);border-bottom:1px solid var(--line);padding:30px 28px 26px;display:flex;flex-direction:column;min-height:230px;transition:background .3s}
.ind-card:hover{background:var(--paper-2)}
.ind-card .no{font-family:"Geist Mono",monospace;font-size:.74rem;color:var(--accent)}
.ind-card h3{font-size:1.4rem;color:var(--ink);font-weight:600;letter-spacing:-.01em;margin:.9rem 0 .6rem}
.ind-card p{font-size:.96rem;color:var(--ink-2);flex:1}
.ind-card .go{display:inline-flex;align-items:center;gap:.45rem;color:var(--accent);font-weight:600;font-size:.9rem;margin-top:1.2rem}
.ind-card .go svg{width:14px;height:14px;transition:transform .25s var(--ease)}
.ind-card:hover .go svg{transform:translateX(4px)}
@media(max-width:880px){.ind-grid{grid-template-columns:1fr}}

/* ---------- solutions / pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px}
.pillar{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:28px 26px;display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.pillar:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(20,24,26,.07)}
.pillar.feat{background:var(--ink);border-color:var(--ink)}
.pillar.feat *{color:var(--paper)!important}
.pillar.feat .pillar-type{background:rgba(255,255,255,.14)}
.pillar.feat .pl li::before{background:var(--accent-bright)}
.pillar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.pillar-num{font-family:"Geist Mono",monospace;font-size:.78rem;color:var(--accent)}
.pillar-type{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);background:var(--paper);border:1px solid var(--line);padding:.25rem .55rem;border-radius:999px}
.pillar h3{font-size:1.35rem;color:var(--ink);font-weight:600;letter-spacing:-.01em}
.pillar>p{font-size:.98rem;color:var(--ink-2);margin:.8rem 0 1.2rem}
.pl{margin:0 0 1.5rem}
.pl li{position:relative;padding:.5rem 0 .5rem 1.1rem;font-size:.92rem;color:var(--ink-2);border-top:1px solid var(--line)}
.pl li::before{content:"";position:absolute;left:0;top:1.15rem;width:7px;height:1px;background:var(--accent)}
.pillar .link{margin-top:auto}
@media(max-width:880px){.pillars{grid-template-columns:1fr}}

/* ---------- split (engine) ---------- */
.split{display:grid;grid-template-columns:1fr 1.08fr;gap:64px;align-items:center}
.split.rev .stage{order:-1}
.split .copy h2{font-size:clamp(2rem,3.8vw,3.2rem);line-height:1.08;letter-spacing:-.022em;color:var(--ink);font-weight:600;margin:1.2rem 0 0}
.split .copy>p{font-size:1.08rem;color:var(--ink-2);margin-top:1.2rem}
.split .copy ul{margin:2rem 0 2.2rem}
.split .copy li{padding:14px 0;border-top:1px solid var(--line);color:var(--ink-2);display:flex;gap:.9rem;font-size:1.02rem}
.split .copy li:last-child{border-bottom:1px solid var(--line)}
.split .copy li b{color:var(--ink);font-weight:600}
.split .copy li .n{font-family:"Geist Mono",monospace;color:var(--accent);font-size:.8rem;padding-top:.2rem;flex:none}
.split .copy li .n .agent-ico{display:block;width:30px;height:30px;object-fit:contain;margin-top:-4px}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:44px}.split .stage,.split.rev .stage{order:-1}}

/* ---------- process steps ---------- */
.steps{margin-top:48px;border-top:1px solid var(--line-2)}
.step{display:grid;grid-template-columns:90px 1fr 1.4fr;gap:32px;padding:34px 0;border-bottom:1px solid var(--line);align-items:start;transition:background .3s}
.step:hover{background:var(--paper-2)}
.step .no{font-family:"Geist Mono",monospace;font-size:.82rem;color:var(--accent)}
.step h3{font-size:1.4rem;color:var(--ink);font-weight:600;letter-spacing:-.01em}
.step p{color:var(--ink-2);font-size:1rem}
@media(max-width:760px){.step{grid-template-columns:1fr;gap:10px;padding:26px 0}}

/* ---------- why (editorial, on dark) ---------- */
.section-ink{background:var(--ink)}
.section-ink .sec-head h2{color:var(--paper)}
.section-ink .sec-head p{color:#b9c2c4}
.section-ink .eyebrow{color:#9aa3a5}
.why{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:54px;border-top:1px solid rgba(255,255,255,.14)}
.why-item{padding:32px 30px 30px;border-bottom:1px solid rgba(255,255,255,.1)}
.why-item:nth-child(odd){border-right:1px solid rgba(255,255,255,.1)}
.why-item .no{font-family:"Geist Mono",monospace;font-size:.76rem;color:var(--accent-bright)}
.why-item h3{font-size:1.35rem;color:var(--paper);font-weight:600;letter-spacing:-.01em;margin:.8rem 0 .6rem}
.why-item p{color:#aab3b5;font-size:.98rem}
@media(max-width:760px){.why{grid-template-columns:1fr}.why-item:nth-child(odd){border-right:none}}

/* ============================================================
   COMING SOON (industry stub)
   ============================================================ */
.coming{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:center}
.coming .badge{display:inline-flex;align-items:center;gap:.5rem;font-family:"Geist Mono",monospace;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);background:var(--accent-tint);padding:.4rem .7rem;border-radius:999px}
.coming .badge .live{width:6px;height:6px;border-radius:50%;background:var(--accent-bright);animation:pulse 1.6s ease-in-out infinite}
.coming h2{font-size:clamp(1.9rem,3.6vw,2.9rem);line-height:1.1;letter-spacing:-.02em;color:var(--ink);font-weight:600;margin:1.2rem 0 0}
.coming>div>p{font-size:1.08rem;color:var(--ink-2);margin-top:1.1rem}
.coming-feats{margin:1.8rem 0 2rem}
.coming-feats li{display:flex;gap:.8rem;padding:12px 0;border-top:1px solid var(--line);font-size:1rem;color:var(--ink-2)}
.coming-feats li:last-child{border-bottom:1px solid var(--line)}
.coming-feats li b{color:var(--ink);font-weight:600}
.coming-feats .n{font-family:"Geist Mono",monospace;color:var(--accent);font-size:.8rem;flex:none}
.coming-cta{display:flex;gap:1rem;flex-wrap:wrap}
@media(max-width:880px){.coming{grid-template-columns:1fr;gap:44px}.coming .stage{order:-1}}

/* ============================================================
   ABOUT
   ============================================================ */
.founders{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:54px}
.founder{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:26px;text-align:left;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.founder:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(20,24,26,.07)}
.founder-photo-wrap{width:72px;height:72px;border-radius:50%;overflow:hidden;margin-bottom:18px;background:var(--paper);border:1px solid var(--line)}
.founder-photo{width:100%;height:100%;object-fit:cover}
.founder-fallback{width:100%;height:100%;display:none;align-items:center;justify-content:center;color:var(--ink-3)}
.founder-fallback svg{width:30px;height:30px}
.founder h3{font-size:1.25rem;color:var(--ink);font-weight:600}
.founder-title{display:block;font-family:"Geist Mono",monospace;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin:.3rem 0 1rem}
.founder-email{display:inline-flex;align-items:center;gap:.45rem;font-size:.88rem;color:var(--ink-2)}
.founder-email:hover{color:var(--accent)}
@media(max-width:760px){.founders{grid-template-columns:1fr}}

.mission{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:start}
.mission-text h2{font-size:clamp(1.9rem,3.6vw,2.9rem);line-height:1.1;letter-spacing:-.02em;color:var(--ink);font-weight:600;margin:1.2rem 0 1.2rem}
.mission-text p{color:var(--ink-2);margin-bottom:1rem;font-size:1.05rem}
.values{display:flex;flex-direction:column}
.value{display:flex;gap:1rem;padding:18px 0;border-top:1px solid var(--line)}
.value:last-child{border-bottom:1px solid var(--line)}
.value .n{font-family:"Geist Mono",monospace;color:var(--accent);font-size:.8rem;padding-top:.15rem;flex:none}
.value strong{display:block;color:var(--ink);font-weight:600;margin-bottom:.2rem}
.value span{color:var(--ink-2);font-size:.95rem}
@media(max-width:880px){.mission{grid-template-columns:1fr;gap:40px}}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:64px;align-items:start}
.contact-info h2{font-size:clamp(1.9rem,3.6vw,2.9rem);line-height:1.1;letter-spacing:-.02em;color:var(--ink);font-weight:600;margin:1.2rem 0 1.1rem}
.contact-info>p{color:var(--ink-2);font-size:1.05rem}
.contact-note{display:inline-flex;align-items:center;gap:.5rem;margin-top:1.4rem;font-size:.85rem;color:var(--accent);font-family:"Geist Mono",monospace}
.contact-details{margin-top:2rem;display:flex;flex-direction:column;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:10px;overflow:hidden}
.contact-item{background:var(--paper-2);padding:14px 16px}
.contact-item .k{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3)}
.contact-item .v{color:var(--ink);margin-top:3px;font-weight:500}
.offerings{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.6rem}
.chip{display:inline-flex;align-items:center;gap:.45rem;font-size:.82rem;color:var(--ink-2);border:1px solid var(--line-2);border-radius:999px;padding:.4rem .8rem}
.chip .mk{width:5px;height:5px;border-radius:50%;background:var(--accent)}

.form-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:28px;box-shadow:0 14px 40px rgba(20,24,26,.06)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{margin-bottom:16px}
.field label{display:block;font-size:.78rem;font-weight:500;color:var(--ink);margin-bottom:.45rem}
.field input,.field select,.field textarea{width:100%;background:var(--paper-2);border:1px solid var(--line-2);border-radius:9px;padding:.8rem .9rem;color:var(--ink);transition:border-color .2s,box-shadow .2s;font-size:.95rem}
.field textarea{resize:vertical;min-height:110px}
.field input::placeholder,.field textarea::placeholder{color:var(--ink-3)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint)}
.form-status{padding:.8rem 1rem;border-radius:9px;font-size:.9rem;margin-bottom:14px}
.form-status.success{background:var(--accent-tint);color:var(--accent)}
.form-status.error{background:rgba(180,69,47,.1);color:var(--danger)}
.form-privacy{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--ink-3);margin-top:14px;justify-content:center}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:40px}}
@media(max-width:520px){.form-row{grid-template-columns:1fr}}

/* ============================================================
   CTA
   ============================================================ */
.cta{padding:clamp(90px,12vh,140px) 0;border-top:1px solid var(--line);text-align:center}
.cta h2{font-size:clamp(2.4rem,5vw,4.2rem);line-height:1.05;letter-spacing:-.025em;color:var(--ink);font-weight:600}
.cta p{font-size:1.12rem;color:var(--ink-2);margin:1.4rem auto 2.4rem;max-width:32rem}
.cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--line);padding:64px 0 34px;background:var(--paper-2)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px}
.footer-brand .brand{margin-bottom:1rem}
.footer-brand p{color:var(--ink-2);font-size:.92rem;max-width:32rem}
.footer-social{display:flex;gap:.7rem;margin-top:1.4rem}
.footer-social a{width:36px;height:36px;display:grid;place-items:center;border:1px solid var(--line-2);border-radius:9px;color:var(--ink-2);transition:color .2s,border-color .2s,transform .2s}
.footer-social a:hover{color:var(--accent);border-color:var(--accent);transform:translateY(-2px)}
.footer-social svg{width:16px;height:16px}
.footer-links h3{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:600;margin-bottom:1.1rem}
.footer-links li{margin-bottom:.7rem}
.footer-links a{color:var(--ink-2);font-size:.92rem;transition:color .2s}
.footer-links a:hover{color:var(--accent)}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--line);color:var(--ink-3);font-size:.84rem}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr;gap:32px}}

/* ============================================================
   MOBILE OPTIMISATION (additive only; desktop base untouched)
   ============================================================ */
*{-webkit-tap-highlight-color:transparent}
@media(max-width:600px){
  .wrap{padding:0 20px}
  .nav-in{padding:0 20px}
  .field input,.field select,.field textarea{font-size:16px}        /* stop iOS zoom-on-focus */
  .kpis{grid-template-columns:repeat(2,1fr)}                          /* product-mockup KPIs: 4 -> 2 cols */
  .frame-body{overflow-x:auto;-webkit-overflow-scrolling:touch}       /* wide tables swipe instead of clip */
  .tbl{min-width:300px;font-size:.74rem}
}
