/* Homepage-specific styles */

/* --- Hero ------------------------------------------------------------ */
.hero {
  position: relative;
  overflow: hidden;
  padding-block: clamp(var(--sp-12), 7vw, var(--sp-20)) clamp(var(--sp-16), 9vw, var(--sp-24));
}
.hero::before {
  content: "";
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(700px 380px at 12% 18%, rgba(0,139,139,.28), transparent 62%),
    radial-gradient(540px 340px at 88% 12%, rgba(159,232,112,.12), transparent 60%),
    radial-gradient(560px 360px at 82% 86%, rgba(246,228,196,.06), transparent 62%);
  pointer-events: none;
}
.hero-grid {
  display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr);
  gap: clamp(var(--sp-8), 5vw, var(--sp-16));
  align-items: center;
}
.hero-copy, .hero-stage { min-width: 0; }
.hero-copy .kicker {
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .45rem .9rem; border-radius: var(--r-pill);
  background: rgba(159,232,112,.09);
  border: 1px solid rgba(159,232,112,.22);
  font-size: var(--fs-xs);
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--brand-lime); font-weight: 700;
}
.hero-copy .kicker .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--brand-lime);
  box-shadow: 0 0 0 3px rgba(159,232,112,.2);
}
.hero-copy h1 {
  margin-top: var(--sp-6);
  font-size: var(--fs-3xl);
  letter-spacing: -.05em; line-height: .97;
  max-width: 14ch;
}
.hero-copy h1 .soft { color: var(--text-muted); font-weight: 500; }
.hero-copy .tag-under {
  display: inline-block;
  margin-top: var(--sp-6);
  padding: .35rem .8rem;
  border-radius: var(--r-pill);
  background: rgba(0,139,139,.16);
  color: var(--brand-lime);
  font-size: .78rem; text-transform: uppercase; letter-spacing: .14em; font-weight: 500;
  border: 1px solid rgba(159,232,112,.2);
}
.hero-copy .sub {
  margin-top: var(--sp-6);
  color: var(--text-muted);
  font-size: var(--fs-lg);
  max-width: 38ch;
}
.hero-actions {
  margin-top: var(--sp-8);
  display: flex; flex-wrap: wrap; gap: .75rem;
}
.hero-meta {
  margin-top: var(--sp-8);
  display: flex; flex-wrap: wrap; gap: var(--sp-6);
  color: var(--text-faint); font-size: var(--fs-sm);
}
.hero-meta span { display: inline-flex; align-items: center; gap: .4rem; }
.hero-meta svg { width: 16px; height: 16px; color: var(--brand-lime); }

/* Hero product preview (stacked phones) */
.hero-stage {
  position: relative;
  aspect-ratio: 6 / 7;
  min-height: 520px;
}
.hero-stage .floor {
  position: absolute; left: 10%; right: 10%; bottom: 6%;
  height: 40px; border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(0,0,0,.55), transparent 70%);
  filter: blur(12px);
}
.hero-stage .orb {
  position: absolute; border-radius: 50%; filter: blur(14px); pointer-events: none;
}
.hero-stage .orb.teal { width: 260px; height: 260px; top: 4%; left: -4%;
  background: radial-gradient(circle, rgba(0,139,139,.45), transparent 62%); }
.hero-stage .orb.lime { width: 220px; height: 220px; top: 0; right: 4%;
  background: radial-gradient(circle, rgba(159,232,112,.28), transparent 62%); }

