/* ============================================================
   RINGSIDE — marketing site stylesheet
   Brand DNA carried from the app: parchment + ink + ember,
   Big Shoulders Display / DM Sans, paper grain. Pushed louder,
   into a cinematic, photographic direction.
   ============================================================ */

/* ---- Self-hosted brand fonts (same TTFs the app ships) ---- */
@font-face{font-family:"Big Shoulders Display";src:url("/fonts/BigShouldersDisplay-Regular.ttf")  format("truetype");font-weight:400;font-display:swap;}
@font-face{font-family:"Big Shoulders Display";src:url("/fonts/BigShouldersDisplay-Medium.ttf")   format("truetype");font-weight:500;font-display:swap;}
@font-face{font-family:"Big Shoulders Display";src:url("/fonts/BigShouldersDisplay-SemiBold.ttf") format("truetype");font-weight:600;font-display:swap;}
@font-face{font-family:"Big Shoulders Display";src:url("/fonts/BigShouldersDisplay-Bold.ttf")     format("truetype");font-weight:700;font-display:swap;}
/* No ExtraBold (800) static instance ships — map the design's 800 headlines to Black. */
@font-face{font-family:"Big Shoulders Display";src:url("/fonts/BigShouldersDisplay-Black.ttf")    format("truetype");font-weight:800;font-display:swap;}
@font-face{font-family:"Big Shoulders Display";src:url("/fonts/BigShouldersDisplay-Black.ttf")    format("truetype");font-weight:900;font-display:swap;}
@font-face{font-family:"DM Sans";src:url("/fonts/DMSans-9pt.ttf")       format("truetype");font-weight:400;font-display:swap;}
@font-face{font-family:"DM Sans";src:url("/fonts/DMSans-9ptMedium.ttf") format("truetype");font-weight:500;font-display:swap;}
@font-face{font-family:"DM Sans";src:url("/fonts/DMSans-9ptBold.ttf")   format("truetype");font-weight:700;font-display:swap;}

:root{
  --parchment:#F2EBDD;
  --parchment-app:#FAF4E8;
  --parchment-deep:#E8E0CD;
  --ink:#1A1611;
  --ink-2:#221C15;
  --ember:#E64A2E;
  --ember-deep:#B8371D;
  --ember-tint:#F1DCCD;
  --slate:#5E6B66;
  --brass:#C4922E;
  --muted:#5C5347;
  --muted-ink:#B9AE9C;
  --cream:#F7F1E5;
  --line:rgba(26,22,17,.14);
  --line-ink:rgba(247,241,229,.16);
  --disp:'Big Shoulders Display','Arial Narrow',sans-serif;
  --sans:'DM Sans',-apple-system,Helvetica,Arial,sans-serif;
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  --maxw:1280px;
  --gut:clamp(20px,5vw,72px);
}

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

/* grain overlay helper */
.grain{position:absolute;inset:0;background-image:var(--grain);background-size:180px;pointer-events:none;z-index:1;}
.bg-parch .grain{opacity:.5;mix-blend-mode:multiply;}
.bg-ink .grain{opacity:.3;mix-blend-mode:soft-light;}

/* ---- type ---- */
.disp{font-family:var(--disp);text-transform:uppercase;line-height:.9;letter-spacing:-.01em;font-weight:800;}
.eyebrow{
  font-family:var(--disp);font-weight:700;
  font-size:clamp(13px,1.05vw,16px);letter-spacing:.26em;text-transform:uppercase;
  color:var(--ember);display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--ember);display:inline-block;}
.eyebrow.no-rule::before{display:none;}

/* ---- layout shells ---- */
section{position:relative;}
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut);position:relative;z-index:2;}
.bg-parch{background:var(--parchment);color:var(--ink);}
.bg-cream{background:var(--parchment-app);color:var(--ink);}
.bg-ink{background:var(--ink);color:var(--cream);}
.bg-ink .eyebrow{color:var(--ember);}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gut);
  transition:background .3s ease,border-color .3s ease,padding .3s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(242,235,221,.82);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  border-bottom:1px solid var(--line);
  padding-block:13px;
}
.lockup{display:flex;align-items:center;gap:11px;}
.wm{font-family:var(--disp);font-weight:800;font-size:24px;letter-spacing:.04em;text-transform:uppercase;line-height:1;}
.wm .dot{color:var(--ember);}
.nav-links{display:flex;gap:34px;align-items:center;}
.nav-links a{
  font-family:var(--disp);font-weight:600;font-size:15px;letter-spacing:.13em;text-transform:uppercase;
  color:var(--muted);transition:color .2s;white-space:nowrap;
}
.nav-links a:hover{color:var(--ink);}
.nav-right{display:flex;align-items:center;gap:20px;}

