/* ═══════════════════════════════════════════════════════════
   TRIAGI v3 — section styles
   Tokens in triagi.css · components in components/inspira.css
   ═══════════════════════════════════════════════════════════ */

@font-face {
  font-family: "Agrandir";
  src: url("../fonts/pp-agrandir-variable.woff2?v=t003") format("woff2");
  font-weight: 200 800; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "Inter";
  src: url("../fonts/inter-latin.woff2?v=t003") format("woff2");
  font-weight: 400 700; font-style: normal; font-display: swap;
}

/* ─── NAV ───────────────────────────────────────────────── */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 90;
  padding: 14px 0;
  transition: background 240ms, backdrop-filter 240ms, border-color 240ms;
  border-bottom: 1px solid transparent;
}
.nav.scrolled {
  background: rgba(250, 250, 249, 0.78);
  backdrop-filter: saturate(160%) blur(18px);
  -webkit-backdrop-filter: saturate(160%) blur(18px);
  border-bottom-color: var(--line);
}
.nav-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px;
}
.nav-logo { height: 22px; width: auto; }
.nav-links { display: none; gap: 28px; }
@media (min-width: 900px) { .nav-links { display: flex; } }
.nav-link {
  font-size: 14px; color: var(--ink-2); font-weight: 500;
  letter-spacing: -0.005em;
  transition: color 200ms;
}
.nav-link:hover { color: var(--ink); }
.nav-cta { display: flex; align-items: center; gap: 14px; }
.nav-enter {
  display: none;
  font-size: 14px; color: var(--ink-2); font-weight: 500;
}
@media (min-width: 700px) { .nav-enter { display: inline; } }
.nav-enter:hover { color: var(--ink); }

/* ─── HERO ─────────────────────────────────────────────── */
.hero {
  position: relative;
  padding: 140px 0 100px;
  overflow: hidden;
  isolation: isolate;
}
.hero-inner {
  display: grid; gap: 32px; max-width: 1100px;
  position: relative; z-index: 2;
}
.hero h1.t-display {
  font-size: clamp(60px, 9.5vw, 132px);
  font-weight: 400;
  letter-spacing: -0.05em;
  line-height: 0.88;
}
.hero-sub {
  font-size: clamp(17px, 1.3vw, 21px);
  line-height: 1.4;
  color: var(--ink-2);
  max-width: 28em;
  letter-spacing: -0.01em;
}
.hero-actions {
  display: flex; gap: 14px; flex-wrap: wrap; align-items: center;
  margin-top: 8px;
}

/* Meta partner badge */
.meta-badge {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 7px 14px 7px 8px;
  border-radius: 999px;
  background: white;
  border: 1px solid var(--line);
  box-shadow: var(--sh-sm);
  align-self: flex-start;
  transition: transform 200ms var(--ease-out);
}
.meta-badge:hover { transform: translateY(-1px); }
.meta-badge-ico {
  width: 30px; height: 30px;
  border-radius: 999px;
  background: white;
  display: grid; place-items: center;
  border: 1px solid var(--line);
}
.meta-badge-text {
  display: flex; flex-direction: column; gap: 1px; padding-right: 4px;
  text-align: left;
}
.meta-badge-kicker {
  font-size: 9px; font-weight: 700; letter-spacing: 0.12em;
  color: var(--ink-3); text-transform: uppercase;
}
.meta-badge-claim {
  font-size: 12px; font-weight: 600; color: var(--ink);
  letter-spacing: -0.005em;
}

/* ─── 2. WHATSAPP — Real talk ──────────────────────────── */
.wa-section { padding: clamp(64px, 9vw, 120px) 0; }
.wa-stage {
  display: grid; gap: 48px;
  align-items: center;
}
@media (min-width: 900px) {
  .wa-stage { grid-template-columns: 1fr 1.05fr; gap: 80px; }
}

.wa-feed {
  background: white;
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 24px;
  box-shadow: var(--sh-md);
  min-height: 480px;
  display: flex; flex-direction: column;
}
.wa-feed-head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 18px;
}
.wa-feed-title {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 600; color: var(--ink);
}
.wa-feed-title .dot {
  width: 8px; height: 8px; border-radius: 999px;
  background: var(--green);
  box-shadow: 0 0 0 3px var(--green-soft);
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { box-shadow: 0 0 0 3px var(--green-soft); }
  50%      { box-shadow: 0 0 0 6px transparent; }
}
.wa-feed-meta {
  font-size: 11px; color: var(--ink-3); font-feature-settings: "tnum";
  letter-spacing: 0.04em; text-transform: uppercase; font-weight: 600;
}

