/* ============================================================
   meethattie.com — page styles
   Tokens come from ./tokens.css
   ============================================================ */

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--canvas);
}

.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--sp-32);
}
.container--narrow { max-width: var(--container-narrow); }

@media (max-width: 720px) {
  .container { padding: 0 var(--sp-24); }
}

.section {
  padding: var(--section-y) 0;
}

/* ============================================================
   BUTTONS — pills.
   ============================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-8);
  font-family: var(--font-sans);
  font-weight: var(--t-button-fw);
  font-size: var(--t-button-size);
  line-height: var(--t-button-lh);
  letter-spacing: 0;
  padding: 12px 22px;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              transform var(--dur-fast) var(--ease-out);
  white-space: nowrap;
  position: relative;
}
.btn:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

.btn--primary {
  background: var(--ink);
  color: var(--on-primary);
  border-color: var(--ink);
}
.btn--primary:hover { background: var(--inverse-surface-1); border-color: var(--inverse-surface-1); }
.btn--primary:active { background: var(--inverse-surface-1); transform: scale(0.98); }
.btn--primary.is-loading { pointer-events: none; }
.btn--primary.is-loading .btn__label { opacity: 0; }
.btn--primary.is-loading::after {
  content: "";
  position: absolute;
  width: 16px; height: 16px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: var(--on-primary);
  border-radius: 999px;
  animation: spin 0.7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.btn--secondary {
  background: var(--surface-1);
  color: var(--ink);
  border-color: var(--hairline);
}
.btn--secondary:hover { border-color: var(--ink-tertiary); }
.btn--secondary:active { transform: scale(0.98); }

.btn--ghost {
  background: transparent;
  color: var(--ink-muted);
  border-color: transparent;
  padding: 10px 14px;
}
.btn--ghost:hover { color: var(--ink); }

.btn--sm { padding: 8px 16px; font-size: 14px; }
.btn--lg { padding: 14px 26px; font-size: 16px; }

.btn--on-dark.btn--primary {
  background: var(--on-primary);
  color: var(--ink);
  border-color: var(--on-primary);
}
.btn--on-dark.btn--primary:hover { background: #ECE7DC; border-color: #ECE7DC; }
.btn--on-dark.btn--secondary {
  background: transparent;
  color: var(--on-primary);
  border-color: rgba(255,255,255,0.4);
}
.btn--on-dark.btn--secondary:hover { border-color: var(--on-primary); }

/* ============================================================
   BADGES + CHIPS
   ============================================================ */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-size: var(--t-caption-size);
  font-weight: 500;
  background: var(--surface-2);
  color: var(--ink);
  border: 1px solid var(--hairline);
  letter-spacing: 0.1px;
}
.badge--dot::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--ink);
}
.badge--live::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--semantic-success);
  box-shadow: 0 0 0 3px rgba(16,185,129,0.18);
  animation: pulse 2s infinite ease-out;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(16,185,129,0.18); }
  50%      { box-shadow: 0 0 0 5px rgba(16,185,129,0.05); }
}

/* ============================================================
   NAV
   ============================================================ */

.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  height: var(--nav-h);
  background: rgba(247, 244, 237, 0.85);
  backdrop-filter: blur(10px) saturate(160%);
  -webkit-backdrop-filter: blur(10px) saturate(160%);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-base) var(--ease-out);
}
.nav.is-scrolled { border-bottom-color: var(--hairline); }
.nav__inner {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-24);
}
.nav__brand { display: flex; align-items: center; text-decoration: none; }
.nav__brand img { height: 22px; display: block; }
.nav__links {
  display: flex;
  align-items: center;
  gap: var(--sp-24);
}
.nav__link {
  font-size: 14px;
  color: var(--ink-muted);
  text-decoration: none;
  font-weight: 500;
  transition: color var(--dur-fast) var(--ease-out);
}
.nav__link:hover { color: var(--ink); }
.nav__right {
  display: flex;
  align-items: center;
  gap: var(--sp-16);
}

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

/* ============================================================
   HERO
   ============================================================ */

.hero {
  padding: var(--sp-96) 0 var(--section-y);
  position: relative;
}
.hero__grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--sp-96);
  align-items: center;
}
@media (max-width: 1080px) {
  .hero__grid { gap: var(--sp-48); }
  .hero__title { letter-spacing: -1.5px; }
}
@media (max-width: 860px) {
  .hero__grid { grid-template-columns: 1fr; gap: var(--sp-48); }
  .hero { padding: var(--sp-48) 0 var(--section-y); }
}
.hero__eyebrow { margin: 0 0 var(--sp-24); }
.hero__title {
  margin: 0 0 var(--sp-24);
  max-width: 620px;
  font-size: clamp(40px, 6.4vw, 72px);
  line-height: 1.05;
  letter-spacing: -2px;
}
.hero__sub { margin: 0 0 var(--sp-32); max-width: 540px; }
.hero__ctas { display: flex; gap: var(--sp-12); flex-wrap: wrap; align-items: center; }
.hero__footnote {
  margin-top: var(--sp-24);
  display: flex; align-items: center; gap: var(--sp-12);
  color: var(--ink-subtle);
  font-size: 13px;
  flex-wrap: wrap;
}
.hero__footnote .dot {
  width: 4px; height: 4px;
  border-radius: 999px;
  background: var(--ink-tertiary);
  display: inline-block;
}