/* CTA pill — "get notified" (pre-launch). Same weight as an App Store badge. */
.btn-store{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--ink);color:var(--cream);
  padding:13px 22px 13px 18px;border-radius:999px;
  border:1px solid var(--ink);
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
  cursor:pointer;
}
.btn-store:hover{transform:translateY(-2px);box-shadow:0 14px 28px -14px rgba(26,22,17,.6);background:#000;}
.btn-store .glyph{width:21px;height:21px;flex:0 0 auto;fill:var(--cream);transition:transform 0.25s cubic-bezier(0.25, 0.46, 0.45, 0.94);}
.btn-store:hover .glyph{transform:scale(1.05) translateX(3px);}
.btn-store .bs-tx{display:flex;flex-direction:column;line-height:1;text-align:left;}
.btn-store .bs-sm{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-ink);font-weight:600;}
.btn-store .bs-lg{font-family:var(--disp);font-weight:700;font-size:20px;letter-spacing:.02em;margin-top:2px;}
.btn-store.on-ink{background:var(--cream);color:var(--ink);border-color:var(--cream);}
.btn-store.on-ink .glyph{fill:var(--ink);}
.btn-store.on-ink .bs-sm{color:var(--muted);}
.btn-store.ember{background:var(--ember);border-color:var(--ember);color:var(--cream);}
.btn-store.ember .glyph{fill:var(--cream);}
.btn-store.ember .bs-sm{color:#FAD9CE;}
.btn-store.lg{padding:18px 30px 18px 26px;}
.btn-store.lg .bs-lg{font-size:26px;}
.btn-store.lg .glyph{width:24px;height:24px;}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding-top:clamp(130px,17vh,210px);padding-bottom:clamp(60px,8vw,110px);overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,4vw,64px);align-items:center;}
.hero-kicker{margin-bottom:26px;}
.hero h1{
  font-family:var(--disp);font-weight:800;text-transform:uppercase;
  font-size:clamp(64px,11vw,168px);line-height:.84;letter-spacing:-.02em;margin:0;
  color:var(--ink);
}
.hero h1 .pd{color:var(--ember);}
.hero-sub{
  margin-top:30px;font-size:clamp(18px,1.7vw,24px);line-height:1.4;color:var(--muted);
  max-width:32ch;font-weight:500;
}
.hero-cta{margin-top:40px;display:flex;align-items:center;gap:22px;flex-wrap:wrap;}
.hero-meta{font-family:var(--disp);font-weight:600;font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);line-height:1.5;}
.hero-meta b{color:var(--ink);font-weight:700;}

.hero-stage{position:relative;display:flex;justify-content:center;align-items:center;perspective:1200px;}
.hero-glow{
  position:absolute;width:120%;height:120%;left:-10%;top:-6%;
  background:radial-gradient(closest-side, rgba(230,74,46,.22), rgba(230,74,46,0) 70%);
  z-index:0;filter:blur(6px);
}

/* device frame (carried from app store assets) */
.device-wrap{position:relative;z-index:2;transform-style:preserve-3d;}
.device-wrap.float{animation:floaty 7s ease-in-out infinite;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-14px);}}

