/* Never Forget — Modern minimal Apple-y, blue */

:root {
  --bg: #FFFFFF;
  --bg-alt: #F5F7FA;
  --bg-blue-soft: #EAF4FB;
  --surface: #FFFFFF;
  --ink: #0A1628;
  --ink-2: #1A2942;
  --ink-soft: #4A5568;
  --muted: #8A95A5;
  --line: #E6EBF1;
  --line-soft: #F0F3F7;
  --blue: #38B6E6;
  --blue-deep: #1E94C5;
  --blue-darker: #0F6F9C;
  --blue-soft: #D9EEF8;
  --blue-tint: #F1F8FC;
  --accent: var(--blue);
  --teal: #2BBFB0;
  --coral: #F18A7E;
  --purple: #B19BE0;
  --text: var(--ink);
  --text-soft: var(--ink-soft);
}

[data-theme="dark"] {
  --bg: #07101D;
  --bg-alt: #0D1A2C;
  --bg-blue-soft: #0F2236;
  --surface: #0F1B2E;
  --ink: #F2F6FB;
  --ink-2: #DCE5F0;
  --ink-soft: #A8B5C7;
  --muted: #6B7888;
  --line: #1A2A40;
  --line-soft: #14223A;
  --blue: #4FC1ED;
  --blue-deep: #38B6E6;
  --blue-darker: #1E94C5;
  --blue-soft: #122E44;
  --blue-tint: #0E1F33;
  --text: var(--ink);
  --text-soft: var(--ink-soft);
}

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

html { scroll-behavior: smooth; }

body {
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", "Inter", system-ui, sans-serif;
  font-size: 17px;
  line-height: 1.5;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.011em;
  transition: background-color 0.4s ease, color 0.4s ease;
  overflow-x: hidden;
}

.shell {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
}
@media (max-width: 720px) {
  .shell { padding: 0 22px; }
}

/* Nav */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(24px) saturate(1.6);
  -webkit-backdrop-filter: blur(24px) saturate(1.6);
  background: color-mix(in srgb, var(--bg) 72%, transparent);
  border-bottom: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
}
.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
}
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: -0.02em;
}
.brand-icon {
  width: 30px; height: 30px;
  border-radius: 8px;
  display: block;
  box-shadow: 0 2px 6px rgba(56,182,230,0.25);
}
.nav-links {
  display: flex;
  gap: 36px;
  align-items: center;
  font-size: 14.5px;
  color: var(--text-soft);
  font-weight: 500;
}
.nav-links a {
  color: inherit;
  text-decoration: none;
  transition: color 0.18s;
}
.nav-links a:hover { color: var(--text); }

.nav-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 18px;
  background: var(--ink);
  color: var(--bg);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  transition: transform 0.2s, opacity 0.2s;
  letter-spacing: -0.01em;
}
.nav-cta:hover { transform: translateY(-1px); opacity: 0.92; }

@media (max-width: 720px) {
  .nav-links { display: none; }
}

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 26px;
  border-radius: 999px;
  font-size: 16px;
  font-weight: 600;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: inherit;
  letter-spacing: -0.01em;
}
.btn-primary {
  background: var(--blue);
  color: white;
  box-shadow: 0 8px 20px -6px rgba(56,182,230,0.5);
}
.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px -8px rgba(56,182,230,0.6);
  background: var(--blue-deep);
}
.btn-ghost {
  background: transparent;
  color: var(--text);
  border: 1px solid var(--line);
}
.btn-ghost:hover { background: var(--bg-alt); }

.app-store-badge {
  display: inline-block;
  height: 52px;
  transition: transform 0.2s;
}
.app-store-badge:hover { transform: translateY(-2px); }
.app-store-badge img { height: 100%; display: block; }

/* Sections */
section { padding: 120px 0; position: relative; }
@media (max-width: 720px) { section { padding: 72px 0; } }

.section-eyebrow {
  display: inline-block;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--blue-soft);
  color: var(--blue-darker);
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 20px;
}
[data-theme="dark"] .section-eyebrow { color: var(--blue); }

h1, h2, h3 {
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.05;
  color: var(--text);
}

.h-display {
  font-size: clamp(48px, 7.4vw, 88px);
  letter-spacing: -0.045em;
  font-weight: 700;
}
.h-1 {
  font-size: clamp(38px, 5vw, 60px);
  letter-spacing: -0.04em;
  font-weight: 700;
}
.h-2 {
  font-size: clamp(28px, 3.4vw, 40px);
  letter-spacing: -0.03em;
  line-height: 1.1;
}
.h-3 {
  font-size: clamp(22px, 2.2vw, 28px);
  line-height: 1.2;
  letter-spacing: -0.025em;
}

.lede {
  font-size: clamp(17px, 1.3vw, 20px);
  line-height: 1.55;
  color: var(--text-soft);
  max-width: 60ch;
  font-weight: 400;
  letter-spacing: -0.01em;
}

.gradient-text {
  background: linear-gradient(135deg, var(--blue) 0%, var(--blue-darker) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Reveal */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s cubic-bezier(.2,.7,.2,1), transform 0.9s cubic-bezier(.2,.7,.2,1);
  transition-delay: var(--reveal-delay, 0ms);
}
.reveal.in { opacity: 1; transform: none; }

.reveal-stagger > * {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.7s cubic-bezier(.2,.7,.2,1), transform 0.7s cubic-bezier(.2,.7,.2,1);
}
.reveal-stagger.in > *:nth-child(1) { opacity: 1; transform: none; transition-delay: 0ms; }
.reveal-stagger.in > *:nth-child(2) { opacity: 1; transform: none; transition-delay: 90ms; }
.reveal-stagger.in > *:nth-child(3) { opacity: 1; transform: none; transition-delay: 180ms; }
.reveal-stagger.in > *:nth-child(4) { opacity: 1; transform: none; transition-delay: 270ms; }
.reveal-stagger.in > *:nth-child(5) { opacity: 1; transform: none; transition-delay: 360ms; }
.reveal-stagger.in > *:nth-child(6) { opacity: 1; transform: none; transition-delay: 450ms; }

.fadein { animation: fadein 1.1s cubic-bezier(.2,.7,.2,1) both; }
@keyframes fadein {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: none; }
}

