/* ============================================================
   Zuzu — Waitlist landing page
   Design tokens lifted from the Warm Companion app
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700;9..144,800;9..144,900&family=Inter:wght@400;500;600;700;800&display=swap');

:root{
  /* surfaces */
  --bg:        #EFE7D3;
  --bg-soft:   #F4ECDA;
  --surface:   #FFFCF5;
  --surface-2: #F6EFDD;
  /* ink */
  --ink:       #1F0F08;
  --ink-cool:  #0F1419;
  --ink-soft:  #5A5953;
  --ink-dim:   #8A8678;
  /* lines */
  --line:      #E4D9BC;
  --line-soft: #EEE6D0;
  /* accents */
  --green:      #0E9669;
  --green-dark: #0A7350;
  --green-soft: #D4E9D6;
  --orange:     #FF7A1F;
  --orange-dark:#B44A0A;
  --orange-soft:#FFE2C9;
  --sun:        #F2C94C;
  --warn:       #C24A3A;
  --warn-soft:  #F7D5CB;

  --shadow-card: 0 24px 48px -28px rgba(31,15,8,0.40);
  --shadow-pop:  0 5px 0 var(--ink);

  --font-disp: 'Fraunces', Georgia, serif;
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;

  --maxw: 1180px;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
a{ color: inherit; text-decoration: none; }
img{ display:block; max-width:100%; }
button{ font-family: inherit; cursor: pointer; }