.wa-rows {
  display: flex; flex-direction: column; gap: 12px; flex: 1;
}

/* ─── 3. EQUIPE ─────────────────────────────────────────── */
.equipe { padding: clamp(96px, 14vw, 180px) 0; background: var(--bg-warm); }
.equipe-tabs {
  display: flex; gap: 8px;
  padding-bottom: 32px;
  margin-bottom: 32px;
  border-bottom: 1px solid var(--line);
  overflow-x: auto;
  scrollbar-width: none;
  scroll-snap-type: x mandatory;
}
.equipe-tabs::-webkit-scrollbar { display: none; }
.equipe-tab {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 18px 10px 10px;
  border-radius: 999px;
  background: white;
  border: 1px solid var(--line);
  flex: 0 0 auto;
  scroll-snap-align: start;
  transition: border-color 200ms, transform 200ms var(--ease-out);
}
.equipe-tab:hover { transform: translateY(-1px); border-color: var(--line-2); }
.equipe-tab.active {
  background: var(--ink); color: white; border-color: var(--ink);
}
.tab-avatar {
  width: 32px; height: 32px; border-radius: 999px;
  object-fit: cover;
}
.tab-meta { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.1; gap: 1px; }
.tab-name { font-size: 13px; font-weight: 600; letter-spacing: -0.005em; }
.tab-role { font-size: 10px; opacity: 0.65; letter-spacing: 0.06em; text-transform: uppercase; font-weight: 600; }

.panel { display: none; }
.panel.active { display: block; animation: panel-in 600ms var(--ease-out); }
@keyframes panel-in {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.panel-grid {
  display: grid; gap: 48px; align-items: center;
}
@media (min-width: 900px) {
  .panel-grid { grid-template-columns: 1fr 1fr; gap: 80px; }
  .panel-grid.flip > :first-child { order: 2; }
}
.panel-text h3 {
  font-family: var(--font-display);
  font-size: clamp(32px, 4.5vw, 60px);
  font-weight: 400;
  letter-spacing: -0.035em;
  line-height: 0.98;
  margin: 0 0 24px;
  max-width: 14ch;
}
.panel-text p {
  font-size: 17px; line-height: 1.55; color: var(--ink-2);
  letter-spacing: -0.005em; max-width: 38ch;
  margin: 0 0 14px;
}
.panel-stat {
  display: flex; gap: 36px; flex-wrap: wrap;
  margin-top: 32px; padding-top: 28px; border-top: 1px solid var(--line);
}
.panel-stat .v {
  font-family: var(--font-display);
  font-size: 44px; font-weight: 400; letter-spacing: -0.04em;
  line-height: 1; color: var(--ink);
  font-feature-settings: "tnum";
}
.panel-stat .v small { font-size: 22px; color: var(--ink-2); }
.panel-stat .l {
  font-size: 12px; color: var(--ink-3); letter-spacing: -0.005em;
  margin-top: 6px; line-height: 1.35;
}

/* ─── 4. INTEL — three-model orchestration ─────────────── */
.intel { padding: clamp(96px, 14vw, 180px) 0; background: var(--bg-dark); color: white; position: relative; overflow: hidden; }
.intel .t-h2 { color: white; max-width: 16ch; }
.intel .t-body-lg { color: rgba(255,255,255,0.65); }
.intel-stage {
  position: relative;
  margin-top: 80px;
  padding: 80px 0;
  min-height: 480px;
}
.intel-hub {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  width: 180px; height: 180px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--accent), #6d28d9);
  display: grid; place-items: center;
  box-shadow: 0 0 80px rgba(37, 99, 255, 0.55), 0 0 0 1px rgba(255,255,255,0.1);
  z-index: 5;
}
.intel-hub::before {
  content: "";
  position: absolute; inset: -8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  animation: hub-pulse 3s ease-in-out infinite;
}
@keyframes hub-pulse {
  0%, 100% { transform: scale(1); opacity: 0.8; }
  50%      { transform: scale(1.15); opacity: 0; }
}
.intel-hub img { height: 38px; }

