/* ============================================================
   beaconGIS — landing page styles
   Editorial / calm · forest-green + cream + signal-yellow
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Spectral:ital,wght@0,400;0,500;0,600;1,400&family=Hanken+Grotesk:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

/* ---- Tokens ---- */
:root{
  /* surfaces */
  --paper:#F3EFE3;        /* main cream */
  --paper-2:#EDE7D6;      /* slightly deeper cream */
  --card:#FAF7EE;         /* raised card */
  --ink:#123B1E;          /* darkest forest (text) */
  --forest:#1B5430;       /* mid forest */
  --forest-deep:#0E2E18;  /* near-black green for the mission band */
  --green:#3FA34D;        /* signal stripe green */
  --sage:#A7CDA1;
  --hill:#BBD7AE;
  --yellow:#F2C53D;       /* beacon */
  --yellow-soft:#F6DA86;
  --rust:#C25E3A;         /* roof / alert accent */
  --line:rgba(18,59,30,.14);
  --line-strong:rgba(18,59,30,.26);

  /* damage classes (xView2 standard) */
  --d-none:#3FA34D;
  --d-minor:#F2C53D;
  --d-major:#E8833A;
  --d-dest:#C5403A;

  /* accent (tweakable) */
  --accent:var(--yellow);

  /* type */
  --serif:'Spectral',Georgia,serif;
  --sans:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  --mono:'IBM Plex Mono',ui-monospace,SFMono-Regular,Menlo,monospace;

  /* layout */
  --maxw:1240px;
  --gutter:clamp(20px,5vw,72px);
  --radius:18px;
  --radius-lg:26px;
  --motion:1; /* tweakable: 0 disables animation */
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.wide{max-width:1440px;margin-inline:auto;padding-inline:var(--gutter)}

/* ---- Typography helpers ---- */
.eyebrow{
  font-family:var(--mono);
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--forest);
  display:inline-flex;align-items:center;gap:.6em;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--line-strong)}
.eyebrow.on-dark{color:var(--yellow-soft)}
.eyebrow.on-dark::before{background:rgba(246,218,134,.45)}

h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-.015em;margin:0}
.display{font-size:clamp(3rem,7.4vw,6.6rem);line-height:.98;letter-spacing:-.025em}
.h2{font-size:clamp(2.1rem,4.4vw,3.5rem)}
.h3{font-size:clamp(1.4rem,2.4vw,2rem)}
.lead{font-size:clamp(1.15rem,1.7vw,1.4rem);line-height:1.5;color:color-mix(in oklab,var(--ink) 80%,transparent)}
.mono{font-family:var(--mono)}
em{font-style:italic}
.serif-em{font-family:var(--serif);font-style:italic;font-weight:400}

/* ---- Buttons ---- */
.btn{
  font-family:var(--sans);font-weight:600;font-size:1rem;
  display:inline-flex;align-items:center;gap:.6em;
  padding:.86em 1.4em;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .18s ease,background .2s,box-shadow .2s,color .2s,border-color .2s;
  white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--forest);box-shadow:0 10px 24px -12px rgba(18,59,30,.7)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(18,59,30,.04)}
.btn-light{background:var(--yellow);color:var(--ink)}
.btn-light:hover{background:var(--yellow-soft);box-shadow:0 10px 24px -12px rgba(242,197,61,.9)}
.btn-on-dark{background:transparent;color:var(--paper);border-color:rgba(243,239,227,.32)}
.btn-on-dark:hover{border-color:var(--paper);background:rgba(243,239,227,.08)}
.btn .ico{width:18px;height:18px;flex:0 0 auto}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--gutter);
  transition:background .3s,box-shadow .3s,padding .3s;
}
.nav.scrolled{
  background:color-mix(in oklab,var(--paper) 86%,transparent);
  backdrop-filter:blur(12px) saturate(1.2);
  box-shadow:0 1px 0 var(--line);
  padding-top:10px;padding-bottom:10px;
}
.brand{display:flex;align-items:center;gap:.6em;font-weight:800;letter-spacing:-.01em;font-size:1.18rem}
.brand .mark{width:38px;height:38px;border-radius:10px;object-fit:cover;box-shadow:inset 0 0 0 1px var(--line)}
.brand b{font-weight:800}
.brand .gis{color:var(--green)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a.lnk{font-weight:500;font-size:.98rem;color:color-mix(in oklab,var(--ink) 78%,transparent);transition:color .2s}
.nav-links a.lnk:hover{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:12px}
@media (max-width:900px){.nav-links .lnk{display:none}}
@media (max-width:560px){.nav-cta .ghost-sm{display:none}}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:clamp(120px,18vh,180px) 0 60px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:48px;align-items:center}
@media (max-width:960px){.hero-grid{grid-template-columns:1fr;gap:36px}}