.device{
  position:relative;width:min(360px,82vw);
  background:linear-gradient(150deg,#2c2722 0%,#0c0a08 38%,#1c1813 60%,#000 100%);
  border-radius:46px;padding:8px;
  box-shadow:0 0 0 1.5px #000,0 2px 3px 1px rgba(255,255,255,.10) inset,0 -2px 4px 1px rgba(0,0,0,.6) inset,0 50px 80px -38px rgba(0,0,0,.6);
  z-index:2;
  transform-style:preserve-3d;
  transition:transform 0.18s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.device::after{content:"";position:absolute;right:-3px;top:150px;width:4px;height:62px;background:linear-gradient(#1a1712,#000);border-radius:3px;}
.device .screen{border-radius:39px;overflow:hidden;background:#000;box-shadow:0 0 0 2px rgba(0,0,0,.9);}
.device.tilt{transform:rotate(-3deg);}

/* ---- photographic hero ---- */
.hero-photo-sec{color:var(--cream);position:relative;background:#15110D;}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden;background:#15110D;}
.hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;}
/* color wash: ink for legibility on the left, ember warmth toward the device */
.hero-tint{position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(99deg, rgba(18,15,11,.95) 0%, rgba(18,15,11,.80) 30%, rgba(26,22,17,.32) 56%, rgba(184,55,29,.30) 84%, rgba(230,74,46,.42) 100%),
    radial-gradient(78% 95% at 90% 112%, rgba(230,74,46,.62) 0%, rgba(230,74,46,0) 58%),
    radial-gradient(60% 70% at 8% -8%, rgba(196,146,46,.30) 0%, rgba(196,146,46,0) 55%);
}
.hero-vignette{position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 -130px 170px -70px rgba(10,8,5,.92), inset 0 70px 120px -50px rgba(10,8,5,.6);}
.hero-photo-sec .grain{opacity:.42;mix-blend-mode:soft-light;}
.hero-photo-sec .hero-glow{background:radial-gradient(closest-side, rgba(230,74,46,.34), rgba(230,74,46,0) 70%);}
.hero-photo-sec h1{color:var(--cream);text-shadow:0 2px 30px rgba(10,8,5,.45);}
.hero-photo-sec .hero-sub{color:rgba(247,241,229,.86);}
.hero-photo-sec .hero-meta{color:var(--muted-ink);}
.hero-photo-sec .hero-meta b{color:var(--cream);}

/* ---- nav over the dark hero (before scroll) ---- */
.nav:not(.scrolled) .wm{color:var(--cream);}
.nav:not(.scrolled) .lk-ring{stroke:var(--cream);}
.nav:not(.scrolled) .nav-links a{color:rgba(247,241,229,.82);}
.nav:not(.scrolled) .nav-links a:hover{color:var(--cream);}
.nav:not(.scrolled) .btn-store{background:var(--cream);color:var(--ink);border-color:var(--cream);}
.nav:not(.scrolled) .btn-store .glyph{fill:var(--ink);}
.nav:not(.scrolled) .btn-store .bs-sm{color:var(--muted);}
.nav:not(.scrolled) .btn-store:hover{box-shadow:0 14px 28px -14px rgba(0,0,0,.5);}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{border-block:1px solid var(--line);overflow:hidden;padding:18px 0;background:var(--parchment-deep);-webkit-mask-image:linear-gradient(to right, transparent, black 12%, black 88%, transparent);mask-image:linear-gradient(to right, transparent, black 12%, black 88%, transparent);}
.bg-ink .marquee{border-color:var(--line-ink);}
.marquee-track{display:flex;gap:0;white-space:nowrap;width:max-content;animation:marq 32s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-track span{
  font-family:var(--disp);font-weight:700;font-size:clamp(22px,2.4vw,34px);
  letter-spacing:.06em;text-transform:uppercase;color:var(--ink);padding:0 28px;display:inline-flex;align-items:center;gap:28px;
}
.marquee-track span::after{content:"";width:9px;height:9px;border-radius:50%;background:var(--ember);}
@keyframes marq{to{transform:translateX(-50%);}}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.sec{padding-block:clamp(80px,11vw,160px);}
.sec-head{max-width:760px;margin-bottom:clamp(40px,5vw,68px);}
.sec-head h2{
  font-family:var(--disp);font-weight:800;text-transform:uppercase;
  font-size:clamp(42px,6.5vw,104px);line-height:.86;letter-spacing:-.015em;margin:18px 0 0;
}
.sec-head h2 .em{color:var(--ember);}
.sec-head p{font-size:clamp(17px,1.5vw,21px);line-height:1.45;color:var(--muted);margin-top:24px;max-width:48ch;font-weight:500;}
.bg-ink .sec-head p{color:var(--muted-ink);}

.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center;}
.split.rev .split-media{order:2;}

/* ============================================================
   LIVE MODE
   ============================================================ */
.live-card{
  position:relative;border:1px solid rgba(230,74,46,.4);border-radius:30px;
  background:rgba(13,10,7,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  padding:clamp(28px,3.4vw,46px);overflow:hidden;
}
.live-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:34px;}
.live-name{font-family:var(--disp);font-weight:700;font-size:22px;letter-spacing:.05em;}
.live-badge{font-family:var(--disp);font-weight:700;font-size:15px;letter-spacing:.18em;color:var(--ember);display:inline-flex;align-items:center;gap:9px;}
.live-badge .dot{width:11px;height:11px;border-radius:50%;background:var(--ember);box-shadow:0 0 16px var(--ember);animation:pulse 1.15s cubic-bezier(0.25, 0.8, 0.25, 1) infinite;}
@keyframes pulse{
  0%, 100% { opacity: 1; transform: scale(1); }
  14% { opacity: 0.85; transform: scale(1.15); }
  28% { opacity: 1; transform: scale(1.02); }
  42% { opacity: 0.9; transform: scale(1.1); }
  70% { opacity: 0.5; transform: scale(0.85); }
}
.live-hr{display:flex;align-items:flex-end;gap:18px;}
.hr-heart{width:54px;height:54px;color:var(--ember);font-size:54px;margin-bottom:14px;animation:beat 1.15s cubic-bezier(0.25, 0.8, 0.25, 1) infinite;transform-origin:center;}
.sf-heart{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text",sans-serif;
  font-weight:900;line-height:1;letter-spacing:0;
}
@keyframes beat{
  0%, 100% { transform: scale(1); }
  14% { transform: scale(1.24); }
  28% { transform: scale(1.06); }
  42% { transform: scale(1.16); }
  70% { transform: scale(1); }
}
.hr-num{font-family:var(--disp);font-weight:800;font-size:clamp(86px,12vw,150px);line-height:.8;color:var(--ember);font-variant-numeric:tabular-nums;transition:transform 0.15s ease-out, filter 0.15s ease-out;display:inline-block;}
.hr-num.tick-pulse{animation:tickFlash 0.35s cubic-bezier(0.175, 0.885, 0.32, 1.275);}
@keyframes tickFlash{
  0% { transform: scale(1); filter: brightness(1); }
  35% { transform: scale(1.06); filter: brightness(1.22) drop-shadow(0 0 10px rgba(230,74,46,0.35)); }
  100% { transform: scale(1); filter: brightness(1); }
}
.hr-unit{font-family:var(--disp);font-weight:600;font-size:26px;letter-spacing:.08em;color:var(--muted-ink);margin-bottom:18px;}
.live-meta{display:flex;justify-content:space-between;align-items:flex-end;margin-top:30px;padding-top:26px;border-top:1px solid var(--line-ink);}
.live-zone .zl{font-family:var(--disp);font-size:13px;letter-spacing:.2em;color:var(--muted-ink);text-transform:uppercase;}
.live-zone .zv{font-family:var(--disp);font-weight:800;font-size:40px;color:var(--cream);line-height:1;margin-top:4px;}
.live-msg{font-size:18px;color:var(--cream);font-weight:500;}
/* zone bar */
.zonebar{display:flex;gap:6px;margin-top:26px;}
.zonebar i{height:9px;flex:1;border-radius:3px;background:rgba(247,241,229,.16);transition:background .4s;}
.zonebar i.on{background:var(--ember);}

/* ============================================================
   READINESS RING (animated)
   ============================================================ */
.ring-wrap{position:relative;display:flex;align-items:center;justify-content:center;}
.ring-svg{width:min(440px,86vw);height:auto;transform:rotate(-90deg);overflow:visible;}
.ring-track{fill:none;stroke:var(--parchment-deep);stroke-width:14;}
.bg-ink .ring-track{stroke:rgba(247,241,229,.12);}
.ring-prog{fill:none;stroke-width:14;stroke-linecap:round;}
.ring-knob{filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));transition:transform 0.15s ease-out;}
.ring-knob.pulse-active {animation:knobGlow 2.5s ease-in-out infinite;}
@keyframes knobGlow {
  0%, 100% { filter: drop-shadow(0 2px 6px rgba(0,0,0,.35)) drop-shadow(0 0 1px rgba(230,74,46,0)); }
  50% { filter: drop-shadow(0 2px 10px rgba(0,0,0,.35)) drop-shadow(0 0 10px rgba(230,74,46,0.6)); }
}
.ring-center{position:absolute;text-align:center;display:flex;flex-direction:column;align-items:center;}
.ring-center .rc-lab{font-family:var(--disp);font-weight:700;font-size:15px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);}
.bg-ink .ring-center .rc-lab{color:var(--muted-ink);}
.ring-center .rc-num{font-family:var(--disp);font-weight:800;font-size:clamp(96px,12vw,150px);line-height:.82;font-variant-numeric:tabular-nums;}
.ring-center .rc-msg{font-family:var(--disp);font-weight:600;font-size:20px;letter-spacing:.04em;color:var(--ember);margin-top:4px;text-transform:uppercase;}

/* stat columns */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--line);}
.bg-ink .stats{border-color:var(--line-ink);}
.stat{padding:26px 4px 26px 22px;border-bottom:1px solid var(--line);border-left:3px solid var(--ember);position:relative;}
.bg-ink .stat{border-bottom-color:var(--line-ink);}
.stat:nth-child(odd){border-left-color:var(--ember);}
.stat .sl{font-family:var(--disp);font-weight:700;font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);}
.bg-ink .stat .sl{color:var(--muted-ink);}
.stat .sv{font-family:var(--disp);font-weight:800;font-size:clamp(44px,5vw,64px);line-height:.9;margin-top:8px;font-variant-numeric:tabular-nums;}
.stat .su{font-family:var(--sans);font-size:15px;color:var(--muted);font-weight:500;margin-left:6px;}