.phone {
  position: absolute; aspect-ratio: 390/844;
  border-radius: 44px; padding: 12px;
  background: linear-gradient(180deg, #1b2322, #06100f);
  box-shadow:
    0 42px 90px rgba(0,0,0,.5),
    inset 0 0 0 1px rgba(255,255,255,.06);
}
.phone::before {
  content: ""; position: absolute; inset: 3px; border-radius: 41px;
  border: 1px solid rgba(255,255,255,.06); pointer-events: none;
}
.phone-main  { width: 60%; right: 4%;  top: 5%;  z-index: 3; }
.phone-left  { width: 44%; left: 0;    bottom: 8%; transform: rotate(-9deg);  z-index: 2; opacity: .95; }
.phone-right { width: 40%; right: 2%;  bottom: 4%; transform: rotate(10deg);  z-index: 1; opacity: .85; }

.screen {
  position: relative; height: 100%; overflow: hidden;
  border-radius: 32px;
  background: linear-gradient(180deg, #081615, #0b201f);
}
.screen::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 75% 10%, rgba(159,232,112,.14), transparent 34%),
    radial-gradient(circle at 15% 90%, rgba(0,139,139,.22), transparent 38%);
}
.island {
  position: absolute; top: 9px; left: 50%; transform: translateX(-50%);
  width: 88px; height: 22px; border-radius: 999px; background: #050607; z-index: 2;
}
.status {
  position: relative; z-index: 1;
  padding: 14px 18px 0;
  display: flex; justify-content: space-between; align-items: center;
  font-size: 10px; color: rgba(238,244,241,.7); font-weight: 500;
}
.status-right { display: inline-flex; gap: 4px; align-items: center; }
.status-right svg { width: 12px; height: 12px; }

.screen-body {
  position: relative; z-index: 1;
  padding: 30px 16px 16px;
  display: grid; gap: 12px;
}
.sc-panel {
  padding: 14px 14px; border-radius: 20px;
  background: rgba(9,19,18,.78);
  border: 1px solid rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
}
.sc-row { display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.sc-label { font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: rgba(238,244,241,.5); font-weight: 500; }
.sc-h { font-size: 1rem; font-weight: 700; letter-spacing: -.02em; }
.sc-sub { font-size: .78rem; color: rgba(238,244,241,.68); }

.sc-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 10px; }
.sc-metric { padding: 10px; border-radius: 14px; background: rgba(255,255,255,.04); }
.sc-metric strong { display: block; font-size: 1.15rem; letter-spacing: -.04em; line-height: 1; }
.sc-metric .u { font-size: .65rem; color: rgba(238,244,241,.48); font-weight: 400; margin-left: 2px; }
.sc-metric span { display: block; margin-top: 6px; font-size: 9px; text-transform: uppercase; letter-spacing: .08em; color: rgba(238,244,241,.5); font-weight: 500; }