/* On mobile the phone stays after the headline so the message lands first */

/* ============================================================
   PHONE FRAME — wraps the WhatsApp mockup in the hero
   ============================================================ */

.phone {
  position: relative;
  width: 100%;
  max-width: 380px;
  margin: 0 auto;
  background: #111;
  border-radius: 44px;
  padding: 10px;
  box-shadow: var(--shadow-lift), 0 0 0 1px rgba(0,0,0,0.08);
}
.phone__screen {
  border-radius: 36px;
  overflow: hidden;
  background: var(--wa-wallpaper);
  position: relative;
  aspect-ratio: 9 / 19;
}
.phone__notch {
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);
  width: 100px;
  height: 28px;
  background: #111;
  border-radius: 999px;
  z-index: 5;
}
.phone .wa {
  border-radius: 0;
  height: 100%;
}
.phone .wa__header {
  padding-top: 50px;
}

/* Hero phone — slight tilt + ambient lift */
.hero__phone-wrap {
  position: relative;
  display: flex;
  justify-content: center;
  perspective: 1400px;
}
.hero__phone-wrap::before,
.hero__phone-wrap::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  z-index: -1;
}
.hero__phone-wrap::before {
  width: 480px; height: 480px;
  background: radial-gradient(ellipse, rgba(31,31,31,0.06), transparent 65%);
  top: 40%; left: 50%;
  transform: translate(-50%, -50%);
}

/* ============================================================
   SECTION HEADERS
   ============================================================ */

.section-head {
  text-align: left;
  max-width: 720px;
  margin: 0 0 var(--sp-48);
}
.section-head--center { text-align: center; margin-left: auto; margin-right: auto; }
.section-head__eyebrow { margin: 0 0 var(--sp-16); }
.section-head__title { margin: 0 0 var(--sp-16); }
.section-head__body { margin: 0; }

/* ============================================================
   PROBLEM SECTION — three cost-cards
   ============================================================ */

.problem__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-24);
}
@media (max-width: 860px) {
  .problem__grid { grid-template-columns: 1fr; }
}
.cost-card {
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  padding: var(--sp-32);
  display: flex;
  flex-direction: column;
  gap: var(--sp-16);
  transition: box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.cost-card:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.cost-card__index {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--ink-tertiary);
  letter-spacing: 0.4px;
}
.cost-card__title {
  font-size: var(--t-card-title-size);
  font-weight: var(--t-card-title-fw);
  letter-spacing: var(--t-card-title-tr);
  line-height: var(--t-card-title-lh);
  color: var(--ink);
  margin: 0;
}
.cost-card__body {
  margin: 0;
  font-size: 15px;
  color: var(--ink-muted);
  line-height: 1.55;
}
.cost-card__cost {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: var(--sp-16);
  border-top: 1px solid var(--hairline-soft);
}
.cost-card__cost-amount {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: -0.2px;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  line-height: 1.35;
}
.cost-card__cost-label {
  font-size: 13px;
  color: var(--ink-subtle);
  line-height: 1.45;
}

.problem__footnote {
  margin-top: var(--sp-48);
  text-align: center;
  font-size: 17px;
  color: var(--ink);
  font-weight: 500;
  letter-spacing: -0.2px;
}

/* ============================================================
   HOW IT WORKS — three steps
   ============================================================ */

.steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-48);
  position: relative;
}
@media (max-width: 860px) {
  .steps { grid-template-columns: 1fr; gap: var(--sp-32); }
}
.step {
  display: flex;
  flex-direction: column;
  gap: var(--sp-16);
}
.step__number {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink-tertiary);
  letter-spacing: 0.4px;
  padding-bottom: var(--sp-16);
  border-bottom: 1px solid var(--hairline);
}
.step__title {
  font-size: var(--t-card-title-size);
  font-weight: var(--t-card-title-fw);
  letter-spacing: var(--t-card-title-tr);
  line-height: var(--t-card-title-lh);
  margin: 0;
  color: var(--ink);
}
.step__body {
  margin: 0;
  font-size: 15px;
  color: var(--ink-muted);
  line-height: 1.55;
}
.step__stack-row {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: var(--sp-12);
}
.step__stack-chip {
  font-size: 12px;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  background: var(--surface-2);
  color: var(--ink);
  border: 1px solid var(--hairline);
  font-weight: 500;
}

/* ============================================================
   CAPABILITY DEEP-DIVES — feature rows + the standalone brief card
   ============================================================ */