.intel-orbits {
  display: grid; gap: 80px;
  grid-template-columns: 1fr;
  position: relative;
}
@media (min-width: 800px) {
  .intel-orbits { grid-template-columns: repeat(3, 1fr); gap: 32px; }
}
.intel-node {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 22px;
  padding: 28px;
  backdrop-filter: blur(10px);
  position: relative;
  z-index: 4;
}
.intel-node:nth-child(1) { transform: translateY(0); }
@media (min-width: 800px) {
  .intel-node:nth-child(1) { transform: translateY(40px); }
  .intel-node:nth-child(3) { transform: translateY(40px); }
}
.intel-node .corp {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.04em;
  color: rgba(255,255,255,0.6); text-transform: uppercase;
  margin-bottom: 16px;
}
.intel-node h4 {
  font-family: var(--font-display);
  font-size: 28px; font-weight: 400; letter-spacing: -0.025em;
  line-height: 1.02; margin: 0 0 12px; color: white;
  max-width: 12ch;
}
.intel-node p {
  font-size: 14px; line-height: 1.5; color: rgba(255,255,255,0.65);
  margin: 0; max-width: 28ch;
}

/* ─── 5. CONTROL — bento ──────────────────────────────── */
.control { padding: clamp(80px, 12vw, 160px) 0; }