.fadein-up-1 { animation: fadeup 1s cubic-bezier(.2,.7,.2,1) 0.05s both; }
.fadein-up-2 { animation: fadeup 1s cubic-bezier(.2,.7,.2,1) 0.18s both; }
.fadein-up-3 { animation: fadeup 1s cubic-bezier(.2,.7,.2,1) 0.32s both; }
.fadein-up-4 { animation: fadeup 1s cubic-bezier(.2,.7,.2,1) 0.46s both; }
.fadein-up-5 { animation: fadeup 1s cubic-bezier(.2,.7,.2,1) 0.6s both; }
@keyframes fadeup {
  from { opacity: 0; transform: translateY(24px); }
  to { opacity: 1; transform: none; }
}

/* Word-by-word reveal */
.word-reveal { display: inline-block; overflow: hidden; vertical-align: top; }
.word-reveal > span {
  display: inline-block;
  transform: translateY(110%);
  animation: word-rise 1.1s cubic-bezier(.2,.8,.2,1) forwards;
  animation-delay: var(--word-delay, 0ms);
}
@keyframes word-rise {
  to { transform: translateY(0); }
}

/* Floating */
@keyframes float-slow {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  33% { transform: translate(20px, -30px) rotate(2deg); }
  66% { transform: translate(-15px, 25px) rotate(-1.5deg); }
}
@keyframes float-med {
  0%, 100% { transform: translate(0, 0); }
  50% { transform: translate(-12px, -18px); }
}

/* Aurora gradient that breathes */
@keyframes aurora {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.55; }
  50% { transform: translate(40px, -30px) scale(1.15); opacity: 0.75; }
}
@keyframes aurora-2 {
  0%, 100% { transform: translate(0, 0) scale(1); opacity: 0.45; }
  50% { transform: translate(-30px, 35px) scale(1.2); opacity: 0.65; }
}

/* Shine sweep */
@keyframes shine {
  0% { transform: translateX(-120%) skewX(-20deg); }
  100% { transform: translateX(220%) skewX(-20deg); }
}

/* Pulse ring */
@keyframes pulse-ring {
  0% { transform: scale(0.85); opacity: 0.7; }
  100% { transform: scale(1.6); opacity: 0; }
}

/* Slow rotate */
@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* Conic gradient border rotation */
@keyframes conic-spin {
  from { --conic-angle: 0deg; transform: rotate(0deg); }
  to   { --conic-angle: 360deg; transform: rotate(360deg); }
}

/* Marquee */
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Twinkle */
@keyframes twinkle {
  0%, 100% { opacity: 0.2; transform: scale(0.85); }
  50% { opacity: 1; transform: scale(1.1); }
}

/* Gradient drift on text */
@keyframes gradient-drift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

/* Hero parallax helpers */
.parallax {
  transition: transform 0.6s cubic-bezier(.2,.7,.2,1);
  will-change: transform;
}

/* Floating mini cards near hero screenshot */
.hero-stage {
  position: relative;
}
.hero-card {
  position: absolute;
  border-radius: 18px;
  background: var(--surface);
  border: 1px solid var(--line);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow:
    0 24px 48px -16px rgba(15,30,55,0.18),
    0 8px 16px -8px rgba(15,30,55,0.10);
  font-size: 13.5px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: -0.01em;
  white-space: nowrap;
  opacity: 0;
  animation: hero-card-in 0.9s cubic-bezier(.2,.8,.2,1) forwards;
  z-index: 2;
}
.hero-card .dot {
  width: 28px; height: 28px; border-radius: 50%;
  display: grid; place-items: center;
  flex-shrink: 0;
  color: white;
  font-size: 14px;
  font-weight: 700;
}
.hero-card-1 { top: 18%; left: -2%; animation-delay: 0.6s; }
.hero-card-2 { top: 46%; right: -2%; animation-delay: 0.85s; }
.hero-card-3 { bottom: 14%; left: 4%; animation-delay: 1.05s; }
.hero-card-1.float { animation: hero-card-in 0.9s cubic-bezier(.2,.8,.2,1) 0.6s forwards, float-slow 9s ease-in-out 1.6s infinite; }
.hero-card-2.float { animation: hero-card-in 0.9s cubic-bezier(.2,.8,.2,1) 0.85s forwards, float-med 7s ease-in-out 1.9s infinite; }
.hero-card-3.float { animation: hero-card-in 0.9s cubic-bezier(.2,.8,.2,1) 1.05s forwards, float-slow 11s ease-in-out 2.1s infinite reverse; }

