:root{
  --room:      #111319;
  --room-2:    #161922;
  --room-3:    #1c2029;
  --ink:       #ECE6D9;
  --ink-dim:   #9A9EA8;
  --ink-faint: #5A5E68;
  --glow:      #F2A65A;
  --glow-2:    #F6C083;
  --line:      rgba(236,230,217,0.09);
  --line-2:    rgba(236,230,217,0.05);
  --maxw:      1100px;
  --pad:       clamp(22px, 5vw, 64px);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body{
  background:var(--room);
  color:var(--ink);
  font-family:"Hanken Grotesk", system-ui, sans-serif;
  font-size:18px;
  line-height:1.65;
  font-weight:400;
  letter-spacing:0.005em;
  overflow-x:hidden;
  position:relative;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

/* faint film grain so the dark room has texture, not flat banding */
body::before{
  content:"";
  position:fixed; inset:0;
  z-index:1;
  pointer-events:none;
  opacity:0.035;
  background-image:url("../img/grain.svg");
}

.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); position:relative; z-index:2; }

a{ color:inherit; }

/* ---------- mono utility label ---------- */
.eyebrow{
  font-family:"JetBrains Mono", monospace;
  font-size:12px;
  font-weight:500;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--glow);
  display:inline-flex;
  align-items:center;
  gap:0.7em;
}
.eyebrow::before{
  content:"";
  width:7px; height:7px; border-radius:50%;
  background:var(--glow);
  box-shadow:0 0 10px 1px var(--glow);
}

h1,h2,h3{
  font-family:"Fraunces", Georgia, serif;
  font-weight:500;
  line-height:1.04;
  letter-spacing:-0.01em;
}

/* ---------- nav ---------- */
nav{
  position:relative; z-index:3;
  display:flex; align-items:center; justify-content:space-between;
  padding-top:26px; padding-bottom:26px;
}
.mark{
  font-family:"Fraunces", serif;
  font-weight:600;
  font-size:22px;
  letter-spacing:-0.01em;
  display:inline-flex; align-items:center; gap:9px;
}
.mark .lens{
  width:13px; height:13px; border-radius:50%;
  background:radial-gradient(circle at 35% 35%, var(--glow-2), var(--glow) 55%, #8a5418 100%);
  box-shadow:0 0 14px 1px rgba(242,166,90,0.55);
  flex:none;
}
.nav-link{
  font-family:"JetBrains Mono", monospace;
  font-size:13px; letter-spacing:0.04em;
  text-decoration:none;
  color:var(--ink-dim);
  border:1px solid var(--line);
  padding:8px 15px;
  border-radius:999px;
  transition:color .25s ease, border-color .25s ease, background .25s ease;
}
.nav-link:hover{ color:var(--ink); border-color:rgba(242,166,90,0.5); background:rgba(242,166,90,0.06); }

/* ---------- hero ---------- */
.hero{
  position:relative;
  padding-top:clamp(70px,13vh,150px);
  padding-bottom:clamp(80px,14vh,170px);
  text-align:center;
}
/* the screen-glow signature: a warm light blooming in the dark room */
.screen-glow{
  position:absolute;
  left:50%; top:50%;
  width:min(920px,96vw); height:520px;
  transform:translate(-50%,-50%);
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(60% 58% at 50% 50%, rgba(246,192,131,0.20), rgba(242,166,90,0.10) 42%, rgba(242,166,90,0) 72%);
  filter:blur(14px);
  animation:breathe 9s ease-in-out infinite;
}
/* the screen: a bordered box that hugs the headline, so it always fits */
.screen-frame{
  position:relative;
  z-index:1;
  max-width:min(680px,86vw);
  margin:0 auto;
  padding:clamp(34px,5vw,54px) clamp(28px,5vw,60px) clamp(40px,5.5vw,58px);
  border:1px solid rgba(246,192,131,0.16);
  border-radius:16px;
  box-shadow:inset 0 0 70px rgba(242,166,90,0.06);
}
.screen-frame > .eyebrow,
.screen-frame > h1,
.screen-frame > .appicon{ position:relative; z-index:2; }
.appicon{
  display:block;
  width:clamp(76px,9.5vw,100px);
  height:auto;
  margin:0 auto 22px;
  border-radius:0;
  filter:drop-shadow(0 10px 26px rgba(0,0,0,0.5));
}
@keyframes breathe{
  0%,100%{ opacity:0.85; transform:translate(-50%,-50%) scale(1); }
  50%{ opacity:1; transform:translate(-50%,-50%) scale(1.04); }
}

.hero-inner{ position:relative; z-index:2; }
.screen-frame .eyebrow{ margin-bottom:4px; }
.hero h1{
  font-size:clamp(2.5rem, 7vw, 5.1rem);
  max-width:100%;
  margin:22px auto 0;
  font-optical-sizing:auto;
  text-wrap:balance;
}
.hero h1 em{
  font-style:italic;
  font-weight:500;
  color:var(--glow-2);
}
.hero .sub{
  max-width:46ch;
  margin:28px auto 0;
  color:var(--ink-dim);
  font-size:clamp(1rem,2vw,1.18rem);
}
.hero .sub b{ color:var(--ink); font-weight:500; }

.cta-row{
  margin-top:60px;
  display:flex; gap:16px; justify-content:center; align-items:center; flex-wrap:wrap;
}
.btn{
  font-family:"JetBrains Mono", monospace;
  font-size:13.5px; letter-spacing:0.03em;
  text-decoration:none;
  padding:14px 24px;
  border-radius:999px;
  display:inline-flex; align-items:center; gap:9px;
  transition:transform .2s ease, box-shadow .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.btn-primary{
  background:linear-gradient(180deg, var(--glow-2), var(--glow));
  color:#2a1602;
  font-weight:500;
  box-shadow:0 8px 30px -8px rgba(242,166,90,0.55);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 12px 38px -8px rgba(242,166,90,0.7); }
.btn-ghost{
  color:var(--ink-dim);
  border:1px solid var(--line);
}
.btn-ghost:hover{ color:var(--ink); border-color:var(--ink-faint); }
.btn svg{ width:15px; height:15px; }

/* ---------- generic section ---------- */
section{ position:relative; z-index:2; }
.band{ padding-top:clamp(60px,10vh,120px); padding-bottom:clamp(60px,10vh,120px); }
.rule{ height:1px; background:var(--line-2); border:0; }

.lede{
  font-family:"Fraunces", serif;
  font-weight:400;
  font-size:clamp(1.5rem,3.6vw,2.5rem);
  line-height:1.28;
  max-width:20ch;
  letter-spacing:-0.01em;
}
.lede .dim{ color:var(--ink-faint); }
.idea-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:clamp(28px,6vw,80px);
  align-items:start;
}
.idea-grid p{ color:var(--ink-dim); max-width:42ch; }
.idea-grid p + p{ margin-top:18px; }

/* ---------- how it works ---------- */
.sec-head{ display:flex; flex-direction:column; gap:18px; margin-bottom:54px; }
.sec-head h2{ font-size:clamp(1.9rem,4.5vw,3rem); max-width:18ch; }

.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-2); border:1px solid var(--line-2); border-radius:16px; overflow:hidden; }
.step{ background:var(--room); padding:34px clamp(22px,2.6vw,34px) 38px; }
.step .num{
  font-family:"JetBrains Mono", monospace;
  font-size:12px; letter-spacing:0.18em;
  color:var(--glow);
  display:block; margin-bottom:22px;
}
.step h3{ font-size:1.45rem; font-weight:500; margin-bottom:12px; }
.step p{ color:var(--ink-dim); font-size:0.98rem; }