/* warm textured backdrop, matches the app stage */
.page-bg{
  position: fixed; inset:0; z-index:-1;
  background:
    radial-gradient(900px 600px at 12% -5%, #F7DEA6 0%, transparent 55%),
    radial-gradient(900px 700px at 95% 8%, #DCEBD8 0%, transparent 55%),
    radial-gradient(1100px 800px at 70% 110%, #F3D9B6 0%, transparent 60%),
    var(--bg);
}
.page-bg::after{
  content:''; position:absolute; inset:0;
  background-image: radial-gradient(circle, rgba(31,15,8,0.045) 1px, transparent 1px);
  background-size: 20px 20px;
}

.wrap{ width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }

/* ---------- pixel star sparkle ---------- */
.spark{ position:absolute; pointer-events:none; }
.spark svg{ display:block; }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position: sticky; top:0; z-index: 60;
  backdrop-filter: blur(10px);
  background: rgba(239,231,211,0.72);
  border-bottom: 1px solid rgba(228,217,188,0.7);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  height: 70px;
}
.brand{ display:flex; align-items:center; gap:9px; }
.brand .mark{
  width: 34px; height:34px; border-radius: 11px;
  background: var(--ink); display:grid; place-items:center;
  overflow:hidden; box-shadow: var(--shadow-card);
}
.brand .mark img{ width: 30px; height:30px; object-fit: contain; transform: translateY(2px); }
.brand .name{
  font-family: var(--font-disp); font-weight: 800; font-size: 24px;
  letter-spacing: -0.02em; color: var(--ink);
}
.brand .dot{ color: var(--green); font-size: 15px; }
.nav-links{ display:flex; align-items:center; gap: 30px; }
.nav-links a{ font-size: 14px; font-weight: 600; color: var(--ink-soft); transition: color .15s; }
.nav-links a:hover{ color: var(--ink); }

/* chunky toy button */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-weight: 700; font-size: 15px; letter-spacing: -0.01em;
  border: 2px solid var(--ink); border-radius: 999px;
  padding: 13px 22px; background: var(--surface); color: var(--ink);
  box-shadow: 0 4px 0 var(--ink);
  transition: transform .12s ease, box-shadow .12s ease, background .15s;
}
.btn:hover{ transform: translateY(-1px); box-shadow: 0 5px 0 var(--ink); }
.btn:active{ transform: translateY(3px); box-shadow: 0 1px 0 var(--ink); }
.btn-green{ background: var(--green); color: #fff; }
.btn-green:hover{ background: var(--green-dark); }
.btn-ink{ background: var(--ink); color: var(--surface); }
.btn-sm{ padding: 10px 18px; font-size: 14px; box-shadow: 0 3px 0 var(--ink); }
.btn-sm:hover{ box-shadow: 0 4px 0 var(--ink); }
.btn-lg{ padding: 17px 30px; font-size: 17px; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding: 64px 0 36px; }
.hero-grid{
  display:grid; grid-template-columns: 1.05fr 0.95fr; gap: 40px; align-items:center;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  background: var(--surface); border:1.5px solid var(--line);
  border-radius: 999px; padding: 7px 14px 7px 9px;
  font-size: 12.5px; font-weight: 700; color: var(--ink);
  letter-spacing: 0.2px; box-shadow: 0 3px 0 rgba(31,15,8,0.10);
}
.eyebrow .pip{
  width: 20px; height:20px; border-radius: 50%; background: var(--green-soft);
  display:grid; place-items:center; color: var(--green-dark);
}
.eyebrow b{ color: var(--green-dark); }

.hero h1{
  font-family: var(--font-disp);
  font-weight: 800; font-size: clamp(40px, 5.4vw, 68px);
  line-height: 1.02; letter-spacing: -0.025em; margin: 22px 0 0;
  text-wrap: balance; color: var(--ink);
}
.hero h1 .swoop{ color: var(--green); font-style: italic; font-weight: 700; position: relative; }
.hero .lede{
  font-size: 19px; line-height: 1.55; color: var(--ink-soft);
  margin: 20px 0 0; max-width: 30em; text-wrap: pretty;
}

/* waitlist form */
.waitlist{ margin-top: 30px; max-width: 440px; }
.waitlist-row{
  display:flex; gap: 10px; background: var(--surface);
  border: 2px solid var(--ink); border-radius: 999px; padding: 6px 6px 6px 8px;
  box-shadow: 0 5px 0 var(--ink);
}
.waitlist-row input{
  flex:1; border:none; outline:none; background: transparent;
  font-family: inherit; font-size: 15.5px; color: var(--ink); padding: 0 12px;
  min-width: 0;
}
.waitlist-row input::placeholder{ color: var(--ink-dim); }
.waitlist-note{
  display:flex; align-items:center; gap: 14px; margin-top: 16px;
  font-size: 13px; color: var(--ink-soft);
}
.avatars{ display:flex; }
.avatars .av{
  width: 28px; height:28px; border-radius: 50%; border: 2px solid var(--bg);
  margin-left: -8px; background: var(--orange-soft); overflow:hidden;
  display:grid; place-items:center;
}
.avatars .av:first-child{ margin-left:0; }
.avatars .av img{ width:100%; height:100%; object-fit: cover; }
.waitlist-note b{ color: var(--ink); }

.form-success{
  display:none; align-items:center; gap: 12px;
  background: var(--green-soft); border: 2px solid var(--green);
  border-radius: 22px; padding: 16px 20px; color: var(--green-dark);
  font-weight: 600; font-size: 15px; box-shadow: 0 5px 0 var(--green-dark);
}
.waitlist.done .waitlist-row, .waitlist.done .waitlist-note{ display:none; }
.waitlist.done .form-success{ display:flex; }

/* ---------- hero phone scene ---------- */
.hero-scene{ position: relative; display:grid; place-items:center; min-height: 640px; }
.hero-scene .blob{
  position:absolute; width: 440px; height: 440px; border-radius: 50%;
  background: radial-gradient(circle at 50% 40%, rgba(255,255,255,0.65), transparent 62%);
  filter: blur(4px);
}
.float-chip{
  position:absolute; z-index: 5;
  background: var(--surface); border: 2px solid var(--ink);
  border-radius: 16px; padding: 11px 14px;
  box-shadow: 0 6px 0 rgba(31,15,8,0.16);
  display:flex; align-items:center; gap: 10px;
}
.float-chip .ic{ width: 34px; height:34px; border-radius: 10px; display:grid; place-items:center; }
.float-chip .t small{ display:block; font-size: 10px; letter-spacing: .6px; text-transform: uppercase; color: var(--ink-dim); font-weight:700; }
.float-chip .t b{ display:block; font-size: 15px; color: var(--ink); font-weight: 800; white-space: nowrap; }
.chip-streak{ top: 150px; left: -52px; animation: floaty 5s ease-in-out infinite; }
.chip-treats{ bottom: 150px; right: -16px; animation: floaty 6s ease-in-out infinite 0.6s; }
.chip-level { bottom: 64px; left: -14px; animation: floaty 5.5s ease-in-out infinite 1.1s; }
@keyframes floaty{ 0%,100%{ transform: translateY(0) } 50%{ transform: translateY(-10px) } }

/* ============================================================
   DEVICE / PHONE
   ============================================================ */
.device{
  --w: 300px;
  width: var(--w);
  aspect-ratio: 300 / 640;
  background: #161310; border-radius: 42px; padding: 7px;
  box-shadow: 0 44px 80px -34px rgba(31,15,8,0.55), 0 0 0 1px rgba(0,0,0,0.06);
  position: relative; flex: none;
}
.device.tilt-l{ transform: rotate(-3deg); }
.device.tilt-r{ transform: rotate(3deg); }
.device-screen{
  width:100%; height:100%; border-radius: 35px; overflow:hidden;
  background: var(--bg-soft); position: relative;
  font-size: 12px; /* base unit for screen content */
}
.notch{
  position:absolute; top:9px; left:50%; transform: translateX(-50%);
  width: 86px; height: 22px; background:#0A0A0A; border-radius: 13px; z-index: 40;
}
.sbar{
  position:absolute; top:0; left:0; right:0; height: 38px; z-index: 30;
  display:flex; align-items:center; justify-content:space-between;
  padding: 14px 18px 0; font-size: 11px; font-weight: 700; color: var(--ink-cool);
  pointer-events:none;
}
.sbar .sb-ic{ display:flex; gap:4px; align-items:center; }
.home-ind{
  position:absolute; bottom:6px; left:50%; transform: translateX(-50%);
  width: 96px; height: 4px; border-radius: 2px; background: rgba(15,20,25,0.30); z-index: 40;
}

/* hero device a touch bigger */
.hero-scene .device{ --w: 322px; z-index: 4; }

/* ---------- shared screen atoms ---------- */
.scr{ position:absolute; inset:0; padding: 44px 14px 16px; display:flex; flex-direction:column; }
.scr-scroll{ flex:1; display:flex; flex-direction:column; gap: 11px; }
.eyetext{ font-size: 10px; letter-spacing: 1px; text-transform: uppercase; font-weight: 700; color: var(--ink-soft); }
.card{
  background: var(--surface); border:1px solid var(--line); border-radius: 20px;
}
.pill-chip{
  display:inline-flex; align-items:center; gap:6px;
  background: var(--surface); border:1px solid var(--line); border-radius: 999px;
  padding: 6px 10px; font-size: 11px; font-weight: 800; color: var(--ink);
}

/* HOME screen */
.h-greet{ display:flex; justify-content:space-between; align-items:flex-start; }
.h-greet .day{ font-size: 21px; font-weight: 800; color: var(--ink); letter-spacing: -0.4px; margin-top: 3px; }
.h-greet .day em{ color: var(--orange); font-style: normal; }
.h-actions{ display:flex; gap:7px; }
.h-ico{ width: 34px; height:34px; border-radius: 999px; background: var(--surface); border:1px solid var(--line); display:grid; place-items:center; position:relative; }
.h-ico.treats{ width:auto; padding: 0 11px; gap:5px; display:flex; font-weight:800; font-size:12px; color:var(--ink); }
.pet-card{ position:relative; padding: 16px; display:flex; flex-direction:column; align-items:center; gap:7px; overflow:visible; }
.pet-stage{
  width: 100%; height: 168px; border-radius: 16px; margin-top: 16px;
  background: radial-gradient(circle at 50% 42%, var(--orange-soft) 0%, #F7EBD2 62%, var(--surface) 100%);
  display:grid; place-items:end center; position:relative; overflow:hidden;
}
.pet-stage img.pet{ width: 132px; height: 132px; object-fit: contain; object-position: bottom; filter: drop-shadow(0 10px 10px rgba(31,15,8,0.18)); }
.badge-tl{ position:absolute; top:10px; left:10px; background: var(--orange-soft); color: var(--orange-dark); font-size: 9px; font-weight:800; padding:4px 8px; border-radius: 999px; letter-spacing:.5px; z-index:3; }
.badge-tr{ position:absolute; top:10px; right:10px; background: var(--ink); color:#fff; font-size: 9px; font-weight:800; padding:4px 8px; border-radius:999px; letter-spacing:.5px; display:flex; align-items:center; gap:4px; z-index:3; }
.pet-name{ font-size: 16px; font-weight:800; color: var(--ink); margin-top:3px; }
.pet-quote{ font-size: 11.5px; color: var(--ink-soft); text-align:center; line-height:1.4; max-width: 200px; text-wrap:pretty; }
.xp{ width:100%; margin-top:5px; }
.xp .row{ display:flex; justify-content:space-between; font-size:10px; color:var(--ink-soft); font-weight:600; margin-bottom:5px; }
.xp .track{ height:7px; background: var(--line); border-radius:4px; overflow:hidden; }
.xp .fill{ height:100%; width:64%; border-radius:4px; background: linear-gradient(90deg, var(--orange), var(--orange-dark)); }
.cta-dark{
  display:flex; align-items:center; justify-content:space-between;
  background: var(--ink-cool); color: var(--surface); border:none; border-radius: 999px;
  padding: 15px 16px; font-size: 14px; font-weight: 700;
  box-shadow: 0 10px 22px -10px rgba(15,20,25,0.5);
}
.cta-dark .arrow{ width: 26px; height:26px; border-radius:50%; background: var(--orange); display:grid; place-items:center; }
.cta-dark .lead{ display:flex; align-items:center; gap:9px; }
.strip-card{ padding: 13px; }
.strip-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:11px; }
.strip-head b{ font-size: 12px; color: var(--ink); }
.strip-head span{ font-size: 11px; color: var(--ink-soft); font-weight:600; }
.strip-cells{ display:flex; gap: 4px; }
.strip-cells i{ flex:1; height: 30px; border-radius:6px; background: var(--orange); }
.strip-cells i.bump{ background: var(--warn); }
.strip-cells i.future{ background: var(--line); opacity:.5; }
.strip-cells i.today{ background: transparent; border: 2px dashed var(--ink); }
.mile{
  display:flex; align-items:center; gap: 11px; background: var(--orange-soft);
  border:none; border-radius: 18px; padding: 13px; text-align:left; width:100%;
}
.mile .num{ width: 42px; height:42px; border-radius: 12px; background: var(--orange); color:#fff; display:grid; place-items:center; font-size: 17px; font-weight:800; }
.mile .mt small{ display:block; font-size:9px; font-weight:800; letter-spacing:1px; text-transform:uppercase; color: var(--orange-dark); }
.mile .mt b{ display:block; font-size: 13px; color: var(--ink); margin-top:2px; }
.mile .mt span{ display:block; font-size: 11px; color: var(--ink-soft); margin-top:1px; }

/* bottom nav */
.bnav{
  position:absolute; left: 12px; right:12px; bottom: 14px; z-index: 20;
  background: var(--ink-cool); border-radius: 999px; padding: 5px;
  display:flex; align-items:center; justify-content:space-between;
  box-shadow: 0 14px 30px -12px rgba(15,20,25,0.5);
}
.bnav button{ width: 38px; height: 38px; border-radius:999px; border:none; background:transparent; display:grid; place-items:center; }
.bnav button.active{ background: var(--surface); }
.bnav button.plus{ background: var(--orange); }

/* CHECK-IN screen */
.ci-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom: 18px; }
.ci-dots{ display:flex; gap:5px; }
.ci-dots i{ width:6px; height:6px; border-radius:3px; background: var(--line); }
.ci-dots i.on{ width: 24px; background: var(--ink); }
.ci-h{ font-size: 23px; font-weight:800; color: var(--ink); letter-spacing:-0.5px; line-height:1.08; }
.ci-sub{ font-size: 12.5px; color: var(--ink-soft); margin: 6px 0 4px; }
.ci-opt{
  display:flex; align-items:center; gap: 12px; text-align:left; width:100%;
  background: var(--surface); border: 1.5px solid var(--line); border-radius: 18px; padding: 16px;
}
.ci-opt.sel{ border-color: var(--orange); }
.ci-opt .oic{ width: 44px; height:44px; border-radius: 12px; display:grid; place-items:center; flex:none; }
.ci-opt .oic.good{ background: var(--orange-soft); }
.ci-opt .oic.bump{ background: var(--warn-soft); }
.ci-opt .ot b{ display:block; font-size: 15px; font-weight:800; color: var(--ink); }
.ci-opt .ot span{ display:flex; align-items:center; gap:5px; font-size: 11px; color: var(--ink-soft); margin-top:3px; }

/* CHAT screen */
.chat-head{ display:flex; align-items:center; gap:10px; padding: 0 2px 12px; border-bottom:1px solid var(--line); }
.chat-av{ width: 40px; height:40px; border-radius:50%; background: var(--orange-soft); display:grid; place-items:center; overflow:hidden; }
.chat-av img{ width: 34px; height:34px; object-fit:contain; transform: translateY(2px); }
.chat-head .ch{ display:flex; flex-direction:column; gap:2px; }
.chat-head .ch b{ display:block; font-size: 13px; font-weight:800; color: var(--ink); }
.chat-head .ch span{ display:flex; align-items:center; gap:5px; font-size: 10.5px; color: var(--green-dark); font-weight:700; }
.chat-head .ch span i{ width:6px; height:6px; border-radius:3px; background: var(--green); }
.chat-body{ flex:1; display:flex; flex-direction:column; gap:8px; padding: 14px 2px; overflow:hidden; }
.chat-day{ align-self:center; font-size:9px; letter-spacing:1px; text-transform:uppercase; color: var(--ink-dim); font-weight:700; margin-bottom:2px; }
.bub{ max-width: 80%; font-size: 12px; line-height:1.42; padding: 9px 12px; border-radius: 16px; text-wrap:pretty; }
.bub.them{ align-self:flex-start; background: var(--surface); border:1px solid var(--line); color: var(--ink); border-bottom-left-radius:5px; }
.bub.me{ align-self:flex-end; background: var(--ink-cool); color: var(--surface); border-bottom-right-radius:5px; }
.bub .tm{ font-size: 9px; margin-top:3px; opacity:.55; font-weight:600; }
.composer{ margin-top:auto; background: var(--surface); border:1px solid var(--line); border-radius:999px; padding:5px 5px 5px 14px; display:flex; align-items:center; gap:8px; }
.composer span{ flex:1; font-size: 12px; color: var(--ink-dim); }
.composer .send{ width:32px; height:32px; border-radius:999px; background: var(--orange); display:grid; place-items:center; flex:none; }

/* PATH screen */
.path-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom: 6px; }
.path-head .pt small{ font-size: 9px; letter-spacing:1px; text-transform:uppercase; font-weight:800; color: var(--ink-soft); }
.path-head .pt b{ display:block; font-size: 20px; font-weight:800; color: var(--ink); letter-spacing:-0.5px; }
.path-list{ position:relative; flex:1; display:flex; flex-direction:column; gap: 4px; padding-left: 8px; margin-top: 6px; }
.path-line{ position:absolute; left: 22px; top: 14px; bottom: 14px; width: 2px;
  background-image: linear-gradient(var(--line) 60%, transparent 0); background-size: 2px 9px; }
.path-line.done{ background-image: linear-gradient(var(--orange) 60%, transparent 0); }
.node{ display:flex; align-items:center; gap:12px; position:relative; z-index:2; padding: 5px 0; flex:none; }
.node .dot{ width: 30px; height:30px; border-radius:50%; display:grid; place-items:center; flex:none; font-size:12px; font-weight:800; border:2px solid var(--line); background: var(--surface); color: var(--ink-dim); }
.node .dot.done{ background: var(--orange); border-color: var(--orange); color:#fff; }
.node.cur .dot{ width: 40px; height:40px; border:3px solid var(--ink); background: radial-gradient(circle, var(--orange-soft), #FFC79A); overflow:hidden; box-shadow: 0 8px 18px -6px rgba(31,15,8,0.3); }
.node.cur .dot img{ width: 36px; height:36px; object-fit:contain; transform: translateY(2px); }
.node .nt{ display:flex; flex-direction:column; gap:1px; }
.node .nt small{ font-size:9px; font-weight:800; letter-spacing:.6px; text-transform:uppercase; color: var(--ink-soft); }
.node.cur .nt small{ color: var(--orange-dark); }
.node .nt b{ display:block; font-size: 13px; font-weight:800; color: var(--ink); }
.node .nt b.lock{ color: var(--ink-dim); }
.node .nt span{ display:block; font-size: 10.5px; color: var(--ink-soft); }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.section{ padding: 80px 0; position: relative; }
.section.tight{ padding: 56px 0; }
.sec-head{ max-width: 640px; }
.sec-head.center{ margin: 0 auto; text-align:center; }
.kicker{
  display:inline-flex; align-items:center; gap:8px;
  font-size: 12.5px; font-weight: 800; letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--green-dark);
}
.kicker .ln{ width: 24px; height:2px; background: var(--green); border-radius:2px; }
.sec-head h2{
  font-family: var(--font-disp); font-weight: 800;
  font-size: clamp(30px, 4vw, 46px); line-height: 1.05; letter-spacing: -0.02em;
  margin: 14px 0 0; color: var(--ink); text-wrap: balance;
}
.sec-head p{ font-size: 17px; line-height:1.6; color: var(--ink-soft); margin: 16px 0 0; text-wrap: pretty; }

/* ---------- inside-the-app showcase ---------- */
.showcase{ margin-top: 52px; }
.phone-row{ display:flex; gap: 30px; justify-content:center; align-items:flex-start; flex-wrap: wrap; }
.phone-col{ display:flex; flex-direction:column; align-items:center; gap: 18px; width: 300px; }
.phone-cap{ text-align:center; }
.phone-cap small{ font-size: 11px; font-weight:800; letter-spacing:1.4px; text-transform:uppercase; color: var(--green-dark); }
.phone-cap b{ display:block; font-family: var(--font-disp); font-size: 21px; font-weight:700; color: var(--ink); margin-top:4px; letter-spacing:-0.01em; }
.phone-cap p{ font-size: 13.5px; color: var(--ink-soft); margin: 6px 0 0; line-height:1.5; text-wrap:pretty; }

/* ---------- how it works ---------- */
.steps{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 52px; }
.step{
  background: var(--surface); border: 2px solid var(--ink); border-radius: 26px;
  padding: 26px 24px 28px; box-shadow: 0 6px 0 rgba(31,15,8,0.14); position:relative;
}
.step .sn{
  position:absolute; top: -16px; left: 22px;
  width: 38px; height:38px; border-radius:11px; background: var(--green); color:#fff;
  display:grid; place-items:center; font-family: var(--font-disp); font-weight:800; font-size:18px;
  border: 2px solid var(--ink); box-shadow: 0 3px 0 var(--ink);
}
.step .sic{ width: 52px; height:52px; border-radius: 15px; display:grid; place-items:center; margin: 8px 0 16px; }
.step h3{ font-family: var(--font-disp); font-weight:700; font-size: 22px; margin:0; letter-spacing:-0.01em; color: var(--ink); }
.step p{ font-size: 14.5px; line-height:1.55; color: var(--ink-soft); margin: 10px 0 0; text-wrap:pretty; }

/* ---------- meet companions ---------- */
.meet{ display:grid; grid-template-columns: 0.9fr 1.1fr; gap: 44px; align-items:center; margin-top: 44px; }
.companion-cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.comp{
  background: var(--surface); border: 2px solid var(--ink); border-radius: 24px;
  padding: 18px 14px 18px; text-align:center; box-shadow: 0 6px 0 rgba(31,15,8,0.13);
  transition: transform .15s;
}
.comp:hover{ transform: translateY(-4px); }
.comp .frame{
  height: 150px; border-radius: 16px; display:grid; place-items:end center; overflow:hidden;
  background: radial-gradient(circle at 50% 38%, var(--orange-soft), #F7EBD3 70%);
}
.comp.dog .frame{ background: radial-gradient(circle at 50% 38%, #F8DEB1, #F4ECD8 70%); }
.comp.cat .frame{ background: radial-gradient(circle at 50% 38%, #F7D6C8, #F4ECDC 70%); }
.comp .frame img{ width: 122px; height:122px; object-fit:contain; object-position:bottom; filter: drop-shadow(0 8px 9px rgba(31,15,8,0.16)); }
.comp b{ display:block; font-family: var(--font-disp); font-size: 18px; font-weight:700; margin-top: 14px; color: var(--ink); }
.comp span{ display:block; font-size: 12px; color: var(--ink-soft); margin-top:3px; }
.comp .tag{ display:inline-block; margin-top:10px; font-size:10px; font-weight:800; letter-spacing:.5px; text-transform:uppercase; color: var(--green-dark); background: var(--green-soft); padding:4px 9px; border-radius:999px; }

.meet-copy ul{ list-style:none; margin: 22px 0 0; padding:0; display:flex; flex-direction:column; gap:14px; }
.meet-copy li{ display:flex; gap: 12px; align-items:flex-start; font-size: 15px; color: var(--ink-soft); line-height:1.5; }
.meet-copy li .ck{ width:24px; height:24px; border-radius:7px; background: var(--green-soft); display:grid; place-items:center; flex:none; margin-top:1px; }
.meet-copy li b{ color: var(--ink); }

/* ---------- roadmap ---------- */
.roadmap{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 50px; }
.road-col{ background: var(--surface); border:1px solid var(--line); border-radius: 24px; padding: 22px 22px 24px; }
.road-col.shipped{ border:2px solid var(--green); box-shadow: 0 6px 0 rgba(14,150,105,0.20); }
.road-col h4{ display:flex; align-items:center; gap:9px; font-size: 13px; font-weight:800; letter-spacing:1.2px; text-transform:uppercase; margin:0 0 16px; }
.road-col.shipped h4{ color: var(--green-dark); }
.road-col.progress h4{ color: var(--orange-dark); }
.road-col.next h4{ color: var(--ink-soft); }
.road-col h4 .tagdot{ width:10px; height:10px; border-radius:3px; }
.shipped h4 .tagdot{ background: var(--green); }
.progress h4 .tagdot{ background: var(--orange); }
.next h4 .tagdot{ background: var(--ink-dim); }
.road-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap: 12px; }
.road-col li{ display:flex; gap: 11px; align-items:flex-start; font-size: 14.5px; color: var(--ink); line-height:1.4; }
.road-col li small{ display:block; font-size: 12px; color: var(--ink-soft); font-weight:500; margin-top:2px; }
.road-col li .mk{ width: 22px; height:22px; border-radius:7px; flex:none; display:grid; place-items:center; margin-top:1px; }
.shipped li .mk{ background: var(--green); color:#fff; }
.progress li .mk{ background: var(--orange-soft); color: var(--orange-dark); border:1.5px solid var(--orange); }
.next li .mk{ background: var(--surface-2); color: var(--ink-dim); border:1.5px dashed var(--line); }
.road-col li b{ font-weight: 700; }

/* ---------- final CTA ---------- */
.finale{
  background: var(--ink); border-radius: 36px; padding: 64px 48px; position:relative; overflow:hidden;
  display:grid; grid-template-columns: 1.2fr 0.8fr; gap: 30px; align-items:center;
  box-shadow: var(--shadow-card);
}
.finale::before{
  content:''; position:absolute; inset:0;
  background: radial-gradient(600px 400px at 88% 120%, rgba(255,122,31,0.30), transparent 60%),
             radial-gradient(500px 360px at 8% -10%, rgba(14,150,105,0.32), transparent 60%);
}
.finale .fin-copy{ position:relative; z-index:2; }
.finale h2{ font-family: var(--font-disp); font-weight:800; font-size: clamp(30px, 3.6vw, 44px); line-height:1.05; letter-spacing:-0.02em; color: var(--surface); margin:0; text-wrap:balance; }
.finale p{ color: rgba(255,252,245,0.72); font-size: 16.5px; line-height:1.55; margin: 16px 0 0; max-width: 30em; }
.finale .waitlist{ margin-top: 26px; }
.finale .waitlist-row{ border-color: #fff; box-shadow: 0 5px 0 rgba(0,0,0,0.5); }
.finale .waitlist-note{ color: rgba(255,252,245,0.7); }
.finale .waitlist-note b{ color:#fff; }
.fin-art{ position:relative; z-index:2; display:grid; place-items:center; }
.fin-art .ring{
  width: 230px; height:230px; border-radius:50%;
  background: radial-gradient(circle at 50% 42%, rgba(255,226,201,0.95), rgba(255,200,154,0.4) 60%, transparent 72%);
  display:grid; place-items:end center; overflow:visible;
}
.fin-art .ring img{ width: 200px; height: 200px; object-fit:contain; filter: drop-shadow(0 14px 14px rgba(0,0,0,0.35)); }

/* ---------- footer ---------- */
.footer{ padding: 56px 0 48px; }
.footer-inner{ display:flex; justify-content:space-between; align-items:flex-start; gap: 40px; flex-wrap:wrap; }
.footer .brand .name{ color: var(--ink); }
.footer-tag{ font-size: 13.5px; color: var(--ink-soft); margin-top: 12px; max-width: 24em; line-height:1.5; }
.footer-cols{ display:flex; gap: 64px; flex-wrap:wrap; }
.footer-col h5{ font-size: 12px; letter-spacing:1px; text-transform:uppercase; color: var(--ink-dim); margin:0 0 14px; font-weight:800; }
.footer-col a{ display:block; font-size: 14px; color: var(--ink-soft); margin-bottom: 10px; font-weight:600; transition: color .15s; }
.footer-col a:hover{ color: var(--ink); }
.footer-base{ display:flex; justify-content:space-between; align-items:center; gap:20px; margin-top: 44px; padding-top: 22px; border-top:1px solid var(--line); font-size: 12.5px; color: var(--ink-dim); flex-wrap:wrap; }
.footer-base .made{ display:inline-flex; align-items:center; gap:7px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; gap: 10px; }
  .hero-scene{ min-height: 560px; margin-top: 18px; }
  .steps{ grid-template-columns: 1fr; }
  .roadmap{ grid-template-columns: 1fr; }
  .meet{ grid-template-columns: 1fr; gap: 30px; }
  .finale{ grid-template-columns: 1fr; text-align:left; }
  .fin-art{ display:none; }
}
@media (max-width: 720px){
  .nav-links{ display:none; }
  .float-chip{ display:none; }
}
@media (max-width: 560px){
  .wrap{ padding: 0 18px; }
  .companion-cards{ grid-template-columns: 1fr; max-width: 280px; margin:0 auto; }
  .hero h1{ font-size: 40px; }
}

/* ---------- founder ---------- */
.founder{ display:grid; grid-template-columns: 0.82fr 1.18fr; gap: 44px; align-items:center; }
.founder-photo img{ width:100%; border-radius: 26px; border: 2px solid var(--ink); box-shadow: 0 8px 0 rgba(31,15,8,0.14); object-fit:cover; object-position: 50% 28%; aspect-ratio: 4 / 5; }
.founder-copy .kicker{ margin-bottom: 6px; }
.founder-copy p{ font-size: 16px; line-height: 1.62; color: var(--ink-soft); margin: 14px 0 0; text-wrap: pretty; }
.founder-sign{ font-family: var(--font-disp); font-weight: 700; color: var(--ink) !important; font-size: 19px; margin-top: 18px !important; }
@media (max-width: 760px){
  .founder{ grid-template-columns: 1fr; gap: 22px; }
  .founder-photo{ max-width: 320px; }
}

/* ---------- launch countdown ---------- */
.countdown{ margin-top: 26px; display:flex; align-items:center; gap:14px; flex-wrap:wrap; }
.countdown .cd-label{ font-size:12.5px; font-weight:800; letter-spacing:1.2px; text-transform:uppercase; color:var(--green-dark); }
.cd-cells{ display:flex; gap:8px; }
.cd-cell{ background:var(--surface); border:2px solid var(--ink); border-radius:14px; box-shadow:0 4px 0 var(--ink); padding:8px 12px; text-align:center; min-width:56px; }
.cd-cell b{ display:block; font-family:var(--font-disp); font-weight:800; font-size:24px; line-height:1; color:var(--ink); font-variant-numeric:tabular-nums; }
.cd-cell small{ display:block; font-size:10px; font-weight:800; letter-spacing:.5px; text-transform:uppercase; color:var(--ink-dim); margin-top:4px; }
.countdown.launched .cd-cells{ display:none; }
.countdown.launched .cd-label{ font-size:15px; letter-spacing:0; text-transform:none; }