@keyframes hero-card-in {
  from { opacity: 0; transform: translateY(20px) scale(0.92); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@media (max-width: 720px) {
  .hero-card { display: none; }
}

/* ---- Hero floaters: soft backdrop of "review items" in the upper hero zone ---- */
/* Stops above the phone screenshot so it doesn't fight the in-frame mini cards. */
.hero-floaters {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 760px;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.hero-floater {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px 9px 9px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--surface) 62%, transparent);
  border: 1px solid color-mix(in srgb, var(--line) 55%, transparent);
  box-shadow:
    0 18px 36px -20px rgba(15,30,55,0.14),
    0 4px 10px -6px rgba(15,30,55,0.05);
  -webkit-backdrop-filter: blur(10px) saturate(1.1);
  backdrop-filter: blur(10px) saturate(1.1);
  font-size: 12px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: -0.01em;
  white-space: nowrap;
  opacity: 0;
  /* fade-in ride, then drift forever */
  animation-name: hero-floater-in, hero-floater-drift-a;
  animation-timing-function: cubic-bezier(.2,.8,.2,1), ease-in-out;
  animation-iteration-count: 1, infinite;
  animation-fill-mode: forwards, none;
  animation-direction: normal, alternate;
  will-change: transform, opacity;
}
.hero-floater-dot {
  width: 26px; height: 26px; border-radius: 8px;
  display: grid; place-items: center;
  flex-shrink: 0;
  color: white;
  font-size: 13px;
  line-height: 1;
}
.hero-floater-text { display: flex; flex-direction: column; gap: 1px; }
.hero-floater-title { font-size: 12.5px; font-weight: 600; color: var(--text); }
.hero-floater-meta {
  font-size: 10.5px;
  font-weight: 600;
  color: var(--muted);
  letter-spacing: 0.4px;
  text-transform: uppercase;
}

/* drift variants — each gives a slightly different path so they don't move in lockstep */
.hero-floater-drift-a { animation-name: hero-floater-in, hero-floater-drift-a; }
.hero-floater-drift-b { animation-name: hero-floater-in, hero-floater-drift-b; }
.hero-floater-drift-c { animation-name: hero-floater-in, hero-floater-drift-c; }

@keyframes hero-floater-in {
  from { opacity: 0; transform: translate3d(0, 14px, 0) scale(0.92); }
  to   { opacity: 0.62; transform: translate3d(0, 0, 0) scale(1); }
}
@keyframes hero-floater-drift-a {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50%      { transform: translate3d(8px, -14px, 0); }
}
@keyframes hero-floater-drift-b {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50%      { transform: translate3d(-10px, -10px, 0); }
}
@keyframes hero-floater-drift-c {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50%      { transform: translate3d(6px, 12px, 0); }
}

/* keep them out of the way on smaller screens — content first */
@media (max-width: 1100px) {
  .hero-floater { transform: scale(0.92); }
}
@media (max-width: 880px) {
  .hero-floaters { display: none; }
}

[data-theme="dark"] .hero-floater {
  background: color-mix(in srgb, var(--surface) 60%, transparent);
  border-color: color-mix(in srgb, var(--line) 50%, transparent);
  box-shadow:
    0 18px 36px -20px rgba(0,0,0,0.4),
    0 4px 10px -6px rgba(0,0,0,0.25);
}

@media (prefers-reduced-motion: reduce) {
  .hero-floater { animation: hero-floater-in 0.9s cubic-bezier(.2,.8,.2,1) forwards !important; }
}

/* Aurora hero background — rebuilt with animation */
.hero-bg-pro {
  position: absolute;
  inset: -10%;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
.hero-bg-pro .blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  will-change: transform, opacity;
}
.hero-bg-pro .blob-1 {
  top: -10%; right: -5%;
  width: 55vw; height: 55vw;
  background: radial-gradient(circle, rgba(56,182,230,0.32), transparent 65%);
  animation: aurora 14s ease-in-out infinite;
}
.hero-bg-pro .blob-2 {
  bottom: -20%; left: -10%;
  width: 50vw; height: 50vw;
  background: radial-gradient(circle, rgba(177,155,224,0.24), transparent 65%);
  animation: aurora-2 18s ease-in-out infinite;
}
.hero-bg-pro .blob-3 {
  top: 30%; left: 35%;
  width: 30vw; height: 30vw;
  background: radial-gradient(circle, rgba(43,191,176,0.18), transparent 65%);
  animation: aurora 22s ease-in-out 2s infinite;
}
[data-theme="dark"] .hero-bg-pro .blob-1 { opacity: 0.7; }
[data-theme="dark"] .hero-bg-pro .blob-2 { opacity: 0.6; }
[data-theme="dark"] .hero-bg-pro .blob-3 { opacity: 0.55; }

/* Grid backdrop */
.grid-backdrop {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(to right, color-mix(in srgb, var(--line) 60%, transparent) 1px, transparent 1px),
    linear-gradient(to bottom, color-mix(in srgb, var(--line) 60%, transparent) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, black 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 40%, black 30%, transparent 80%);
  pointer-events: none;
  opacity: 0.5;
}

/* Animated gradient text — stronger version */
.gradient-text-anim {
  background: linear-gradient(120deg, var(--blue) 0%, #B19BE0 30%, var(--blue-darker) 55%, var(--blue) 80%, #5BC0E8 100%);
  background-size: 240% 240%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: gradient-drift 7s ease-in-out infinite;
}

/* Lede emphasis — bold ink phrase with hand-drawn underline */
.lede-emph {
  position: relative;
  display: inline-block;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
}
.lede-emph::after {
  content: "";
  position: absolute;
  left: -2px;
  right: -2px;
  bottom: -4px;
  height: 8px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 8' preserveAspectRatio='none'><path d='M2 5 C 40 1, 80 7, 120 3 S 180 6, 198 4' fill='none' stroke='%2338B6E6' stroke-width='2.2' stroke-linecap='round'/></svg>");
  background-repeat: no-repeat;
  background-size: 100% 100%;
  pointer-events: none;
  /* Reveal animation: draw in after lede fades up */
  transform-origin: left center;
  transform: scaleX(0);
  animation: lede-emph-draw 0.9s cubic-bezier(.6,.2,.2,1) forwards;
  animation-delay: 1.1s;
}
@keyframes lede-emph-draw {
  to { transform: scaleX(1); }
}
@media (prefers-reduced-motion: reduce) {
  .lede-emph::after { animation: none; transform: scaleX(1); }
}

/* Magnetic / pressable button */
.btn-primary, .nav-cta, .btn-ghost {
  position: relative;
  overflow: hidden;
  transition: transform 0.25s cubic-bezier(.2,.7,.2,1), box-shadow 0.25s, opacity 0.25s, background-color 0.2s;
}
.btn-primary::after, .nav-cta::after {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 60%; height: 100%;
  background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.45) 50%, transparent 100%);
  transform: translateX(-150%) skewX(-20deg);
  pointer-events: none;
}
.btn-primary:hover::after, .nav-cta:hover::after {
  animation: shine 0.9s ease-out;
}