/* ============================================================
   OURA + APPLE COMPARISON
   ============================================================ */
.compare-board{
  position:relative;overflow:hidden;border-radius:30px;
  background:rgba(247,241,229,.06);
  border:1px solid var(--line-ink);
  padding:clamp(24px,3vw,36px);
  color:var(--cream);
  box-shadow:0 34px 70px -46px rgba(0,0,0,.75);
}
.compare-board::before{
  content:"";position:absolute;inset:0;background-image:var(--grain);
  opacity:.2;mix-blend-mode:soft-light;pointer-events:none;
}
.compare-title{
  position:relative;z-index:1;
  font-family:var(--disp);font-weight:700;font-size:12px;
  letter-spacing:.24em;text-transform:uppercase;color:var(--ember);
  padding-bottom:18px;border-bottom:1px solid var(--line-ink);
}
.compare-row{
  position:relative;z-index:1;
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:center;
  padding:20px 0;border-bottom:1px solid var(--line-ink);
}
.compare-row:last-child{border-bottom:0;padding-bottom:0;}
.compare-label{
  font-family:var(--disp);font-weight:700;font-size:14px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--cream);
}
.compare-label span{
  display:block;margin-top:5px;font-family:var(--sans);font-weight:500;
  font-size:12px;letter-spacing:0;text-transform:none;color:var(--muted-ink);
}
.compare-sources{
  margin-top:8px;font-size:14px;font-weight:500;color:var(--muted-ink);
  font-variant-numeric:tabular-nums;
}
.compare-headline{
  display:grid;grid-template-columns:auto auto;grid-template-rows:auto auto;
  column-gap:8px;align-items:center;justify-items:end;text-align:right;
}
.compare-headline i{
  width:8px;height:8px;border-radius:50%;background:var(--muted-ink);
  grid-row:1;grid-column:1;align-self:center;
}
.compare-headline strong{
  font-family:var(--disp);font-weight:800;font-size:48px;line-height:.85;
  color:var(--cream);font-variant-numeric:tabular-nums;grid-row:1;grid-column:2;
}
.compare-headline small{
  font-size:12px;color:var(--muted-ink);font-weight:500;grid-column:2;
}