.cmd{
  margin-top:30px;
  background:var(--room-2);
  border:1px solid var(--line);
  border-radius:12px;
  padding:18px 20px;
  font-family:"JetBrains Mono", monospace;
  font-size:14px;
  color:var(--ink);
  display:flex; align-items:center; gap:12px;
  overflow-x:auto;
}
.cmd .prompt{ color:var(--glow); user-select:none; }
.cmd .arg{ color:var(--ink-dim); }

/* ---------- get eyezo: the two-part setup ---------- */
/* The page makes the architecture explicit: one shared server, then at least
   one app — and every app can be downloaded OR built from source. */
.setup{ display:grid; grid-template-columns:54px 1fr; gap:clamp(18px,3.2vw,36px); align-items:start; }
.setup-num{
  width:54px; height:54px; border-radius:50%;
  border:1px solid var(--line);
  background:var(--room-2);
  display:flex; align-items:center; justify-content:center;
  font-family:"JetBrains Mono", monospace;
  font-size:20px; color:var(--glow);
  flex:none;
}
.setup-card{
  background:var(--room-2);
  border:1px solid var(--line);
  border-radius:16px;
  padding:clamp(26px,3.4vw,40px);
}
.setup-card.is-server{
  border-color:rgba(242,166,90,0.22);
  box-shadow:inset 0 0 70px rgba(242,166,90,0.05);
}
/* step 3 — the payoff: warm it up so "Press play." reads as the reward */
.setup-card.is-play{ border-color:rgba(246,192,131,0.16); }
.setup-card.is-play h3{ color:var(--glow-2); }
/* the start-the-server command sits against the darker room tone so it reads as a terminal */
.setup-card.is-server .cmd{ background:var(--room); }
.setup-card .eyebrow{ margin-bottom:14px; }
.setup-card h3{ font-size:clamp(1.5rem,3vw,2rem); font-weight:500; margin-bottom:12px; }
.setup-card > p{ color:var(--ink-dim); max-width:56ch; }
.setup-card > p b{ color:var(--ink); font-weight:500; }