/* Scroll cue */
.scroll-cue {
  position: absolute;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--muted);
  font-weight: 600;
  text-transform: uppercase;
  opacity: 0;
  animation: fadein 1s cubic-bezier(.2,.7,.2,1) 1.4s both;
}
.scroll-cue .line {
  width: 1px; height: 36px;
  background: linear-gradient(to bottom, transparent, var(--muted), transparent);
  position: relative;
  overflow: hidden;
}
.scroll-cue .line::after {
  content: "";
  position: absolute;
  top: -50%; left: 0;
  width: 100%; height: 50%;
  background: linear-gradient(to bottom, transparent, var(--blue));
  animation: scroll-line 2.4s cubic-bezier(.6,.0,.4,1) infinite;
}
@keyframes scroll-line {
  0% { top: -50%; }
  100% { top: 100%; }
}

/* Schedule card 3D tilt + glow */
.feature-card.tilt {
  transform-style: preserve-3d;
  transition: transform 0.35s cubic-bezier(.2,.7,.2,1), box-shadow 0.35s;
  position: relative;
}
.feature-card.tilt::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(600px circle at var(--mx, 50%) var(--my, 50%), rgba(56,182,230,0.10), transparent 40%);
  opacity: 0;
  transition: opacity 0.35s;
  pointer-events: none;
}
.feature-card.tilt:hover::before { opacity: 1; }
.feature-card.tilt:hover {
  box-shadow: 0 30px 60px -20px rgba(15,30,55,0.18), 0 12px 24px -12px rgba(56,182,230,0.18);
}

/* Schedule image gentle bob */
.schedule-img {
  transition: transform 0.5s cubic-bezier(.2,.7,.2,1);
}
.feature-card.tilt:hover .schedule-img {
  transform: translateY(-6px) scale(1.03);
}

/* Premium card animated border */
.premium-glow {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
}
.premium-glow::before {
  content: "";
  position: absolute;
  inset: -2px;
  background: conic-gradient(from var(--ang, 0deg), var(--blue), #B19BE0, var(--blue-darker), var(--blue));
  border-radius: inherit;
  z-index: 0;
  animation: spin-slow 8s linear infinite;
  filter: blur(0.5px);
  opacity: 0.85;
}
.premium-glow > .premium-inner {
  position: relative;
  z-index: 1;
  margin: 1px;
  border-radius: calc(20px - 1px);
  background: var(--surface);
  display: flex;
  flex-direction: column;
  gap: 1px;
  overflow: hidden;
}

/* Premium list — staggered slide-in rows + check draw */
.premium-list .premium-row {
  transform: translateX(40px);
  opacity: 0;
  transition: transform 0.7s cubic-bezier(.2,.8,.2,1), opacity 0.7s cubic-bezier(.2,.8,.2,1);
}
.premium-list.in .premium-row { transform: none; opacity: 1; }
.premium-list.in .premium-row:nth-child(1) { transition-delay: 0.05s; }
.premium-list.in .premium-row:nth-child(2) { transition-delay: 0.18s; }
.premium-list.in .premium-row:nth-child(3) { transition-delay: 0.31s; }
.premium-list.in .premium-row:nth-child(4) { transition-delay: 0.44s; }
.premium-list.in .premium-row:nth-child(5) { transition-delay: 0.57s; }

.premium-list .premium-row::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--blue-tint), transparent 60%);
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
}
.premium-list .premium-row:hover::before { opacity: 1; }

.premium-list .premium-check {
  transform: scale(0.4) rotate(-90deg);
  opacity: 0;
  transition: transform 0.6s cubic-bezier(.5,1.6,.4,1), opacity 0.5s ease;
}
.premium-list.in .premium-row:nth-child(1) .premium-check { transition-delay: 0.25s; }
.premium-list.in .premium-row:nth-child(2) .premium-check { transition-delay: 0.38s; }
.premium-list.in .premium-row:nth-child(3) .premium-check { transition-delay: 0.51s; }
.premium-list.in .premium-row:nth-child(4) .premium-check { transition-delay: 0.64s; }
.premium-list.in .premium-row:nth-child(5) .premium-check { transition-delay: 0.77s; }
.premium-list.in .premium-row .premium-check {
  transform: none;
  opacity: 1;
}

.premium-list .premium-check-path {
  transition: stroke-dashoffset 0.6s cubic-bezier(.4,.6,.3,1);
}
.premium-list.in .premium-row:nth-child(1) .premium-check-path { stroke-dashoffset: 0; transition-delay: 0.45s; }
.premium-list.in .premium-row:nth-child(2) .premium-check-path { stroke-dashoffset: 0; transition-delay: 0.58s; }
.premium-list.in .premium-row:nth-child(3) .premium-check-path { stroke-dashoffset: 0; transition-delay: 0.71s; }
.premium-list.in .premium-row:nth-child(4) .premium-check-path { stroke-dashoffset: 0; transition-delay: 0.84s; }
.premium-list.in .premium-row:nth-child(5) .premium-check-path { stroke-dashoffset: 0; transition-delay: 0.97s; }

/* Premium icons — bespoke per-feature, animated tiles */
.premium-icon {
  position: relative;
  width: 56px;
  height: 56px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  border-radius: 16px;
  overflow: visible;
  transform: scale(0.4) rotate(-18deg);
  opacity: 0;
  transition: transform 0.75s cubic-bezier(.5,1.7,.4,1), opacity 0.5s ease;
}
.premium-list.in .premium-row:nth-child(1) .premium-icon { transition-delay: 0.18s; }
.premium-list.in .premium-row:nth-child(2) .premium-icon { transition-delay: 0.31s; }
.premium-list.in .premium-row:nth-child(3) .premium-icon { transition-delay: 0.44s; }
.premium-list.in .premium-row:nth-child(4) .premium-icon { transition-delay: 0.57s; }
.premium-list.in .premium-row:nth-child(5) .premium-icon { transition-delay: 0.70s; }
.premium-list.in .premium-row .premium-icon {
  transform: scale(1) rotate(0deg);
  opacity: 1;
}