/* ============================================================
   WIDGETS GALLERY
   ============================================================ */
.widget-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(16px, 2vw, 26px);
}

@media (min-width: 768px) {
  .widget-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .wcard-medium, .wcard-la {
    grid-column: span 2;
  }
}

@media (min-width: 1024px) {
  .widget-grid {
    grid-template-columns: repeat(3, 1fr);
  }
  .wcard-small, .wcard-lock {
    grid-column: span 1;
  }
  .wcard-medium, .wcard-la {
    grid-column: span 2;
  }
}

.wcard{
  position:relative;border-radius:26px;padding:26px;overflow:hidden;
  border:1px solid var(--line);background:var(--parchment-app);
  min-height:230px;display:flex;flex-direction:column;justify-content:space-between;
}
.wcard.dark{background:var(--ink);border-color:rgba(247,241,229,.1);color:var(--cream);}
.wcard .wlab{font-family:var(--disp);font-weight:700;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);position:relative;z-index:2;}
.wcard.dark .wlab{color:var(--muted-ink);}
.wcard .wcap{font-family:var(--sans);font-size:14px;color:var(--muted);font-weight:500;position:relative;z-index:2;}
.wcard.dark .wcap{color:var(--muted-ink);}

/* Card centering of mockups */
.wcard .ios-widget,
.wcard .lock-preview,
.wcard .live-activity-preview {
  margin: 24px auto;
}
/* iOS widget mockups - mirrored from WidgetExtension/RecoveryWidget.swift */
.ios-widget{
  background:var(--ink);color:var(--cream);
  border:1px solid rgba(247,241,229,.12);
  box-shadow:0 14px 30px -20px rgba(0,0,0,.5);
  position:relative;z-index:2;
}
.system-small-widget{
  width:142px;height:142px;border-radius:28px;
  padding:16px;display:flex;flex-direction:column;align-items:stretch;
}
.system-medium-widget{
  width:292px;height:142px;border-radius:28px;padding:18px;
  display:flex;align-items:center;gap:18px;
}
.medium-copy{min-width:0;display:flex;flex-direction:column;align-items:flex-start;}
.ios-label{
  font-family:var(--disp);font-weight:700;font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted-ink);white-space:nowrap;
}
.small-score-row{display:flex;align-items:center;gap:8px;margin-top:8px;}
.ios-score{
  font-family:var(--disp);font-weight:800;font-size:52px;line-height:.85;
  color:var(--cream);font-variant-numeric:tabular-nums;
}
.ios-readiness-ring{width:42px;height:42px;flex:0 0 auto;}
.medium-ring{width:76px;height:76px;margin-left:auto;}
.medium-score{font-size:58px;margin-top:3px;}
.medium-cue{
  font-size:13px;font-weight:500;line-height:1.18;color:var(--muted-ink);
  max-width:16ch;margin-top:1px;
}
.ios-freshness{margin-top:auto;font-size:11px;color:rgba(185,174,156,.82);}