.feature {
  padding: var(--section-y) 0;
}
.feature--tight {
  padding: calc(var(--section-y) * 0.6) 0;
}
.feature__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-96);
  align-items: center;
}
.feature__grid--reverse .feature__copy { order: 2; }
.feature__grid--reverse .feature__mockup { order: 1; }
@media (max-width: 1080px) {
  .feature__grid { gap: var(--sp-48); }
}
@media (max-width: 860px) {
  .feature__grid { grid-template-columns: 1fr; gap: var(--sp-48); }
  .feature__grid--reverse .feature__copy { order: 1; }
  .feature__grid--reverse .feature__mockup { order: 2; }
}
.feature__eyebrow { margin: 0 0 var(--sp-16); }
.feature__title { margin: 0 0 var(--sp-16); max-width: 460px; }
.feature__body { margin: 0; max-width: 480px; }
.feature__bullets {
  list-style: none;
  padding: 0;
  margin: var(--sp-24) 0 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-12);
}
.feature__bullets li {
  display: flex;
  gap: var(--sp-12);
  align-items: flex-start;
  font-size: 15px;
  color: var(--ink-muted);
}
.feature__bullets svg {
  flex: none;
  margin-top: 3px;
  color: var(--ink);
}

/* ============================================================
   THE MORNING BRIEF CARD — standalone, full-width hero of capability section
   ============================================================ */

.brief {
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xxl);
  box-shadow: var(--shadow-lift);
  overflow: hidden;
  max-width: 920px;
  margin: 0 auto;
  position: relative;
}
.brief__head {
  padding: var(--sp-24) var(--sp-32);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-16);
  border-bottom: 1px solid var(--hairline);
  background: var(--surface-1);
  flex-wrap: wrap;
}
.brief__head-left { display: flex; align-items: center; gap: var(--sp-12); min-width: 0; }
.brief__avatar {
  width: 36px; height: 36px;
  border-radius: 999px;
  background: var(--ink);
  color: var(--on-primary);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 500;
  flex: none;
}
.brief__title-block { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.brief__title { font-size: 15px; font-weight: 500; color: var(--ink); margin: 0; letter-spacing: -0.1px; }
.brief__sub { font-size: 13px; color: var(--ink-subtle); margin: 0; }
.brief__head-right { display: flex; align-items: center; gap: var(--sp-12); }

.brief__summary {
  padding: var(--sp-24) var(--sp-32);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-16);
  border-bottom: 1px solid var(--hairline);
  background: var(--canvas);
}
@media (max-width: 720px) {
  .brief__summary { grid-template-columns: repeat(2, 1fr); }
}
.brief__stat { display: flex; flex-direction: column; gap: 4px; }
.brief__stat-n {
  font-size: 28px;
  font-weight: 500;
  letter-spacing: -0.7px;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.brief__stat-l {
  font-size: 12px;
  color: var(--ink-muted);
  letter-spacing: 0;
}

.brief__list {
  padding: var(--sp-8) var(--sp-32) var(--sp-24);
}
.brief__list-title {
  padding: var(--sp-16) 0 var(--sp-8);
  font-size: 11px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--ink-tertiary);
  font-weight: 500;
}

.brief-item {
  display: grid;
  grid-template-columns: 28px 1fr auto;
  gap: var(--sp-16);
  padding: var(--sp-16) 0;
  border-top: 1px solid var(--hairline-soft);
  align-items: flex-start;
  position: relative;
  transition: opacity var(--dur-slow) var(--ease-out), max-height var(--dur-slow) var(--ease-out), padding var(--dur-slow) var(--ease-out);
  max-height: 300px;
  overflow: hidden;
}
.brief-item.is-hiding { opacity: 0; max-height: 0; padding-top: 0; padding-bottom: 0; border-top-color: transparent; }

.brief-item__sev {
  width: 24px; height: 24px;
  border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  flex: none;
  margin-top: 1px;
}
.brief-item__sev--high {
  background: rgba(229,57,53,0.1);
  color: var(--semantic-error);
}
.brief-item__sev--med {
  background: rgba(255,160,0,0.12);
  color: #B86E00;
}
.brief-item__sev--low {
  background: var(--surface-2);
  color: var(--ink-muted);
}
.brief-item__sev--done {
  background: rgba(16,185,129,0.12);
  color: var(--semantic-success);
}