.hero h1{margin:.32em 0 .28em}
.hero .lead{max-width:30ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero-stat{
  margin-top:34px;display:flex;gap:28px;flex-wrap:wrap;align-items:center;
  font-family:var(--mono);font-size:.86rem;color:var(--forest);
}
.hero-stat .s b{font-family:var(--sans);font-weight:800;font-size:1.5rem;color:var(--ink);display:block;line-height:1}
.hero-stat .s span{opacity:.72;letter-spacing:.02em}
.hero-stat .div{width:1px;height:34px;background:var(--line-strong)}

/* hero artwork: beacon */
.hero-art{position:relative;aspect-ratio:1/1;max-width:560px;margin-inline:auto;width:100%}
.hero-art .halo{
  position:absolute;inset:-6% -6% -6% -6%;z-index:0;border-radius:50%;
  background:radial-gradient(circle at 42% 30%,rgba(242,197,61,.20),transparent 60%);
}
.beacon{position:relative;z-index:1;width:100%;height:100%;display:block;overflow:visible}
.beam-sweep{
  transform-box:view-box;transform-origin:206px 128px;
  animation:beaconSweep calc(7s / var(--motion,1)) ease-in-out infinite;
  opacity:var(--motion,1);
}
@keyframes beaconSweep{
  0%,100%{transform:rotate(-9deg)}
  50%{transform:rotate(7deg)}
}
.lamp-glow{animation:lampPulse calc(3.6s / var(--motion,1)) ease-in-out infinite}
@keyframes lampPulse{0%,100%{opacity:.5}50%{opacity:.92}}
.lamp-win{animation:winPulse calc(3.6s / var(--motion,1)) ease-in-out infinite}
@keyframes winPulse{0%,100%{opacity:.82}50%{opacity:1}}
@media (prefers-reduced-motion:reduce){.beam-sweep,.lamp-glow,.lamp-win{animation:none}}

/* ============================================================
   MISSION BAND — the big pre/post/classified visual
   ============================================================ */
.mission{background:var(--forest-deep);color:var(--paper);position:relative;padding:clamp(64px,9vw,110px) 0}
.mission::before{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 80% at 84% -5%,rgba(242,197,61,.10),transparent 60%),
  radial-gradient(50% 60% at 6% 110%,rgba(63,163,77,.16),transparent 60%);
  pointer-events:none}
.mission .head{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap;margin-bottom:22px}
.mission h2{color:var(--paper);max-width:18ch}
.mission .head p{color:rgba(243,239,227,.7);max-width:40ch;margin:0;font-family:var(--mono);font-size:.82rem;letter-spacing:.04em}
.mission .head p .credit{display:block;margin-top:7px;color:rgba(243,239,227,.42);font-size:.74rem}

/* compact, centered example module */
.ex{max-width:1060px;margin-inline:auto}

/* city switcher tabs */
.example-tabs{position:relative;z-index:2;display:flex;gap:9px;flex-wrap:wrap;margin-bottom:18px}
.ex-tab{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-align:left;
  background:rgba(243,239,227,.06);border:1px solid rgba(243,239,227,.15);border-radius:13px;
  padding:11px 17px;cursor:pointer;transition:background .2s,border-color .2s,transform .15s;font-family:var(--sans)}