.mini-widget{background:var(--cream);border-radius:20px;padding:18px 20px;display:flex;align-items:center;gap:16px;box-shadow:0 14px 30px -20px rgba(0,0,0,.5);position:relative;z-index:2;border:1px solid var(--line);}
.mini-widget.on-ink{background:var(--ink);border-color:rgba(247,241,229,.12);}
.mini-widget .mw-ring{width:54px;height:54px;flex:0 0 auto;}
.mini-widget .mw-heart{width:30px;height:30px;margin:0;flex:0 0 auto;color:var(--ember);font-size:31px;}
.mini-widget .mw-num{font-family:var(--disp);font-weight:800;font-size:40px;line-height:.85;color:var(--ink);}
.mini-widget.on-ink .mw-num{color:var(--ember);}
.mini-widget .mw-lab{font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
.mini-widget .mw-msg{font-size:13px;color:var(--muted);margin-top:2px;}
.mini-widget.on-ink .mw-msg{color:var(--muted-ink);}
.live-activity-preview{
  width:350px;max-width:100%;height:84px;
  background:var(--ink);color:var(--cream);
  border-color:rgba(247,241,229,.12);
  padding:12px 16px;
  border-radius:24px;
  display:flex;align-items:center;
}
.live-activity-preview .la-main{
  display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;min-width:0;
}
.la-hr-line{display:flex;align-items:baseline;gap:7px;min-width:0;}
.la-hr-line .mw-heart{align-self:center;margin-right:1px;}
.la-hr-line .mw-num{font-size:44px;color:var(--ember);font-variant-numeric:tabular-nums;}
.mw-unit{font-size:12px;color:var(--muted-ink);font-weight:500;}
.live-activity-preview .mw-msg{color:var(--muted-ink);font-size:12px;margin-top:0;}
.la-readiness{display:flex;flex-direction:column;align-items:flex-end;gap:1px;flex:0 0 auto;}
.la-label{font-family:var(--disp);font-weight:700;font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted-ink);}
.la-value{font-family:var(--disp);font-weight:800;font-size:34px;line-height:.85;color:var(--cream);font-variant-numeric:tabular-nums;}
/* lock-screen accessory widgets */
.lock-preview{
  width:256px;height:104px;
  display:flex;align-items:center;gap:14px;position:relative;z-index:2;min-width:0;
  background:var(--ink);border:1px solid rgba(247,241,229,.12);
  border-radius:24px;padding:20px 18px;box-shadow:0 14px 30px -20px rgba(0,0,0,.5);
}
.accessory-circular{
  width:64px;height:64px;border-radius:50%;position:relative;flex:0 0 auto;
  display:grid;place-items:center;color:var(--cream);z-index:2;
}
.accessory-gauge{position:absolute;inset:0;width:100%;height:100%;}
.accessory-icon{
  position:absolute;top:10px;width:15px;height:15px;color:var(--muted-ink);
}
.accessory-heart{fill:currentColor;}
.accessory-bolt{fill:var(--ink);}
.accessory-score{
  position:absolute;top:26px;font-family:var(--disp);font-weight:800;
  font-size:24px;line-height:.9;color:var(--cream);font-variant-numeric:tabular-nums;
}
.accessory-rect{
  width:142px;height:64px;flex:0 0 auto;
  border-radius:14px;padding:8px 10px;
  background:rgba(247,241,229,.08);border:1px solid rgba(247,241,229,.16);
  display:flex;flex-direction:column;gap:2px;position:relative;z-index:2;
}
.accessory-rect.standalone{width:100%;max-width:250px;flex:0 1 auto;}
.accessory-title{
  font-family:var(--disp);font-weight:700;font-size:13px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--cream);white-space:nowrap;
}
.accessory-copy{font-size:11px;line-height:1.15;color:var(--muted-ink);}

/* ============================================================
   DEVICE STATUS + CHIPS
   ============================================================ */
.device-status-board{
  display:flex;flex-direction:column;gap:16px;max-width:520px;margin-inline:auto;
}
.device-status-card{
  position:relative;overflow:hidden;border-radius:28px;
  background:var(--parchment-app);border:1px solid var(--line);
  padding:24px 26px;box-shadow:0 24px 60px -44px rgba(26,22,17,.72);
}
.device-status-card::after{
  content:"";position:absolute;right:-24px;top:-24px;width:112px;height:112px;
  border-radius:50%;border:16px solid rgba(230,74,46,.12);
}
.device-status-card.watch::after{border-color:rgba(94,107,102,.16);}
.device-status-kicker{
  display:block;font-family:var(--disp);font-weight:700;font-size:12px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--ember);
}
.device-status-main{margin-top:16px;display:flex;flex-direction:column;gap:5px;}
.device-status-main span{
  font-family:var(--sans);font-weight:500;font-size:clamp(22px,2.7vw,32px);
  color:var(--ink);line-height:1.08;
}
.device-status-main strong{
  font-size:15px;color:var(--muted);font-weight:500;
}
.device-status-card p{
  margin:16px 0 0;font-size:14px;color:var(--muted);font-weight:500;
}
.finishes{display:flex;flex-wrap:wrap;gap:14px;margin-top:8px;}
.finish{display:inline-flex;align-items:center;gap:10px;border:1px solid var(--line);border-radius:999px;padding:9px 16px 9px 11px;font-family:var(--disp);font-weight:600;font-size:15px;letter-spacing:.04em;background:var(--parchment-app);}
.finish .sw{width:22px;height:22px;border-radius:50%;border:3px solid;}