.brief-item__main { min-width: 0; }
.brief-item__title {
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  margin: 0 0 4px;
  letter-spacing: -0.1px;
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-8);
  align-items: center;
}
.brief-item__chip {
  font-size: 11px;
  font-weight: 500;
  padding: 2px 8px;
  border-radius: var(--r-pill);
  background: var(--surface-2);
  color: var(--ink-muted);
  letter-spacing: 0.1px;
}
.brief-item__chip--high { background: rgba(229,57,53,0.1); color: #C5221F; }
.brief-item__chip--in-progress { background: rgba(59,130,246,0.1); color: #2056B3; }
.brief-item__chip--done { background: rgba(16,185,129,0.12); color: #047D5A; }
.brief-item__body {
  font-size: 14px;
  color: var(--ink-muted);
  line-height: 1.5;
  margin: 0;
}
.brief-item__draft {
  margin-top: var(--sp-12);
  padding: var(--sp-12) var(--sp-16);
  background: var(--canvas);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  font-size: 14px;
  color: var(--ink);
  line-height: 1.5;
}
.brief-item__draft-label {
  font-size: 11px;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--ink-tertiary);
  font-weight: 500;
  margin-bottom: 6px;
  display: block;
}
.brief-item__draft-text { white-space: pre-wrap; }
.brief-item__draft-text[contenteditable="true"] {
  outline: none;
  border-radius: 4px;
  background: rgba(255, 244, 200, 0.4);
  box-shadow: 0 0 0 1px rgba(255, 160, 0, 0.4);
}
.brief-item__draft-controls {
  margin-top: var(--sp-12);
  display: flex;
  gap: var(--sp-8);
  font-size: 13px;
  color: var(--ink-subtle);
}

.brief-item__actions {
  display: flex;
  gap: 6px;
  align-items: center;
  flex: none;
}
.brief-item__action {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  padding: 7px 14px;
  border-radius: var(--r-pill);
  border: 1px solid var(--hairline);
  background: var(--surface-1);
  color: var(--ink);
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.brief-item__action:hover { border-color: var(--ink-tertiary); }
.brief-item__action:focus-visible { outline: none; box-shadow: var(--focus-ring); }
.brief-item__action--primary {
  background: var(--ink); color: var(--on-primary); border-color: var(--ink);
}
.brief-item__action--primary:hover { background: var(--inverse-surface-1); border-color: var(--inverse-surface-1); }
.brief-item__action--ghost { background: transparent; border-color: transparent; color: var(--ink-muted); }
.brief-item__action--ghost:hover { color: var(--ink); }

.brief-item__status-line {
  display: flex;
  align-items: center;
  gap: var(--sp-8);
  font-size: 13px;
  color: var(--ink-muted);
  font-style: normal;
}
.brief-item__status-line strong { color: var(--ink); font-weight: 500; }

.brief__footer {
  padding: var(--sp-16) var(--sp-32);
  background: var(--canvas);
  border-top: 1px solid var(--hairline);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-16);
  flex-wrap: wrap;
  font-size: 13px;
  color: var(--ink-subtle);
}

/* ============================================================
   APPROVAL PROMISE — bold section
   ============================================================ */

.approval {
  background: var(--canvas);
  padding: var(--sp-96) 0;
}
.approval__inner {
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}
.approval__title {
  margin: 0 0 var(--sp-24);
}
.approval__body {
  font-size: 20px;
  line-height: 1.55;
  color: var(--ink-muted);
  margin: 0 auto;
  max-width: 700px;
  letter-spacing: -0.1px;
}
.approval__body strong { color: var(--ink); font-weight: 500; }

.approval__rules {
  margin: var(--sp-48) auto 0;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-16);
  max-width: 880px;
}
@media (max-width: 720px) {
  .approval__rules { grid-template-columns: repeat(2, 1fr); }
}
.approval__rule {
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  padding: var(--sp-16);
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.approval__rule-icon {
  width: 28px; height: 28px;
  border-radius: 6px;
  background: var(--surface-2);
  color: var(--ink);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--sp-8);
}
.approval__rule-title {
  font-size: 14px; font-weight: 500; color: var(--ink); margin: 0;
}
.approval__rule-body {
  font-size: 13px; color: var(--ink-muted); margin: 0; line-height: 1.45;
}

/* ============================================================
   SLACK SECTION
   ============================================================ */
.section--slack {
  padding: calc(var(--section-y) + 32px) 0;
  background: var(--canvas);
}
.slack-section__inner {
  max-width: var(--container-narrow);
  margin: 0 auto;
}

/* ============================================================
   FOUNDING PARTNERS — clean, no slot visual
   ============================================================ */

.founders {
  padding: var(--section-y) 0;
}
.founders__inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--sp-24);
  align-items: center;
}
.founders__eyebrow { margin: 0; }
.founders__title { margin: 0; }
.founders__body {
  margin: 0;
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink-muted);
  max-width: 600px;
}
.founders__cta { margin-top: var(--sp-16); display: flex; gap: var(--sp-12); flex-wrap: wrap; justify-content: center; }
.founders__sub { margin-top: var(--sp-12); font-size: 13px; color: var(--ink-subtle); }

/* ============================================================
   FAQ
   ============================================================ */

.faq__list {
  background: var(--canvas);
  border-radius: var(--r-lg);
  overflow: hidden;
}
.faq__row {
  border-bottom: 1px solid var(--hairline-soft);
}
.faq__row:last-child { border-bottom: none; }
.faq__q {
  width: 100%;
  background: transparent;
  border: none;
  text-align: left;
  cursor: pointer;
  padding: 22px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-16);
  font-family: var(--font-sans);
  font-size: 17px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.1px;
}
.faq__q:focus-visible { outline: none; box-shadow: var(--focus-ring); border-radius: 4px; }
.faq__icon { transition: transform var(--dur-base) var(--ease-out); color: var(--ink-muted); flex: none; }
.faq__row[data-open="true"] .faq__icon { transform: rotate(45deg); color: var(--ink); }
.faq__a {
  max-height: 0;
  overflow: hidden;
  transition: max-height var(--dur-slow) var(--ease-out);
}
.faq__row[data-open="true"] .faq__a { max-height: 320px; }
.faq__a-inner {
  padding-bottom: 24px;
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-muted);
  max-width: 720px;
}

/* ============================================================
   CTA BANNER
   ============================================================ */