.ex-tab:active{transform:translateY(1px)}
.ex-tab .nm{font-weight:600;font-size:1rem;color:rgba(243,239,227,.92);line-height:1.1}
.ex-tab .sb{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(243,239,227,.5)}
.ex-tab:hover[aria-pressed=false]{border-color:rgba(243,239,227,.4)}
.ex-tab:hover[aria-pressed=false] .nm{color:#fff}
.ex-tab[aria-pressed=true]{background:var(--yellow);border-color:var(--yellow)}
.ex-tab[aria-pressed=true] .nm{color:var(--ink)}
.ex-tab[aria-pressed=true] .sb{color:rgba(18,59,30,.72)}

/* viewer shell */
.viewer{position:relative;z-index:2;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:0 40px 90px -50px rgba(0,0,0,.9),inset 0 0 0 1px rgba(243,239,227,.1);background:#0a2010}
.viewer-frame{position:relative;width:100%;aspect-ratio:16/9;background:#0a2010;overflow:hidden}

/* three reusable layers (pre / post / classified) repositioned per mode */
.layer{position:absolute;inset:0;overflow:hidden;transition:inset .55s cubic-bezier(.2,.7,.2,1),opacity .5s ease;border-radius:0;
  background:repeating-linear-gradient(135deg,#0d2a16 0 13px,#0f2f1a 13px 26px)}
.layer image-slot{position:absolute;inset:0;width:100%;height:100%}

/* per-city image-slots: show only the active city's set */
#viewer image-slot[data-loc]{display:none}
#viewer[data-loc="hatay"]    image-slot[data-loc="hatay"],
#viewer[data-loc="kmaras"]   image-slot[data-loc="kmaras"],
#viewer[data-loc="adiyaman"] image-slot[data-loc="adiyaman"]{display:block}

/* light, legible empty-state on dark placeholders */
image-slot::part(empty){color:rgba(243,239,227,.9);font-size:14px}
image-slot::part(frame){background:transparent}
/* keep the two prompts from colliding dead-centre under the handle */
.layer.pre  image-slot::part(empty){align-items:flex-start;padding-left:7%}
.layer.post image-slot::part(empty){align-items:flex-end;padding-right:7%}

.tag{position:absolute;z-index:7;font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
  padding:.4em .8em;border-radius:999px;background:rgba(10,32,16,.74);color:var(--paper);backdrop-filter:blur(4px);
  border:1px solid rgba(243,239,227,.16);white-space:nowrap}
.layer.pre  .tag{left:14px;bottom:14px}
.layer.post .tag{right:14px;bottom:14px}
.layer.classified .tag{left:14px;top:14px}

/* handle (slider only) */
.va-handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:var(--yellow);z-index:6;transform:translateX(-1px);cursor:ew-resize;display:none}
.va-handle .grip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:50%;background:var(--yellow);color:var(--ink);
  display:grid;place-items:center;box-shadow:0 6px 20px -6px rgba(0,0,0,.7);font:700 15px/1 var(--mono)}
.va-handle .grip::before{content:"\2039 \203A";letter-spacing:-3px}

/* ---- MODE: SLIDER ---- */
.mode-slider .va-handle{display:block}
.mode-slider .layer.post{inset:0;opacity:1}
.mode-slider .layer.pre{inset:0;opacity:1}      /* clipped via clip-path in JS */
.mode-slider .layer.classified{inset:0;opacity:0;pointer-events:none}
.mode-slider.show-class .layer.classified{opacity:1;pointer-events:auto}

/* ---- MODE: TRIPTYCH ---- */
.mode-triptych .layer{opacity:1!important;clip-path:none!important}
.mode-triptych .layer.pre       {inset:0 calc(66.666% + 5px) 0 0}
.mode-triptych .layer.post      {inset:0 calc(33.333% + 3px) 0 calc(33.333% + 3px)}
.mode-triptych .layer.classified{inset:0 0 0 calc(66.666% + 5px)}
.mode-triptych .layer .tag{left:14px!important;right:auto!important;bottom:14px!important;top:auto!important}
@media (max-width:680px){
  .mode-triptych .viewer-frame{aspect-ratio:3/4}
  .mode-triptych .layer.pre       {inset:0 0 calc(66.666% + 5px) 0}
  .mode-triptych .layer.post      {inset:calc(33.333% + 3px) 0 calc(33.333% + 3px) 0}
  .mode-triptych .layer.classified{inset:calc(66.666% + 5px) 0 0 0}
}

/* ---- MODE: SEQUENCE ---- */
.mode-sequence .layer{inset:0;opacity:0;clip-path:none!important;pointer-events:none}
.mode-sequence .layer.active{opacity:1;pointer-events:auto}

/* viewer toolbar */
.viewer-bar{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:18px}
.legend{display:flex;gap:18px;flex-wrap:wrap;font-family:var(--mono);font-size:.78rem;color:rgba(243,239,227,.82)}
.legend .it{display:inline-flex;align-items:center;gap:.5em}
.legend .sw{width:13px;height:13px;border-radius:3px;display:inline-block}
.view-toggle{display:inline-flex;gap:0;background:rgba(243,239,227,.08);border-radius:999px;padding:4px;border:1px solid rgba(243,239,227,.14)}
.view-toggle button{font-family:var(--mono);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:rgba(243,239,227,.7);
  background:transparent;border:0;padding:.5em 1em;border-radius:999px;cursor:pointer;transition:.2s}
.view-toggle button[aria-pressed=true]{background:var(--yellow);color:var(--ink);font-weight:600}

/* tiny note */
.mission-note{position:relative;z-index:2;margin-top:18px;font-family:var(--mono);font-size:.76rem;color:rgba(243,239,227,.55)}

/* ============================================================
   BENCHMARK STRIP
   ============================================================ */
.bench{padding:clamp(56px,8vw,96px) 0;background:var(--paper)}
.bench-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
@media (max-width:860px){.bench-grid{grid-template-columns:repeat(2,1fr);gap:34px}}
@media (max-width:480px){.bench-grid{grid-template-columns:1fr}}
.metric .num{font-family:var(--sans);font-weight:800;font-size:clamp(2.6rem,5vw,3.8rem);line-height:.9;letter-spacing:-.03em}
.metric .num small{font-size:.4em;font-weight:600;opacity:.5;margin-left:.1em}
.metric .lbl{font-family:var(--mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--forest);margin-top:14px}
.metric .sub{font-size:.92rem;color:color-mix(in oklab,var(--ink) 62%,transparent);margin-top:4px}
.metric .num.accent{color:var(--green)}
.bench-foot{margin-top:38px;display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:.82rem;color:var(--forest);flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:.5em;border:1px solid var(--line-strong);border-radius:999px;padding:.4em .9em}
.chip .dot{width:7px;height:7px;border-radius:50%;background:var(--green)}

/* ============================================================
   COVERAGE BAND — xView2 / xBD dataset reach
   ============================================================ */
.coverage{background:var(--forest-deep);color:var(--paper);position:relative;padding:clamp(64px,9vw,108px) 0;overflow:hidden}
.coverage::before{content:"";position:absolute;inset:0;pointer-events:none;background:
  radial-gradient(58% 78% at 88% -8%,rgba(242,197,61,.10),transparent 60%),
  radial-gradient(50% 60% at 4% 112%,rgba(63,163,77,.16),transparent 60%)}
.coverage>.wrap{position:relative;z-index:2}
.cov-head{display:flex;justify-content:space-between;align-items:flex-end;gap:clamp(30px,5vw,72px);flex-wrap:wrap}
.coverage h2{color:var(--paper);max-width:18ch}
.cov-head p{margin:0;color:rgba(243,239,227,.74);max-width:42ch;flex:0 0 auto;width:clamp(260px,32%,400px)}
.cov-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,40px);
  margin-top:clamp(40px,5vw,64px);padding-top:clamp(36px,4vw,52px);border-top:1px solid rgba(243,239,227,.16)}
.cs{display:flex;flex-direction:column}
.cs b{font-family:var(--sans);font-weight:800;font-size:clamp(2.8rem,5.4vw,4.2rem);line-height:.86;letter-spacing:-.03em;color:var(--yellow);display:inline}
.cs i{font-style:normal;font-weight:700;font-size:clamp(1.1rem,1.8vw,1.5rem);color:var(--yellow-soft);margin-left:.12em;letter-spacing:-.02em}
.cs span{font-family:var(--mono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(243,239,227,.72);margin-top:16px}
.cov-types{display:flex;flex-wrap:wrap;gap:12px;margin-top:clamp(34px,4vw,46px)}
.chip.on-dark{border-color:rgba(243,239,227,.28);color:rgba(243,239,227,.9);font-family:var(--mono);font-size:.82rem}
@media (max-width:860px){
  .cov-head p{width:auto;max-width:46ch}
  .cov-stats{grid-template-columns:repeat(2,1fr);gap:34px 24px}
}
@media (max-width:430px){
  .cov-stats{grid-template-columns:1fr 1fr}
}

/* ============================================================
   SECTION HEADERS
   ============================================================ */
.sec{padding:clamp(64px,9vw,120px) 0}
.sec-head{max-width:62ch;margin-bottom:54px}
.sec-head h2{margin:.3em 0 .4em}
.sec-head .lead{max-width:48ch}
/* features intro — heading left (fills the row), lead right to balance */
.feat-intro{max-width:none;display:flex;justify-content:space-between;align-items:flex-end;gap:clamp(32px,5vw,72px)}
.feat-intro-l{flex:1 1 auto;min-width:0}
.feat-intro-l .h2{margin-bottom:0}
.feat-intro .lead{flex:0 0 auto;width:clamp(260px,30%,360px);padding-bottom:.5em;border-left:1px solid var(--line);padding-left:clamp(20px,2.4vw,32px)}
@media (max-width:860px){
  .feat-intro{flex-direction:column;align-items:flex-start;gap:20px}
  .feat-intro .lead{width:auto;max-width:46ch;border-left:0;padding-left:0;padding-bottom:0}
}

/* ============================================================
   FEATURES — alternating editorial rows
   ============================================================ */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,86px);align-items:center;padding:clamp(40px,6vw,78px) 0;border-top:1px solid var(--line)}