/* ============================================================
   CREDIBILITY STRIP
   ============================================================ */
.cred{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px,3vw,48px);}
.cred .ci{border-left:3px solid var(--ember);padding-left:20px;}
.cred .cv{font-family:var(--disp);font-weight:800;font-size:clamp(40px,4.4vw,60px);line-height:.86;}
.cred .ck{font-family:var(--sans);font-size:15px;color:var(--muted);margin-top:10px;font-weight:500;line-height:1.4;}
.bg-ink .cred .ck{color:var(--muted-ink);}

/* compatibility chips */
.compat{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.compat .chip{font-family:var(--disp);font-weight:600;font-size:15px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:999px;padding:9px 18px;}
.bg-ink .compat .chip{color:var(--muted-ink);border-color:var(--line-ink);}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final{text-align:center;}
.final h2{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:clamp(56px,11vw,168px);line-height:.82;letter-spacing:-.02em;margin:0;}
.final h2 .pd{color:var(--ember);}
.final p{font-size:clamp(18px,1.6vw,23px);color:var(--muted);margin:26px auto 40px;max-width:34ch;font-weight:500;}
.final .hero-cta{justify-content:center;}

/* ============================================================
   FOOTER  (link columns + "made by humans")
   ============================================================ */
.footer{background:var(--ink);color:var(--cream);padding-top:clamp(60px,7vw,90px);padding-bottom:46px;}
.foot-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr;gap:clamp(28px,4vw,56px);padding-bottom:54px;border-bottom:1px solid var(--line-ink);}
.foot-brand .wm{font-size:30px;}
.foot-brand .lockup{margin-bottom:18px;}
.foot-brand p{color:var(--muted-ink);font-size:15px;line-height:1.5;margin-top:4px;max-width:30ch;font-weight:500;}
.foot-col h4{font-family:var(--disp);font-weight:700;font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-ink);margin:0 0 18px;}
.foot-col a{display:block;font-size:15px;color:var(--cream);margin-bottom:12px;opacity:.85;transition:opacity .2s,color .2s;}
.foot-col a:hover{opacity:1;color:var(--ember);}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:30px;flex-wrap:wrap;gap:16px;}
.foot-bottom .made{font-family:var(--disp);font-weight:600;font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-ink);display:inline-flex;align-items:center;gap:10px;}
.foot-bottom .made a{color:inherit;transition:color .2s;}
.foot-bottom .made a:hover{color:var(--ember);}
.foot-bottom .made .hb{width:15px;height:15px;fill:var(--ember);}
.foot-bottom .cp{font-size:13px;color:var(--muted-ink);}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{transition:opacity .8s cubic-bezier(.22,.61,.36,1),transform .8s cubic-bezier(.22,.61,.36,1);}
.js .reveal{opacity:0;transform:translateY(28px);}
.reveal.in,.js .reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}
.reveal.d2{transition-delay:.16s;}
.reveal.d3{transition-delay:.24s;}

/* Staggered Group Reveals */
.reveal-group > * {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s cubic-bezier(.22,.61,.36,1), transform 0.8s cubic-bezier(.22,.61,.36,1);
}
.reveal-group.in > * {
  opacity: 1;
  transform: none;
}
@media (prefers-reduced-motion:reduce){
  .reveal, .reveal-group > *{opacity:1;transform:none;transition:none;}
  .device-wrap.float{animation:none;}
  .marquee-track{animation:none;}
  .hr-heart,.live-badge .dot{animation:none;}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:48px;}
  .hero-stage{order:-1;}
  .hero-glow{width:100%;left:0;}
  .split{grid-template-columns:1fr;gap:42px;}
  .split.rev .split-media{order:0;}
  .widget-grid{grid-template-columns:1fr;}
  .cred{grid-template-columns:repeat(2,1fr);gap:30px;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .nav-links{display:none;}
}
@media (max-width:520px){
  .stats{grid-template-columns:1fr;}
  .compare-row{grid-template-columns:1fr;gap:12px;}
  .compare-headline{justify-self:start;text-align:left;}
  .cred{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;}
}