.premium-icon-bg {
  position: absolute; inset: 0;
  border-radius: 16px;
  background:
    radial-gradient(120% 120% at 30% 20%, color-mix(in oklch, var(--blue) 24%, var(--surface)) 0%, color-mix(in oklch, var(--blue) 6%, var(--surface)) 60%, var(--surface) 100%);
  box-shadow:
    inset 0 0 0 1px color-mix(in oklch, var(--blue) 22%, transparent),
    inset 0 -6px 12px -6px color-mix(in oklch, var(--blue) 18%, transparent),
    0 6px 18px -10px color-mix(in oklch, var(--blue) 30%, transparent);
  transition: box-shadow 0.4s ease, transform 0.4s ease;
}
.premium-icon-ring {
  position: absolute; inset: -3px;
  border-radius: 19px;
  pointer-events: none;
  background: conic-gradient(from 0deg,
    color-mix(in oklch, var(--blue) 60%, transparent),
    transparent 35%,
    color-mix(in oklch, var(--blue) 50%, transparent) 60%,
    transparent 90%);
  opacity: 0;
  filter: blur(4px);
  transition: opacity 0.5s ease;
  animation: premium-ring-spin 6s linear infinite;
}
.premium-row:hover .premium-icon-ring { opacity: 0.7; }
.premium-row:hover .premium-icon-bg {
  box-shadow:
    inset 0 0 0 1px color-mix(in oklch, var(--blue) 50%, transparent),
    inset 0 -6px 12px -6px color-mix(in oklch, var(--blue) 35%, transparent),
    0 12px 28px -8px color-mix(in oklch, var(--blue) 50%, transparent);
  transform: translateY(-1px);
}
@keyframes premium-ring-spin {
  to { transform: rotate(360deg); }
}

.premium-icon-glyph {
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 2px 3px color-mix(in oklch, var(--blue) 25%, transparent));
  transition: transform 0.5s cubic-bezier(.5,1.6,.4,1);
}

/* Idle floats — different per icon, staggered */
.premium-icon-infinity .premium-icon-glyph { animation: premium-float-soft 5s ease-in-out infinite; }
.premium-icon-bolt .premium-icon-glyph { animation: premium-bolt-idle 3.6s ease-in-out infinite; }
.premium-icon-tools .premium-tools-gear { transform-origin: 24px 24px; animation: premium-spin 14s linear infinite; }
.premium-icon-palette .premium-icon-glyph { animation: premium-tilt 6s ease-in-out infinite; }
.premium-icon-sparkles .premium-spark-big { transform-origin: 24px 21px; animation: premium-twinkle-big 3.2s ease-in-out infinite; }
.premium-icon-sparkles .premium-spark-mid { transform-origin: 38px 36.5px; animation: premium-twinkle-big 2.4s ease-in-out infinite 0.4s; }
.premium-icon-sparkles .premium-spark-small { transform-origin: 9px 36px; animation: premium-twinkle-big 2.8s ease-in-out infinite 0.8s; }

@keyframes premium-float-soft {
  0%, 100% { transform: translateY(0) rotate(0); }
  50%      { transform: translateY(-2px) rotate(2deg); }
}
@keyframes premium-bolt-idle {
  0%, 92%, 100% { transform: translateY(0) scale(1); }
  94%           { transform: translateY(-1px) scale(1.08); }
  96%           { transform: translateY(0) scale(0.96); }
}
@keyframes premium-spin { to { transform: rotate(360deg); } }
@keyframes premium-tilt {
  0%, 100% { transform: rotate(-3deg); }
  50%      { transform: rotate(5deg); }
}
@keyframes premium-twinkle-big {
  0%, 100% { transform: scale(1) rotate(0); opacity: 1; }
  50%      { transform: scale(1.18) rotate(20deg); opacity: 0.85; }
}

/* Bolt flash — radial pulse behind the lightning */
.premium-bolt-flash {
  position: absolute;
  width: 70%; height: 70%;
  left: 15%; top: 15%;
  border-radius: 50%;
  background: radial-gradient(circle, color-mix(in oklch, var(--blue) 60%, white) 0%, transparent 65%);
  opacity: 0;
  z-index: 1;
  animation: premium-bolt-flash 3.6s ease-in-out infinite;
}
@keyframes premium-bolt-flash {
  0%, 90%, 100% { opacity: 0; transform: scale(0.6); }
  93%           { opacity: 0.9; transform: scale(1.1); }
  97%           { opacity: 0; transform: scale(1.4); }
}

/* Infinity stroke draw on entry */
.premium-infinity-path {
  stroke-dasharray: 140;
  stroke-dashoffset: 140;
  transition: stroke-dashoffset 1.4s cubic-bezier(.4,.6,.3,1) 0.5s;
}
.premium-list.in .premium-row .premium-infinity-path { stroke-dashoffset: 0; }

