/* ====== Tokens ====== */
:root{
  --bg:#0f1216; --surface:#161a20; --text:#e5e7eb; --muted:#9aa4b2; --border:#242a33;
  --accent:#17A1A8; --accent-2:#24E5F5;

  --font-heading:"Inter",system-ui,sans-serif;
  --font-body:"Inter",system-ui,sans-serif;

  --grain-a:0; --grid-a:0; --mesh-a:0; --scan-a:0; --dots-a:0; --stripes-a:0; --vig-a:0;

  --radius:16px;
  --shadow-1:0 10px 28px rgba(0,0,0,.16);
  --shadow-2:0 18px 60px rgba(0,0,0,.28);
}

*{ box-sizing:border-box; }
html,body{ margin:0; }
html, body { width:100%; max-width:100%; overflow-x:hidden; }
a{ color:inherit; text-decoration:none; }
body{ background:var(--bg); color:var(--text); font-family:var(--font-body); transition:background .5s,color .5s; }

/* Fluid container – never exceed viewport width */
.wrap{
  width:min(1200px,100%);
  margin-inline:auto;
  display:flex; align-items:center; gap:16px;
  padding-inline: clamp(12px, 4vw, 24px);
}

/* ====== Header + step banner ====== */
.site-header{
  position:sticky; top:0; z-index:1000;
  background: color-mix(in oklab, var(--bg), transparent 10%);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
}
.site-header .wrap{ padding:12px 0; gap:18px; }
.brand{ font-weight:900; letter-spacing:-.02em; white-space:nowrap; }

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:12px; padding:10px 14px; font-weight:800;
  transition: transform .08s, box-shadow .2s, border-color .2s;
}
.btn-primary{ background:var(--accent); color:#fff; box-shadow:var(--shadow-1); }
.btn-primary:hover{ transform:translateY(-1px); box-shadow:var(--shadow-2); }
.btn-secondary{ border:2px solid color-mix(in oklab, var(--accent), var(--border) 65%); color:var(--accent); }
.btn-secondary:hover{ border-color:var(--accent); transform:translateY(-1px); }
.btn-secondary.light{ border-color: rgba(255,255,255,.75); color:#fff; }

.step-nav{ flex:1 1 auto; }
.step-nav ol{ list-style:none; margin:0; padding:0; display:flex; justify-content:center; gap: clamp(6px,1.8vw,22px); }
.step-nav li{ display:flex; align-items:center; gap:8px; }
.step-nav li::before{
  content:""; width:8px; height:8px; border-radius:999px;
  background: color-mix(in oklab, var(--text), transparent 60%);
  transition: background .25s, transform .25s;
}
.step-nav li.is-active::before{ background:var(--accent); transform:scale(1.25); }
.step-nav button{
  background:transparent; border:none;
  color: color-mix(in oklab, var(--text), transparent 15%);
  font-weight:700; font-size:.9rem; cursor:pointer; padding:6px 0;
}
.step-nav li.is-active button{ color: var(--text); }

.step-banner{
  position: sticky;
  top: var(--hdr);
  z-index:900;
  background: color-mix(in oklab, var(--bg), transparent 6%);
  border-bottom:1px solid color-mix(in oklab, var(--border), transparent 35%);
  backdrop-filter: blur(6px);
}
.sb-inner{ width:min(1200px,100%); margin-inline:auto; padding:10px 0; gap:10px; display:flex; align-items:center; }
.sb-step{ font-weight:900; letter-spacing:-.02em; }
.sb-sep{ opacity:.5; }
.sb-desc{ color:var(--muted); }

/* ====== Background overlays ====== */
#stars{ position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.8; }
.bg-overlays>*{ position:fixed; inset:0; z-index:0; pointer-events:none; }
.bg-grain{ opacity:var(--grain-a); background-image:url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAgAAAAICAYAAADED76LAAAAMUlEQVQYV2NkwA7+Z2BgYGB4wMDA8J8B8c9gYGBg+M8gEw0MQ8QYxgYGBrgYg4oGAAy8wP8c0wJywAAAABJRU5ErkJggg=='); mix-blend-mode:overlay; }
.bg-grid{ opacity:var(--grid-a); background-image:linear-gradient(to right, rgba(36,243,238,.22) 1px, transparent 1px),linear-gradient(to bottom, rgba(36,243,238,.22) 1px, transparent 1px); background-size:36px 36px; animation:gridPan 30s linear infinite; }
@keyframes gridPan { to { background-position:200px 120px; } }
.bg-mesh{ opacity:var(--mesh-a); background: radial-gradient(60% 60% at 20% 30%, rgba(23,161,168,.38), transparent 60%), radial-gradient(50% 50% at 80% 70%, rgba(36,229,245,.28), transparent 60%), radial-gradient(40% 50% at 50% 10%, rgba(124,58,237,.18), transparent 70%); filter:blur(18px); }
.bg-scanlines{ opacity:var(--scan-a); background-image: repeating-linear-gradient(to bottom, rgba(255,255,255,.12), rgba(255,255,255,.12) 1px, transparent 2px, transparent 4px); mix-blend-mode: overlay; }
.bg-dots{ opacity:var(--dots-a); background: radial-gradient(circle at 10% 20%, rgba(0,0,0,.05) 2px, transparent 3px), radial-gradient(circle at 40% 60%, rgba(0,0,0,.05) 2px, transparent 3px), radial-gradient(circle at 70% 30%, rgba(0,0,0,.05) 2px, transparent 3px), radial-gradient(circle at 90% 80%, rgba(0,0,0,.05) 2px, transparent 3px); background-size:120px 120px; }
.bg-stripes{ opacity:var(--stripes-a); background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.08) 0 10px, transparent 10px 24px); }
.bg-vignette{ opacity:var(--vig-a); background: radial-gradient(60% 60% at 50% 50%, transparent 60%, rgba(0,0,0,.5) 100%); }

/* ====== Story container ====== */
.story{ position:relative; }
.story-sticky{
  position: relative; top:auto; min-height:0; z-index:1;
  display:grid; place-items:center;
}

/* Fill container width (no 100vw spill) */
.scene-wrap{ position:relative; width:100%; min-height:76vh; max-width:100%; }

/* ====== Scene base ====== */
.scene{
  position:absolute; inset:0;
  display:grid; place-content:center; text-align:left;
  padding: clamp(16px,4vw,28px);
  background: color-mix(in oklab, var(--surface), transparent 78%);
  border:1px solid color-mix(in oklab, var(--border), transparent 60%);
  border-radius: var(--radius);
  box-shadow: 0 12px 48px rgba(0,0,0,.10);
  max-width:100%;
  overflow:hidden;
}

/* ====== Mini-site frame ====== */
.site{
  position:relative;
  background: var(--site-surface, var(--surface));
  color: var(--site-text, var(--text));
  border:1px solid var(--site-border, var(--border));
  border-radius: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.22);
  overflow:hidden;
  padding-bottom: 10px;
  width:100%; /* stick to parent width */
}
.site-wipe{ position:absolute; inset:0; background: var(--site-surface, var(--surface)); transform-origin: left; }