/* vertical connector showing the steps are sequential */
.setup-join{
  width:1px; height:40px;
  margin:6px 0 6px 26px;
  background:linear-gradient(var(--glow), rgba(242,166,90,0.06));
  opacity:0.5;
}

/* step 1 — the server: copy on the left, the call to action on the right */
.server-row{ display:grid; grid-template-columns:1fr auto; gap:clamp(22px,4vw,48px); align-items:center; }
.server-actions{ display:flex; flex-direction:column; align-items:flex-start; gap:14px; }

/* step 2 — the apps: one card per device, each offering both ways to get it */
.apps{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-top:28px; }
.app{
  position:relative;
  background:var(--room);
  border:1px solid var(--line-2);
  border-radius:14px;
  padding:24px 22px 26px;
  display:flex; flex-direction:column; gap:18px;
}
.app-head{ display:flex; align-items:center; gap:13px; }
.app-head .gi{ color:var(--ink); flex:none; display:flex; }
.app-head .gi svg{ height:30px; width:auto; }
.app-head h4{ font-family:"Fraunces", serif; font-weight:500; font-size:1.18rem; line-height:1.1; }
.app-head .os{ display:block; margin-top:3px; font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:0.04em; color:var(--ink-faint); }
.acq{ display:flex; flex-direction:column; gap:9px; }
.acq + .acq{ margin-top:4px; }
.acq-label{
  font-family:"JetBrains Mono", monospace;
  font-size:10px; letter-spacing:0.12em; text-transform:uppercase;
  color:var(--ink-faint);
}
.apps .store-badge{ width:100%; }
.apps .store-src{ margin-top:0; }

/* coming-soon platforms (e.g. Android, future clients) */
.acq-note{ color:var(--ink-dim); font-size:0.92rem; line-height:1.5; }
/* a non-link build-from-source row for clients whose repo isn't public yet */
.store-src.is-soon{ color:var(--ink-faint); cursor:default; }
.store-src.is-soon:hover{ color:var(--ink-faint); }

.plays-note{ text-align:center; margin-top:30px; color:var(--ink-dim); font-size:0.96rem; }
.plays-note code{ font-family:"JetBrains Mono",monospace; font-size:0.9em; color:var(--ink); background:var(--room-2); border:1px solid var(--line); border-radius:6px; padding:1px 6px; }

/* App Store badge + build-from-source link (shared by every app card) */
.store-badge{
  display:inline-flex; align-items:center; gap:11px;
  padding:11px 18px 11px 16px;
  border:1px solid var(--line);
  border-radius:13px;
  background:var(--room-2);
  text-decoration:none;
  color:var(--ink);
  position:relative;
  transition:border-color .25s ease, transform .2s ease, background .25s ease;
}
.store-badge:hover{ border-color:rgba(242,166,90,0.5); background:rgba(242,166,90,0.06); transform:translateY(-2px); }
.store-badge .apple-glyph{ width:23px; height:23px; color:var(--ink); flex:none; }
.sb-copy{ display:flex; flex-direction:column; line-height:1.05; text-align:left; }
.sb-copy small{
  font-family:"JetBrains Mono", monospace;
  font-size:9.5px; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--glow);
  margin-bottom:3px;
}
.sb-copy b{ font-family:"Hanken Grotesk", sans-serif; font-size:19px; font-weight:600; letter-spacing:-0.01em; }
.store-src{
  display:inline-flex; align-items:center; gap:7px;
  font-family:"JetBrains Mono", monospace;
  font-size:12px; letter-spacing:0.02em;
  color:var(--ink-dim);
  text-decoration:none;
  transition:color .2s ease;
  margin-top:-2px;
}
.store-src svg{ width:14px; height:14px; flex:none; }
.store-src:hover{ color:var(--glow); }

/* ---------- what's not here ---------- */
.absent{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:clamp(30px,6vw,70px); align-items:center; }
.absent ul{ list-style:none; }
.absent li{
  display:flex; gap:16px; align-items:baseline;
  padding:18px 0;
  border-bottom:1px solid var(--line-2);
  font-size:clamp(1.05rem,2.2vw,1.35rem);
  font-family:"Fraunces", serif; font-weight:400;
  letter-spacing:-0.01em;
}
.absent li:last-child{ border-bottom:0; }
.absent li .x{
  font-family:"JetBrains Mono",monospace;
  color:var(--glow);
  font-size:0.85em;
  flex:none;
  transform:translateY(1px);
}
.absent li small{
  display:block;
  font-family:"Hanken Grotesk",sans-serif;
  font-size:0.7em;
  color:var(--ink-dim);
  letter-spacing:0;
  margin-top:2px;
}