/* Palette dots — pop in sequentially, then breathe */
.premium-palette-dot {
  transform: scale(0);
  transform-origin: center;
  transition: transform 0.5s cubic-bezier(.5,1.7,.4,1);
}
.premium-palette-dot-1 { fill: #5BC5E5; }
.premium-palette-dot-2 { fill: #B19BE0; }
.premium-palette-dot-3 { fill: #F0B36B; }
.premium-palette-dot-4 { fill: #E07B95; }
.premium-list.in .premium-row .premium-palette-dot-1 { transform: scale(1); transition-delay: 0.85s; }
.premium-list.in .premium-row .premium-palette-dot-2 { transform: scale(1); transition-delay: 0.97s; }
.premium-list.in .premium-row .premium-palette-dot-3 { transform: scale(1); transition-delay: 1.09s; }
.premium-list.in .premium-row .premium-palette-dot-4 { transform: scale(1); transition-delay: 1.21s; }
.premium-row:hover .premium-palette-dot { animation: premium-dot-breathe 1.8s ease-in-out infinite; }
.premium-row:hover .premium-palette-dot-2 { animation-delay: 0.15s; }
.premium-row:hover .premium-palette-dot-3 { animation-delay: 0.30s; }
.premium-row:hover .premium-palette-dot-4 { animation-delay: 0.45s; }
@keyframes premium-dot-breathe {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.35); }
}

/* Mini sparkles around each tile */
.premium-mini-spark {
  position: absolute;
  font-size: 10px;
  color: var(--blue);
  opacity: 0;
  pointer-events: none;
  text-shadow: 0 0 8px color-mix(in oklch, var(--blue) 60%, transparent);
  z-index: 3;
}
.premium-mini-spark-1 { top: -4px; right: -4px; }
.premium-mini-spark-2 { bottom: -4px; left: -2px; font-size: 8px; }
.premium-mini-spark-3 { top: 14px; right: -8px; font-size: 7px; }

.premium-row:hover .premium-mini-spark-1 { animation: premium-spark-pop 1s ease-out 0.05s; }
.premium-row:hover .premium-mini-spark-2 { animation: premium-spark-pop 1s ease-out 0.20s; }
.premium-row:hover .premium-mini-spark-3 { animation: premium-spark-pop 1s ease-out 0.35s; }

@keyframes premium-spark-pop {
  0%   { opacity: 0; transform: scale(0.2) rotate(0); }
  35%  { opacity: 1; transform: scale(1.5) rotate(90deg); }
  100% { opacity: 0; transform: scale(0.6) translate(8px, -10px) rotate(180deg); }
}

/* Entry sparkle burst as each row arrives */
.premium-list.in .premium-row:nth-child(1) .premium-mini-spark-1 { animation: premium-spark-pop 1s ease-out 0.55s 1; }
.premium-list.in .premium-row:nth-child(1) .premium-mini-spark-2 { animation: premium-spark-pop 1s ease-out 0.70s 1; }
.premium-list.in .premium-row:nth-child(2) .premium-mini-spark-1 { animation: premium-spark-pop 1s ease-out 0.68s 1; }
.premium-list.in .premium-row:nth-child(2) .premium-mini-spark-2 { animation: premium-spark-pop 1s ease-out 0.83s 1; }
.premium-list.in .premium-row:nth-child(3) .premium-mini-spark-1 { animation: premium-spark-pop 1s ease-out 0.81s 1; }
.premium-list.in .premium-row:nth-child(3) .premium-mini-spark-2 { animation: premium-spark-pop 1s ease-out 0.96s 1; }
.premium-list.in .premium-row:nth-child(4) .premium-mini-spark-1 { animation: premium-spark-pop 1s ease-out 0.94s 1; }
.premium-list.in .premium-row:nth-child(4) .premium-mini-spark-2 { animation: premium-spark-pop 1s ease-out 1.09s 1; }
.premium-list.in .premium-row:nth-child(5) .premium-mini-spark-1 { animation: premium-spark-pop 1s ease-out 1.07s 1; }
.premium-list.in .premium-row:nth-child(5) .premium-mini-spark-2 { animation: premium-spark-pop 1s ease-out 1.22s 1; }

/* Row sheen — sweeps across on hover */
.premium-row-sheen {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg,
    transparent 30%,
    color-mix(in oklch, var(--blue) 14%, transparent) 50%,
    transparent 70%);
  transform: translateX(-100%);
  transition: transform 0.9s cubic-bezier(.4,.6,.3,1);
  pointer-events: none;
  z-index: 0;
}
.premium-row:hover .premium-row-sheen { transform: translateX(100%); }

/* Section ambient particles */
.premium-particles {
  position: absolute; inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
.premium-particle {
  position: absolute;
  bottom: -20px;
  width: 6px; height: 6px;
  border-radius: 50%;
  opacity: 0;
  animation: premium-rise linear infinite;
}
.premium-particle-1 {
  background: radial-gradient(circle, color-mix(in oklch, var(--blue) 80%, white) 0%, transparent 70%);
  width: 5px; height: 5px;
}
.premium-particle-2 {
  background: radial-gradient(circle, color-mix(in oklch, var(--blue) 60%, white) 0%, transparent 70%);
  width: 8px; height: 8px;
}
.premium-particle-3 {
  width: 4px; height: 4px;
  background: var(--blue);
  box-shadow: 0 0 10px color-mix(in oklch, var(--blue) 70%, transparent);
}
.premium-particle-4 {
  width: 10px; height: 10px;
  background: radial-gradient(circle, color-mix(in oklch, var(--blue) 35%, white) 0%, transparent 65%);
}
@keyframes premium-rise {
  0%   { transform: translateY(0) translateX(0); opacity: 0; }
  10%  { opacity: 0.7; }
  50%  { transform: translateY(-50vh) translateX(20px); opacity: 0.5; }
  90%  { opacity: 0.3; }
  100% { transform: translateY(-100vh) translateX(-15px); opacity: 0; }
}

/* Big diffuse orbs for depth */
.premium-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  opacity: 0.45;
  pointer-events: none;
}
.premium-orb-1 {
  width: 380px; height: 380px;
  top: -120px; left: -120px;
  background: radial-gradient(circle, color-mix(in oklch, var(--blue) 60%, transparent) 0%, transparent 70%);
  animation: premium-orb-drift 18s ease-in-out infinite;
}
.premium-orb-2 {
  width: 460px; height: 460px;
  bottom: -180px; right: -160px;
  background: radial-gradient(circle, color-mix(in oklch, #B19BE0 50%, transparent) 0%, transparent 70%);
  animation: premium-orb-drift 22s ease-in-out infinite reverse;
}
@keyframes premium-orb-drift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33%      { transform: translate(40px, -30px) scale(1.08); }
  66%      { transform: translate(-30px, 20px) scale(0.95); }
}

/* Eyebrow star */
.premium-eyebrow-star {
  display: inline-block;
  margin-right: 6px;
  color: var(--blue);
  animation: premium-twinkle-big 2.4s ease-in-out infinite;
  transform-origin: center;
}

/* CTA shine */
.premium-cta { position: relative; overflow: hidden; }
.premium-cta-shine {
  position: absolute; inset: 0;
  background: linear-gradient(105deg,
    transparent 35%,
    rgba(255,255,255,0.45) 50%,
    transparent 65%);
  transform: translateX(-120%);
  pointer-events: none;
}
.premium-cta:hover .premium-cta-shine { animation: premium-cta-sweep 1.1s ease; }
@keyframes premium-cta-sweep {
  to { transform: translateX(120%); }
}

@media (prefers-reduced-motion: reduce) {
  .premium-icon-glyph,
  .premium-tools-gear,
  .premium-spark-big,
  .premium-spark-mid,
  .premium-spark-small,
  .premium-bolt-flash,
  .premium-mini-spark,
  .premium-particle,
  .premium-orb,
  .premium-eyebrow-star,
  .premium-icon-ring,
  .premium-row:hover .premium-palette-dot { animation: none !important; }
}

/* Pulsing dot */
.pulse-dot {
  position: relative;
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--blue);
}
.pulse-dot::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--blue);
  animation: pulse-ring 1.6s cubic-bezier(.2,.7,.2,1) infinite;
}