.cta-banner {
  background: var(--inverse-canvas);
  color: var(--on-primary);
  border-radius: var(--r-xxl);
  padding: 72px 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-48);
  position: relative;
  overflow: hidden;
}
@media (max-width: 720px) {
  .cta-banner { flex-direction: column; align-items: flex-start; padding: 48px 32px; }
}
.cta-banner__title { margin: 0 0 var(--sp-12); color: var(--on-primary); max-width: 560px; }
.cta-banner__sub { margin: 0; color: rgba(255,255,255,0.65); max-width: 480px; font-size: 17px; line-height: 1.5; }
.cta-banner__actions { display: flex; flex-direction: column; gap: var(--sp-12); flex-shrink: 0; align-items: flex-start; }
.cta-banner__sub-line { color: rgba(255,255,255,0.5); font-size: 13px; }

/* ============================================================
   FOOTER
   ============================================================ */

.footer {
  padding: var(--sp-48) 0 var(--sp-48);
  border-top: 1px solid var(--hairline);
  margin-top: var(--section-y);
}
.footer__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-24);
  flex-wrap: wrap;
}
.footer__left {
  display: flex;
  align-items: center;
  gap: var(--sp-16);
}
.footer__mark { height: 22px; display: block; }
.footer__copyright {
  font-size: 13px;
  color: var(--ink-subtle);
  font-variant-numeric: tabular-nums;
}
.footer__right {
  display: flex;
  align-items: center;
  gap: var(--sp-12);
  flex-wrap: wrap;
}
.footer__link {
  font-size: 13px;
  color: var(--ink-muted);
  text-decoration: none;
  transition: color var(--dur-fast) var(--ease-out);
}
.footer__link:hover { color: var(--ink); }
.footer__credit a {
  color: var(--ink);
  text-decoration: underline;
  text-decoration-color: var(--hairline-soft);
  text-underline-offset: 2px;
  transition: text-decoration-color var(--dur-fast) var(--ease-out);
}
.footer__credit a:hover { text-decoration-color: var(--ink); }
.footer__dot {
  color: var(--ink-tertiary);
  font-size: 12px;
  user-select: none;
}

/* ============================================================
   HERO interactive phone — chip row + input bar + animations
   ============================================================ */

.hero-eyebrow-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.1px;
  color: var(--ink-muted);
  background: var(--surface-2);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--hairline);
  margin: 0 auto var(--sp-12);
  width: max-content;
}
.hero-eyebrow-chip__dot {
  width: 6px; height: 6px;
  background: var(--semantic-success);
  border-radius: 999px;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.18);
}

.hero__phone-wrap { display: flex; flex-direction: column; align-items: center; gap: 8px; }

/* The screen needs to host the thread (flex 1) plus the input dock */
.phone__screen { display: flex; flex-direction: column; }
.phone .wa { flex: 1 1 0; min-height: 0; display: flex; flex-direction: column; }
.phone .wa__thread {
  flex: 1 1 0;
  overflow-y: auto;
  min-height: 0;
  scrollbar-width: none;
}
.phone .wa__thread::-webkit-scrollbar { display: none; }

.hero-input {
  flex: none;
  background: var(--wa-wallpaper, #ECE5DD);
  padding: 8px 12px 12px;
  border-top: 1px solid rgba(0,0,0,0.04);
}

.hero-chips-label {
  font-size: 11px;
  text-align: center;
  color: var(--ink-tertiary);
  font-weight: 500;
  padding: 4px 0 8px;
}

.hero-chips {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 0 0 10px;
}
.hero-chip {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  padding: 11px 14px 11px 18px;
  border-radius: var(--r-pill);
  border: none;
  background: var(--wa-sent-bubble);
  color: var(--ink);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  text-align: left;
  transition: background 120ms var(--ease-out), opacity 120ms var(--ease-out), transform 120ms var(--ease-out);
}
.hero-chip:hover { background: #CDEFB3; }
.hero-chip:active { transform: scale(0.99); }
.hero-chip:disabled { opacity: 0.6; cursor: default; }
.hero-chip__label {
  flex: 1 1 0;
  min-width: 0;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
  letter-spacing: -0.1px;
}
.hero-chip__arrow {
  flex: none;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: var(--wa-action);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.hero-chip--pulse { animation: chipPulse 1.8s ease-out infinite; }
@keyframes chipPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(31,31,31,0.0); }
  40%      { box-shadow: 0 0 0 6px rgba(31,31,31,0.10); }
  70%      { box-shadow: 0 0 0 10px rgba(31,31,31,0.0); }
}

.hero-composer {
  display: flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border-radius: 999px;
  padding: 6px 8px 6px 12px;
}
.hero-composer-input {
  flex: 1 1 0;
  min-width: 0;
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--ink);
  padding: 4px 4px;
  height: 24px;
  line-height: 24px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: color 120ms var(--ease-out);
}
.hero-composer-input--typing { color: var(--ink); font-weight: 500; }
.hero-composer-placeholder { color: #9AA0A6; font-weight: 400; }
.hero-composer-mic {
  flex: none;
  width: 32px; height: 32px;
  background: var(--wa-action, #25D366);
  color: #fff;
  border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
}

/* Hero bubble fade-in */
.hero-bubble-enter { animation: heroBubbleIn 240ms var(--ease-out); }
@keyframes heroBubbleIn {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: none; }
}

/* Typing dots in hero */
.hero-typing { display: inline-flex; gap: 4px; padding: 10px 14px !important; }
.hero-typing span {
  width: 6px; height: 6px;
  background: #9AA0A6;
  border-radius: 999px;
  display: inline-block;
  animation: heroDot 1.2s infinite ease-in-out;
}
.hero-typing span:nth-child(2) { animation-delay: 0.15s; }
.hero-typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes heroDot {
  0%, 80%, 100% { opacity: 0.3; transform: translateY(0); }
  40%           { opacity: 1;   transform: translateY(-2px); }
}

/* ============================================================
   THREE WORKFLOWS — Lindy-style stacked list
   ============================================================ */

.workflows {
  padding: var(--section-y) 0;
}
.workflows__list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-24);
}

