/* ---------- Pronto — clean editorial, light default ---------- */

:root {
  /* Light theme (default) */
  --bg: #fafaf8;
  --bg-2: #f0ede6;
  --ink: #1a1814;
  --ink-dim: #6b6459;
  --line: rgba(26, 24, 20, 0.09);
  --line-strong: rgba(26, 24, 20, 0.18);
  --accent: #0d9488;
  --accent-ink: #ffffff;
  --warn: #b45309;
  --serif: "Instrument Serif", "Cormorant Garamond", Georgia, serif;
  --sans: "Suisse Intl", "Söhne", "Inter", -apple-system, system-ui, sans-serif;
  --mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, Menlo, monospace;
  --pad: clamp(20px, 4vw, 56px);
  --col: clamp(1100px, 90vw, 1280px);
  --density: 1;
}

[data-theme="dark"] {
  --bg: #0f0e0c;
  --bg-2: #1a1812;
  --ink: #f0ece0;
  --ink-dim: #a09a8e;
  --line: rgba(240, 236, 224, 0.11);
  --line-strong: rgba(240, 236, 224, 0.22);
  --warn: #e06b3a;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body { overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }

::selection { background: var(--accent); color: var(--accent-ink); }

/* ---------- shell ---------- */
.page { min-height: 100vh; }
.container { max-width: var(--col); margin: 0 auto; padding: 0 var(--pad); }

/* ---------- nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  background: color-mix(in oklab, var(--bg) 78%, transparent);
  border-bottom: 1px solid var(--line);
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 64px;
}
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--serif); font-size: 26px; letter-spacing: -0.01em; }
.brand-mark {
  width: 26px; height: 26px; border-radius: 7px;
  background: var(--accent);
  color: var(--accent-ink);
  position: relative; display: flex; align-items: center; justify-content: center;
}
.brand-mark svg { width: 15px; height: 15px; }
.nav-links { display: flex; gap: 28px; font-size: 13px; color: var(--ink-dim); }
.nav-links a:hover { color: var(--ink); }
.nav-cta {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--accent); color: var(--accent-ink);
  padding: 9px 16px; border-radius: 999px;
  font-size: 13px; font-weight: 500;
  transition: transform .15s ease;
}
.nav-cta:hover { transform: translateY(-1px); }
@media (max-width: 720px) { .nav-links { display: none; } }

/* ---------- hero ---------- */
.hero { padding: calc(72px * var(--density)) 0 calc(96px * var(--density)); position: relative; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: stretch; }
@media (max-width: 960px) { .hero-grid { grid-template-columns: 1fr; } }

.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink-dim);
}
.eyebrow .dot { width: 6px; height: 6px; border-radius: 999px; background: var(--accent); box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent) 25%, transparent); }

.hero h1 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(40px, 6.8vw, 96px);
  line-height: 0.97;
  letter-spacing: -0.02em;
  margin-top: 28px;
}
.hero h1 em { font-style: italic; color: var(--ink-dim); }
.hero h1 .lime { color: var(--accent); font-style: normal; }
.hero h1 .strike {
  position: relative; display: inline-block;
}
.hero h1 .strike::after {
  content: ""; position: absolute; left: -2%; right: -2%; top: 52%;
  height: 4px; background: var(--warn);
  transform: rotate(-2deg);
}
.hero-sub {
  margin-top: 28px; max-width: 46ch;
  color: var(--ink-dim); font-size: 17px; line-height: 1.55;
}
.hero-cta-row {
  margin-top: 36px; display: flex; gap: 14px; flex-wrap: wrap; align-items: center;
}
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px; border-radius: 999px;
  font-size: 14px; font-weight: 500;
  transition: transform .15s ease, background .2s ease;
}
.btn-primary { background: var(--accent); color: var(--accent-ink); }
.btn-primary:hover { transform: translateY(-1px); }
.btn-ghost {
  background: transparent; color: var(--ink);
  border: 1px solid var(--line-strong);
}
.btn-ghost:hover { border-color: var(--ink); }
.btn .arrow { transition: transform .2s ease; }
.btn:hover .arrow { transform: translateX(3px); }

.hero-meta {
  margin-top: 56px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  border-top: 1px solid var(--line); padding-top: 24px;
}
.hero-meta .num { font-family: var(--serif); font-size: 36px; line-height: 1; letter-spacing: -0.02em; }
.hero-meta .lbl { color: var(--ink-dim); font-size: 12px; margin-top: 8px; font-family: var(--mono); text-transform: uppercase; letter-spacing: 0.08em; }