/* Privacy data packet flow */
.packet {
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #5BC0E8;
  box-shadow: 0 0 12px #5BC0E8, 0 0 20px rgba(91,192,232,0.5);
  left: 50%;
  top: 0;
  margin-left: -3px;
  opacity: 0;
}
.packet.up {
  animation: packet-up 2.6s linear infinite;
}
.packet.down {
  animation: packet-down 2.6s linear infinite;
}
@keyframes packet-up {
  0% { transform: translateY(48px); opacity: 0; }
  20% { opacity: 1; }
  80% { opacity: 1; }
  100% { transform: translateY(-72px); opacity: 0; }
}
@keyframes packet-down {
  0% { transform: translateY(-72px); opacity: 0; }
  20% { opacity: 1; }
  80% { opacity: 1; }
  100% { transform: translateY(48px); opacity: 0; }
}

/* Section eyebrow shimmer */
.section-eyebrow {
  position: relative;
  overflow: hidden;
}
.section-eyebrow::after {
  content: "";
  position: absolute;
  top: 0; left: -100%;
  width: 60%; height: 100%;
  background: linear-gradient(110deg, transparent, rgba(255,255,255,0.55), transparent);
  animation: eyebrow-shine 4.5s cubic-bezier(.6,.0,.4,1) infinite;
}
@keyframes eyebrow-shine {
  0% { left: -100%; }
  35% { left: 200%; }
  100% { left: 200%; }
}

/* CTA ambient orbs */
.cta-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(40px);
  pointer-events: none;
}

/* Marquee strip */
.marquee {
  overflow: hidden;
  position: relative;
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, black 8%, black 92%, transparent 100%);
}
.marquee-track {
  display: flex;
  gap: 36px;
  width: max-content;
  animation: marquee 28s linear infinite;
  align-items: center;
}
.marquee-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 14.5px;
  font-weight: 500;
  color: var(--text-soft);
  letter-spacing: -0.01em;
  white-space: nowrap;
}
.marquee-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--blue);
  opacity: 0.6;
}

/* Subtle screenshot float on idle */
.screenshot-float {
  animation: screenshot-bob 8s ease-in-out infinite;
}
@keyframes screenshot-bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

/* Number countup styling */
.bignum {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
}

::selection { background: var(--blue); color: white; }

/* ---------- Legal pages (Privacy / Terms) ---------- */
.legal-hero {
  position: relative;
  padding: 96px 0 56px;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  background:
    radial-gradient(ellipse 80% 60% at 50% 0%, color-mix(in srgb, var(--blue) 12%, transparent) 0%, transparent 60%),
    var(--bg);
}
.legal-hero-inner {
  position: relative;
  z-index: 1;
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
}
.legal-hero .section-eyebrow { margin-bottom: 22px; }
.legal-hero h1 {
  font-size: clamp(40px, 5.4vw, 64px);
  letter-spacing: -0.04em;
  font-weight: 700;
  line-height: 1.05;
  margin-bottom: 18px;
}
.legal-hero p.lede {
  margin: 0 auto;
  font-size: clamp(16px, 1.2vw, 19px);
}
.legal-meta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 28px;
  padding: 7px 14px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--line);
  font-size: 13px;
  color: var(--text-soft);
  font-weight: 500;
}
.legal-meta-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--blue);
}

.legal-body {
  padding: 80px 0 120px;
}
.legal-grid {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 72px;
  align-items: start;
  max-width: 1080px;
  margin: 0 auto;
}
@media (max-width: 900px) {
  .legal-grid { grid-template-columns: 1fr; gap: 32px; }
  .legal-toc { position: static !important; }
}

.legal-toc {
  position: sticky;
  top: 96px;
  font-size: 13.5px;
}
.legal-toc-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 14px;
  padding-left: 14px;
}
.legal-toc ol {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 2px;
  border-left: 1px solid var(--line);
  padding: 0;
  margin: 0;
}
.legal-toc a {
  display: block;
  padding: 7px 14px;
  margin-left: -1px;
  border-left: 2px solid transparent;
  color: var(--text-soft);
  text-decoration: none;
  font-weight: 500;
  letter-spacing: -0.005em;
  transition: color 0.18s, border-color 0.18s, background 0.18s;
}
.legal-toc a:hover {
  color: var(--text);
  border-left-color: color-mix(in srgb, var(--blue) 40%, var(--line));
}
.legal-toc a.is-active {
  color: var(--blue-darker);
  border-left-color: var(--blue);
  background: linear-gradient(90deg, var(--blue-tint), transparent);
}
[data-theme="dark"] .legal-toc a.is-active { color: var(--blue); }