.workflow-row {
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xxl);
  padding: var(--sp-12);
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: var(--sp-12);
  align-items: stretch;
  overflow: hidden;
}
.workflow-row__copy {
  padding: var(--sp-48);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--sp-16);
}
.workflow-row__eyebrow {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.2px;
  color: var(--ink-muted);
}
.workflow-row__title {
  font-size: var(--t-headline-size);
  font-weight: var(--t-headline-fw);
  letter-spacing: var(--t-headline-tr);
  line-height: var(--t-headline-lh);
  color: var(--ink);
  margin: 0;
  max-width: 380px;
}
.workflow-row__body {
  margin: 0;
  font-size: 15px;
  line-height: 1.55;
  color: var(--ink-muted);
  max-width: 440px;
}
.workflow-row__panel {
  background: var(--surface-2);
  border-radius: 22px;
  padding: var(--sp-32);
  display: flex;
  align-items: center;
  justify-content: center;
}
.workflow-row__panel--wa {
  background: var(--wa-wallpaper);
}
.workflow-row__panel--cream {
  background: var(--surface-2);
}
.workflow-row__panel--airbnb {
  background: #F5F2EC;
}
.workflow-row__mockup {
  width: 100%;
  max-width: 380px;
}

@media (max-width: 860px) {
  .workflow-row { grid-template-columns: 1fr; }
  .workflow-row__copy { padding: var(--sp-24) var(--sp-24) 0; }
  .workflow-row__panel { padding: var(--sp-24); }
  .workflow-row__title { max-width: none; }
}

/* Couch + stain inside the cleaner's photo bubble */
.snippet-couch {
  background: linear-gradient(180deg, #C9B89E 0%, #B49E83 60%, #9C8569 100%);
}
.snippet-couch__sofa {
  position: absolute;
  inset: 18% 8% 14%;
  background: linear-gradient(180deg, #8C7256 0%, #6E5740 100%);
  border-radius: 8px;
  box-shadow: inset 0 -8px 12px rgba(0,0,0,0.25), inset 0 8px 12px rgba(255,255,255,0.10);
}
.snippet-couch__sofa::before,
.snippet-couch__sofa::after {
  content: "";
  position: absolute;
  top: 18%;
  width: 30%;
  height: 65%;
  border-radius: 6px;
  background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(0,0,0,0.10));
}
.snippet-couch__sofa::before { left: 4%; }
.snippet-couch__sofa::after  { right: 4%; }
.snippet-couch__stain {
  position: absolute;
  bottom: 28%;
  left: 38%;
  width: 26%;
  height: 24%;
  background: radial-gradient(ellipse at center, rgba(38,18,8,0.85) 0%, rgba(38,18,8,0.55) 45%, rgba(38,18,8,0.0) 75%);
  border-radius: 50%;
  filter: blur(1px);
}

/* Airbnb pricing UI — used in the pricing workflow snippet */
.ab-pricing {
  background: #fff;
  border: 1px solid #EBEBEB;
  border-radius: 16px;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  width: 100%;
  font-family: var(--font-sans);
  color: #222;
}
.ab-pricing__topbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid #EBEBEB;
}
.ab-pricing__search {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  background: #fff;
  border: 1px solid #DDDDDD;
  border-radius: 999px;
  padding: 8px 14px;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
}
.ab-pricing__search-text { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.ab-pricing__search-where {
  font-size: 12px;
  font-weight: 500;
  color: #222;
  letter-spacing: -0.1px;
}
.ab-pricing__search-when {
  font-size: 11px;
  color: #717171;
}
.ab-pricing__filters {
  width: 36px; height: 36px;
  border-radius: 999px;
  border: 1px solid #DDDDDD;
  background: #fff;
  display: flex; align-items: center; justify-content: center;
  flex: none;
}

.ab-pricing__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 14px;
}