.feature:nth-child(even) .feat-media{order:2}
@media (max-width:900px){.feature{grid-template-columns:1fr;gap:30px}.feature:nth-child(even) .feat-media{order:0}}
.feat-kicker{font-family:var(--mono);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
.feature h3{margin:.5em 0 .45em}
.feature p{color:color-mix(in oklab,var(--ink) 78%,transparent);max-width:46ch}
.feat-list{list-style:none;padding:0;margin:22px 0 0;display:flex;flex-direction:column;gap:12px}
.feat-list li{display:flex;gap:.7em;align-items:flex-start;font-size:1rem}
.feat-list li::before{content:"";flex:0 0 auto;width:18px;height:18px;margin-top:3px;border-radius:6px;
  background:var(--green);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.4z'/%3E%3C/svg%3E") center/14px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.4z'/%3E%3C/svg%3E") center/14px no-repeat}

/* media frames */
.media-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--card);border:1px solid var(--line);
  box-shadow:0 30px 70px -50px rgba(18,59,30,.7)}

/* full-width feature heads (inspect / speed) */
.inspect,.speed{padding-block:0 clamp(56px,8vw,96px)}
.inspect-head{display:flex;justify-content:space-between;align-items:flex-end;gap:clamp(30px,5vw,64px);flex-wrap:wrap;margin-bottom:30px}
.speed .inspect-head{border-top:1px solid var(--line);padding-top:clamp(40px,6vw,72px)}
.inspect-title h3{margin-top:.25em;max-width:20ch}
.inspect-right{max-width:50ch}
.inspect-right p{color:color-mix(in oklab,var(--ink) 78%,transparent);margin:0}