/* ─── 6. SPECIALTIES carousel ──────────────────────────── */
.esp { padding: clamp(80px, 12vw, 160px) 0; background: var(--bg-warm); }
.apple-card.derm  { background: linear-gradient(135deg, #f5d6c8, #e89a7e); }
.apple-card.odon  { background: linear-gradient(135deg, #d8e2f0, #9ab4d3); }
.apple-card.cir   { background: linear-gradient(135deg, #e8d8e3, #c595b3); }
.apple-card.nut   { background: linear-gradient(135deg, #d6e5d2, #87a988); }
.apple-card.fis   { background: linear-gradient(135deg, #efe1c8, #c9a868); }
.apple-card.psi   { background: linear-gradient(135deg, #d9d4eb, #8d83b8); }

/* ─── 7. STATS ─────────────────────────────────────────── */
.stats { padding: clamp(80px, 12vw, 160px) 0; }
.stats-grid {
  display: grid; gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 24px;
  overflow: hidden;
}
@media (min-width: 700px) { .stats-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .stats-grid { grid-template-columns: repeat(4, 1fr); } }
.stat-cell {
  background: white;
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 8px;
}
.stat-cell .ticker {
  font-size: clamp(48px, 6vw, 72px);
  letter-spacing: -0.04em;
  color: var(--ink);
  line-height: 0.95;
}
.stat-cell .label {
  font-size: 14px; color: var(--ink-2); line-height: 1.4;
  letter-spacing: -0.005em;
  margin-top: 4px;
}
.stat-cell .src {
  font-size: 11px; color: var(--ink-3); margin-top: auto;
  padding-top: 16px; border-top: 1px solid var(--line);
}

/* ─── 8. CLT vs TRIAGI — container scroll ─────────────── */
.versus { padding: clamp(80px, 12vw, 160px) 0; background: var(--bg-warm); }
.versus-card {
  padding: 64px 48px;
  background: white;
}
.versus-card h3 {
  font-family: var(--font-display);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 400; letter-spacing: -0.03em;
  margin: 0 0 32px;
}
.cmp-table {
  display: grid;
  border-top: 1px solid var(--line);
}
.cmp-row {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  border-bottom: 1px solid var(--line);
  align-items: center;
  padding: 18px 0;
  gap: 12px;
}
@media (max-width: 700px) {
  .cmp-row { grid-template-columns: 1fr; padding: 14px 0; }
  .cmp-row > div:first-child { font-size: 11px; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.06em; }
}
.cmp-row.head {
  font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--ink-3); font-weight: 600;
}
.cmp-row .label { font-size: 14px; color: var(--ink-2); font-weight: 500; }
.cmp-row .clt { color: var(--ink-3); font-size: 14px; display: flex; align-items: center; gap: 8px; text-decoration: line-through; text-decoration-color: rgba(0,0,0,0.18); }
.cmp-row .triagi { color: var(--ink); font-size: 15px; font-weight: 500; display: flex; align-items: center; gap: 8px; letter-spacing: -0.005em; }
.cmp-row .triagi .ph { color: var(--green); }

/* ─── 9. MIGROU — compare slider + marquee ────────────── */
.migrou { padding: clamp(80px, 12vw, 160px) 0; }
.migrou-quote {
  margin: 64px 0;
  padding: 48px;
  background: var(--bg-warm);
  border-radius: 28px;
  display: grid; gap: 32px;
}
@media (min-width: 800px) { .migrou-quote { grid-template-columns: 1.5fr 1fr; align-items: center; } }
.migrou-quote .q {
  font-family: var(--font-display);
  font-size: clamp(24px, 2.6vw, 34px);
  font-weight: 400; letter-spacing: -0.025em;
  line-height: 1.2;
  color: var(--ink);
}
.migrou-quote .who {
  display: flex; align-items: center; gap: 12px;
  margin-top: 24px;
}
.migrou-quote .who img {
  width: 44px; height: 44px; border-radius: 999px; object-fit: cover;
}
.migrou-quote .who strong { display: block; font-size: 14px; }
.migrou-quote .who span { font-size: 12px; color: var(--ink-3); }
.migrou-from {
  background: white; border: 1px solid var(--line);
  border-radius: 18px; padding: 24px;
}
.migrou-from .label { font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-3); font-weight: 600; }
.migrou-from strong { display: block; font-size: 17px; margin: 6px 0 8px; letter-spacing: -0.01em; }
.migrou-from .note { font-size: 13px; color: var(--ink-2); line-height: 1.45; }

.mini-card {
  flex: 0 0 360px;
  padding: 24px;
  background: white;
  border: 1px solid var(--line);
  border-radius: 18px;
}
.mini-card p {
  font-size: 15px; color: var(--ink); line-height: 1.45;
  letter-spacing: -0.005em; margin: 0;
}
.mini-card .who {
  display: flex; align-items: center; gap: 10px;
  margin-top: 16px; padding-top: 14px;
  border-top: 1px solid var(--line);
  font-size: 12px; color: var(--ink-3);
}
.mini-card .who img { width: 28px; height: 28px; border-radius: 999px; object-fit: cover; }

/* ─── 10. STEPS ────────────────────────────────────────── */
.steps { padding: clamp(80px, 12vw, 160px) 0; background: var(--bg-warm); }
.steps-grid { display: grid; gap: 24px; }
@media (min-width: 800px) { .steps-grid { grid-template-columns: repeat(3, 1fr); } }
.step {
  position: relative;
  background: white;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 32px;
  display: flex; flex-direction: column; gap: 16px;
  min-height: 260px;
}
.step .num {
  font-family: var(--font-display);
  font-size: 64px; font-weight: 400; letter-spacing: -0.04em;
  line-height: 0.85; color: var(--ink-3);
  font-feature-settings: "tnum";
}
.step h4 {
  font-family: var(--font-display);
  font-size: 26px; font-weight: 400; letter-spacing: -0.025em;
  margin: 0; line-height: 1.05;
}
.step p {
  font-size: 14px; line-height: 1.5; color: var(--ink-2);
  margin: auto 0 0; letter-spacing: -0.005em;
}

/* ─── 11. PRICING ─────────────────────────────────────── */
.pricing { padding: clamp(96px, 14vw, 180px) 0; text-align: center; background: var(--bg-warm); }
.pricing-card {
  max-width: 540px; margin: 0 auto;
  position: relative;
  background: white;
  border-radius: 32px;
  padding: 48px 40px;
  box-shadow: var(--sh-lg);
}
.pricing-card .t-h2 { font-size: clamp(40px, 5vw, 64px); }
.pricing-amt {
  display: flex; align-items: baseline; justify-content: center; gap: 6px;
  margin: 32px 0 12px;
}
.pricing-amt .cur { font-size: 22px; color: var(--ink-2); font-weight: 500; }
.pricing-amt .num {
  font-family: var(--font-display);
  font-size: 124px; font-weight: 400; letter-spacing: -0.05em;
  line-height: 0.9; color: var(--ink);
  font-feature-settings: "tnum";
}
.pricing-amt .per { font-size: 18px; color: var(--ink-2); }
.pricing-fine { font-size: 14px; color: var(--ink-3); margin: 0 0 32px; }

/* ─── 12. FAQ ──────────────────────────────────────────── */
.faqsec { padding: clamp(80px, 12vw, 160px) 0; }
.faqsec details {
  border-top: 1px solid var(--line);
  padding: 24px 0;
}
.faqsec details:last-child { border-bottom: 1px solid var(--line); }
.faqsec summary {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-body);
  font-size: clamp(17px, 1.4vw, 21px);
  font-weight: 500; letter-spacing: -0.015em;
  cursor: pointer; list-style: none;
  color: var(--ink);
}
.faqsec summary::-webkit-details-marker { display: none; }
.faqsec summary .ph { font-size: 18px; transition: transform 240ms var(--ease-out); color: var(--ink-2); }
.faqsec details[open] summary .ph { transform: rotate(45deg); }
.faqsec .a {
  margin-top: 16px;
  font-size: 16px; line-height: 1.55; color: var(--ink-2);
  max-width: 60ch; letter-spacing: -0.005em;
}

/* ─── 13. FINAL CTA ────────────────────────────────────── */
.final {
  position: relative;
  padding: clamp(120px, 16vw, 220px) 0;
  background: var(--bg-dark); color: white;
  text-align: center;
  overflow: hidden;
  isolation: isolate;
}
.final-inner { position: relative; z-index: 2; }
.final h2 { color: white; margin: 0 auto; }
.final-fine {
  font-size: 14px; color: rgba(255,255,255,0.55);
  margin: 24px 0 0;
}
.final .btn { margin-top: 32px; }

/* ─── Scroll Island (sticky bottom CTA — simple) ───── */
.scroll-island {
  position: fixed; bottom: 24px; left: 50%;
  transform: translateX(-50%) translateY(160%);
  z-index: 80;
  background: var(--ink); color: white;
  border-radius: 999px;
  padding: 14px 22px;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 500; letter-spacing: -0.005em;
  text-decoration: none;
  box-shadow: 0 12px 32px rgba(15,15,16,0.22), 0 2px 6px rgba(15,15,16,0.12);
  transition: transform 480ms var(--ease-spring), background 200ms;
  pointer-events: none;
}
.scroll-island.show {
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.scroll-island:hover { background: #1c1c20; }
.scroll-island .ph { font-size: 15px; }

/* ─── Stars ─── */
.stars { color: #ffb800; font-size: 11px; letter-spacing: 0.1em; }

/* split-list moved to bottom — single canonical block */

/* ─── Pricing v3 (cleaner, v1-styled) ─── */
.pricing-card.clean {
  background: white;
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 48px 40px;
  text-align: left;
  display: grid;
  gap: 28px;
  max-width: 560px;
  margin: 48px auto 0;
  box-shadow:
    0 1px 2px rgba(15, 15, 16, 0.04),
    0 12px 32px rgba(15, 15, 16, 0.06);
}
.pricing-card.clean .price-row .cur {
  font-size: 22px; color: var(--ink-2); font-weight: 500;
}
.pricing-card.clean .price-row .per {
  font-size: 16px; color: var(--ink-3); margin-left: 4px;
}
.pricing-card.clean .pricing-cta {
  margin-top: 4px;
}
.pricing-card.clean .pricing-fine {
  text-align: center; font-size: 13px; color: var(--ink-3);
  margin: 0; padding-top: 4px;
}
.pricing-card.clean .price-row {
  display: flex; align-items: baseline; gap: 8px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 20px;
}
.pricing-card.clean .price-row .num {
  font-family: var(--font-display);
  font-size: 88px; font-weight: 400; letter-spacing: -0.04em;
  line-height: 0.9;
}
.pricing-card.clean .feats {
  display: grid; gap: 12px; padding: 0; margin: 0; list-style: none;
}
.pricing-card.clean .feats li {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 14px; color: var(--ink-2); letter-spacing: -0.005em;
}
.pricing-card.clean .feats li .ph { color: var(--green); padding-top: 2px; }

/* ─── Steps v3 — denser ─── */
.step-art {
  height: 100px; border-radius: 14px;
  background: linear-gradient(135deg, #ece7e0, #d8d2c8);
  position: relative; overflow: hidden;
  margin-bottom: 20px;
}
.step-art.s1 { background: linear-gradient(135deg, #e3eef9, #b9d2ec); }
.step-art.s2 { background: linear-gradient(135deg, #fce8d8, #f4c8a4); }
.step-art.s3 { background: linear-gradient(135deg, #d9eedb, #aed5b3); }
.step-art .glyph {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-size: 44px; opacity: 0.7;
  color: white;
  font-family: var(--font-display);
  letter-spacing: -0.04em;
}

/* ─── Specialty card details (testimonial+feats inside) ─── */
.spec-detail {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 28px;
  display: flex; flex-direction: column; justify-content: flex-end; gap: 16px;
  opacity: 0;
  transition: opacity 320ms var(--ease-out);
  color: white;
}
.apple-card:hover .spec-detail { opacity: 1; }
.apple-card:hover .meta { opacity: 0; transition: opacity 200ms; }
.spec-detail blockquote {
  font-size: 14px; line-height: 1.45; letter-spacing: -0.005em;
  margin: 0; font-style: italic;
}
.spec-detail .by { font-size: 11px; opacity: 0.7; }
.spec-detail .feats {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 6px;
  border-top: 1px solid rgba(255,255,255,0.15);
  padding-top: 14px;
}
.spec-detail .feats li {
  font-size: 12px; display: flex; gap: 8px; align-items: center;
}
.spec-detail .feats li .ph { color: #34c759; }

/* ─── FOOTER ──────────────────────────────────────────── */
.footer { background: var(--bg-dark); color: white; padding: 80px 0 40px; }
.footer-top {
  display: grid; gap: 48px;
  grid-template-columns: 1fr;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--line-dark);
}
@media (min-width: 800px) { .footer-top { grid-template-columns: 2fr 1fr 1fr 1fr; gap: 64px; } }
.footer-brand img { height: 22px; margin-bottom: 18px; }
.footer-brand p { font-size: 14px; color: rgba(255,255,255,0.55); max-width: 32ch; line-height: 1.5; margin: 0; }
.footer h5 { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; margin: 0 0 18px; color: rgba(255,255,255,0.45); font-weight: 600; }
.footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.footer ul a { font-size: 14px; color: rgba(255,255,255,0.7); transition: color 200ms; }
.footer ul a:hover { color: white; }
.footer-bottom {
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
  padding-top: 24px; font-size: 12px; color: rgba(255,255,255,0.4);
}

/* ─── Split list (A IA cuida / Você cuida) ───────────── */
.split-list {
  display: grid; gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 24px;
  overflow: hidden;
  margin-top: 64px;
}
@media (min-width: 800px) { .split-list { grid-template-columns: 1fr 1fr; } }
.split-col {
  background: white;
  padding: 48px;
  display: flex; flex-direction: column;
}
.split-col.ai {
  background: var(--ink);
  color: white;
}
.split-col h4 {
  font-family: var(--font-display);
  font-size: 32px; font-weight: 400;
  letter-spacing: -0.025em; line-height: 1;
  margin: 0 0 8px;
}
.split-col.ai h4 { color: white; }
.split-col .sub {
  font-size: 14px; color: var(--ink-2);
  margin: 0 0 32px;
  letter-spacing: -0.005em;
}
.split-col.ai .sub { color: rgba(255,255,255,0.6); }
.split-col ul {
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 16px;
}
.split-col li {
  display: flex; gap: 14px; align-items: flex-start;
  font-size: 15px; line-height: 1.4;
  letter-spacing: -0.005em;
  color: var(--ink-2);
}
.split-col.ai li { color: rgba(255,255,255,0.85); }
.split-col li i {
  font-size: 18px; flex-shrink: 0;
  margin-top: 1px;
  color: var(--green);
}
.split-col.ai li i { color: #6ee7b7; }

/* ─── Migrou mini testimonials row ───────────────────── */
.migrou-mini-row {
  display: grid; gap: 16px;
  grid-template-columns: 1fr;
  margin: 64px 0 32px;
}
@media (min-width: 700px) { .migrou-mini-row { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px) { .migrou-mini-row { grid-template-columns: repeat(4, 1fr); } }
.migrou-mini {
  background: white;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 24px;
  display: flex; flex-direction: column; gap: 14px;
}
.migrou-mini .stars {
  display: flex; gap: 2px;
  color: #f59e0b;
  font-size: 14px;
}
.migrou-mini p {
  font-size: 15px; line-height: 1.4;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin: 0;
  flex: 1;
}
.migrou-mini .who {
  display: flex; align-items: center; gap: 10px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.migrou-mini .who img {
  width: 36px; height: 36px; border-radius: 999px;
  object-fit: cover;
}
.migrou-mini .who strong { display: block; font-size: 13px; letter-spacing: -0.01em; }
.migrou-mini .who span { font-size: 11px; color: var(--ink-3); }

/* ─── Stars (★★★★★ inline) ──────────────────────────── */
.stars5 {
  color: #f59e0b;
  font-size: 13px;
  letter-spacing: 0.05em;
  margin-bottom: 6px;
}

/* ─── Handoff timeline (Step 3 follow-up) ──────────── */
.handoff {
  margin-top: clamp(64px, 8vw, 104px);
  padding: clamp(40px, 5vw, 64px) clamp(28px, 4vw, 56px);
  background: white;
  border: 1px solid var(--line);
  border-radius: 28px;
  box-shadow: var(--sh-sm);
}
.handoff-head {
  margin-bottom: clamp(48px, 6vw, 64px);
  max-width: 560px;
}
.handoff-eyebrow {
  display: inline-block;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.handoff-track { position: relative; padding: 0 0 8px; }
.handoff-rail {
  position: absolute;
  top: 22px;
  left: 8%; right: 8%;
  height: 6px;
  background: linear-gradient(90deg, #1c1c20 0%, #1c1c20 50%, #e6f0ea 50%, #e6f0ea 100%);
  border-radius: 999px;
  overflow: hidden;
}
.handoff-fill {
  position: absolute; inset: 0;
  background: linear-gradient(90deg,
    #1c1c20 0%,
    #4a4a52 30%,
    #7c9c84 60%,
    #2f8a4a 100%);
  border-radius: 999px;
  opacity: 0;
  animation: handoff-fill 2.4s var(--ease-spring, cubic-bezier(.2,.8,.2,1)) forwards;
  animation-delay: 0.2s;
  transform-origin: left;
}
@keyframes handoff-fill {
  0%   { opacity: 1; clip-path: inset(0 100% 0 0); }
  100% { opacity: 1; clip-path: inset(0 0 0 0); }
}
.handoff-stops {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  position: relative;
}
.hstop {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  position: relative;
}
.hstop::before {
  content: attr(data-week);
  position: absolute;
  top: -28px;
  left: 0;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
}
.hstop-dot {
  width: 50px; height: 50px;
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
  background: white;
  border: 6px solid #1c1c20;
  box-shadow: 0 0 0 3px white, 0 4px 14px rgba(0,0,0,0.08);
}
.hstop-dot.you     { border-color: #1c1c20; }
.hstop-dot.mix-low { border-color: #4a4a52; background: linear-gradient(135deg, #1c1c20 50%, #d9eedb 50%); }
.hstop-dot.mix-mid { border-color: #7c9c84; background: linear-gradient(135deg, #1c1c20 30%, #d9eedb 30%); }
.hstop-dot.ai      { border-color: #2f8a4a; background: #2f8a4a; }
.hstop-dot.ai::after {
  content: '';
  position: absolute; inset: 30%;
  background: white;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M9 16.2l-3.5-3.5 1.4-1.4L9 13.4 16.6 5.8 18 7.2z'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='black'><path d='M9 16.2l-3.5-3.5 1.4-1.4L9 13.4 16.6 5.8 18 7.2z'/></svg>") center/contain no-repeat;
}
.hstop-label strong {
  display: block;
  font-size: 16px;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 4px;
}
.hstop-label span {
  display: block;
  font-size: 13px;
  line-height: 1.45;
  color: var(--ink-2);
  text-wrap: pretty;
  max-width: 220px;
}
.handoff-foot {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px dashed var(--line);
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 14px;
  color: var(--ink-2);
}
.handoff-foot i { font-size: 22px; color: #2f8a4a; }
@media (max-width: 760px) {
  .handoff-stops { grid-template-columns: 1fr; gap: 28px; }
  .handoff-rail { display: none; }
  .hstop { flex-direction: row; align-items: center; gap: 16px; padding-top: 20px; }
  .hstop::before { position: static; }
  .hstop > .hstop-dot { width: 36px; height: 36px; border-width: 4px; }
}

/* ─── Meta Partner section ─────────────────────────── */
.meta-partner {
  padding: clamp(80px, 10vw, 140px) 0;
  background: linear-gradient(180deg, #0a0d12 0%, #0e1420 100%);
  color: white;
  position: relative;
  overflow: hidden;
}
.meta-partner::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 800px 400px at 20% 0%, rgba(0,129,251,0.18), transparent 60%),
    radial-gradient(ellipse 600px 400px at 80% 100%, rgba(0,100,224,0.12), transparent 60%);
  pointer-events: none;
}
.meta-partner .container { position: relative; z-index: 1; }
.mp-grid {
  display: grid;
  gap: clamp(48px, 6vw, 88px);
  align-items: center;
}
@media (min-width: 920px) {
  .mp-grid { grid-template-columns: 1.05fr 1fr; }
}
.mp-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(0,129,251,0.12);
  border: 1px solid rgba(0,129,251,0.35);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #5fb0ff;
  font-weight: 500;
  margin-bottom: 24px;
}
.mp-eyebrow svg { width: 16px; height: 16px; }
.mp-grid h2 {
  font-size: clamp(36px, 5vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.025em;
  margin: 0 0 24px;
  color: white;
  text-wrap: balance;
}
.mp-grid h2 em {
  font-style: normal;
  background: linear-gradient(90deg, #0081FB, #5fb0ff);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.mp-lead {
  font-size: 18px;
  line-height: 1.55;
  color: rgba(255,255,255,0.7);
  max-width: 520px;
  margin-bottom: 32px;
  text-wrap: pretty;
}
.mp-perks {
  display: grid;
  gap: 14px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.mp-perks li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 15px;
  color: rgba(255,255,255,0.85);
  line-height: 1.5;
}
.mp-perks li i {
  color: #0081FB;
  font-size: 20px;
  margin-top: 1px;
}

/* Visual side: comparison */
.mp-compare {
  display: grid;
  gap: 16px;
}
.mp-card {
  border-radius: 18px;
  padding: 22px 24px;
  position: relative;
  border: 1px solid rgba(255,255,255,0.08);
}
.mp-card.bad {
  background: rgba(220,38,38,0.06);
  border-color: rgba(220,38,38,0.25);
}
.mp-card.bad::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(45deg,
      transparent 0,
      transparent 12px,
      rgba(220,38,38,0.04) 12px,
      rgba(220,38,38,0.04) 13px);
  pointer-events: none;
  border-radius: inherit;
}
.mp-card.good {
  background: linear-gradient(135deg, rgba(0,129,251,0.12), rgba(0,100,224,0.08));
  border-color: rgba(0,129,251,0.4);
  box-shadow: 0 0 0 1px rgba(0,129,251,0.15), 0 12px 40px -12px rgba(0,129,251,0.4);
}
.mp-card-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 500;
}
.mp-card.bad .mp-card-head { color: #f87171; }
.mp-card.good .mp-card-head { color: #5fb0ff; }
.mp-card-head i { font-size: 16px; }
.mp-card h4 {
  margin: 0 0 8px;
  font-size: 18px;
  letter-spacing: -0.01em;
  color: white;
  font-weight: 600;
}
.mp-card p {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: rgba(255,255,255,0.65);
}
.mp-card .ban-tag {
  display: inline-block;
  margin-top: 10px;
  padding: 3px 8px;
  border-radius: 6px;
  background: rgba(220,38,38,0.18);
  border: 1px solid rgba(220,38,38,0.35);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #fca5a5;
  font-weight: 500;
}
.mp-card .seal {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0,129,251,0.18);
  border: 1px solid rgba(0,129,251,0.35);
  font-size: 11px;
  letter-spacing: 0.04em;
  color: #93c5fd;
  font-weight: 500;
}
.mp-card .seal svg { width: 12px; height: 12px; }

/* ─── Pricing BOLD (v2-style: big number, no feature list) ── */
.pricing-bold {
  padding: clamp(120px, 16vw, 200px) 0;
  background: var(--bg-warm);
  text-align: center;
}
.pricing-bold-inner {
  max-width: 880px;
  margin: 0 auto;
}
.pricing-bold-h {
  font-size: clamp(48px, 7vw, 88px);
  line-height: 0.98;
  letter-spacing: -0.035em;
  margin: 0 0 48px;
  text-wrap: balance;
}
.pricing-amt {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 28px;
}
.pricing-amt .cur {
  font-size: clamp(28px, 3vw, 40px);
  color: var(--ink-2);
  font-weight: 500;
  letter-spacing: -0.02em;
}
.pricing-amt .num {
  font-family: var(--ff-display, var(--ff-sans));
  font-size: clamp(120px, 18vw, 220px);
  line-height: 0.85;
  letter-spacing: -0.06em;
  font-weight: 600;
  color: var(--ink);
  font-feature-settings: 'tnum';
}
.pricing-amt .per {
  font-size: clamp(20px, 2vw, 28px);
  color: var(--ink-3);
  font-weight: 400;
  letter-spacing: -0.01em;
}
.pricing-fine {
  font-size: 15px;
  color: var(--ink-2);
  max-width: 460px;
  margin: 0 auto 40px;
  line-height: 1.5;
  text-wrap: pretty;
}
.pricing-cta {
  display: inline-flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  justify-content: center;
}