.ab-card { display: flex; flex-direction: column; gap: 2px; }
.ab-card__photo {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 12px;
  overflow: hidden;
  margin-bottom: 6px;
}
.ab-card__heart {
  position: absolute;
  top: 8px; right: 8px;
  width: 26px; height: 26px;
  background: transparent;
  border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  padding: 0;
}
.ab-card__badge {
  position: absolute;
  top: 8px; left: 8px;
  background: #fff;
  color: #222;
  font-size: 10px;
  font-weight: 500;
  padding: 4px 8px;
  border-radius: 999px;
  letter-spacing: 0;
}
.ab-card__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
}
.ab-card__title {
  font-size: 13px;
  font-weight: 500;
  color: #222;
  letter-spacing: -0.1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ab-card__rating {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 12px;
  color: #222;
  flex: none;
  font-variant-numeric: tabular-nums;
}
.ab-card__area {
  font-size: 11px;
  color: #717171;
}
.ab-card__price {
  font-size: 13px;
  color: #222;
  margin-top: 2px;
  font-variant-numeric: tabular-nums;
}
.ab-card__price strong { font-weight: 500; letter-spacing: -0.2px; }
.ab-card__per { font-size: 12px; color: #717171; }
.ab-card--you .ab-card__title { color: var(--ink); }
.ab-card--you .ab-card__photo {
  box-shadow: 0 0 0 2px var(--ink), 0 0 0 4px var(--canvas);
}

.ab-pricing__proposal {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  background: var(--canvas);
  border-top: 1px solid #EBEBEB;
  font-family: var(--font-sans);
  color: var(--ink);
}
.ab-pricing__proposal-left { min-width: 0; }
.ab-pricing__proposal-label {
  font-size: 10px;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--ink-tertiary);
  font-weight: 500;
}
.ab-pricing__proposal-text {
  font-size: 13px;
  color: var(--ink-muted);
  margin-top: 2px;
}
.ab-pricing__proposal-text strong { color: var(--ink); font-weight: 500; }
.ab-pricing__proposal-arrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -0.3px;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
  flex: none;
}
.ab-pricing__strike {
  text-decoration: line-through;
  text-decoration-thickness: 1px;
  color: var(--ink-tertiary);
  font-weight: 400;
}
.ab {
  background: #fff;
  border: 1px solid #EBEBEB;
  border-radius: 16px;
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  width: 100%;
  font-family: var(--font-sans);
  color: #222;
}
.ab__topbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid #EBEBEB;
}
.ab__back {
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  color: #222;
}
.ab__brand { display: inline-flex; align-items: center; gap: 4px; }
.ab__topbar-spacer { flex: 1; }
.ab__menu { color: #717171; font-size: 18px; letter-spacing: 1px; }

.ab__listing {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-bottom: 1px solid #EBEBEB;
}
.ab__listing-thumb {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  overflow: hidden;
  flex: none;
  background: #F7F4ED;
}
.ab__listing-thumb-tile {
  width: 100%; height: 100%;
}
.ab__listing-info { min-width: 0; }
.ab__listing-name {
  font-size: 14px;
  font-weight: 500;
  color: #222;
  letter-spacing: -0.1px;
}
.ab__listing-meta {
  font-size: 12px;
  color: #717171;
  margin-top: 2px;
}

.ab__thread {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: #fff;
}

.ab__sender-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 2px;
}
.ab__avatar {
  width: 24px; height: 24px;
  border-radius: 999px;
  background: #FF385C;
  color: #fff;
  font-size: 11px;
  font-weight: 500;
  display: inline-flex; align-items: center; justify-content: center;
  flex: none;
}
.ab__sender-name {
  font-size: 13px;
  font-weight: 500;
  color: #222;
}
.ab__sender-time {
  font-size: 11px;
  color: #717171;
  margin-left: auto;
}

.ab__bubble {
  font-size: 13.5px;
  line-height: 1.45;
  padding: 10px 14px;
  border-radius: 18px;
  max-width: 92%;
  letter-spacing: -0.1px;
}
.ab__bubble--guest {
  background: #F7F7F7;
  color: #222;
  border-bottom-left-radius: 6px;
  align-self: flex-start;
}

.ab__unread {
  align-self: center;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 500;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255,56,92,0.10);
  color: #C13854;
  margin: 4px 0;
}
.ab__unread-dot {
  width: 6px; height: 6px;
  background: #FF385C;
  border-radius: 999px;
  box-shadow: 0 0 0 3px rgba(255,56,92,0.18);
}

.ab__hattie-draft {
  margin-top: 4px;
  background: var(--canvas);
  border: 1px solid var(--hairline);
  border-radius: 12px;
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.ab__hattie-head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.ab__hattie-avatar {
  width: 24px; height: 24px;
  border-radius: 999px;
  background: var(--ink);
  color: var(--on-primary);
  font-size: 11px; font-weight: 500;
  display: inline-flex; align-items: center; justify-content: center;
  flex: none;
}
.ab__hattie-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--ink);
}
.ab__hattie-sub {
  font-size: 11px;
  color: var(--ink-subtle);
}
.ab__hattie-body {
  font-size: 13px;
  line-height: 1.5;
  color: var(--ink);
}
.ab__hattie-actions {
  display: flex;
  gap: 6px;
}
.ab__hattie-btn {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--hairline);
  background: #fff;
  color: var(--ink);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.ab__hattie-btn--primary {
  background: var(--ink);
  color: var(--on-primary);
  border-color: var(--ink);
}

/* Airbnb comp listing rows */
.comps {
  display: flex;
  flex-direction: column;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--hairline);
}
.comps__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 12px;
  font-size: 13px;
  color: var(--ink-muted);
  border-top: 1px solid var(--hairline-soft);
  font-variant-numeric: tabular-nums;
}
.comps__row:first-child { border-top: none; }
.comps__name { letter-spacing: -0.1px; }
.comps__rate { font-weight: 500; color: var(--ink); }
.comps__row--you {
  background: var(--canvas);
  border-top: 1px solid var(--hairline);
}
.comps__row--you .comps__name { color: var(--ink); font-weight: 500; }
.comps__row--you .comps__rate { color: var(--semantic-error); }