/* ---- inference speed ---- */
.rig{display:inline-flex;align-items:center;gap:.7em;margin-top:20px;font-size:.78rem;letter-spacing:.04em;
  color:var(--forest);border:1px solid var(--line-strong);border-radius:999px;padding:.5em 1.05em}
.rig-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px color-mix(in oklab,var(--green) 22%,transparent)}
.speed-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(18px,2.2vw,28px);margin-top:clamp(24px,3.4vw,40px)}
@media (max-width:860px){.speed-grid{grid-template-columns:1fr}}

.spdcard{background:var(--forest-deep);color:var(--paper);border-radius:var(--radius-lg);
  padding:clamp(26px,3vw,40px);border:1px solid rgba(243,239,227,.08);
  box-shadow:0 30px 70px -50px rgba(18,59,30,.7);display:flex;flex-direction:column}
.scene-top{display:flex;align-items:baseline;justify-content:space-between;gap:12px 18px;flex-wrap:wrap}
.scene-name{font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--yellow-soft);white-space:nowrap}
.scene-dim{font-size:.76rem;letter-spacing:.05em;color:rgba(243,239,227,.55)}
.scene-hero{margin-top:clamp(24px,3.4vw,40px)}
.wall{display:flex;align-items:baseline;gap:.1em;font-family:var(--sans);font-weight:800;letter-spacing:-.035em;line-height:.82}
.wall b{font-size:clamp(3.4rem,8vw,5.6rem)}
.wall i{font-style:normal;font-weight:700;color:var(--yellow);font-size:clamp(1.3rem,3vw,2rem)}
.scene-sub{display:block;font-size:.92rem;color:rgba(243,239,227,.6);margin-top:12px}
.scene-count{display:flex;align-items:baseline;gap:.55em;margin:clamp(20px,2.6vw,30px) 0;
  padding-top:clamp(18px,2.4vw,26px);border-top:1px solid rgba(243,239,227,.13)}