/* ---------- phone / demo card ---------- */
.demo {
  position: relative;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: linear-gradient(180deg, var(--bg-2), color-mix(in oklab, var(--bg-2) 70%, var(--bg)));
  overflow: hidden;
  min-height: 540px;
  display: flex; flex-direction: column;
}
.demo-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--line);
  font-family: var(--mono); font-size: 11px; color: var(--ink-dim); letter-spacing: 0.08em;
}
.demo-head .lights { display: flex; gap: 6px; }
.demo-head .lights span { width: 9px; height: 9px; border-radius: 999px; background: var(--line-strong); }
.demo-head .live { display: flex; align-items: center; gap: 8px; }
.demo-head .live .pulse { width: 7px; height: 7px; border-radius: 999px; background: #5cff8a; box-shadow: 0 0 0 0 rgba(92,255,138,0.6); animation: pulse 1.6s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(92,255,138,0.6);} 70% { box-shadow: 0 0 0 8px rgba(92,255,138,0);} 100% { box-shadow: 0 0 0 0 rgba(92,255,138,0);} }

.demo-body { flex: 1; padding: 22px; display: flex; flex-direction: column; gap: 14px; overflow: hidden; }

/* missed call event */
.missed-event {
  align-self: center;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px 22px;
  background: rgba(255,106,61,0.08);
  border: 1px solid rgba(255,106,61,0.22);
  border-radius: 12px;
  font-family: var(--mono); font-size: 11px; color: var(--warn);
  letter-spacing: 0.08em; text-transform: uppercase;
  max-width: 84%;
}
.missed-event .phone-icon { font-size: 20px; }
.missed-event .caller { color: var(--ink); font-size: 13px; letter-spacing: 0; text-transform: none; margin-top: 4px; font-family: var(--sans); }
.missed-event .caller small { color: var(--ink-dim); font-family: var(--mono); font-size: 10px; }

.msg { max-width: 78%; padding: 12px 14px; border-radius: 14px; font-size: 14px; line-height: 1.45; }
.msg.them { background: rgba(0,0,0,0.05); border: 1px solid var(--line); align-self: flex-start; border-bottom-left-radius: 4px; }
.msg.us { background: var(--accent); color: var(--accent-ink); align-self: flex-end; border-bottom-right-radius: 4px; }
[data-theme="dark"] .msg.them { background: rgba(255,255,255,0.06); }
.msg .meta { display: block; font-family: var(--mono); font-size: 10px; color: var(--ink-dim); margin-top: 6px; letter-spacing: 0.06em; }
.msg.us .meta { color: color-mix(in oklab, var(--accent-ink) 70%, transparent); }

.typing { display: inline-flex; gap: 4px; padding: 4px 0; }
.typing span { width: 6px; height: 6px; border-radius: 999px; background: var(--ink-dim); animation: bounce 1s infinite; }
.typing span:nth-child(2){ animation-delay: .15s; }
.typing span:nth-child(3){ animation-delay: .3s; }
@keyframes bounce { 0%,80%,100% { transform: translateY(0); opacity: .4; } 40% { transform: translateY(-4px); opacity: 1; } }

.demo-status {
  margin: 0 22px 22px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px 14px;
  font-family: var(--mono); font-size: 11px;
  display: flex; align-items: center; gap: 10px;
  background: color-mix(in oklab, var(--bg) 50%, transparent);
}
.demo-status .ok { color: var(--accent); }
.demo-status .dim { color: var(--ink-dim); }

/* calendar booking card inside demo */
.demo-cal-card {
  align-self: flex-end;
  max-width: 86%;
  background: var(--bg);
  border: 1px solid var(--line-strong);
  border-radius: 14px;
  border-bottom-right-radius: 4px;
  padding: 14px 16px;
  font-family: var(--mono); font-size: 11px;
}
.demo-cal-card .cal-head { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; color: var(--ink); font-weight: 500; letter-spacing: 0.02em; }
.demo-cal-card .gcal-dot-sm { width: 9px; height: 9px; border-radius: 3px; background: linear-gradient(135deg,#4285f4,#34a853 50%,#fbbc04 75%,#ea4335); flex-shrink: 0; }
.demo-cal-card .cal-label { color: var(--ink-dim); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 8px; }
.demo-cal-card .slot-row { display: flex; gap: 6px; flex-wrap: wrap; }
.demo-cal-card .slot-chip { padding: 5px 10px; border: 1px solid var(--line-strong); border-radius: 7px; color: var(--ink); font-size: 11px; white-space: nowrap; }
.demo-cal-card .slot-chip.hot { background: color-mix(in oklab, var(--accent) 12%, transparent); border-color: var(--accent); color: var(--accent); }
.demo-cal-card .cal-footer { margin-top: 10px; color: var(--ink-dim); font-size: 10px; letter-spacing: 0.08em; }

/* ---------- sections ---------- */
section { padding: calc(110px * var(--density)) 0; border-top: 1px solid var(--line); }
.sec-head {
  display: grid; grid-template-columns: 180px 1fr; gap: 32px; margin-bottom: 56px;
}
@media (max-width: 720px) { .sec-head { grid-template-columns: 1fr; gap: 12px; } }
.sec-num { font-family: var(--mono); font-size: 11px; color: var(--ink-dim); letter-spacing: 0.14em; text-transform: uppercase; padding-top: 8px; }
.sec-title {
  font-family: var(--serif); font-size: clamp(34px, 4.6vw, 60px); line-height: 1.02; letter-spacing: -0.02em; max-width: 18ch;
  font-weight: 400;
}
.sec-title em { color: var(--ink-dim); font-style: italic; }

/* problem stats */
.stats-grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 14px; overflow: hidden;
}
.stat {
  background: var(--bg);
  padding: 36px 28px;
  display: flex; flex-direction: column; gap: 14px;
  position: relative; overflow: hidden;
}
.stat.big { grid-column: span 7; min-height: 280px; }
.stat.med { grid-column: span 5; }
.stat.sm  { grid-column: span 4; }
@media (max-width: 860px) {
  .stat.big, .stat.med, .stat.sm { grid-column: span 12; }
}
.stat .num {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(56px, 7vw, 96px);
  line-height: 0.92; letter-spacing: -0.03em;
}
.stat .num .unit { color: var(--ink-dim); font-size: 0.5em; margin-left: 6px; }
.stat .body { color: var(--ink); font-size: 16px; line-height: 1.5; max-width: 36ch; }
.stat .src {
  margin-top: auto; font-family: var(--mono); font-size: 11px; color: var(--ink-dim);
  display: inline-flex; align-items: center; gap: 6px;
  border-top: 1px solid var(--line); padding-top: 14px;
}
.stat .src a { border-bottom: 1px dashed var(--line-strong); }
.stat .src a:hover { color: var(--ink); border-color: var(--ink); }

/* timeline / how it works */
.steps {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border: 1px solid var(--line); border-radius: 14px; overflow: hidden;
}
@media (max-width: 860px) { .steps { grid-template-columns: 1fr; } }
.step {
  padding: 28px 26px 32px; border-right: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 14px; min-height: 260px;
  position: relative;
}
.step:last-child { border-right: 0; }
@media (max-width: 860px) { .step { border-right: 0; border-bottom: 1px solid var(--line); } }
.step .stepnum { font-family: var(--mono); font-size: 11px; color: var(--ink-dim); letter-spacing: 0.14em; }
.step .stept { font-family: var(--serif); font-size: 26px; line-height: 1.05; letter-spacing: -0.01em; }
.step .stepb { color: var(--ink-dim); font-size: 14px; line-height: 1.5; }
.step .ico {
  width: 32px; height: 32px; border: 1px solid var(--line-strong); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
}

/* features */
.features {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 24px;
}
.feat {
  grid-column: span 2;
  border: 1px solid var(--line); border-radius: 14px; padding: 28px;
  display: flex; flex-direction: column; gap: 14px; min-height: 220px;
  background: linear-gradient(180deg, transparent, color-mix(in oklab, var(--bg-2) 55%, transparent));
  transition: border-color .2s ease, transform .2s ease;
}
.feat:hover { border-color: var(--line-strong); transform: translateY(-2px); }
.feat.wide { grid-column: span 3; }
.feat.huge { grid-column: span 6; min-height: 320px; }
.feat.soon { opacity: 0.5; }
.feat.soon:hover { transform: none; }
@media (max-width: 860px) { .feat, .feat.wide, .feat.huge { grid-column: span 6; } }
.feat .ftag { font-family: var(--mono); font-size: 11px; color: var(--accent); letter-spacing: 0.14em; text-transform: uppercase; }
.feat .ftag.soon-tag { color: var(--ink-dim); }
.feat .ftitle { font-family: var(--serif); font-size: 28px; line-height: 1.05; letter-spacing: -0.01em; }
.feat .fbody { color: var(--ink-dim); font-size: 14px; line-height: 1.55; }

/* sms mock in feature card */
.sms-mock {
  margin-top: auto;
  border: 1px solid var(--line); border-radius: 10px; overflow: hidden;
  font-size: 13px;
}
.sms-mock .sms-head {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-bottom: 1px solid var(--line);
  font-family: var(--mono); font-size: 10px; color: var(--ink-dim);
}
.sms-mock .sms-head .pulse { width: 6px; height: 6px; border-radius: 999px; background: var(--accent); flex-shrink: 0; }
.sms-mock .sms-body { padding: 12px 14px; display: flex; flex-direction: column; gap: 8px; }
.sms-mock .sms-msg { padding: 8px 12px; border-radius: 10px; font-size: 12px; line-height: 1.4; max-width: 88%; }
.sms-mock .sms-msg.out { background: var(--accent); color: var(--accent-ink); align-self: flex-end; }
.sms-mock .sms-msg.in  { background: rgba(0,0,0,0.05); border: 1px solid var(--line); }
[data-theme="dark"] .sms-mock .sms-msg.in { background: rgba(255,255,255,0.06); }

/* logos */
.logos {
  display: grid; grid-template-columns: repeat(6, 1fr); border: 1px solid var(--line); border-radius: 14px; overflow: hidden;
  background: var(--line);
  gap: 1px;
}
@media (max-width: 720px) { .logos { grid-template-columns: repeat(2, 1fr); } }
.logo-cell {
  background: var(--bg);
  padding: 32px 18px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 22px; letter-spacing: -0.01em;
  color: var(--ink-dim);
  transition: color .15s ease;
}
.logo-cell:hover { color: var(--ink); }
.logo-cell .mono { font-family: var(--mono); font-size: 14px; letter-spacing: 0.04em; text-transform: uppercase; }

/* founder */
.founder {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center;
}
@media (max-width: 860px) { .founder { grid-template-columns: 1fr; gap: 32px; } }
.founder-img {
  aspect-ratio: 4/5;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  position: relative;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.founder-img .initial {
  font-family: var(--serif); font-style: italic;
  font-size: clamp(100px, 18vw, 180px); line-height: 1;
  color: var(--accent); opacity: 0.18;
  letter-spacing: -0.04em; user-select: none;
  position: absolute;
}
.founder-img .portrait-shape {
  width: 54%; position: relative; z-index: 1;
}
.founder-img .tag {
  font-family: var(--mono); font-size: 10px; color: var(--ink-dim);
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--bg); padding: 6px 10px; border: 1px solid var(--line); border-radius: 6px;
}
.founder-letter p { font-size: 18px; line-height: 1.6; color: var(--ink); margin-bottom: 18px; font-family: var(--serif); }
.founder-letter .sig { font-family: var(--serif); font-style: italic; font-size: 28px; margin-top: 24px; }
.founder-letter .role { font-family: var(--mono); font-size: 11px; color: var(--ink-dim); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 4px; }

/* CTA */
.cta {
  text-align: center; padding: clamp(80px, 14vw, 180px) 0;
  border-top: 1px solid var(--line);
}
.cta h2 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(48px, 9vw, 130px);
  line-height: 0.96; letter-spacing: -0.025em;
}
.cta h2 em { color: var(--ink-dim); font-style: italic; }
.cta h2 .lime { color: var(--accent); }
.cta-sub { color: var(--ink-dim); font-size: 16px; margin-top: 24px; }
.cta-row { margin-top: 40px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* footer */
footer {
  border-top: 1px solid var(--line);
  padding: 40px 0 32px;
  font-family: var(--mono); font-size: 11px; color: var(--ink-dim);
  letter-spacing: 0.06em;
}
.footer-row { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px; }
.footer-row a { color: var(--ink-dim); }
.footer-row a:hover { color: var(--ink); }

/* ---------- booking modal ---------- */
.modal-bg {
  position: fixed; inset: 0; z-index: 100;
  background: color-mix(in oklab, #000 60%, transparent);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: fadeIn .2s ease;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.modal {
  width: 100%; max-width: 920px;
  background: var(--bg-2);
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  overflow: hidden;
  display: grid; grid-template-columns: 320px 1fr;
  max-height: 90vh;
  animation: pop .25s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes pop { from { transform: translateY(12px) scale(.98); opacity: 0; } to { transform: none; opacity: 1; } }
@media (max-width: 720px) { .modal { grid-template-columns: 1fr; } }
.modal-side {
  padding: 28px;
  border-right: 1px solid var(--line);
  background: var(--bg);
  display: flex; flex-direction: column; gap: 14px;
  position: relative;
}
@media (max-width: 720px) { .modal-side { border-right: 0; border-bottom: 1px solid var(--line); } }
.modal-side .gcal {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; color: var(--ink-dim);
  text-transform: uppercase;
}
.modal-side .gcal-dot { width: 10px; height: 10px; border-radius: 3px; background: linear-gradient(135deg,#4285f4,#34a853 50%,#fbbc04 75%,#ea4335); }
.modal-side h3 { font-family: var(--serif); font-size: 28px; line-height: 1.05; letter-spacing: -0.01em; font-weight: 400; }
.modal-side .meta { font-size: 13px; color: var(--ink-dim); display: flex; flex-direction: column; gap: 8px; margin-top: 4px; }
.modal-side .meta .row { display: flex; gap: 10px; align-items: center; }

.modal-main { padding: 28px; overflow-y: auto; }
.modal-main .step-h { font-family: var(--mono); font-size: 11px; color: var(--ink-dim); letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: 14px; }
.cal-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
}
@media (max-width: 540px) { .cal-grid { grid-template-columns: 1fr; } }
.cal-month-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.cal-month-head .m { font-family: var(--serif); font-size: 18px; }
.cal-month-head .nav-btns { display: flex; gap: 6px; }
.cal-month-head button { width: 28px; height: 28px; border: 1px solid var(--line); border-radius: 8px; }
.cal-month-head button:hover { border-color: var(--ink); }
.cal-days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-day-h { font-family: var(--mono); font-size: 10px; color: var(--ink-dim); text-align: center; padding: 4px 0; letter-spacing: 0.08em; }
.cal-day {
  aspect-ratio: 1; display: flex; align-items: center; justify-content: center;
  font-size: 13px; border-radius: 8px; cursor: pointer;
  border: 1px solid transparent;
  transition: all .12s ease;
  position: relative;
}
.cal-day:hover { border-color: var(--line-strong); }
.cal-day.muted { color: var(--ink-dim); opacity: 0.4; cursor: default; }
.cal-day.has::after {
  content: ""; position: absolute; bottom: 5px;
  width: 4px; height: 4px; border-radius: 999px; background: var(--accent);
}
.cal-day.sel { background: var(--accent); color: var(--accent-ink); }
.cal-day.sel.has::after { background: var(--accent-ink); }

.slot-list { display: flex; flex-direction: column; gap: 8px; max-height: 320px; overflow-y: auto; padding-right: 4px; }
.slot {
  padding: 12px 14px; border: 1px solid var(--line); border-radius: 10px;
  font-family: var(--mono); font-size: 13px; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center;
  transition: all .12s ease;
}
.slot:hover { border-color: var(--ink); }
.slot.sel { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.slot .tz { font-size: 10px; color: var(--ink-dim); letter-spacing: 0.06em; }
.slot.sel .tz { color: color-mix(in oklab, var(--accent-ink) 70%, transparent); }

.confirm-form { display: flex; flex-direction: column; gap: 12px; }
.confirm-form label { font-family: var(--mono); font-size: 10px; color: var(--ink-dim); text-transform: uppercase; letter-spacing: 0.1em; }
.confirm-form input, .confirm-form textarea {
  width: 100%; padding: 12px 14px; border: 1px solid var(--line); border-radius: 10px;
  background: var(--bg); color: var(--ink); font-family: var(--sans); font-size: 14px;
  outline: none; transition: border-color .15s ease;
}
.confirm-form input:focus, .confirm-form textarea:focus { border-color: var(--accent); }
.confirm-form textarea { resize: vertical; min-height: 80px; }

.modal-foot {
  border-top: 1px solid var(--line);
  padding: 16px 28px;
  display: flex; justify-content: space-between; align-items: center;
  grid-column: 1 / -1;
  background: var(--bg);
}
.modal-foot .legend { font-family: var(--mono); font-size: 11px; color: var(--ink-dim); }

.success {
  text-align: center; padding: 60px 20px;
}
.success .check {
  width: 64px; height: 64px; border-radius: 999px;
  background: var(--accent); color: var(--accent-ink);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 32px;
  margin-bottom: 24px;
}
.success h3 { font-family: var(--serif); font-size: 36px; font-weight: 400; letter-spacing: -0.02em; }
.success p { color: var(--ink-dim); margin-top: 12px; font-size: 15px; }

/* marquee */
.marquee {
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  overflow: hidden;
  padding: 14px 0;
  background: var(--bg-2);
}
.marquee-track {
  display: flex; gap: 56px; white-space: nowrap;
  animation: scroll 38s linear infinite;
  font-family: var(--mono); font-size: 12px; color: var(--ink-dim); letter-spacing: 0.1em;
  text-transform: uppercase;
}
.marquee-track span { display: inline-flex; align-items: center; gap: 56px; }
.marquee-track .sep { color: var(--accent); }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* responsive density tweak */
[data-density="compact"] { --density: 0.7; }
[data-density="spacious"] { --density: 1.15; }