/* WhatsApp snippet within a workflow card */
.wa--snippet {
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xs);
  overflow: hidden;
  height: auto;
}
.wa--snippet .wa__header { padding: 10px 12px; }
.wa--snippet .wa__avatar { width: 28px; height: 28px; font-size: 11px; }
.wa--snippet .wa__name { font-size: 13px; }
.wa--snippet .wa__status { font-size: 11px; }
.wa--snippet .wa__thread { padding: 10px 12px; min-height: 0; gap: 4px; }
.wa--snippet .wa__bubble { padding: 7px 10px; font-size: 12.5px; }
.wa--snippet .wa__bubble-meta { font-size: 10px; }

/* Snippet card — pricing */
.snippet-card {
  background: var(--surface-1);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  padding: var(--sp-16);
  display: flex;
  flex-direction: column;
  gap: var(--sp-12);
  box-shadow: var(--shadow-xs);
}
.snippet-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-12);
}
.snippet-card__eyebrow {
  font-size: 10px;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--ink-tertiary);
  font-weight: 500;
}
.snippet-card__title {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
  margin-top: 2px;
  letter-spacing: -0.1px;
}
.snippet-cal {
  display: grid;
  grid-template-columns: repeat(11, 1fr);
  gap: 3px;
}
.snippet-cal__cell {
  background: var(--surface-2);
  color: var(--ink-muted);
  border-radius: 4px;
  padding: 5px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  font-variant-numeric: tabular-nums;
}
.snippet-cal__cell.is-booked {
  background: var(--ink);
  color: var(--on-primary);
}
.snippet-cal__d { font-size: 9px; opacity: 0.7; }
.snippet-cal__n { font-size: 11px; font-weight: 500; }

.snippet-card__price {
  background: var(--canvas);
  border: 1px solid var(--hairline);
  border-radius: 10px;
  padding: 10px 12px;
}
.snippet-card__price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.snippet-card__price-label { font-size: 11px; letter-spacing: 0.3px; text-transform: uppercase; color: var(--ink-tertiary); font-weight: 500; }
.snippet-card__price-amount {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 16px; font-weight: 500; letter-spacing: -0.3px; color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.snippet-card__strike {
  color: var(--ink-tertiary);
  text-decoration: line-through;
  text-decoration-thickness: 1px;
  font-weight: 400;
}
.snippet-card__price-foot {
  margin-top: 4px;
  font-size: 11px;
  color: var(--ink-subtle);
}

/* ============================================================
   LIVES IN YOUR STACK — integration ring
   ============================================================ */

.stack {
  padding: var(--section-y) 0;
  background: var(--canvas);
}
.stack__inner {
  max-width: 980px;
  margin: 0 auto;
  text-align: center;
}
.stack__ring {
  position: relative;
  width: 100%;
  max-width: 640px;
  margin: var(--sp-32) auto 0;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
.stack__ring::before,
.stack__ring::after {
  content: "";
  position: absolute;
  border: 1px dashed var(--hairline);
  border-radius: 999px;
  pointer-events: none;
}
.stack__ring::before {
  inset: 8%;
}
.stack__ring::after {
  inset: 22%;
}

.stack__center {
  position: relative;
  z-index: 2;
  width: 96px; height: 96px;
  border-radius: 999px;
  background: var(--ink);
  color: var(--on-primary);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 2px;
  box-shadow: var(--shadow-md);
}
.stack__center-h {
  font-size: 36px;
  font-weight: 500;
  letter-spacing: -1.5px;
  line-height: 1;
  font-family: var(--font-sans);
}
.stack__center-label {
  font-size: 10px;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  font-weight: 500;
}

.stack__tile {
  position: absolute;
  background: var(--surface-2);
  color: var(--ink);
  border: 1px solid var(--hairline);
  border-radius: var(--r-lg);
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.1px;
  white-space: nowrap;
  box-shadow: var(--shadow-xs);
  display: flex;
  flex-direction: column;
  gap: 1px;
  transform: translate(-50%, -50%);
}
.stack__tile-sub {
  font-size: 10px;
  letter-spacing: 0.3px;
  text-transform: uppercase;
  color: var(--ink-tertiary);
  font-weight: 500;
}
.stack__tile-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
}

.stack__caption {
  margin-top: var(--sp-32);
  font-size: 14px;
  color: var(--ink-subtle);
  text-align: center;
}

/* Mobile: stack the tiles in a clean grid, drop the ring */
@media (max-width: 720px) {
  .stack__ring { aspect-ratio: auto; display: block; max-width: 480px; }
  .stack__ring::before, .stack__ring::after { display: none; }
  .stack__center { margin: 0 auto var(--sp-24); }
  .stack__tile {
    position: static !important;
    transform: none !important;
    margin-bottom: 8px;
    display: inline-flex;
    margin-right: 8px;
  }
}

/* ============================================================
   ENTRANCE animations (subtle)
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(8px);
  transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out);
}
.reveal.is-in {
  opacity: 1;
  transform: none;
}