/* ---------- legal / prose page ---------- */
.legal{ max-width:74ch; }
.legal .eyebrow{ margin-bottom:18px; }
.legal h1{
  font-size:clamp(2.2rem,5.5vw,3.4rem);
  margin-bottom:14px;
  text-wrap:balance;
}
.legal .updated{
  font-family:"JetBrains Mono", monospace;
  font-size:12px; letter-spacing:0.04em;
  color:var(--ink-faint);
  margin-bottom:8px;
}
.legal .intro{ color:var(--ink-dim); font-size:1.08rem; margin-bottom:8px; }
.legal h2{
  font-size:clamp(1.35rem,2.8vw,1.75rem);
  font-weight:500;
  margin-top:48px; margin-bottom:14px;
}
.legal p{ color:var(--ink-dim); margin-bottom:16px; }
.legal p b{ color:var(--ink); font-weight:500; }
.legal a{ color:var(--glow); text-decoration:none; transition:color .2s ease; }
.legal a:hover{ color:var(--glow-2); }
.legal ul{ list-style:none; margin:0 0 16px; }
.legal ul li{
  position:relative;
  color:var(--ink-dim);
  padding-left:22px;
  margin-bottom:11px;
}
.legal ul li::before{
  content:"";
  position:absolute; left:2px; top:0.62em;
  width:6px; height:6px; border-radius:50%;
  background:var(--glow);
  box-shadow:0 0 9px 1px rgba(242,166,90,0.5);
}
.legal ul li b{ color:var(--ink); font-weight:500; }
.legal .contact{
  margin-top:48px;
  background:var(--room-2);
  border:1px solid var(--line);
  border-radius:14px;
  padding:clamp(22px,3vw,30px);
}
.legal .contact p:last-child{ margin-bottom:0; }

/* ---------- closing cta ---------- */
.close{ text-align:center; position:relative; }
.close .screen-glow{ height:380px; top:50%; opacity:0.7; }
.close h2{ font-size:clamp(2rem,5vw,3.4rem); max-width:16ch; margin:0 auto 14px; position:relative; z-index:2; }
.close p{ color:var(--ink-dim); max-width:40ch; margin:0 auto 34px; position:relative; z-index:2; }
.close .cta-row{ margin-top:0; position:relative; z-index:2; }

/* ---------- footer ---------- */
footer{ border-top:1px solid var(--line-2); padding-top:50px; padding-bottom:60px; position:relative; z-index:2; }
.foot-grid{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; align-items:flex-start; }
.foot-mark{ display:flex; flex-direction:column; gap:12px; max-width:30ch; }
.foot-mark p{ color:var(--ink-faint); font-size:0.92rem; }
.repos{ display:grid; gap:11px; }
.repos .rh{ font-family:"JetBrains Mono",monospace; font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:5px; }
.repos a{
  font-family:"JetBrains Mono",monospace;
  font-size:13.5px;
  text-decoration:none;
  color:var(--ink-dim);
  transition:color .2s ease;
  display:inline-flex; align-items:center; gap:8px;
}
.repos a:hover{ color:var(--glow); }
.repos a .slash{ color:var(--ink-faint); }
.foot-base{ margin-top:46px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-family:"JetBrains Mono",monospace; font-size:12px; color:var(--ink-faint); letter-spacing:0.03em; }
.foot-base a{ text-decoration:none; color:var(--ink-faint); }
.foot-base a:hover{ color:var(--ink-dim); }

/* ---------- reveal ---------- */
.reveal{ opacity:0; transform:translateY(18px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }

/* ---------- focus ---------- */
a:focus-visible, .btn:focus-visible{ outline:2px solid var(--glow); outline-offset:3px; border-radius:6px; }

/* ---------- responsive ---------- */
@media (max-width:860px){
  .steps{ grid-template-columns:1fr; }
  .apps{ grid-template-columns:1fr; }
  .server-row{ grid-template-columns:1fr; gap:26px; }
  .server-actions{ align-items:stretch; }
  .idea-grid{ grid-template-columns:1fr; gap:30px; }
  .absent{ grid-template-columns:1fr; gap:24px; }
}
@media (max-width:560px){
  .setup{ grid-template-columns:1fr; gap:16px; }
  .setup-num{ width:46px; height:46px; font-size:17px; }
  .setup-join{ display:none; }
}
@media (max-width:460px){
  .nav-link{ padding:7px 13px; }
}

@media (prefers-reduced-motion:reduce){
  *{ scroll-behavior:auto !important; }
  .screen-glow{ animation:none !important; }
  .reveal{ opacity:1 !important; transform:none !important; transition:none !important; }
}