.legal-prose {
  max-width: 68ch;
  font-size: 16.5px;
  line-height: 1.7;
  color: var(--text);
}
.legal-prose .legal-section + .legal-section {
  margin-top: 56px;
}
.legal-prose h2 {
  font-size: clamp(22px, 2.2vw, 28px);
  letter-spacing: -0.025em;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 16px;
  scroll-margin-top: 96px;
  display: flex;
  align-items: baseline;
  gap: 14px;
}
.legal-prose h2 .legal-num {
  font-size: 14px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--blue-darker);
  letter-spacing: 0.04em;
  flex-shrink: 0;
}
[data-theme="dark"] .legal-prose h2 .legal-num { color: var(--blue); }

.legal-prose p {
  color: var(--text-soft);
  margin-bottom: 14px;
}
.legal-prose p:last-child { margin-bottom: 0; }
.legal-prose strong { color: var(--text); font-weight: 600; }
.legal-prose a {
  color: var(--blue-darker);
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--blue) 35%, transparent);
  transition: border-color 0.2s, color 0.2s;
}
[data-theme="dark"] .legal-prose a { color: var(--blue); }
.legal-prose a:hover { border-bottom-color: var(--blue); }

.legal-prose ul {
  list-style: none;
  padding: 0;
  margin: 14px 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.legal-prose ul li {
  position: relative;
  padding-left: 22px;
  color: var(--text-soft);
}
.legal-prose ul li::before {
  content: "";
  position: absolute;
  left: 4px;
  top: 11px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--blue);
  opacity: 0.8;
}

.legal-callout {
  margin: 18px 0;
  padding: 18px 22px;
  border-radius: 14px;
  background: var(--blue-tint);
  border: 1px solid color-mix(in srgb, var(--blue) 22%, var(--line));
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
[data-theme="dark"] .legal-callout {
  background: color-mix(in srgb, var(--blue) 8%, var(--surface));
}
.legal-callout-icon {
  width: 28px; height: 28px;
  border-radius: 8px;
  background: linear-gradient(160deg, var(--blue), var(--blue-darker));
  color: white;
  display: grid; place-items: center;
  flex-shrink: 0;
  font-weight: 700;
  font-size: 14px;
  margin-top: 1px;
}
.legal-callout-text {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--text);
}
.legal-callout-text strong { display: block; margin-bottom: 2px; font-weight: 600; }

.legal-data-table {
  margin: 18px 0 6px;
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  font-size: 14.5px;
}
.legal-data-table > div {
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
}
.legal-data-table > div:nth-child(odd) {
  background: var(--bg-alt);
  font-weight: 600;
  color: var(--text);
}
.legal-data-table > div:nth-child(even) {
  color: var(--text-soft);
}
.legal-data-table > div:nth-last-child(-n+2) { border-bottom: none; }
@media (max-width: 600px) {
  .legal-data-table { grid-template-columns: 1fr; }
  .legal-data-table > div:nth-child(odd) { padding-bottom: 4px; }
  .legal-data-table > div:nth-child(even) { padding-top: 4px; }
}

.legal-cross {
  margin-top: 80px;
  padding: 32px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: var(--bg-alt);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.legal-cross-text { font-size: 14.5px; color: var(--text-soft); }
.legal-cross-text strong { display: block; color: var(--text); font-size: 16px; margin-bottom: 4px; font-weight: 600; }

/* Subtle bg gradient for hero */
.hero-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
.hero-bg::before {
  content: "";
  position: absolute;
  top: -20%;
  right: -10%;
  width: 60%;
  height: 100%;
  background: radial-gradient(ellipse at center, rgba(56,182,230,0.18), transparent 60%);
  filter: blur(40px);
}
.hero-bg::after {
  content: "";
  position: absolute;
  bottom: -30%;
  left: -10%;
  width: 50%;
  height: 80%;
  background: radial-gradient(ellipse at center, rgba(177,155,224,0.14), transparent 60%);
  filter: blur(40px);
}
[data-theme="dark"] .hero-bg::before { opacity: 0.6; }
[data-theme="dark"] .hero-bg::after { opacity: 0.5; }

/* Phone container — clean, premium */
.phone-frame {
  border-radius: 48px;
  background: linear-gradient(160deg, #2a3441, #0f1620);
  padding: 8px;
  box-shadow:
    0 60px 120px -30px rgba(15,30,55,0.30),
    0 20px 40px -12px rgba(15,30,55,0.18),
    inset 0 0 0 1px rgba(255,255,255,0.06);
  position: relative;
}
[data-theme="dark"] .phone-frame {
  box-shadow:
    0 60px 120px -30px rgba(0,0,0,0.6),
    0 20px 40px -12px rgba(0,0,0,0.4),
    inset 0 0 0 1px rgba(255,255,255,0.08);
}
.phone-frame img {
  display: block;
  width: 100%;
  border-radius: 40px;
}

/* Screenshot, no frame (for real preview pngs that already include frame) */
.screenshot {
  display: block;
  width: 100%;
  height: auto;
}

/* feature card */
.feature-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 32px;
  transition: transform 0.3s cubic-bezier(.2,.7,.2,1), box-shadow 0.3s;
}
.feature-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 20px 40px -16px rgba(15,30,55,0.12);
}

/* schedule chip card */
.schedule-card {
  border-radius: 28px;
  padding: 28px 24px;
  color: white;
  position: relative;
  overflow: hidden;
  aspect-ratio: 1 / 1.05;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.schedule-card .reps {
  font-size: 56px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.04em;
}
.schedule-card .reps-label {
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -0.02em;
  margin-left: 8px;
}