/* ============================================================
   LEGAL PAGES (privacy) — same brand system, simple article flow
   ============================================================ */
.legal-main{max-width:760px;margin:0 auto;padding:clamp(140px,18vh,200px) var(--gut) clamp(80px,11vw,140px);position:relative;z-index:2;}
.legal-hero{margin-bottom:clamp(40px,5vw,64px);border-bottom:1px solid var(--line);padding-bottom:clamp(32px,4vw,48px);}
.legal-hero h1{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:clamp(48px,9vw,104px);line-height:.86;letter-spacing:-.015em;margin:14px 0 0;}
.legal-date{font-family:var(--disp);font-weight:600;font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:20px;}
.legal-intro{font-size:clamp(17px,1.5vw,21px);line-height:1.5;color:var(--muted);margin-top:18px;max-width:54ch;font-weight:500;}
.legal-item{margin-bottom:clamp(28px,3.4vw,42px);}
.legal-item h2{font-family:var(--disp);font-weight:700;text-transform:uppercase;font-size:clamp(22px,2.6vw,30px);letter-spacing:.02em;margin:0 0 12px;}
.legal-item p{font-size:17px;line-height:1.6;color:var(--muted);font-weight:500;}
.legal-item a{color:var(--ember);text-decoration:underline;text-underline-offset:3px;}

/* ============================================================
   GET-NOTIFIED MODAL
   ============================================================ */
html.modal-lock{overflow:hidden;}
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;}
.modal[hidden]{display:none;}
.modal-backdrop{position:absolute;inset:0;background:rgba(13,10,7,.62);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;transition:opacity .24s ease;}
.modal.open .modal-backdrop{opacity:1;}
.modal-card{
  position:relative;z-index:1;width:min(460px,100%);
  max-height:calc(100vh - 48px);overflow:auto;
  background:var(--parchment-app);color:var(--ink);
  border:1px solid var(--line);border-radius:26px;
  padding:clamp(28px,4vw,44px);
  box-shadow:0 40px 90px -30px rgba(10,8,5,.7);
  opacity:0;transform:translateY(16px) scale(.98);
  transition:opacity .24s ease,transform .28s cubic-bezier(.22,.61,.36,1);
}
.modal.open .modal-card{opacity:1;transform:none;}
.modal-close{
  position:absolute;top:16px;right:16px;width:38px;height:38px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  background:transparent;border:1px solid var(--line);color:var(--muted);
  transition:color .2s,border-color .2s,background .2s;
}
.modal-close:hover{color:var(--ink);border-color:var(--ink);}
.modal-close svg{width:18px;height:18px;}
.modal-title{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:clamp(40px,8vw,64px);line-height:.84;letter-spacing:-.015em;margin:14px 0 0;}
.modal-title .pd{color:var(--ember);}
.modal-sub{font-size:16px;line-height:1.5;color:var(--muted);margin:18px 0 0;font-weight:500;max-width:40ch;}

.notify-form{margin-top:26px;display:flex;flex-direction:column;gap:16px;}
.notify-form[hidden]{display:none;}
.notify-done[hidden]{display:none;}
.field{display:flex;flex-direction:column;gap:7px;}
.field-lab{font-family:var(--disp);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
.field-lab em{font-style:normal;font-weight:600;opacity:.7;letter-spacing:.1em;}
.field-in{
  font-family:var(--sans);font-size:16px;color:var(--ink);font-weight:500;
  background:var(--cream);border:1px solid var(--line);border-radius:12px;
  padding:13px 15px;transition:border-color .2s,box-shadow .2s;
}
.field-in::placeholder{color:var(--muted);opacity:.6;}
.field-in:focus{outline:none;border-color:var(--ember);box-shadow:0 0 0 3px rgba(230,74,46,.16);}
.field-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}

.notify-submit{justify-content:center;margin-top:6px;width:100%;}
.notify-submit.loading{opacity:.7;pointer-events:none;}
.notify-status{font-size:14px;color:var(--muted);min-height:18px;margin:2px 0 0;font-weight:500;}
.notify-status.err{color:var(--ember-deep);}

.notify-done{text-align:center;padding:8px 0 4px;}
.notify-done-mark{width:64px;height:64px;border-radius:50%;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;background:var(--ember);color:var(--cream);}
.notify-done-mark svg{width:30px;height:30px;}
.notify-done-title{font-family:var(--disp);font-weight:800;text-transform:uppercase;font-size:clamp(28px,5vw,40px);line-height:.9;letter-spacing:-.01em;margin:0;}
.notify-done-sub{font-size:16px;color:var(--muted);margin:14px auto 26px;max-width:34ch;font-weight:500;}
.notify-done-close{justify-content:center;}

@media (prefers-reduced-motion:reduce){
  .modal-backdrop,.modal-card{transition:none;}
}