/* Ring */
.sc-ring-wrap { display: grid; grid-template-columns: 86px 1fr; gap: 12px; align-items: center; margin-top: 10px; }
.sc-ring {
  width: 86px; height: 86px; border-radius: 50%;
  background: conic-gradient(var(--brand-lime) 0 252deg, rgba(255,255,255,.08) 252deg);
  display: grid; place-items: center;
}
.sc-ring > div { width: 70px; height: 70px; border-radius: 50%; background: #081514; display: grid; place-items: center; text-align: center; }
.sc-ring strong { display: block; font-size: 1.25rem; line-height: 1; letter-spacing: -.04em; }
.sc-ring span { display: block; font-size: 9px; letter-spacing: .08em; text-transform: uppercase; color: rgba(238,244,241,.5); margin-top: 3px; }

.sc-week { display: grid; gap: 4px; }
.sc-week .days { display: flex; gap: 4px; }
.sc-week .days span {
  flex: 1; height: 32px; border-radius: 8px;
  background: linear-gradient(180deg, rgba(159,232,112,.85), rgba(65,127,49,.6));
}
.sc-week .days span.off { background: rgba(255,255,255,.06); }
.sc-week .day-labels { display: flex; gap: 4px; }
.sc-week .day-labels span { flex: 1; text-align: center; font-size: 8px; color: rgba(238,244,241,.4); letter-spacing: .08em; }

.sc-pack { display: grid; gap: 8px; }
.sc-pack-row {
  display: grid; grid-template-columns: 28px 1fr auto; gap: 10px; align-items: center;
  padding: 8px 10px; border-radius: 14px; background: rgba(255,255,255,.04);
}
.sc-pack-row .av {
  width: 28px; height: 28px; border-radius: 999px; overflow: hidden;
  background: linear-gradient(135deg, var(--brand-teal), var(--brand-lime));
  display: grid; place-items: center; font-size: 11px; font-weight: 700; color: #0c1a19;
}
.sc-pack-row strong { font-size: .82rem; letter-spacing: -.01em; }
.sc-pack-row small { display: block; font-size: .7rem; color: rgba(238,244,241,.55); }
.sc-pack-row em { font-style: normal; font-size: .66rem; text-transform: uppercase; letter-spacing: .08em; color: var(--brand-lime); font-weight: 700; }

/* Map preview */
.sc-map {
  aspect-ratio: 16/12; border-radius: 16px;
  background: linear-gradient(135deg, #06322f, #051f1e);
  position: relative; overflow: hidden;
  margin-top: 10px;
}
.sc-map svg { position: absolute; inset: 0; width: 100%; height: 100%; }

.hero-meta-card {
  position: absolute; z-index: 5;
  background: rgba(9,19,18,.9); border: 1px solid rgba(159,232,112,.2);
  border-radius: 20px; padding: 12px 14px;
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(14px);
}
.hero-meta-card .label { color: var(--text-faint); font-size: 10px; }
.hero-meta-card strong { display: block; margin-top: 4px; font-size: .98rem; letter-spacing: -.015em; }
.hero-meta-card p { font-size: .8rem; color: var(--text-muted); margin-top: 4px; }
.hero-meta-card.top  { top: 6%;  left: -6%; max-width: 220px; }
.hero-meta-card.bot  { bottom: 8%; right: -4%; max-width: 200px; }

@media (max-width: 960px) {
  .hero-grid { grid-template-columns: minmax(0, 1fr); }
  .hero-stage { min-height: 560px; max-width: 540px; margin-inline: auto; width: 100%; }
  .hero-meta-card.top { left: 0; }
  .hero-meta-card.bot { right: 0; }
}
@media (max-width: 520px) {
  .hero-stage { min-height: 480px; }
  .hero-meta-card { padding: 10px 12px; border-radius: 16px; }
  .hero-meta-card strong { font-size: .88rem; }
  .hero-meta-card p { font-size: .72rem; }
  .hero-meta-card.top, .hero-meta-card.bot { max-width: 45vw; }
}

/* --- Trust strip ----------------------------------------------------- */
.trust-strip {
  padding-block: var(--sp-10);
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.trust-strip .inner {
  display: grid; grid-template-columns: auto 1fr;
  gap: clamp(var(--sp-6), 5vw, var(--sp-12));
  align-items: center;
}
.trust-strip .label-line {
  font-size: .78rem; text-transform: uppercase; letter-spacing: .14em;
  color: var(--text-faint); font-weight: 500;
  max-width: 20ch;
}
.trust-list {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-6);
}
.trust-list .item {
  display: grid; gap: .3rem;
  padding-left: var(--sp-5);
  border-left: 1px solid var(--divider);
}
.trust-list strong { font-size: 1rem; font-weight: 600; letter-spacing: -.02em; }
.trust-list small { font-size: .8rem; color: var(--text-muted); }
@media (max-width: 820px) {
  .trust-strip .inner { grid-template-columns: 1fr; gap: var(--sp-6); }
  .trust-list { grid-template-columns: 1fr 1fr; }
}

/* --- Why grid -------------------------------------------------------- */
.why {
  display: grid; grid-template-columns: 1fr 1.4fr;
  gap: clamp(var(--sp-10), 5vw, var(--sp-16));
  align-items: start;
}
.why-cards { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-5); }
.why-card {
  padding: var(--sp-6);
  border-radius: var(--r-xl);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  transition: transform var(--t), border-color var(--t), background var(--t);
}
.why-card:hover { transform: translateY(-2px); border-color: var(--border-accent); }
.why-card .ico {
  width: 40px; height: 40px; border-radius: 12px;
  display: grid; place-items: center;
  background: rgba(159,232,112,.12); color: var(--brand-lime);
  margin-bottom: var(--sp-4);
}
.why-card .ico svg { width: 20px; height: 20px; }
.why-card h3 { font-size: 1.12rem; letter-spacing: -.02em; }
.why-card p { color: var(--text-muted); font-size: var(--fs-sm); margin-top: .5rem; }

@media (max-width: 860px) {
  .why { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .why-cards { grid-template-columns: 1fr; }
}

/* --- Product preview (screens scroller) ------------------------------ */
.product {
  background:
    radial-gradient(900px 500px at 50% 0%, rgba(0,139,139,.14), transparent 70%);
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.product .intro { max-width: 680px; margin: 0 auto var(--sp-12); text-align: center; }
.product .intro .eyebrow { display: inline-block; }
.product .intro p { margin-inline: auto; color: var(--text-muted); }

.screens-row {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: clamp(var(--sp-4), 2vw, var(--sp-6));
  align-items: end;
}
.screen-card {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-5);
  transition: transform var(--t), border-color var(--t);
}
.screen-card:hover { transform: translateY(-4px); border-color: var(--border-accent); }
.screen-card .phone-mini {
  aspect-ratio: 9/19; border-radius: 26px;
  padding: 8px;
  background: linear-gradient(180deg, #1b2322, #06100f);
  box-shadow: 0 14px 34px rgba(0,0,0,.35), inset 0 0 0 1px rgba(255,255,255,.06);
  margin-bottom: var(--sp-4);
}
.screen-card .phone-mini .screen-mini {
  height: 100%;
  border-radius: 20px;
  background: linear-gradient(180deg, #081615, #0b201f);
  position: relative; overflow: hidden;
}
.screen-card h4 { font-size: 1rem; letter-spacing: -.02em; }
.screen-card p { color: var(--text-muted); font-size: .88rem; margin-top: .35rem; }

@media (max-width: 940px) {
  .screens-row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 520px) {
  .screens-row { grid-template-columns: 1fr; }
}

/* Mini screens: SVG + text composition */
.mini-scene { position: absolute; inset: 0; padding: 18px 14px; display: grid; gap: 10px; align-content: start; }
.mini-scene .head { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: rgba(238,244,241,.5); font-weight: 500; }
.mini-scene .big { font-size: 1.6rem; letter-spacing: -.04em; line-height: 1; font-weight: 700; }
.mini-scene .big .u { font-size: .6rem; color: rgba(238,244,241,.5); margin-left: 2px; }
.mini-scene .row { display: flex; justify-content: space-between; font-size: .72rem; color: rgba(238,244,241,.7); }
.mini-scene .bar {
  height: 6px; border-radius: 999px; background: rgba(255,255,255,.08);
  overflow: hidden; margin-top: 6px;
}
.mini-scene .bar > span {
  display: block; height: 100%;
  background: linear-gradient(90deg, var(--brand-lime), #55a73c);
}
.mini-scene .bars7 { display: flex; align-items: flex-end; gap: 5px; height: 64px; margin-top: 6px; }
.mini-scene .bars7 span { flex: 1; border-radius: 6px 6px 2px 2px; background: linear-gradient(180deg, var(--brand-lime), rgba(159,232,112,.4)); }
.mini-scene .ring-sm {
  width: 90px; height: 90px; border-radius: 50%; margin: 6px auto 0;
  background: conic-gradient(var(--brand-lime) 0 230deg, rgba(255,255,255,.1) 230deg);
  display: grid; place-items: center;
}
.mini-scene .ring-sm > div { width: 68px; height: 68px; border-radius: 50%; background: #081514; display: grid; place-items: center; text-align: center; }
.mini-scene .ring-sm strong { font-size: 1rem; line-height: 1; }
.mini-scene .ring-sm span { font-size: 8px; text-transform: uppercase; letter-spacing: .08em; color: rgba(238,244,241,.5); }
.mini-scene .mini-list { display: grid; gap: 5px; }
.mini-scene .mini-list .li {
  padding: 6px 8px; border-radius: 10px; background: rgba(255,255,255,.04);
  display: flex; justify-content: space-between; font-size: .7rem;
}
.mini-scene .mini-list .li em { font-style: normal; color: var(--brand-lime); font-size: .6rem; text-transform: uppercase; letter-spacing: .08em; }
.mini-scene .map-frame {
  flex: 1; border-radius: 12px;
  background: linear-gradient(135deg, #06322f, #051f1e);
  position: relative; overflow: hidden; min-height: 90px;
}
.mini-scene .map-frame svg { position: absolute; inset: 0; width: 100%; height: 100%; }

/* --- Routine / streak section --------------------------------------- */
.routine {
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: clamp(var(--sp-10), 5vw, var(--sp-16));
  align-items: center;
}
.routine-copy h2 { font-size: var(--fs-2xl); line-height: 1.04; letter-spacing: -.035em; max-width: 18ch; }
.routine-copy .lede { margin-top: var(--sp-5); }
.routine-points { margin-top: var(--sp-8); display: grid; gap: var(--sp-5); }
.routine-point { display: grid; grid-template-columns: 28px 1fr; gap: var(--sp-3); align-items: start; }
.routine-point .badge {
  width: 28px; height: 28px; border-radius: 9px;
  background: rgba(159,232,112,.14); color: var(--brand-lime);
  display: grid; place-items: center;
}
.routine-point .badge svg { width: 14px; height: 14px; }
.routine-point strong { display: block; font-size: 1rem; letter-spacing: -.015em; }
.routine-point p { color: var(--text-muted); font-size: var(--fs-sm); margin-top: .25rem; }

.routine-visual {
  padding: var(--sp-8);
  border-radius: var(--r-2xl);
  background: linear-gradient(180deg, rgba(0,139,139,.12), rgba(11,23,22,.9));
  border: 1px solid rgba(159,232,112,.18);
  position: relative; overflow: hidden;
}
.routine-visual::before {
  content: ""; position: absolute; inset: -30% auto auto -30%;
  width: 200%; height: 60%; z-index: 0;
  background: radial-gradient(circle at 20% 50%, rgba(159,232,112,.12), transparent 60%);
  pointer-events: none;
}
.streak-ring {
  position: relative; z-index: 1;
  width: 220px; height: 220px; border-radius: 50%;
  margin: 0 auto var(--sp-6);
  background: conic-gradient(var(--brand-lime) 0 310deg, rgba(255,255,255,.08) 310deg);
  display: grid; place-items: center;
}
.streak-ring > div {
  width: 170px; height: 170px; border-radius: 50%;
  background: #061413;
  display: grid; place-items: center; text-align: center;
}
.streak-ring strong { display: block; font-size: 3rem; letter-spacing: -.06em; line-height: 1; }
.streak-ring span { display: block; margin-top: .4rem; font-size: .78rem; text-transform: uppercase; letter-spacing: .14em; color: var(--text-faint); font-weight: 500; }
.streak-caption { position: relative; z-index: 1; text-align: center; color: var(--text-muted); font-size: var(--fs-sm); max-width: 28ch; margin: 0 auto; }
.streak-weeks {
  position: relative; z-index: 1;
  margin-top: var(--sp-8); display: grid; gap: var(--sp-3);
}
.streak-weeks .wk-row {
  display: grid; grid-template-columns: 42px 1fr 42px; gap: 10px; align-items: center;
}
.streak-weeks .wk-row small { font-size: .72rem; color: var(--text-faint); text-align: center; }
.streak-weeks .wk-row .days { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.streak-weeks .wk-row .days span {
  height: 18px; border-radius: 5px;
  background: linear-gradient(180deg, rgba(159,232,112,.85), rgba(65,127,49,.55));
}
.streak-weeks .wk-row .days span.off { background: rgba(255,255,255,.05); }
.streak-weeks .wk-row .days span.hl { box-shadow: 0 0 0 1.5px var(--brand-lime); }

@media (max-width: 900px) { .routine { grid-template-columns: 1fr; } }

/* --- Pack mode ------------------------------------------------------- */
.pack {
  background:
    radial-gradient(900px 440px at 100% 30%, rgba(0,139,139,.18), transparent 60%),
    radial-gradient(600px 320px at 0% 70%, rgba(159,232,112,.06), transparent 60%);
  border-top: 1px solid var(--divider);
}
.pack-grid {
  display: grid; grid-template-columns: 1fr 1.05fr;
  gap: clamp(var(--sp-10), 5vw, var(--sp-16));
  align-items: center;
}
.pack-copy .lede { margin-top: var(--sp-5); }
.pack-copy h2 { font-size: var(--fs-2xl); line-height: 1.04; letter-spacing: -.035em; max-width: 18ch; }
.pack-copy .premium-chip {
  display: inline-flex; align-items: center; gap: .45rem;
  padding: .4rem .8rem; margin-top: var(--sp-4);
  border-radius: var(--r-pill);
  background: rgba(246,228,196,.12);
  border: 1px solid rgba(246,228,196,.28);
  color: var(--brand-sand);
  font-size: .72rem; text-transform: uppercase; letter-spacing: .14em; font-weight: 600;
}
.pack-bullets { margin-top: var(--sp-8); display: grid; gap: var(--sp-3); }
.pack-bullets li {
  display: grid; grid-template-columns: 18px 1fr; gap: .6rem; align-items: start;
  color: var(--text-muted); font-size: var(--fs-base);
}
.pack-bullets li svg { width: 18px; height: 18px; color: var(--brand-lime); margin-top: 4px; }
.pack-bullets li strong { color: var(--text); font-weight: 600; }

.pack-panel {
  padding: var(--sp-6);
  border-radius: var(--r-2xl);
  background: var(--bg-surface);
  border: 1px solid var(--border);
}
.pack-panel h4 { font-size: 1.1rem; letter-spacing: -.02em; }
.pack-panel .subline { color: var(--text-muted); font-size: .88rem; margin-top: .25rem; }
.pack-list { margin-top: var(--sp-5); display: grid; gap: var(--sp-3); }
.pack-item {
  display: grid; grid-template-columns: 44px 1fr auto; gap: var(--sp-4); align-items: center;
  padding: var(--sp-4); border-radius: var(--r-lg);
  background: rgba(255,255,255,.03);
  border: 1px solid var(--divider);
}
.pack-item .av {
  width: 44px; height: 44px; border-radius: 14px;
  display: grid; place-items: center;
  font-weight: 700; color: var(--text-invert); font-size: 1rem;
}
.pack-item .av.a { background: linear-gradient(135deg, #7bd25a, #3f8b2a); }
.pack-item .av.b { background: linear-gradient(135deg, #f0c97d, #c28849); }
.pack-item .av.c { background: linear-gradient(135deg, #74dcdc, #1f7979); }
.pack-item strong { display: block; font-size: .98rem; letter-spacing: -.01em; }
.pack-item small { display: block; color: var(--text-faint); font-size: .78rem; margin-top: .15rem; }
.pack-item em { font-style: normal; font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; color: var(--brand-lime); font-weight: 700; }

.pack-compare {
  margin-top: var(--sp-6);
  padding: var(--sp-5);
  border-radius: var(--r-lg);
  background: rgba(159,232,112,.08);
  border: 1px solid rgba(159,232,112,.2);
  display: grid; grid-template-columns: 1fr auto; gap: var(--sp-3); align-items: center;
  color: var(--text-muted); font-size: var(--fs-sm);
}
.pack-compare strong { color: var(--text); font-weight: 600; }

@media (max-width: 900px) { .pack-grid { grid-template-columns: 1fr; } }

/* --- Pricing --------------------------------------------------------- */
.pricing-intro { max-width: 640px; margin: 0 auto var(--sp-12); text-align: center; }
.pricing-intro p { margin-inline: auto; color: var(--text-muted); }

.pricing-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--sp-6);
  max-width: 940px; margin-inline: auto;
}
.tier {
  padding: var(--sp-8);
  border-radius: var(--r-2xl);
  background: var(--bg-surface);
  border: 1px solid var(--border);
  position: relative;
}
.tier.featured {
  background: linear-gradient(180deg, rgba(159,232,112,.06), rgba(11,23,22,.95));
  border-color: rgba(159,232,112,.3);
  box-shadow: var(--shadow-md);
}
.tier .tier-name { font-size: .82rem; text-transform: uppercase; letter-spacing: .12em; color: var(--text-faint); font-weight: 500; }
.tier .tier-price { margin-top: var(--sp-3); font-size: 2.6rem; font-weight: 700; letter-spacing: -.04em; line-height: 1; }
.tier .tier-price .u { font-size: 1rem; color: var(--text-muted); font-weight: 500; margin-left: .25rem; }
.tier .tier-price .alt { display: block; font-size: .9rem; color: var(--text-muted); font-weight: 400; margin-top: .35rem; letter-spacing: 0; }
.tier .tier-lede { color: var(--text-muted); font-size: var(--fs-sm); margin-top: var(--sp-4); }
.tier .tier-features { margin-top: var(--sp-6); display: grid; gap: var(--sp-3); }
.tier .tier-features li { display: grid; grid-template-columns: 18px 1fr; gap: .6rem; color: var(--text-muted); font-size: var(--fs-sm); }
.tier .tier-features li svg { width: 18px; height: 18px; color: var(--brand-lime); }
.tier .tier-features li strong { color: var(--text); font-weight: 600; }
.tier .tier-cta { margin-top: var(--sp-8); display: block; width: 100%; }
.tier .badge {
  position: absolute; top: -14px; right: var(--sp-8);
  padding: .3rem .7rem; border-radius: var(--r-pill);
  background: var(--brand-lime); color: var(--text-invert);
  font-size: .7rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 700;
}

@media (max-width: 780px) { .pricing-grid { grid-template-columns: 1fr; } }

.pricing-fineprint {
  max-width: 640px; margin: var(--sp-10) auto 0;
  text-align: center; color: var(--text-faint); font-size: var(--fs-xs);
}

/* --- FAQ ------------------------------------------------------------- */
.faq {
  max-width: 860px; margin-inline: auto;
}
.faq-head { text-align: center; margin-bottom: var(--sp-12); }
.faq-list { display: grid; gap: var(--sp-3); }
.faq-item {
  background: var(--bg-surface); border: 1px solid var(--border);
  border-radius: var(--r-lg);
  transition: border-color var(--t), background var(--t);
}
.faq-item[open] { border-color: var(--border-accent); }
.faq-item summary {
  list-style: none;
  padding: var(--sp-5) var(--sp-6);
  display: grid; grid-template-columns: 1fr 20px; align-items: center; gap: var(--sp-4);
  cursor: pointer;
  font-size: var(--fs-base); font-weight: 600; letter-spacing: -.01em;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary .chev {
  width: 20px; height: 20px; color: var(--text-muted);
  transition: transform var(--t);
}
.faq-item[open] summary .chev { transform: rotate(45deg); color: var(--brand-lime); }
.faq-item .body {
  padding: 0 var(--sp-6) var(--sp-6);
  color: var(--text-muted); font-size: var(--fs-base);
}
.faq-item .body p { max-width: 60ch; margin-bottom: .6rem; }

/* --- Final CTA ------------------------------------------------------- */
.final-cta {
  padding: clamp(var(--sp-16), 8vw, var(--sp-24)) clamp(var(--sp-8), 5vw, var(--sp-16));
  border-radius: var(--r-2xl);
  background:
    radial-gradient(600px 340px at 20% 20%, rgba(0,139,139,.35), transparent 60%),
    radial-gradient(480px 300px at 85% 80%, rgba(159,232,112,.25), transparent 60%),
    #0b1b1a;
  border: 1px solid rgba(159,232,112,.18);
  text-align: center;
}
.final-cta h2 { font-size: var(--fs-2xl); line-height: 1.05; letter-spacing: -.035em; max-width: 18ch; margin-inline: auto; }
.final-cta p { color: var(--text-muted); max-width: 48ch; margin: var(--sp-4) auto 0; }
.final-cta .actions { margin-top: var(--sp-8); display: flex; flex-wrap: wrap; gap: var(--sp-3); justify-content: center; }
.final-cta small { display: block; margin-top: var(--sp-6); color: var(--text-faint); font-size: var(--fs-xs); }