/* ====== Shared mini-site layout ====== */
.mini-header{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding: 14px 18px;
  border-bottom: 1px solid color-mix(in oklab, var(--site-border, var(--border)), transparent 40%);
  background: color-mix(in oklab, var(--site-surface, var(--surface)), transparent 6%);
}
.mini-logo{ font-weight:900; letter-spacing:-.02em; }
.mini-logo.serif{ font-family:"Playfair Display", serif; font-weight:700; }
.mini-logo.fancy{ font-family:"Syne", system-ui, sans-serif; font-weight:800; letter-spacing:.01em; }
.mini-nav{ display:flex; gap:14px; flex-wrap:wrap; }
.mini-nav a{ color: color-mix(in oklab, var(--site-text, var(--text)), transparent 25%); font-weight:600; white-space:nowrap; }
.mini-cta{ border-radius:10px; padding:8px 12px; font-weight:800; border:1px solid color-mix(in oklab, var(--accent), var(--border) 60%); background: color-mix(in oklab, var(--surface), transparent 0%); color: var(--accent); }
.mini-cta.warm{ background:#e07a5f; border-color:#e07a5f; color:#fff; }

.mini-hero{
  display:grid; grid-template-columns: 1.1fr .9fr; gap: 16px;
  padding: 16px 18px 6px;
}
.hero-copy h1{ margin:.1rem 0 .25rem; font-size: clamp(1.6rem, 3.4vw, 2.2rem); font-family: var(--font-heading); font-weight:900; }
.hero-copy p{ margin:.25rem 0 .6rem; color: color-mix(in oklab, var(--site-text, var(--text)), transparent 25%); }
.btn-row{ display:flex; gap:10px; flex-wrap:wrap; }

.hero-media{
  position:relative; min-height: 180px;
  border: 1px solid color-mix(in oklab, var(--site-border, var(--border)), transparent 40%);
  border-radius:14px; overflow:hidden; max-width:100%;
}

/* ====== Grids ====== */
.mini-grid.three{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 12px; padding: 10px 18px; }
.tile{ border-radius:14px; padding:12px; border:1px solid color-mix(in oklab, var(--site-border, var(--border)), transparent 40%); background: color-mix(in oklab, var(--site-surface, var(--surface)), transparent 4%); }
.tile h3{ margin:.2rem 0 .15rem; font-size:1.02rem; }
.tile p{ margin:0; color: color-mix(in oklab, var(--site-text, var(--text)), transparent 25%); }

/* ====== Split section ====== */
.mini-split{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; padding: 10px 18px; }
.hours-card,.map-card{ border-radius:14px; padding:12px; }
.map-faux{ height:120px; border-radius:10px; background: repeating-linear-gradient(45deg, #f2d8c6 0 8px, #ffeedd 8px 16px); opacity:.6; }

.mini-footer{
  border-top:1px solid color-mix(in oklab, var(--site-border, var(--border)), transparent 40%);
  padding:10px 18px; font-size:.9rem;
  color: color-mix(in oklab, var(--site-text, var(--text)), transparent 40%);
}

/* ====== Theme-specific looks ====== */
/* TECH */
.site-tech{ --site-surface:#12161c; --site-text:#e6f7ff; --site-border:#1b2230; }
.terminal{ background: #0b0f15; color:#bfeaff; box-shadow: inset 0 0 0 1px #1b2230; }
.term-title{ font-size:.85rem; padding:8px 10px; border-bottom:1px solid #1b2230; background: linear-gradient(90deg,#0d1218,#0b0f15); }
.term-body{ padding:10px; display:grid; gap:6px; }
.tile.glow{ background: linear-gradient(155deg, rgba(18,22,28,.74), rgba(14,18,24,.66)); border-color: rgba(18,243,224,.25); box-shadow: 0 0 0 1px rgba(18,243,224,.15), 0 18px 60px rgba(0,0,0,.36); color:#e5feff; }

/* BAKERY */
.site-bakery{ --site-surface:#fff7ef; --site-text:#5a4636; --site-border:#f2d8c6; }
.tile.paper{ background:#fff6ee; border:1px solid #f2d8c6; box-shadow: 6px 6px 0 #f0c59f, 0 6px 24px rgba(160,110,70,.14); color:#5a4636; }
.sticker{ position:relative; }
.sticker::before{ content:"★"; position:absolute; right:-8px; top:-8px; transform:rotate(-12deg); background:#ffde8a; border:1px solid #e7c35f; color:#6b4d00; padding:4px 6px; border-radius:8px; font-weight:800; font-size:.8rem; }
.hero-media.pastry{ background: radial-gradient(circle at 30% 40%, #ffe1c6 0 40%, transparent 41%), radial-gradient(circle at 70% 65%, #ffd6d6 0 34%, transparent 35%); }
.pastry-circle{ position:absolute; width:120px; height:120px; border-radius:999px; background: radial-gradient(circle at 40% 40%, #ffdd99, #f4a261); left: 26px; top: 26px; box-shadow: inset -8px -10px 0 #e89055; }
.pastry-chip{ position:absolute; width:18px; height:18px; border-radius:999px; background:#7a4b2b; left: 126px; top: 66px; box-shadow: 18px -8px 0 #7a4b2b, -16px 10px 0 #7a4b2b; }
.pastry-shadow{ position:absolute; width:140px; height:22px; border-radius:999px; background:rgba(0,0,0,.15); filter:blur(10px); left:20px; bottom: 18px; }

/* CORPORATE */
.site-corporate{ --site-surface:#ffffff; --site-text:#0f172a; --site-border:#e5e7eb; }
.tile.outline.corp{ background:#fff; border-color:#e5e7eb; box-shadow:none; }
.hero-media.stats{ display:grid; gap:8px; background: linear-gradient(180deg, #f8fafc, #ffffff); }
.stat{ padding:10px; border:1px solid #e5e7eb; border-radius:10px; }
.stat span{ display:block; font-weight:900; font-size:1.1rem; }

/* ARTIST */
.site-artist{ --site-surface:#10161d; --site-text:#f4fbff; --site-border:#1c2732; }
.hero-media.prism{ background: conic-gradient(from 180deg, #ff8a21, #f72585, #7209b7, #3a86ff, #00f5d4, #ff8a21); filter: saturate(120%) contrast(105%); }
.tile.prism{ position:relative; overflow:hidden; color:#08131a; background:#ffffff; border:1px solid transparent; }
.tile.prism::before{ content:""; position:absolute; inset:-2px; background: conic-gradient(from 180deg, #ff8a21, #f72585, #7209b7, #3a86ff, #00f5d4, #ff8a21); filter: blur(6px); opacity:.85; -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; padding:2px; border-radius:15px; }

/* SAAS */
.site-saas{ --site-surface:#0f172a; --site-text:#cfe3ff; --site-border:#19304b; }
.hero-media.dashboard{ display:grid; grid-template-columns: 1fr 1fr; gap:10px; background: linear-gradient(180deg, #0f172a, #0b1220); }
.chart{ height:120px; border-radius:10px; background: linear-gradient(90deg, rgba(34,211,238,.3), rgba(96,165,250,.3)); }
.table .row{ height:24px; border-radius:6px; background: rgba(255,255,255,.08); margin:6px 0; }

/* CINEMATIC */
.site-cinematic{ --site-surface:#0d1117; --site-text:#e6f0ff; --site-border:#152033; }
.hero-media.rocket{ background: radial-gradient(circle at 50% 80%, rgba(58,180,255,.18), transparent 60%); position:relative; }
.rocket .body{ position:absolute; left:50%; top:30%; transform:translate(-50%,-50%); width:40px; height:90px; background:#e6f0ff; border-radius:20px 20px 6px 6px; }
.rocket .fin{ position:absolute; top:55%; width:22px; height:18px; background:#93c5fd; }
.rocket .fin-l{ left: calc(50% - 30px); clip-path: polygon(0 0, 100% 100%, 0 100%); }
.rocket .fin-r{ left: calc(50% + 8px); clip-path: polygon(100% 0, 0 100%, 100% 100%); }
.rocket .flame{ position:absolute; left:50%; top:78%; transform:translateX(-50%); width:16px; height:26px; border-radius:999px; background: radial-gradient(circle at 50% 30%, #ffd166, #ef476f); filter: blur(1px); }
.tile.elevate{ background: color-mix(in oklab, var(--site-surface), transparent 8%); border:1px solid color-mix(in oklab, var(--site-border), transparent 35%); box-shadow: 0 18px 60px rgba(0,0,0,.28); }

/* ECO */
.site-eco{ --site-surface:#f7fbf8; --site-text:#0f2a1f; --site-border:#cfe3d9; }
.tile.neumo{ background:#eef6f2; color:#1f2937; border:none; box-shadow:10px 10px 24px #cfe3d9, -10px -10px 24px #ffffff; }
.hero-media.leaf{ background: linear-gradient(180deg, #f7fbf8, #ecf7f1); }
.leaf .stem{ position:absolute; left:50%; top:20%; width:6px; height:120px; background:#0ea5a8; border-radius:6px; transform:translateX(-50%); }
.leaf .leaf1,.leaf .leaf2{ position:absolute; width:120px; height:70px; background:#10b981; border-radius:120px 120px 0 120px; filter: drop-shadow(0 6px 12px rgba(0,0,0,.1)); }
.leaf .leaf1{ left: calc(50% - 16px); top: 26%; transform: rotate(28deg); }
.leaf .leaf2{ left: calc(50% - 104px); top: 52%; transform: rotate(208deg); }

/* CTA (Start) */
.site-cta{ --site-surface: linear-gradient(120deg, var(--accent), var(--accent-2)); color:#fff; border-color: transparent; }
.cta-wrap{ max-width: 760px; margin: 0 auto; text-align: center; padding: 36px 26px; }
.scene-h1{ font-weight: 900; letter-spacing: -0.02em; font-size: clamp(1.6rem, 3.4vw, 2.2rem); margin: 0 0 .35rem; }
.scene-sub{ opacity: .92; margin: .25rem 0 1rem; }
.scene-cta .btn{ margin: 0 .4rem; }

/* Tilt */
.tilt{ will-change: transform; transform-style: preserve-3d; }

/* Desktop layout tweaks */
@media (max-width:900px){
  .mini-hero{ grid-template-columns: 1fr; }
  .mini-grid.three{ grid-template-columns: 1fr; }
  .mini-split{ grid-template-columns:1fr; }
}

/* ===== Dot Nav ===== */
.dot-nav{
  position: fixed;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 900;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.dot-nav .dot-btn{
  width: 30px; height: 30px; display: grid; place-items: center;
  border-radius: 999px; border: 1px solid var(--border);
  background: color-mix(in oklab, var(--bg), transparent 20%);
  cursor: pointer; transition: transform .15s, background .2s, border-color .2s;
}
.dot-nav .dot-btn:hover{ transform: translateY(-1px); }
.dot-nav .dot-btn.up::before,
.dot-nav .dot-btn.down::before{
  content:""; width:0; height:0; border-left:6px solid transparent; border-right:6px solid transparent;
}
.dot-nav .dot-btn.up::before{ border-bottom:8px solid var(--text); }
.dot-nav .dot-btn.down::before{ border-top:8px solid var(--text); }
.dot-nav .dot-list{
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.dot-nav .dot{
  width:10px; height:10px; border-radius:999px;
  border:2px solid color-mix(in oklab, var(--text), transparent 55%);
  background:transparent; opacity:.75;
  cursor:pointer; transition: transform .15s, background .2s, opacity .2s, border-color .2s;
}
.dot-nav .dot.is-active{ background:var(--accent); border-color:var(--accent); opacity:1; }
@media (max-width:640px){
  .dot-nav{
    right:8px; bottom:12px; top:auto; transform:none;
    flex-direction:row; gap:8px;
    background: color-mix(in oklab, var(--bg), transparent 24%);
    border:1px solid var(--border); border-radius:9999px;
    padding:6px 8px; backdrop-filter: blur(8px);
  }
  .dot-nav .dot-list{ flex-direction:row; gap:8px; }
  .dot-nav .dot-btn{ display:none; }
  .dot-nav .dot{ width:8px; height:8px; }
}

/* ===== Card variants ===== */
.tile.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.18);
  box-shadow: 0 10px 32px rgba(0,0,0,.28), inset 0 0 0 1px rgba(255,255,255,.06);
  backdrop-filter: blur(8px);
}
.tile.term{
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  background: #0b0f15; color:#bfeaff; border-color:#1b2230;
  box-shadow: inset 0 0 0 1px #162030, 0 16px 40px rgba(0,0,0,.38);
  position:relative;
}
.tile.term::before{
  content:""; position:absolute; left:0; top:0; right:0; height:28px;
  background: linear-gradient(90deg,#0d1218,#0b0f15); border-bottom:1px solid #182234;
}
.tile.term::after{
  content:"●  ●  ●"; position:absolute; left:10px; top:2px; font-size:14px; letter-spacing:4px; color:#3aaed9; opacity:.6;
}
.tile.torn{
  background:#fff6ee; border:1px solid #f2d8c6;
  box-shadow: 6px 6px 0 #f0c59f, 0 6px 24px rgba(160,110,70,.14);
  position:relative;
  --rip: radial-gradient(12px 12px at 12px 12px, transparent 12px, #fff6ee 13px);
  -webkit-mask: var(--rip) 0 0 / 24px 24px repeat-x, linear-gradient(#000 0 0) content-box;
  mask-composite: add;
  padding-top:18px;
}
.tile.tape::before{
  content:""; position:absolute; top:-10px; left:14px; width:74px; height:22px;
  background: repeating-linear-gradient(45deg, rgba(255,248,200,.9) 0 6px, rgba(255,241,170,.9) 6px 12px);
  border:1px solid rgba(170,140,60,.35); box-shadow: 0 2px 6px rgba(100,80,40,.2);
  transform: rotate(-6deg); mix-blend-mode:multiply; border-radius:4px;
}
.tile.notch{ background:#fff; border:1px solid #e5e7eb; box-shadow:none; position:relative; }
.tile.notch::after{ content:""; position:absolute; top:0; right:0; width:22px; height:22px; background: linear-gradient(135deg, transparent 50%, #e5e7eb 51% 100%); }
.tile.ribbon{ position:relative; }
.tile.ribbon::before{
  content:attr(data-ribbon);
  position:absolute; top:10px; left:-6px;
  background:#2563eb; color:#fff; font-weight:800; font-size:.72rem;
  padding:4px 10px; border-radius:4px; box-shadow:0 6px 14px rgba(37,99,235,.25);
}
.tile.stroke{ position:relative; color:#08131a; background:#ffffff; border:1px solid transparent; }
.tile.stroke::before{
  content:""; position:absolute; inset:-2px;
  background: conic-gradient(from 180deg, #ff8a21, #f72585, #7209b7, #3a86ff, #00f5d4, #ff8a21);
  filter: blur(8px); opacity:.9;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding:2px; border-radius:15px;
}
.tile.scribble{ background:#fff; border:2px dashed #111827; box-shadow: 0 10px 28px rgba(0,0,0,.12); position:relative; }
.tile.scribble::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(12px 6px at 10% 12%, rgba(0,0,0,.08), transparent 60%),
             radial-gradient(6px 3px at 80% 80%, rgba(0,0,0,.06), transparent 60%);
  mix-blend-mode:multiply; opacity:.7; border-radius:inherit;
}
.tile.glass-dark{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  border:1px solid rgba(96,165,250,.22);
  box-shadow: 0 18px 60px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.04);
  backdrop-filter: blur(10px);
}
.tile.mono{
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  background: linear-gradient(180deg,#0f172a,#0b1220);
  border:1px dashed rgba(207,227,255,.28);
  color:#cfe3ff;
}
.tile.film{ background: linear-gradient(180deg, #0d1117, #0a0e14); border:1px solid #152033; position:relative; box-shadow: 0 18px 60px rgba(0,0,0,.35); }
.tile.film::before{
  content:""; position:absolute; inset:0;
  background: repeating-linear-gradient(to bottom, rgba(255,255,255,.06) 0 1px, transparent 2px 4px);
  mix-blend-mode:overlay; opacity:.25; pointer-events:none; border-radius: inherit;
}
.tile.aperture{ background: radial-gradient(120% 120% at 50% 20%, rgba(58,180,255,.18), transparent 60%), #0b0f15; border:1px solid #1b2433; box-shadow: 0 18px 60px rgba(0,0,0,.38); }
.tile.fiber{
  background: radial-gradient(circle at 20% 30%, rgba(34,197,94,.08), transparent 60%),
              repeating-linear-gradient(0deg, #eef6f2, #eef6f2 8px, #f6fbf8 8px, #f6fbf8 16px);
  border:1px solid #cfe3d9; box-shadow: 10px 10px 24px #cfe3d9, -10px -10px 24px #ffffff;
}
.tile.seed::after{
  content:""; position:absolute; right:10px; top:10px; width:12px; height:18px;
  background: radial-gradient(80% 60% at 50% 40%, #10b981, #0ea5a8);
  border-radius:10px 10px 10px 2px / 14px 14px 6px 2px; box-shadow: 0 2px 0 rgba(0,0,0,.06);
}
.tile.glass:hover, .tile.glass-dark:hover{ transform: translateY(-2px); }
.tile.term:hover{ box-shadow: inset 0 0 0 1px #1b2230, 0 22px 60px rgba(0,0,0,.46); }
.tile.torn:hover{ transform: rotate(-.2deg) translateY(-1px); }
.tile.notch:hover{ transform: translateY(-2px); }
.tile.stroke:hover{ transform: translateY(-1px) scale(1.01); }
.tile.scribble:hover{ transform: rotate(.2deg) translateY(-1px); }
.tile.film:hover{ transform: translateY(-2px); }
.tile.fiber:hover{ transform: translateY(-2px); }

@media (prefers-reduced-motion: reduce){
  .tile:hover{ transform:none!important; }
}

/* Optional: tweak radius by theme */
body[data-theme="tech"] .tile{ border-radius:12px; }
body[data-theme="corporate"] .tile{ border-radius:10px; }
body[data-theme="artist"] .tile{ border-radius:16px; }
body[data-theme="cinematic"] .tile{ border-radius:14px; }
body[data-theme="eco"] .tile{ border-radius:18px; }

/* ===== Performance/lighten ===== */
.site-wipe { display: none !important; }
.bg-mesh { filter: blur(8px) !important; opacity: .12 !important; }
.scene:not(.is-active){
  content-visibility:auto;
  contain-intrinsic-size: 900px 700px;
}
.scene .site{ box-shadow: 0 8px 24px rgba(0,0,0,.14) !important; }

@media (max-width:900px){
  .site-header{
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
    background: color-mix(in oklab, var(--surface), #000 6%) !important;
  }
}

/* ----- Mobile Snap/Swipe (no pinning) ----- */
@media (pointer: coarse){
  /* JS sets inline width:100vw on swipe wrapper; clamp it to container width */
  html.m-swipe .scene-wrap[data-swipe="1"]{
    width:100% !important;
    max-width:100%;
    margin:0;
    padding:0 12px 12px;
    overflow-x:auto; overflow-y:visible;
  }
  /* JS sets minWidth: calc(100vw - 24px); replace with container-based width */
  html.m-swipe .scene-wrap[data-swipe="1"] .scene{
    position:relative !important; inset:auto !important; transform:none !important; opacity:1 !important;
    flex:0 0 auto; min-width: calc(100% - 24px) !important;
    height: calc(100dvh - var(--hdr) - var(--sb));
    scroll-snap-align:start; margin:0;
    max-width:100%;
  }
}

/* === Mobile header + hamburger === */
.hamburger{
  display:none; position:relative; width:36px; height:32px;
  border:1px solid var(--border); border-radius:10px; background:transparent; cursor:pointer;
}
.hamburger .bar{ position:absolute; left:7px; right:7px; height:2px; background: var(--text); top:9px; }
.hamburger .bar:nth-child(2){ top:15px; }
.hamburger .bar:nth-child(3){ top:21px; }

/* Drawer */
.step-nav-mobile{
  display:none;
  position:fixed; left:0; right:0; top:var(--hdr); bottom:0; z-index:1100;
  background: color-mix(in oklab, var(--bg), #000 12%);
  backdrop-filter: blur(10px);
  border-top: 1px solid var(--border);
  padding: 12px 16px 28px;
}
.step-nav-mobile ol{ list-style:none; margin:0; padding:0; display:grid; gap:10px; }
.step-nav-mobile li{
  display:flex; align-items:center; gap:10px; padding:10px 12px;
  border:1px solid var(--border); border-radius:12px;
  background: color-mix(in oklab, var(--surface), transparent 10%);
}
.step-nav-mobile li.is-active{
  border-color: var(--accent);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--accent), transparent 65%);
}
.step-nav-mobile button{
  background:none; border:0; color:var(--text);
  font-weight:800; font-size:1rem; text-align:left; width:100%;
}

/* Open state */
body.menu-open .step-nav-mobile{ display:block; }
body.menu-open{ overflow:hidden; }

/* Reorder on small screens: Brand | … | Get Started | Hamburger */
@media (max-width: 768px){
  .step-nav{ display:none; }
  .hamburger{ display:inline-flex; align-items:center; justify-content:center; }

  .site-header .wrap{ display:flex; align-items:center; gap:12px; }
  .site-header .brand{ order: 1; }
  /* desktop strip hidden anyway */
  .step-nav{ order: 2; }

  /* ensure "Get started" pushes to the right edge */
  .site-header .btn.btn-primary{ order: 3; margin-left:auto; }
  /* hamburger comes immediately AFTER the button, tight to its right */
  .site-header .hamburger{ order: 4; margin-left:8px; }
}

/* === Mobile sizing polish === */
@media (max-width: 768px){
  .scene{ padding:10px; max-width:100%; }
  .site{ border-radius:14px; width:100%; }
  .mini-header{ padding:10px 12px; gap:10px; }
  .mini-nav a{ font-size:.95rem; }
  .mini-cta{ padding:7px 10px; font-size:.9rem; }

  .mini-hero{ padding:12px; grid-template-columns:1fr; }
  .hero-copy h1{ font-size: clamp(1.15rem, 5.5vw, 1.5rem); }
  .hero-copy p{ font-size:.95rem; line-height:1.35; }
  .btn{ padding:9px 12px; font-size:.92rem; }

  .mini-grid.three{ grid-template-columns:1fr; gap:10px; padding:8px 12px; }
  .mini-split{ grid-template-columns:1fr; gap:10px; padding:8px 12px; }
}

/* Prefer small viewport height to avoid URL-bar jumps */
@supports (height: 100svh){
  .m-swipe .scene-wrap[data-swipe="1"] .scene{
    height: calc(100svh - var(--hdr) - var(--sb));
  }
}

/* Desktop breathing room under sticky header */
@media (pointer:fine){
  .scene{ margin-top: calc(var(--hdr) + 8px); }
}

/* Safety: never exceed container width */
.scene, .site, .mini-header, .mini-hero, .mini-grid.three, .mini-split { max-width: 100%; }