.scene-count b{font-family:var(--sans);font-weight:800;font-size:1.8rem;letter-spacing:-.02em}
.scene-count span{font-size:.85rem;color:rgba(243,239,227,.6)}
.tput{list-style:none;margin:auto 0 0;padding:0;display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;background:rgba(243,239,227,.1);border:1px solid rgba(243,239,227,.1);border-radius:14px;overflow:hidden}
.spdcard.wide-card .tput{grid-template-columns:repeat(4,1fr)}
@media (max-width:560px){.spdcard.wide-card .tput{grid-template-columns:repeat(2,1fr)}}
.tput li{background:var(--forest-deep);padding:15px 17px;display:flex;flex-direction:column;gap:4px}
.tput b{font-size:1.15rem;font-weight:600;letter-spacing:-.01em;color:var(--paper)}
.tput span{font-size:.68rem;letter-spacing:.07em;text-transform:uppercase;color:rgba(243,239,227,.5)}

/* UI screenshot windows */
.win{border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#e9e9ef;box-shadow:0 30px 70px -50px rgba(18,59,30,.7)}
.win-bar{display:flex;align-items:center;gap:7px;padding:9px 12px;background:#d8d8e0;border-bottom:1px solid rgba(0,0,0,.08)}
.win-bar .d{width:11px;height:11px;border-radius:50%}
.win-bar .d.r{background:#ec6a5e}.win-bar .d.y{background:#f4bf4f}.win-bar .d.g{background:#61c554}
.win-bar .t{margin-left:8px;font-size:.78rem;color:#555;font-family:var(--sans)}
.win img{width:100%;display:block;background:#fff}

/* ---- Branded plugin-panel illustrations (replace raw screenshots) ---- */
.ui{background:var(--card);padding:clamp(14px,1.5vw,20px);font-family:var(--sans);color:var(--ink);font-size:13.5px;line-height:1.35;
  background-image:radial-gradient(120% 90% at 100% 0,rgba(63,163,77,.05),transparent 55%)}
.ui-title{display:flex;align-items:center;gap:9px;font-weight:700;font-size:15px;letter-spacing:-.01em;margin-bottom:15px}
.ui-title .gico{width:20px;height:20px;border-radius:6px;background:var(--ink);color:var(--yellow);flex:0 0 auto;display:grid;place-items:center}
.ui-title .gico svg{width:13px;height:13px}
.ui-group{border:1px solid var(--line);border-radius:11px;padding:13px 13px 14px;margin-bottom:11px;
  background:color-mix(in oklab,var(--paper) 55%,#fff)}
.ui-group:last-child{margin-bottom:0}
.ui-legend{font-family:var(--mono);font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--green);margin-bottom:11px}
.ui-row{display:flex;align-items:center;gap:9px;margin-bottom:9px}
.ui-row:last-child{margin-bottom:0}
.ui-lbl{color:color-mix(in oklab,var(--ink) 68%,transparent);white-space:nowrap}
.ui-input{flex:1;min-width:0;background:#fff;border:1px solid var(--line-strong);border-radius:8px;padding:7px 11px;
  color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:8px;font-variant-numeric:tabular-nums}
.ui-input .ph{color:color-mix(in oklab,var(--ink) 38%,transparent)}
.ui-input .car{color:color-mix(in oklab,var(--ink) 40%,transparent);font-size:11px;flex:0 0 auto}
.ui-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;background:#fff;border:1px solid var(--line-strong);
  border-radius:8px;padding:8px 13px;font-weight:600;color:var(--ink);white-space:nowrap}
.ui-btn svg{width:14px;height:14px;flex:0 0 auto}
.ui-btn.full{width:100%}
.ui-btn.accent{background:var(--green);border-color:transparent;color:#fff}
.ui-btn.lg{padding:13px;font-size:14.5px}
.ui-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.ui-grid2{display:grid;grid-template-columns:1fr 1.4fr;gap:8px}
.ui-stack{display:flex;flex-direction:column;gap:8px}
.ui-check{display:flex;align-items:center;gap:10px;margin-bottom:10px;color:color-mix(in oklab,var(--ink) 84%,transparent)}
.ui-check:last-child{margin-bottom:0}
.ui-box{width:16px;height:16px;border-radius:5px;border:1.5px solid var(--line-strong);flex:0 0 auto;background:#fff}
.ui-box.on{background:var(--green);border-color:var(--green);position:relative}
.ui-box.on::after{content:"";position:absolute;inset:0;background:#fff;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.4z'/%3E%3C/svg%3E") center/12px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.4z'/%3E%3C/svg%3E") center/12px no-repeat}
.ui-slider{flex:1;height:6px;border-radius:3px;background:var(--line);position:relative}
.ui-slider .fill{position:absolute;left:0;top:0;bottom:0;width:50%;background:var(--green);border-radius:3px}
.ui-slider .knob{position:absolute;left:50%;top:50%;width:16px;height:16px;border-radius:50%;background:#fff;
  border:3px solid var(--green);transform:translate(-50%,-50%);box-shadow:0 2px 5px -1px rgba(18,59,30,.4)}
.ui-pct{font-family:var(--mono);font-size:12px;color:var(--forest);min-width:34px;text-align:right}

/* AOI svg demo */
.aoi-demo{position:relative;aspect-ratio:4/3;background:linear-gradient(135deg,#16401f,#0c2b15);overflow:hidden}

/* ============================================================
   COMPACT FEATURE GRID (the rest)
   ============================================================ */
.mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
@media (max-width:860px){.mini-grid{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.mini-grid{grid-template-columns:1fr}}
.mini{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;transition:transform .2s,box-shadow .2s,border-color .2s}
.mini:hover{transform:translateY(-3px);box-shadow:0 24px 50px -40px rgba(18,59,30,.7);border-color:var(--line-strong)}
.mini .ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;background:rgba(63,163,77,.14);color:var(--forest);margin-bottom:18px}
.mini .ic svg{width:22px;height:22px}
.mini h4{font-family:var(--sans);font-weight:700;font-size:1.12rem;margin:0 0 .4em}
.mini p{font-size:.95rem;color:color-mix(in oklab,var(--ink) 66%,transparent);margin:0}

/* ============================================================
   WORKFLOW
   ============================================================ */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
@media (max-width:860px){.flow{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.flow{grid-template-columns:1fr}}
.step{position:relative;padding-top:30px;border-top:2px solid var(--ink)}
.step .n{font-family:var(--mono);font-size:.8rem;color:var(--green);font-weight:600}
.step h4{font-family:var(--serif);font-weight:500;font-size:1.4rem;margin:.5em 0 .35em}
.step p{font-size:.95rem;color:color-mix(in oklab,var(--ink) 66%,transparent);margin:0}

/* ============================================================
   INSTALL
   ============================================================ */
.install{background:var(--forest-deep);color:var(--paper);position:relative;overflow:hidden}
.install::before{content:"";position:absolute;right:-10%;top:-30%;width:60%;height:160%;
  background:radial-gradient(circle,rgba(242,197,61,.12),transparent 62%);pointer-events:none}
.install .grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center;position:relative;z-index:2}
@media (max-width:900px){.install .grid{grid-template-columns:1fr;gap:40px}}
.install h2{color:var(--paper)}
.install .lead{color:rgba(243,239,227,.74)}
.code{font-family:var(--mono);font-size:.92rem;background:rgba(10,32,16,.6);border:1px solid rgba(243,239,227,.16);
  border-radius:14px;padding:22px 24px;color:rgba(243,239,227,.92);line-height:1.9}
.code .cmt{color:rgba(167,205,161,.8)}
.code ol{margin:0;padding-left:1.3em}
.code li{margin:.2em 0}
.code li::marker{color:var(--yellow)}
.install-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--paper);padding:64px 0 40px;border-top:1px solid var(--line)}
.foot-grid{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start}
.foot .brand{font-size:1.3rem}
.foot p{max-width:34ch;color:color-mix(in oklab,var(--ink) 62%,transparent);font-size:.95rem;margin:.8em 0 0}
.foot-links{display:flex;gap:60px;flex-wrap:wrap}
.foot-col h5{font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--forest);margin:0 0 14px}
.foot-col a{display:block;font-size:.96rem;color:color-mix(in oklab,var(--ink) 76%,transparent);margin:9px 0;transition:color .2s}
.foot-col a:hover{color:var(--ink)}
.foot-bottom{margin-top:48px;padding-top:22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  font-family:var(--mono);font-size:.78rem;color:color-mix(in oklab,var(--ink) 55%,transparent)}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* selection */
::selection{background:var(--yellow);color:var(--ink)}
