/* =====================================================================
   MATEO BEVACQUA — Sistema de diseño
   Dirección: Aurora oscuro + estructura/forma/animaciones tipo SaaS
   (referencia: tradesyncer.com). Vibrante, glassmorphism, vivo.
   ===================================================================== */

:root {
  /* Base oscura */
  --bg:        #05070f;
  --bg-2:      #080c18;
  --panel:     #0b1120;

  /* Aurora / acentos vivos */
  --accent:    #5b8dff;   /* azul eléctrico */
  --accent-2:  #38bdf8;   /* cian */
  --accent-3:  #7c5cff;   /* violeta (solo aurora) */
  --grad:      linear-gradient(135deg, #5b8dff 0%, #38bdf8 100%);
  --grad-vivid:linear-gradient(120deg, #7c5cff 0%, #5b8dff 45%, #38bdf8 100%);
  --grad-text: linear-gradient(180deg, #ffffff 0%, #c3d0ee 70%, #8aa0d4 100%);

  /* Texto */
  --text:      #f2f5fc;
  --dim:       #c6cfe2;
  --mute:      #8a96b0;

  /* Cristal / líneas */
  --glass:     rgba(255, 255, 255, 0.045);
  --glass-2:   rgba(255, 255, 255, 0.07);
  --line:      rgba(255, 255, 255, 0.08);
  --line-2:    rgba(255, 255, 255, 0.15);
  --glow:      rgba(77, 124, 255, 0.35);

  --font-sans: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-mono: "JetBrains Mono", "SFMono-Regular", Consolas, monospace;

  --maxw: 1180px;
  --r:    16px;
  --r-sm: 12px;
  --r-lg: 28px;

  --shadow:    0 24px 70px -28px rgba(0, 0, 0, 0.75);
  --shadow-lg: 0 50px 130px -34px rgba(0, 0, 0, 0.9);
  --shadow-glow: 0 20px 60px -20px var(--glow);

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --t-fast: 0.2s;
  --t: 0.45s;
  --t-slow: 0.9s;
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; }

body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  font-size: 16px;
  letter-spacing: -0.011em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  max-width: 100%;
  overscroll-behavior-x: none;
}
img, svg, canvas { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; color: inherit; }
ul { list-style: none; }
::selection { background: rgba(91, 141, 255, 0.35); color: #fff; }

/* ---------- Fondo Aurora animado ---------- */
.aurora { position: fixed; inset: 0; z-index: -3; overflow: hidden; pointer-events: none; }
.aurora .blob { position: absolute; border-radius: 50%; filter: blur(90px); opacity: 0.55; mix-blend-mode: screen; }
.blob.b1 { width: 56vw; height: 56vw; top: -16vw; left: 46vw;
  background: radial-gradient(circle, #4d7cff, transparent 68%); animation: float1 24s var(--ease) infinite alternate; }
.blob.b2 { width: 50vw; height: 50vw; top: 24vh; left: -14vw;
  background: radial-gradient(circle, #7c5cff, transparent 68%); animation: float2 30s var(--ease) infinite alternate; }
.blob.b3 { width: 44vw; height: 44vw; bottom: -16vw; right: -8vw;
  background: radial-gradient(circle, #38bdf8, transparent 68%); animation: float3 27s var(--ease) infinite alternate; }
.blob.b4 { width: 36vw; height: 36vw; top: 44vh; left: 40vw;
  background: radial-gradient(circle, #2f56c9, transparent 70%); animation: float1 33s var(--ease) infinite alternate; }
@keyframes float1 { to { transform: translate(-12vw, 12vh) scale(1.18); } }
@keyframes float2 { to { transform: translate(12vw, -10vh) scale(1.12); } }
@keyframes float3 { to { transform: translate(-10vw, -10vh) scale(1.22); } }

body::before { content: ""; position: fixed; inset: 0; z-index: -2;
  background: radial-gradient(120% 70% at 50% -10%, rgba(91,141,255,0.18), transparent 55%); }
body::after { content: ""; position: fixed; inset: 0; z-index: -1; opacity: 0.4;
  background-image: linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 80px 80px;
  -webkit-mask-image: radial-gradient(circle at 50% 18%, #000, transparent 70%);
          mask-image: radial-gradient(circle at 50% 18%, #000, transparent 70%); }

/* grano sutil para dar textura (vida) */
.grain { position: fixed; inset: 0; z-index: -1; pointer-events: none; opacity: 0.035;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

.scroll-bar { position: fixed; top: 0; left: 0; height: 2px; width: 0; z-index: 200;
  background: var(--grad-vivid); box-shadow: 0 0 14px var(--glow); }

/* ---------- Layout ---------- */
.container { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: 26px; }
section { position: relative; padding-block: clamp(38px, 4.4vw, 68px); }
.center { text-align: center; margin-inline: auto; }

.pill { display: inline-flex; align-items: center; gap: 9px; padding: 7px 15px 7px 11px;
  border: 1px solid var(--line-2); border-radius: 100px; background: var(--glass);
  font-size: 0.78rem; color: var(--dim); backdrop-filter: blur(8px); }
.pill .dot { display: none; }
@keyframes pulse { 50% { opacity: 0.4; transform: scale(0.8); } }

.eyebrow { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-sans); font-weight: 600;
  font-size: 0.78rem; letter-spacing: 0.04em; text-transform: none; color: var(--accent-2); margin-bottom: 20px; }
.eyebrow::before { content: ""; width: 24px; height: 1px; background: linear-gradient(90deg, var(--accent-2), transparent); }

h1, h2, h3 { line-height: 1.07; font-weight: 600; letter-spacing: -0.035em; }
h1 { font-size: clamp(2.7rem, 6.6vw, 5.2rem); }
h2 { font-size: clamp(2rem, 4.3vw, 3.3rem); }
h3 { font-size: clamp(1.15rem, 2vw, 1.4rem); letter-spacing: -0.02em; }

.grad-text { background: var(--grad-text); background-size: 200% 200%;
  -webkit-background-clip: text; background-clip: text; color: transparent; animation: shimmer 9s var(--ease) infinite; }
.accent-text { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
@keyframes shimmer { 0%,100% { background-position: 0 50%; } 50% { background-position: 100% 50%; } }

.section-head { max-width: 680px; margin-bottom: 30px; }
.section-head.center { margin-inline: auto; }
.section-head p { color: var(--dim); margin-top: 18px; font-size: 1.06rem; }
.lead { color: var(--dim); font-size: 1.16rem; }

/* ---------- Botones ---------- */
.btn { position: relative; display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  padding: 13px 24px; border-radius: var(--r-sm); border: 1px solid transparent; font-weight: 500;
  font-size: 0.95rem; cursor: pointer; overflow: hidden; white-space: nowrap;
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t), background var(--t-fast), border-color var(--t-fast); }
.btn:active { transform: translateY(1px) scale(0.99); }
.btn::after { content: ""; position: absolute; top: 0; left: -130%; width: 70%; height: 100%;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,0.35), transparent); transform: skewX(-18deg); transition: left 0.75s var(--ease); }
.btn:hover::after { left: 140%; }
.btn-primary { background: var(--grad); color: #04122e; font-weight: 600;
  box-shadow: 0 10px 32px -10px var(--glow), inset 0 1px 0 rgba(255,255,255,0.45); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 18px 46px -12px var(--glow), inset 0 1px 0 rgba(255,255,255,0.55); }
.btn-ghost { background: var(--glass); border-color: var(--line-2); color: var(--text); backdrop-filter: blur(8px); }
.btn-ghost:hover { background: var(--glass-2); border-color: var(--accent); transform: translateY(-2px); }
.btn-lg { padding: 16px 32px; font-size: 1rem; }

/* ---------- Navbar ---------- */
.nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; transition: all var(--t) var(--ease);
  border-bottom: 1px solid transparent; }
.nav.scrolled { background: rgba(5, 7, 15, 0.72); backdrop-filter: blur(18px) saturate(150%); border-bottom-color: var(--line); }
.nav-inner { max-width: var(--maxw); margin-inline: auto; padding: 16px 26px; display: flex; align-items: center; justify-content: space-between; }
.brand { display: flex; align-items: center; gap: 12px; font-weight: 600; font-size: 1rem; letter-spacing: -0.02em; }
.brand .mark { width: 36px; height: 36px; display: grid; place-items: center; border-radius: 10px;
  overflow: hidden; box-shadow: 0 6px 20px -8px var(--glow); }
.brand .mark img { width: 100%; height: 100%; }
.brand small { display: block; font-size: 0.62rem; color: var(--mute); font-family: var(--font-mono);
  letter-spacing: 0.16em; text-transform: uppercase; font-weight: 400; }
.nav-links { display: flex; align-items: center; gap: 30px; }
.nav-links a { color: var(--dim); font-size: 0.9rem; transition: color var(--t-fast); position: relative; }
.nav-links a:not(.btn):hover { color: var(--text); }
.nav-links a:not(.btn)::after { content: ""; position: absolute; left: 0; bottom: -6px; height: 1px; width: 0; background: var(--grad); transition: width var(--t) var(--ease); }
.nav-links a:not(.btn):hover::after { width: 100%; }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav-toggle span { display: block; width: 22px; height: 2px; background: var(--text); margin: 4px 0; transition: var(--t-fast); }

/* ---------- Hero (centrado, tipo SaaS) ---------- */
.hero { padding-top: 150px; padding-bottom: 70px; text-align: center; }
.hero .pill { margin-bottom: 28px; }
.hero h1 { margin: 0 auto 26px; max-width: 16ch; }
.hero .lead { max-width: 620px; margin: 0 auto 36px; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.hero-note { margin-top: 22px; font-size: 0.84rem; color: var(--mute); display: flex; gap: 8px; justify-content: center; align-items: center; }
.hero-note svg { color: var(--accent-2); }

/* Preview grande (mock del producto) */
.hero-preview { margin-top: 64px; perspective: 1600px; }
.preview { position: relative; border: 1px solid var(--line-2); border-radius: var(--r-lg);
  background: linear-gradient(180deg, rgba(13,19,36,0.85), rgba(5,7,15,0.85)); box-shadow: var(--shadow-lg);
  overflow: hidden; backdrop-filter: blur(8px); transform: rotateX(7deg); transform-origin: center top;
  transition: transform var(--t-slow) var(--ease); }
.hero-preview.in .preview { transform: rotateX(0deg); }
.preview::before { content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1px;
  background: linear-gradient(180deg, rgba(91,141,255,0.5), transparent 40%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
.preview .glow { position: absolute; top: -40%; left: 50%; width: 70%; height: 80%; transform: translateX(-50%);
  background: radial-gradient(circle, var(--glow), transparent 65%); filter: blur(30px); pointer-events: none; }

/* ---------- Mock UI (panel del generador / dashboard) ---------- */
.mock { display: grid; grid-template-columns: 1fr 1.1fr; gap: 0; min-height: 360px; position: relative; z-index: 1; }
.mock-bar { grid-column: 1 / -1; display: flex; align-items: center; gap: 8px; padding: 13px 18px; border-bottom: 1px solid var(--line); font-family: var(--font-mono); font-size: 0.72rem; color: var(--mute); }
.mock-bar i { width: 9px; height: 9px; border-radius: 50%; background: #2a3a5e; }
.mock-bar i:nth-child(1){ background:#ff5f57;} .mock-bar i:nth-child(2){ background:#febc2e;} .mock-bar i:nth-child(3){ background:#28c840;}
.mock-bar span { margin-left: auto; }
.mock-left { padding: 22px; border-right: 1px solid var(--line); display: grid; gap: 12px; align-content: start; }
.mock-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 14px;
  border: 1px solid var(--line); border-radius: 10px; background: var(--glass); font-size: 0.84rem; }
.mock-row .lbl { color: var(--dim); display: flex; align-items: center; gap: 9px; }
.mock-row .lbl b { color: var(--text); font-weight: 500; }
.toggle { width: 38px; height: 22px; border-radius: 100px; background: rgba(255,255,255,0.1); position: relative; flex: none; }
.toggle.on { background: var(--grad); }
.toggle::after { content: ""; position: absolute; top: 3px; left: 3px; width: 16px; height: 16px; border-radius: 50%; background: #fff; transition: var(--t); }
.toggle.on::after { left: 19px; }
.chip { font-family: var(--font-mono); font-size: 0.74rem; color: var(--accent-2); border: 1px solid var(--line-2); border-radius: 7px; padding: 3px 9px; }
.mock-right { padding: 22px; position: relative; }
.mock-chart { height: 100%; min-height: 260px; display: flex; align-items: flex-end; gap: 6px; padding-bottom: 26px; position: relative; }
.candle { width: 9px; border-radius: 2px; position: relative; opacity: 0; transform: translateY(14px);
  animation: candleIn 0.5s var(--ease) forwards; }
.candle.up { background: linear-gradient(180deg, #3ddc97, #1f9e6b); }
.candle.down { background: linear-gradient(180deg, #ff6b6b, #c93f3f); }
.candle::before { content: ""; position: absolute; left: 50%; top: -8px; bottom: -8px; width: 1px; transform: translateX(-50%); background: inherit; opacity: 0.5; }
@keyframes candleIn { to { opacity: 0.95; transform: none; } }
.mock-marker { position: absolute; font-size: 0.7rem; font-family: var(--font-mono); padding: 2px 7px; border-radius: 6px; }
.mock-marker.buy { background: rgba(61,220,151,0.16); color: #6ff0b6; border: 1px solid rgba(61,220,151,0.4); }
.mock-comment { position: absolute; top: 16px; left: 16px; font-family: var(--font-mono); font-size: 0.72rem; color: var(--dim); line-height: 1.7; }
.mock-comment b { color: var(--accent-2); }

/* ---------- Marquee de tecnologías (en movimiento) ---------- */
.marquee { overflow: hidden; padding-block: 34px; position: relative;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent);
          mask-image: linear-gradient(90deg, transparent, #000 10%, #000 90%, transparent); }
.marquee-track { display: flex; align-items: center; gap: 56px; width: max-content; animation: marquee 32s linear infinite; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.marquee-item { display: flex; align-items: center; gap: 56px; font-family: var(--font-mono); font-size: 0.95rem;
  color: var(--mute); letter-spacing: 0.04em; white-space: nowrap; }
.marquee-item b { color: var(--dim); font-weight: 500; transition: color var(--t); }
.marquee-item b:hover { color: var(--accent-2); }
.marquee-item .sep { color: var(--accent); opacity: 0.5; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---------- Features ---------- */
.grid { display: grid; gap: 22px; }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }

.feature-card { position: relative; border: 1px solid var(--line); border-radius: var(--r); background: var(--glass);
  padding: 32px; backdrop-filter: blur(8px); overflow: hidden;
  transition: transform var(--t) var(--ease), border-color var(--t), box-shadow var(--t); }
.feature-card:hover { border-color: var(--line-2); box-shadow: var(--shadow); }
.feature-card .icon { width: 50px; height: 50px; border-radius: 13px; display: grid; place-items: center; margin-bottom: 22px;
  color: #04122e; background: var(--grad); box-shadow: 0 10px 26px -10px var(--glow); }
.feature-card h3 { margin-bottom: 10px; }
.feature-card p { color: var(--dim); font-size: 0.95rem; }

/* ---------- Showcase (secciones alternadas) ---------- */
.showcase-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.showcase-grid.reverse .showcase-text { order: 2; }
.showcase-text .eyebrow { margin-bottom: 16px; }
.showcase-text h2 { margin-bottom: 18px; }
.showcase-text p { color: var(--dim); font-size: 1.04rem; }
.showcase-list { display: grid; gap: 14px; margin-top: 26px; }
.showcase-list li { display: flex; gap: 12px; align-items: flex-start; color: var(--dim); font-size: 0.96rem; }
.showcase-list svg { flex: none; width: 24px; height: 24px; padding: 4px; border-radius: 8px; background: var(--grad); color: #04122e; box-shadow: 0 6px 14px -6px var(--glow); }
.showcase-visual { border: 1px solid var(--line-2); border-radius: var(--r); overflow: hidden;
  background: linear-gradient(180deg, rgba(13,19,36,0.8), rgba(5,7,15,0.8)); box-shadow: var(--shadow); }
.next-step { display: flex; gap: 14px; align-items: center; margin-top: 24px; padding: 16px 18px; border: 1px solid var(--line-2);
  border-radius: 14px; background: linear-gradient(160deg, rgba(56,189,248,0.09), rgba(91,141,255,0.04)); }
.next-step .ns-ico { flex: none; width: 42px; height: 42px; border-radius: 12px; display: grid; place-items: center; color: #04122e; background: var(--grad); box-shadow: 0 8px 20px -8px var(--glow); }
.next-step p { color: var(--dim); font-size: 0.95rem; line-height: 1.55; }

/* ---------- Planes ---------- */
.plans { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; align-items: stretch; }
.plan { display: flex; flex-direction: column; border: 1px solid var(--line); border-radius: var(--r);
  background: var(--glass); padding: 34px 30px; backdrop-filter: blur(8px);
  transition: transform var(--t) var(--ease), border-color var(--t), box-shadow var(--t); }
.plan:hover { box-shadow: var(--shadow); border-color: var(--line-2); }
.plan.featured { background: linear-gradient(180deg, rgba(91,141,255,0.1), var(--glass)); border-color: transparent;
  box-shadow: 0 0 0 1.5px var(--accent), var(--shadow-glow); position: relative; }
.plan .tag { align-self: flex-start; font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--accent-2); border: 1px solid var(--line-2); border-radius: 100px; padding: 5px 13px; margin-bottom: 22px; }
.plan .featured-tag { background: var(--grad); color: #04122e; border-color: transparent; font-weight: 600; }
.plan .duration { font-size: 3rem; font-weight: 600; letter-spacing: -0.04em; line-height: 1; }
.plan .duration small { font-size: 1rem; color: var(--mute); font-weight: 400; }
.plan h3 { margin: 14px 0 6px; }
.plan .plan-desc { color: var(--dim); font-size: 0.93rem; margin-bottom: 22px; }
.plan ul { display: grid; gap: 12px; margin-bottom: 28px; }
.plan li { display: flex; gap: 11px; align-items: flex-start; font-size: 0.92rem; color: var(--dim); }
.plan li svg { flex: none; margin-top: 3px; color: var(--accent-2); }
.plan .btn { margin-top: auto; }

/* ---------- Filosofía ---------- */
.philosophy { position: relative; border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden;
  background: linear-gradient(160deg, rgba(91,141,255,0.12), rgba(124,92,255,0.06) 60%, rgba(5,7,15,0.3));
  padding: clamp(40px, 6vw, 78px); }
.philosophy h2 { max-width: 800px; }
.philosophy .promise { margin-top: 32px; display: grid; gap: 18px; max-width: 760px; }
.promise-item { display: flex; gap: 15px; align-items: flex-start; }
.promise-item .badge { flex: none; width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; font-weight: 700; font-size: 0.9rem; }
.promise-item.no .badge { background: rgba(255,107,107,0.14); color: #ff9a9a; border: 1px solid rgba(255,107,107,0.3); }
.promise-item.yes .badge { background: rgba(56,189,248,0.14); color: var(--accent-2); border: 1px solid rgba(56,189,248,0.3); }
.promise-item p { color: var(--text); font-size: 1.04rem; }

/* ---------- Tabla comparativa de niveles ---------- */
.ptable-wrap { overflow-x: auto; border-radius: var(--r-lg); }
.ptable { display: grid; grid-template-columns: 1.8fr 1fr 1fr 1fr; min-width: 760px;
  border: 1px solid var(--line-2); border-radius: var(--r-lg); overflow: hidden; background: var(--glass); backdrop-filter: blur(8px); box-shadow: var(--shadow); }
.ptable > div { padding: 15px 20px; display: flex; align-items: center; border-bottom: 1px solid var(--line); }
.ptable > div:nth-last-child(-n+4) { border-bottom: 0; }
.pt-feat { color: var(--dim); font-size: 0.96rem; }
.pt-cell { justify-content: center; }
.col1 { background: rgba(56,189,248,0.05); }
.col2 { background: rgba(124,92,255,0.06); }
.col3 { background: rgba(245,196,94,0.06); }
.pt-corner { font-weight: 700; font-size: 1.1rem; color: var(--text); }
.pt-head { flex-direction: column; align-items: flex-start; gap: 5px; padding: 24px 20px; }
.pt-head .ph-name { font-weight: 700; font-size: 1.25rem; letter-spacing: -0.02em; }
.pt-head .ph-sub { font-size: 0.78rem; color: var(--mute); font-family: var(--font-mono); }
.pt-h1 { border-top: 3px solid #38bdf8; } .pt-h1 .ph-name { color: #67e8f9; }
.pt-h2 { border-top: 3px solid #a78bfa; } .pt-h2 .ph-name { color: #a78bfa; }
.pt-h3 { border-top: 3px solid #f5c45e; } .pt-h3 .ph-name { color: #f5c45e; }
.pt-yes { width: 27px; height: 27px; border-radius: 8px; display: grid; place-items: center; }
.col1 .pt-yes { background: linear-gradient(135deg,#38bdf8,#67e8f9); color: #04222e; }
.col2 .pt-yes { background: linear-gradient(135deg,#5b8dff,#7c5cff); color: #fff; }
.col3 .pt-yes { background: linear-gradient(135deg,#f5c45e,#f59e0b); color: #3a2600; }
.pt-no { color: var(--mute); opacity: 0.45; font-size: 1.1rem; }
.pt-num { font-family: var(--font-mono); font-weight: 700; font-size: 1.05rem; }
.col1 .pt-num { color: #67e8f9; } .col2 .pt-num { color: #a78bfa; } .col3 .pt-num { color: #f5c45e; }
.pt-foot { padding: 22px 16px !important; justify-content: center; }
.pt-foot .btn { width: 100%; }
.col1.pt-foot .btn { background: linear-gradient(135deg,#38bdf8,#67e8f9); color: #04222e; }
.col2.pt-foot .btn { background: linear-gradient(135deg,#5b8dff,#7c5cff); color: #fff; }
.col3.pt-foot .btn { background: linear-gradient(135deg,#f5c45e,#f59e0b); color: #3a2600; }

/* Duración de la mentoría, resaltada (badge) */
.ph-dur, .pc-dur { display: inline-block; font-weight: 700; font-size: 0.74rem; color: #04231a;
  background: linear-gradient(135deg,#3ddc97,#22c55e); padding: 3px 11px; border-radius: 100px; margin-top: 3px; box-shadow: 0 4px 12px rgba(61,220,151,0.28); }

/* Tarjetas de planes (versión mobile, un solo scroll vertical) */
.plan-cards { display: none; }
.plan-card { border: 1px solid var(--line-2); border-radius: var(--r-lg); background: var(--glass); backdrop-filter: blur(8px); padding: 24px; }
.plan-card.l1 { border-top: 3px solid #38bdf8; }
.plan-card.l2 { border-top: 3px solid #a78bfa; }
.plan-card.l3 { border-top: 3px solid #f5c45e; }
.pc-head { display: flex; flex-direction: column; align-items: flex-start; gap: 6px; margin-bottom: 14px; }
.pc-name { font-weight: 700; font-size: 1.35rem; letter-spacing: -0.02em; }
.plan-card.l1 .pc-name { color: #67e8f9; }
.plan-card.l2 .pc-name { color: #a78bfa; }
.plan-card.l3 .pc-name { color: #f5c45e; }
.pc-sub { font-size: 0.86rem; color: var(--mute); }
.pc-incl { font-size: 0.84rem; color: var(--dim); font-weight: 600; margin-bottom: 10px; }
.plan-card .pc-list { list-style: none; display: grid; gap: 10px; margin-bottom: 18px; }
.plan-card .pc-list li { position: relative; padding-left: 28px; font-size: 0.93rem; color: var(--dim); line-height: 1.45; }
.plan-card .pc-list li::before { content: "✓"; position: absolute; left: 0; top: 1px; width: 19px; height: 19px; border-radius: 50%; display: grid; place-items: center; font-size: 0.68rem; font-weight: 700; background: rgba(61,220,151,0.16); color: #6ff0b6; }
.plan-card .pc-list li b { color: var(--text); }
.plan-card .btn { width: 100%; }
@media (max-width: 760px) {
  .ptable-wrap { display: none; }
  .plan-cards { display: grid; gap: 16px; }
}

/* ---------- Escalera de niveles (hero) ---------- */
.ladder-card { border: 1px solid var(--line-2); border-radius: var(--r-lg); background: var(--glass); backdrop-filter: blur(10px); padding: 30px; box-shadow: var(--shadow-lg); }
.ladder-title { font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mute); margin-bottom: 20px; text-align: center; }
.ladder { display: grid; gap: 16px; }
.lad { display: flex; align-items: center; gap: 16px; padding: 18px 20px; border-radius: var(--r); border: 1px solid var(--line); background: rgba(255,255,255,0.025); transition: transform var(--t) var(--ease); }
.lad:hover { border-color: var(--line-2); }
.lad .lad-num { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; font-weight: 700; font-size: 1.25rem; flex: none; }
.lad b { display: block; font-size: 1.05rem; margin-bottom: 3px; }
.lad span { color: var(--dim); font-size: 0.92rem; }
.lad.s1 { border-left: 3px solid #38bdf8; } .lad.s1 .lad-num { background: linear-gradient(135deg,#38bdf8,#67e8f9); color: #04222e; }
.lad.s2 { border-left: 3px solid #a78bfa; margin-left: 26px; } .lad.s2 .lad-num { background: linear-gradient(135deg,#5b8dff,#7c5cff); color: #fff; }
.lad.s3 { border-left: 3px solid #f5c45e; margin-left: 52px; } .lad.s3 .lad-num { background: linear-gradient(135deg,#f5c45e,#f59e0b); color: #3a2600; }
.lad.s3 b { color: #f5c45e; }
@media (max-width: 560px) { .lad.s2, .lad.s3 { margin-left: 0; } }
.road-svg { width: 100%; height: auto; display: block; overflow: visible; }

/* Tarjeta explicativa para principiantes (hero) */
/* Primer del hero: glosario término → definición (limpio, sin emojis) */
.primer { border: 1px solid var(--line-2); border-radius: var(--r-lg); background: linear-gradient(180deg, rgba(13,19,36,0.6), rgba(5,7,15,0.35)); backdrop-filter: blur(12px); padding: 26px 30px; box-shadow: var(--shadow-lg); position: relative; overflow: hidden; }
.primer::before { content: ""; position: absolute; top: 0; left: 0; width: 3px; height: 100%; background: var(--grad); opacity: 0.9; }
.primer-eyebrow { display: block; font-family: var(--font-sans); font-weight: 600; font-size: 0.8rem; letter-spacing: 0.02em; color: var(--accent-2); margin-bottom: 10px; }
.primer-row { display: block; padding: 15px 0; border-top: 1px solid var(--line); }
.primer-row:first-of-type { border-top: 0; padding-top: 4px; }
.primer-k { display: block; font-weight: 700; font-size: 1.05rem; letter-spacing: -0.01em; margin-bottom: 5px; }
.primer-row p { color: var(--dim); font-size: 0.95rem; line-height: 1.6; }
/* Progresión de color psicológica: confianza → claridad → valor → recompensa (compra) */
.primer-row:nth-of-type(1) .primer-k { color: #6ea2ff; }
.primer-row:nth-of-type(2) .primer-k { color: #38bdf8; }
.primer-row:nth-of-type(3) .primer-k { color: #f5c45e; }
.primer-row:nth-of-type(4) .primer-k { color: #3ddc97; }
.primer-row.hl p { color: var(--text); }
@media (max-width: 560px) { .primer { padding: 22px; } }

/* Diccionario: qué configura el robot, explicado */
.gloss { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 24px; }
.gloss-item { border: 1px solid var(--line); border-radius: var(--r); background: var(--glass); backdrop-filter: blur(6px); padding: 22px; transition: transform var(--t) var(--ease), border-color var(--t); }
.gloss-item:hover { border-color: var(--line-2); }
.gloss-item .gi-ico { width: 40px; height: 40px; border-radius: 11px; display: grid; place-items: center; color: #04122e; background: var(--grad); margin-bottom: 14px; }
.gloss-item b { display: block; font-size: 1.04rem; margin-bottom: 6px; color: var(--text); }
.gloss-item span { color: var(--dim); font-size: 0.93rem; line-height: 1.5; }
@media (max-width: 880px) { .gloss { grid-template-columns: 1fr; } }

/* Equipo de robots (visual, en vez de gráfico abstracto) */
.robots-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.robot-card { border: 1px solid var(--line); border-radius: 16px; background: rgba(255,255,255,0.025); padding: 24px 18px; text-align: center; transition: transform var(--t) var(--ease), border-color var(--t); }
.robot-card:hover { border-color: var(--line-2); }
.robot-card .rc-emoji { font-size: 2.4rem; line-height: 1; display: inline-block; animation: floaty 4s var(--ease) infinite; }
.robot-card:nth-child(2) .rc-emoji { animation-delay: 0.5s; } .robot-card:nth-child(3) .rc-emoji { animation-delay: 1s; } .robot-card:nth-child(4) .rc-emoji { animation-delay: 1.5s; }
.robot-card b { display: block; margin-top: 12px; font-size: 1.02rem; }
.robot-card .rc-task { color: var(--dim); font-size: 0.88rem; margin-top: 2px; }
.robot-card .rc-status { margin-top: 12px; font-size: 0.74rem; font-family: var(--font-mono); color: var(--accent-2); border: 1px solid var(--line-2); border-radius: 100px; padding: 4px 11px; display: inline-block; }
@media (max-width: 760px) { .robots-grid { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Roadmap animado 0% → 100% ---------- */
.rmh { position: relative; margin-top: 46px; }
.rmh-track { position: absolute; top: 27px; left: 10%; right: 10%; height: 4px; background: rgba(255,255,255,0.08); border-radius: 4px; overflow: hidden; }
.rmh-fill { position: absolute; inset: 0; width: 0; border-radius: 4px; background: linear-gradient(90deg,#38bdf8,#a78bfa,#f5c45e,#3ddc97); box-shadow: 0 0 14px var(--glow); animation: rmhfill 3.4s var(--ease) forwards; }
@keyframes rmhfill { to { width: 100%; } }
.rmh-steps { position: relative; display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
.rmh-step { text-align: center; }
.rmh-dot { width: 56px; height: 56px; border-radius: 50%; margin: 0 auto 16px; display: grid; place-items: center;
  font-family: var(--font-sans); font-weight: 700; font-size: 0.95rem; background: var(--panel); border: 2px solid var(--line-2); color: var(--dim); position: relative; z-index: 1; overflow: hidden; animation: rmhpulse 2.8s ease-out infinite; }
/* relleno "líquido" que sube por dentro hasta el % del círculo */
.rmh-dot::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 0; background: var(--c, var(--accent-2)); opacity: 0.42; }
@keyframes rmpulse { 0% { transform: scale(0.85); opacity: 0.6; } 100% { transform: scale(1.5); opacity: 0; } }
@keyframes rmhpulse { 0% { box-shadow: 0 0 0 0 var(--c, var(--accent-2)); } 70% { box-shadow: 0 0 0 9px transparent; } 100% { box-shadow: 0 0 0 0 transparent; } }
@keyframes rmhfill25 { 0%, 100% { height: 0; } 28%, 82% { height: 25%; } }
@keyframes rmhfill50 { 0%, 100% { height: 0; } 28%, 82% { height: 50%; } }
@keyframes rmhfill75 { 0%, 100% { height: 0; } 28%, 82% { height: 75%; } }
@keyframes rmhfill100 { 0%, 100% { height: 0; } 28%, 82% { height: 100%; } }
.rmh-label b { display: block; font-size: 1rem; margin-bottom: 4px; }
.rmh-label span { color: var(--dim); font-size: 0.86rem; }
.rmh-step.c1 .rmh-dot { --c: #38bdf8; border-color: #38bdf8; color: #67e8f9; }
.rmh-step.c2 .rmh-dot { --c: #a78bfa; border-color: #7c8dff; color: #a78bfa; }
.rmh-step.c3 .rmh-dot { --c: #b9a6fc; border-color: #a78bfa; color: #c4b5fd; }
.rmh-step.c4 .rmh-dot { --c: #f5c45e; border-color: #f5c45e; color: #f5c45e; }
.rmh-step.c5 .rmh-dot { --c: #3ddc97; border-color: #3ddc97; color: #6ff0b6; }
/* El relleno arranca SOLO cuando la sección entra en pantalla (.rmh.in),
   así se ve cómo se van llenando uno tras otro. */
.rmh.in .rmh-step.c2 .rmh-dot::after { animation: rmhfill25 4.5s var(--ease) infinite 0.3s; }
.rmh.in .rmh-step.c3 .rmh-dot::after { animation: rmhfill50 4.5s var(--ease) infinite 0.6s; }
.rmh.in .rmh-step.c4 .rmh-dot::after { animation: rmhfill75 4.5s var(--ease) infinite 0.9s; }
.rmh.in .rmh-step.c5 .rmh-dot::after { animation: rmhfill100 4.5s var(--ease) infinite 1.2s; }
.rmh-step.c2 .rmh-dot { animation-delay: .4s; }
.rmh-step.c3 .rmh-dot { animation-delay: .8s; }
.rmh-step.c4 .rmh-dot { animation-delay: 1.2s; }
.rmh-step.c5 .rmh-dot { animation-delay: 1.6s; }
.rmh-step.c5 .rmh-label b { color: #6ff0b6; }
@media (max-width: 820px) { .rmh-steps { grid-template-columns: repeat(1, 1fr); gap: 22px; text-align: left; } .rmh-track { display: none; }
  .rmh-step { display: grid; grid-template-columns: 56px 1fr; align-items: center; gap: 16px; } .rmh-dot { margin: 0; } }

/* ===== Mapa conceptual (línea de tiempo vertical animada) ===== */
.roadmap { position: relative; max-width: 860px; margin: 64px auto 0; }
.rm-line { position: absolute; left: 28px; top: 20px; bottom: 44px; width: 3px; border-radius: 4px; overflow: hidden; background: rgba(255,255,255,0.08); }
.rm-line i { position: absolute; left: 0; right: 0; top: 0; height: 200%; background: linear-gradient(180deg, #38bdf8, #7c5cff, #f5c45e, #3ddc97, #38bdf8); animation: rmflow 5s linear infinite; }
@keyframes rmflow { from { transform: translateY(-50%); } to { transform: translateY(0); } }
.rm-stage { position: relative; display: grid; grid-template-columns: 58px 1fr; gap: 20px; padding-bottom: 30px; }
.rm-stage:last-child { padding-bottom: 0; }
.rm-node { width: 58px; height: 58px; border-radius: 50%; display: grid; place-items: center; font-family: var(--font-mono); font-weight: 700; font-size: 0.9rem; color: #04122e; background: var(--grad); position: relative; z-index: 1; box-shadow: 0 0 0 6px var(--bg), 0 8px 22px rgba(56,189,248,0.32); }
.rm-node::after { content: ""; position: absolute; inset: -6px; border-radius: 50%; border: 2px solid rgba(56,189,248,0.45); animation: rmpulse 2.8s ease-out infinite; }
.rm-card { border: 1px solid var(--line); border-radius: 18px; background: var(--glass); backdrop-filter: blur(10px); padding: 22px 24px; transition: transform var(--t) var(--ease), border-color var(--t); }
.rm-card:hover { border-color: var(--line-2); }
.rm-phase { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent-2); }
.rm-card h3 { font-size: 1.22rem; margin: 8px 0 8px; letter-spacing: -0.01em; }
.rm-card > p { color: var(--dim); font-size: 0.94rem; line-height: 1.6; }
.rm-list { list-style: none; margin: 16px 0 0; padding: 0; display: grid; gap: 9px; }
.rm-list li { position: relative; padding-left: 24px; font-size: 0.92rem; color: var(--dim); line-height: 1.5; }
.rm-list li::before { content: ""; position: absolute; left: 3px; top: 7px; width: 9px; height: 9px; border-radius: 3px; background: var(--grad); }
.rm-mateo { display: flex; gap: 12px; align-items: center; margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--line); }
.rm-mateo .rm-av { width: 32px; height: 32px; border-radius: 50%; background: var(--grad-vivid); color: #fff; font-weight: 700; display: grid; place-items: center; flex: none; font-size: 0.88rem; box-shadow: 0 0 16px rgba(124,92,255,0.4); }
.rm-mateo p { font-size: 0.88rem; color: var(--mute); margin: 0; }
.rm-mateo b { color: var(--accent-2); }
.rm-stage.final .rm-node { background: linear-gradient(135deg,#3ddc97,#22c55e); color: #04231a; box-shadow: 0 0 0 6px var(--bg), 0 0 28px rgba(61,220,151,0.5); }
.rm-stage.final .rm-node::after { border-color: rgba(61,220,151,0.5); }
.rm-stage.final .rm-card { border-color: rgba(61,220,151,0.35); background: linear-gradient(180deg, rgba(61,220,151,0.08), var(--glass)); }
.rm-stage.final .rm-phase { color: #6ff0b6; }
@media (max-width: 560px) { .rm-line { left: 23px; } .rm-stage { grid-template-columns: 48px 1fr; gap: 14px; } .rm-node { width: 48px; height: 48px; font-size: 0.8rem; } .rm-card { padding: 18px; } }

/* Psicología — lista editorial (sin cajas) */
.psy-list { display: grid; gap: 24px; align-content: center; }
.psy-item { display: flex; gap: 18px; align-items: flex-start; }
.psy-item .pi-num { flex: none; width: 40px; height: 40px; border-radius: 12px; display: grid; place-items: center; font-family: var(--font-mono); font-weight: 700; color: #04122e; background: var(--grad); box-shadow: 0 8px 20px -8px var(--glow); }
.psy-item b { display: block; font-size: 1.06rem; margin-bottom: 4px; }
.psy-item span { color: var(--dim); font-size: 0.95rem; line-height: 1.55; }

/* Narrativa tipo historia (sin cubos) */
.story-flow { max-width: 740px; margin: 26px auto 0; }
.story-flow p { font-size: 1.16rem; line-height: 1.75; color: var(--dim); margin-bottom: 18px; }
.story-flow p:first-child { font-size: 1.4rem; color: var(--text); font-weight: 600; line-height: 1.4; }
.story-flow p:last-child { margin-bottom: 0; }
.story-flow b { color: var(--text); }
.story-flow .hl { color: var(--accent-2); font-weight: 600; }

/* ===== Escena animada: el robot cobra vida (generador) ===== */
.robot-scene { max-width: 600px; margin: 30px auto 0; }
.robot-scene svg { width: 100%; height: auto; display: block; overflow: visible; }
.rs-bot { transform-box: fill-box; transform-origin: center; animation: rsBob 3.2s ease-in-out infinite; }
@keyframes rsBob { 50% { transform: translateY(-12px); } }
.rs-eye { transform-box: fill-box; transform-origin: center; animation: rsBlink 4.2s infinite; }
@keyframes rsBlink { 0%, 90%, 100% { transform: scaleY(1); } 95% { transform: scaleY(0.1); } }
.rs-ant { transform-box: fill-box; transform-origin: center; animation: rsAnt 1.6s ease-in-out infinite; }
@keyframes rsAnt { 50% { opacity: 0.35; transform: scale(0.6); } }
.rs-arm-l { transform-box: fill-box; transform-origin: 50% 0%; animation: rsWaveL 2.6s ease-in-out infinite; }
.rs-arm-r { transform-box: fill-box; transform-origin: 50% 0%; animation: rsWaveR 2.6s ease-in-out infinite; }
@keyframes rsWaveL { 50% { transform: rotate(-20deg); } }
@keyframes rsWaveR { 50% { transform: rotate(20deg); } }
.rs-chip { transform-box: fill-box; transform-origin: center; animation: rsFloat 3.4s ease-in-out infinite; }
@keyframes rsFloat { 50% { transform: translateY(-9px); } }
.rs-listo { transform-box: fill-box; transform-origin: center; animation: rsListo 3.6s ease-in-out infinite; }
@keyframes rsListo { 0%, 30% { transform: scale(0); opacity: 0; } 46% { transform: scale(1.18); opacity: 1; } 90% { transform: scale(1); opacity: 1; } 100% { transform: scale(1); opacity: 0; } }
.rs-cd { transform-box: fill-box; transform-origin: bottom; animation: rsCd 2.2s ease-in-out infinite; }
@keyframes rsCd { 0% { transform: scaleY(0.25); } 50% { transform: scaleY(1); } 100% { transform: scaleY(0.25); } }
@media (prefers-reduced-motion: reduce) { .rs-bot,.rs-eye,.rs-ant,.rs-arm-l,.rs-arm-r,.rs-chip,.rs-listo,.rs-cd { animation: none !important; } }

/* Contraste de números grandes (1 vs Millones) */
.vs { display: grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items: center; margin-top: 44px; }
.vs-side { text-align: center; padding: 26px 20px; }
.vs-label { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mute); }
.vs-num { font-size: clamp(3.2rem, 10vw, 6.5rem); font-weight: 700; letter-spacing: -0.045em; line-height: 1; margin: 12px 0; }
.vs-side.a .vs-num { color: var(--mute); }
.vs-side.b .vs-num { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.vs-sub { display: block; font-family: var(--font-mono); font-size: 0.95rem; font-weight: 600; margin: 2px 0 12px; }
.vs-side.a .vs-sub { color: var(--mute); }
.vs-side.b .vs-sub { color: var(--accent-2); }
.vs-desc { color: var(--dim); font-size: 0.96rem; max-width: 300px; margin: 0 auto; display: block; line-height: 1.5; }
.vs-side.a .vs-desc { color: var(--mute); }
.vs-mid { font-family: var(--font-mono); font-weight: 700; color: var(--accent-2); font-size: 1.05rem; border: 1px solid var(--line-2);
  border-radius: 50%; width: 58px; height: 58px; display: grid; place-items: center; background: var(--glass); }
@media (max-width: 720px) { .vs { grid-template-columns: 1fr; gap: 12px; } .vs-mid { margin: 0 auto; } }

/* ---------- Herramienta: opciones → robot listo ---------- */
.tool-demo { display: grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items: center; margin-top: 26px;
  border: 1px solid var(--line-2); border-radius: var(--r-lg); background: var(--glass); backdrop-filter: blur(8px); padding: 30px; box-shadow: var(--shadow); }
.td-title { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mute); margin-bottom: 14px; }
.td-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 13px 15px; border: 1px solid var(--line); border-radius: 11px; background: rgba(255,255,255,0.025); margin-bottom: 10px; font-size: 0.96rem; color: var(--dim); }
.td-pill { font-size: 0.86rem; color: var(--accent-2); border: 1px solid var(--line-2); border-radius: 100px; padding: 5px 13px; white-space: nowrap; }
.td-pill.td-on { background: var(--grad); color: #04122e; border-color: transparent; font-weight: 600; }
.td-arrow { font-size: 2.2rem; color: var(--accent); }
.td-result { text-align: center; display: grid; gap: 7px; justify-items: center; padding: 26px 20px; border: 1px solid rgba(56,189,248,0.3); border-radius: var(--r); background: linear-gradient(180deg, rgba(56,189,248,0.09), var(--glass)); }
.td-robot { font-size: 3.2rem; line-height: 1; }
.td-result b { font-size: 1.25rem; }
.td-result > span { color: var(--dim); font-size: 0.92rem; }
.td-badge { font-family: var(--font-mono); font-size: 0.78rem; color: #6ff0b6; border: 1px solid rgba(61,220,151,0.4); border-radius: 100px; padding: 5px 13px; margin-top: 6px; }
@media (max-width: 760px) { .tool-demo { grid-template-columns: 1fr; } .td-arrow { transform: rotate(90deg); justify-self: center; } }

/* ---------- Movimiento continuo automático ---------- */
.feature-card .icon { animation: floaty 5s var(--ease) infinite; }
.feature-card:nth-child(2) .icon { animation-delay: 0.5s; }
.feature-card:nth-child(3) .icon { animation-delay: 1s; }
.td-robot { animation: tdbounce 2.4s ease-in-out infinite; }
@keyframes tdbounce { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.td-arrow { animation: tdarrow 1.5s ease-in-out infinite; }
@keyframes tdarrow { 50% { transform: translateX(8px); } }
.tool-demo .td-pill.td-on { animation: tdglow 2.2s ease-in-out infinite; }
@keyframes tdglow { 50% { box-shadow: 0 0 20px var(--glow); } }
.td-badge { animation: tdbadge 2.2s ease-in-out infinite; }
@keyframes tdbadge { 50% { box-shadow: 0 0 18px rgba(61,220,151,0.5); } }
.td-result { animation: tdfloat 4s var(--ease) infinite; }
@keyframes tdfloat { 50% { transform: translateY(-6px); } }
/* aurora del fondo más visible */
.aurora .blob { opacity: 0.62; }

/* ---------- Callout (IA / clientes) ---------- */
.callout { display: grid; grid-template-columns: auto 1fr; gap: 26px; align-items: center; border: 1px solid var(--line-2); border-radius: var(--r-lg);
  background: linear-gradient(160deg, rgba(91,141,255,0.13), rgba(124,92,255,0.06) 55%, rgba(5,7,15,0.3)); padding: clamp(28px, 4vw, 48px); box-shadow: var(--shadow); }
.callout .c-icon { width: 66px; height: 66px; border-radius: 19px; display: grid; place-items: center; color: #04122e; background: var(--grad); box-shadow: 0 14px 34px -12px var(--glow); flex: none; }
.callout h3 { font-size: clamp(1.3rem, 2.4vw, 1.75rem); margin-bottom: 10px; }
.callout p { color: var(--dim); font-size: 1.02rem; max-width: 800px; line-height: 1.6; }
.callout .c-points { display: flex; gap: 22px; flex-wrap: wrap; margin-top: 18px; }
.callout .c-points span { display: flex; gap: 9px; align-items: center; font-size: 0.9rem; color: var(--dim); }
.callout .c-points svg { width: 22px; height: 22px; padding: 3px; border-radius: 7px; background: linear-gradient(135deg,#3ddc97,#22c55e); color: #04231a; flex: none; }
@media (max-width: 720px) { .callout { grid-template-columns: 1fr; } }

/* ---------- FAQ ---------- */
.faq-list { max-width: 820px; margin-inline: auto; display: grid; gap: 14px; }
.faq-item { border: 1px solid var(--line); border-radius: var(--r-sm); background: var(--glass); overflow: hidden; transition: border-color var(--t); }
.faq-item.open { border-color: var(--line-2); }
.faq-q { width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: 20px 22px;
  display: flex; align-items: center; justify-content: space-between; gap: 16px; font-size: 1.02rem; font-weight: 500; color: var(--text); }
.faq-q .ico { flex: none; width: 24px; height: 24px; display: grid; place-items: center; border: 1px solid var(--line-2); border-radius: 7px; color: var(--accent-2); transition: transform var(--t) var(--ease); }
.faq-item.open .faq-q .ico { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height var(--t) var(--ease); }
.faq-a p { padding: 0 22px 22px; color: var(--dim); font-size: 0.96rem; }

/* ---------- CTA / Footer ---------- */
.cta-band { text-align: center; border: 1px solid var(--line-2); border-radius: var(--r-lg); position: relative; overflow: hidden;
  padding: clamp(48px, 7vw, 88px); background: linear-gradient(160deg, rgba(91,141,255,0.16), rgba(124,92,255,0.08), rgba(5,7,15,0.4)); }
.cta-band .glow { position: absolute; top: -50%; left: 50%; width: 60%; height: 100%; transform: translateX(-50%);
  background: radial-gradient(circle, var(--glow), transparent 60%); filter: blur(40px); pointer-events: none; }
.cta-band > * { position: relative; }
.cta-band h2 { margin-bottom: 16px; }
.cta-band p { color: var(--dim); max-width: 540px; margin: 0 auto 32px; }
.cta-band .hero-cta { justify-content: center; }

.footer { padding-block: 60px 44px; margin-top: 30px; }
.footer-inner { display: flex; justify-content: space-between; gap: 30px; flex-wrap: wrap; align-items: flex-start; }
.footer p { color: var(--mute); font-size: 0.86rem; max-width: 360px; margin-top: 16px; }
.footer-links { display: flex; gap: 28px; flex-wrap: wrap; }
.footer-links a { color: var(--dim); font-size: 0.88rem; transition: color var(--t-fast); }
.footer-links a:hover { color: var(--text); }
.footer-legal { margin-top: 40px; display: flex; justify-content: space-between;
  gap: 16px; flex-wrap: wrap; color: var(--mute); font-size: 0.78rem; font-family: var(--font-mono); }

/* ---------- Animaciones de movimiento continuo ---------- */
@keyframes floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-9px); } }
@keyframes borderspin { to { --angle: 360deg; } }
@property --angle { syntax: "<angle>"; initial-value: 0deg; inherits: false; }

/* Borde con degradado giratorio para la tarjeta destacada */
.plan.featured { background: linear-gradient(180deg, rgba(91,141,255,0.1), var(--glass)); position: relative; border: 1px solid transparent; box-shadow: var(--shadow-glow); }
.plan.featured::after { content: ""; position: absolute; inset: -1px; border-radius: inherit; z-index: -1; padding: 1.5px;
  background: conic-gradient(from var(--angle), transparent 30%, var(--accent), var(--accent-2), transparent 70%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude;
  animation: borderspin 6s linear infinite; }
.feature-card .icon { animation: floaty 5s var(--ease) infinite; }
.feature-card:nth-child(2) .icon { animation-delay: 0.6s; }
.feature-card:nth-child(3) .icon { animation-delay: 1.2s; }
.feature-card:nth-child(5) .icon { animation-delay: 0.9s; }

/* ---------- Comparación manual vs robots ---------- */
.compare { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.compare-card { border: 1px solid var(--line); border-radius: var(--r); background: var(--glass); padding: 34px; backdrop-filter: blur(8px); }
.compare-card.good { border-color: rgba(56,189,248,0.32); background: linear-gradient(180deg, rgba(56,189,248,0.08), var(--glass)); box-shadow: var(--shadow-glow); }
.compare-card .tagm { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--mute); }
.compare-card h3 { margin: 8px 0 22px; }
.pc-list { display: grid; gap: 14px; }
.pc-list li { display: flex; gap: 12px; align-items: flex-start; font-size: 0.95rem; color: var(--dim); }
.pc-list li .mk { flex: none; width: 22px; height: 22px; border-radius: 6px; display: grid; place-items: center; font-size: 0.72rem; font-weight: 700; margin-top: 1px; }
.pc-list li.con .mk { background: rgba(255,107,107,0.14); color: #ff9a9a; border: 1px solid rgba(255,107,107,0.3); }
.pc-list li.pro .mk { background: rgba(61,220,151,0.16); color: #6ff0b6; border: 1px solid rgba(61,220,151,0.35); }

/* ---------- Stats ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-bottom: 42px; }
.stat { border: 1px solid var(--line); border-radius: var(--r); background: var(--glass); padding: 28px 22px; text-align: center; backdrop-filter: blur(8px); transition: transform var(--t) var(--ease), border-color var(--t); }
.stat:hover { border-color: var(--line-2); }
.stat b { display: block; font-size: 2.3rem; font-weight: 600; letter-spacing: -0.04em; line-height: 1;
  background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
.stat span { color: var(--dim); font-size: 0.88rem; margin-top: 8px; display: block; }

/* ---------- Portfolio de robots (diversificación) ---------- */
.portfolio { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.bot-card { border: 1px solid var(--line); border-radius: 13px; background: var(--glass); padding: 16px 16px 12px;
  display: grid; gap: 11px; backdrop-filter: blur(6px); transition: transform var(--t) var(--ease), border-color var(--t), box-shadow var(--t); }
.bot-card:hover { border-color: var(--line-2); box-shadow: var(--shadow); }
.bot-head { display: flex; align-items: center; justify-content: space-between; }
.bot-head .sym { font-weight: 600; font-size: 0.92rem; }
.bot-head .tf { font-family: var(--font-mono); font-size: 0.68rem; color: var(--mute); border: 1px solid var(--line); border-radius: 6px; padding: 2px 7px; }
.bot-spark { height: 36px; }
.bot-foot { display: flex; align-items: center; justify-content: space-between; font-family: var(--font-mono); font-size: 0.72rem; }
.bot-foot .st { display: flex; align-items: center; gap: 7px; color: var(--dim); }
.bot-foot .st .d { width: 7px; height: 7px; border-radius: 50%; background: #3ddc97; box-shadow: 0 0 8px #3ddc97; animation: pulse 2.2s ease-in-out infinite; }
.bot-foot .strat { color: var(--mute); }

/* ---------- Ventana de código completa ---------- */
.code-window { border: 1px solid var(--line-2); border-radius: var(--r); overflow: hidden; box-shadow: var(--shadow);
  background: linear-gradient(180deg, rgba(11,17,32,0.92), rgba(5,7,15,0.92)); font-family: var(--font-mono); }
.code-window .cw-bar { display: flex; align-items: center; gap: 8px; padding: 13px 16px; border-bottom: 1px solid var(--line); font-size: 0.72rem; color: var(--mute); }
.code-window .cw-bar i { width: 9px; height: 9px; border-radius: 50%; background: #2a3a5e; }
.code-window .cw-bar i:nth-child(1){background:#ff5f57;} .code-window .cw-bar i:nth-child(2){background:#febc2e;} .code-window .cw-bar i:nth-child(3){background:#28c840;}
.code-window .cw-bar span { margin-left: auto; }
.code-window pre { margin: 0; padding: 18px 18px; font-size: 0.76rem; line-height: 1.8; overflow-x: auto; color: var(--dim);
  max-height: 460px; }
.code-window .k { color: #7cc3ff; } .code-window .s { color: #8ee6b4; } .code-window .c { color: var(--mute); font-style: italic; }
.code-window .n { color: #c7d2f0; } .code-window .f { color: #b9a7ff; } .code-window .t { color: #ffd391; }

/* ===================================================================
   Demo animado de la plataforma con cursor macOS autónomo
   =================================================================== */
.app-window { position: relative; border-radius: var(--r-lg); overflow: hidden;
  background: linear-gradient(180deg, rgba(13,19,36,0.94), rgba(5,7,15,0.94));
  box-shadow: var(--shadow-lg); backdrop-filter: blur(10px);
  transform: perspective(1700px) rotateX(8deg); transform-origin: center top;
  transition: transform 1.1s var(--ease); }
.hero-preview.in .app-window { transform: perspective(1700px) rotateX(0deg); }
.app-window::before { content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1.4px; z-index: 4; pointer-events: none;
  background: linear-gradient(155deg, rgba(91,141,255,0.7), transparent 32%, transparent 66%, rgba(56,189,248,0.55));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; }
.aw-glow { position: absolute; top: -34%; left: 50%; width: 72%; height: 70%; transform: translateX(-50%);
  background: radial-gradient(circle, var(--glow), transparent 64%); filter: blur(46px); pointer-events: none; z-index: 0; }

.aw-bar { display: flex; align-items: center; gap: 14px; padding: 15px 18px; border-bottom: 1px solid var(--line); position: relative; z-index: 1; }
.aw-bar .lights { display: flex; gap: 8px; }
.aw-bar .lights i { width: 11px; height: 11px; border-radius: 50%; }
.aw-bar .lights i:nth-child(1){background:#ff5f57;} .aw-bar .lights i:nth-child(2){background:#febc2e;} .aw-bar .lights i:nth-child(3){background:#28c840;}
.aw-title { font-family: var(--font-mono); font-size: 0.74rem; color: var(--mute); }
.aw-tab { margin-left: auto; font-family: var(--font-mono); font-size: 0.72rem; color: var(--dim);
  border: 1px solid var(--line); border-radius: 8px; padding: 4px 11px; background: var(--glass); }

.aw-body { display: grid; grid-template-columns: 1fr 1.18fr; position: relative; z-index: 1; min-height: 366px; }
.aw-panel { padding: 22px; border-right: 1px solid var(--line); display: grid; gap: 11px; align-content: start; }
.demo-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 13px 15px;
  border: 1px solid var(--line); border-radius: 11px; background: var(--glass); font-size: 0.86rem; transition: border-color var(--t), background var(--t); }
.demo-row.touch { border-color: var(--accent); background: rgba(91,141,255,0.09); }
.demo-row .lbl { color: var(--dim); }
.demo-row .chip { font-family: var(--font-mono); font-size: 0.73rem; color: var(--mute); border: 1px solid var(--line-2);
  border-radius: 7px; padding: 3px 10px; min-width: 86px; text-align: center; transition: all var(--t); }
.demo-row .chip.set { color: #04122e; background: var(--grad); border-color: transparent; font-weight: 600; }
.demo-row .toggle { width: 40px; height: 23px; border-radius: 100px; background: rgba(255,255,255,0.12); position: relative; flex: none; transition: background var(--t); }
.demo-row .toggle::after { content: ""; position: absolute; top: 3px; left: 3px; width: 17px; height: 17px; border-radius: 50%; background: #fff; transition: left var(--t) var(--ease); }
.demo-row .toggle.on { background: var(--grad); } .demo-row .toggle.on::after { left: 20px; }
.aw-generate { margin-top: 10px; padding: 13px; border: 0; border-radius: 11px; background: var(--grad); color: #04122e;
  font-weight: 600; font-family: inherit; font-size: 0.9rem; cursor: default; position: relative; overflow: hidden;
  box-shadow: 0 12px 28px -10px var(--glow); transition: transform 0.15s var(--ease); }
.aw-generate.press { transform: scale(0.96); }

.aw-output { display: grid; grid-template-rows: 0.85fr 1.15fr; }
.aw-chart { position: relative; padding: 16px 16px 22px; display: flex; align-items: flex-end; gap: 5px; border-bottom: 1px solid var(--line); }
.aw-chart .candle { width: 8px; border-radius: 2px; opacity: 0; transform: translateY(14px); }
.aw-chart .candle.show { animation: candleIn 0.45s var(--ease) forwards; }
.aw-chart .candle.up { background: linear-gradient(180deg,#3ddc97,#1f9e6b); } .aw-chart .candle.down { background: linear-gradient(180deg,#ff6b6b,#c93f3f); }
.aw-marker { position: absolute; font-family: var(--font-mono); font-size: 0.66rem; padding: 2px 7px; border-radius: 6px;
  background: rgba(61,220,151,0.18); color: #6ff0b6; border: 1px solid rgba(61,220,151,0.45); opacity: 0; transform: translateY(4px); transition: all var(--t); }
.aw-marker.show { opacity: 1; transform: none; }
.aw-code { margin: 0; padding: 16px 18px; font-family: var(--font-mono); font-size: 0.72rem; line-height: 1.75; color: var(--dim); overflow: hidden; white-space: pre-wrap; }
.aw-code .k{color:#7cc3ff;} .aw-code .c{color:var(--mute);font-style:italic;} .aw-code .n{color:#c7d2f0;} .aw-code .s{color:#8ee6b4;} .aw-code .f{color:#b9a7ff;} .aw-code .t{color:#ffd391;}
.aw-caret { display: inline-block; width: 7px; background: var(--accent-2); animation: blink 1s steps(1) infinite; color: transparent; }
@keyframes blink { 50% { opacity: 0; } }

/* Cursor macOS falso */
.fake-cursor { position: absolute; top: 0; left: 0; z-index: 6; pointer-events: none;
  filter: drop-shadow(0 3px 5px rgba(0,0,0,0.55)); will-change: transform;
  transition: transform 0.72s cubic-bezier(0.5, 0, 0.2, 1); }
.fake-cursor .ring { position: absolute; left: 2px; top: 2px; width: 16px; height: 16px; border-radius: 50%; border: 2px solid var(--accent-2); opacity: 0; }
.fake-cursor.click .ring { animation: clickring 0.55s var(--ease); }
@keyframes clickring { 0% { transform: scale(0.3); opacity: 0.9; } 100% { transform: scale(2.2); opacity: 0; } }

@media (prefers-reduced-motion: reduce) { .fake-cursor { display: none !important; } .app-window { transform: none; } }
@media (max-width: 720px) { .fake-cursor { display: none; } .aw-body { grid-template-columns: 1fr; } .aw-panel { border-right: 0; border-bottom: 1px solid var(--line); } }

/* ===== Sección Mi camino (historia, pasos numerados) ===== */
.story-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: 1000px; margin: 0 auto; }
.story-step { position: relative; padding: 24px 22px; border: 1px solid var(--line); border-radius: 16px; background: var(--glass); backdrop-filter: blur(8px); }
.story-step .ss-n { display: grid; place-items: center; width: 38px; height: 38px; border-radius: 12px; background: var(--grad); color: #04122e; font-weight: 700; font-size: 1.05rem; margin-bottom: 16px; box-shadow: 0 8px 20px -8px var(--glow); }
.story-step b { display: block; font-size: 1.02rem; margin-bottom: 6px; letter-spacing: -0.01em; }
.story-step p { color: var(--dim); font-size: 0.88rem; line-height: 1.6; }
.story-step:not(:last-child)::after { content: "→"; position: absolute; top: 36px; right: -12px; color: var(--mute); font-size: 1.1rem; z-index: 2; }
@media (max-width: 820px) { .story-steps { grid-template-columns: 1fr 1fr; } .story-step:not(:last-child)::after { display: none; } }
@media (max-width: 480px) { .story-steps { grid-template-columns: 1fr; } }

/* ===== Sección Transparencia / Compromiso ===== */
.honesty { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 920px; margin: 0 auto; }
.hon-item { display: flex; gap: 16px; align-items: flex-start; padding: 22px 24px; border: 1px solid var(--line); border-radius: 16px; background: var(--glass); backdrop-filter: blur(8px); }
.hon-item.no { border-color: rgba(255,110,110,0.2); }
.hon-item.yes { border-color: rgba(61,220,151,0.3); background: linear-gradient(180deg, rgba(61,220,151,0.07), var(--glass)); }
.hon-ic { flex: none; width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; font-size: 0.8rem; font-weight: 700; margin-top: 2px; }
.hon-item.no .hon-ic { background: rgba(255,90,90,0.14); color: #ff9a9a; }
.hon-item.yes .hon-ic { background: rgba(61,220,151,0.16); color: #6ff0b6; }
.hon-item b { display: block; font-size: 1.04rem; margin-bottom: 5px; }
.hon-item.yes b { color: #6ff0b6; }
.hon-item p { color: var(--dim); font-size: 0.92rem; line-height: 1.6; }
@media (max-width: 680px) { .honesty { grid-template-columns: 1fr; } }

/* "0 chances reales" (lado perdedor de la sección capacitado) en rojo */
#capacitado .vs-side.a .vs-num,
#capacitado .vs-side.a .vs-sub { color: #ff6b6b; }

/* ===== Sección Sin humo (NO / SÍ) ===== */
.no-si { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 900px; margin: 0 auto; }
.ns-col { border: 1px solid var(--line); border-radius: 18px; padding: 26px 28px; background: var(--glass); backdrop-filter: blur(8px); }
.ns-col.no { border-color: rgba(255,110,110,0.22); background: linear-gradient(180deg, rgba(255,90,90,0.055), var(--glass)); }
.ns-col.si { border-color: rgba(61,220,151,0.26); background: linear-gradient(180deg, rgba(61,220,151,0.06), var(--glass)); }
.ns-tag { display: block; font-family: var(--font-sans); font-weight: 700; font-size: 0.95rem; letter-spacing: 0.01em; margin-bottom: 18px; }
.ns-col.no .ns-tag { color: #ff9a9a; }
.ns-col.si .ns-tag { color: #6ff0b6; }
.ns-col ul { list-style: none; display: grid; gap: 13px; }
.ns-col li { position: relative; padding-left: 32px; font-size: 0.96rem; color: var(--dim); line-height: 1.5; }
.ns-col li::before { position: absolute; left: 0; top: 1px; width: 21px; height: 21px; border-radius: 50%; display: grid; place-items: center; font-size: 0.72rem; font-weight: 700; }
.ns-col.no li::before { content: "✕"; background: rgba(255,90,90,0.14); color: #ff9a9a; }
.ns-col.si li::before { content: "✓"; background: rgba(61,220,151,0.16); color: #6ff0b6; }
@media (max-width: 680px) { .no-si { grid-template-columns: 1fr; } }

/* ===== Demo del panel de progreso (puntuación + curva) ===== */
.dash-demo { grid-template-columns: 0.92fr 1.08fr; min-height: 330px; }
.dd-left { padding: 24px; border-right: 1px solid var(--line); display: grid; gap: 18px; align-content: start; }
.dd-right { padding: 24px; display: grid; gap: 12px; align-content: start; }
.dd-score { display: flex; align-items: center; gap: 16px; }
.dd-ring { width: 78px; height: 78px; border-radius: 50%; display: grid; place-items: center; flex: none; position: relative;
  background: conic-gradient(var(--accent-2) calc(var(--p) * 1%), rgba(255,255,255,0.08) 0); }
.dd-ring::before { content: ""; position: absolute; inset: 8px; border-radius: 50%; background: #0a0f1e; }
.dd-ring b { position: relative; font-family: var(--font-mono); font-weight: 700; font-size: 1.25rem; color: var(--text); }
.dd-score-txt b { display: block; font-size: 1.02rem; }
.dd-score-txt span { font-size: 0.82rem; color: var(--mute); }
.dd-checks { display: grid; gap: 9px; }
.dd-chk { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 11px 14px; border: 1px solid var(--line); border-radius: 10px; background: var(--glass); font-size: 0.86rem; color: var(--mute); }
.dd-chk .m { font-family: var(--font-mono); font-size: 0.74rem; }
.dd-chk.done { color: var(--text); } .dd-chk.done .m { color: #6ff0b6; }
.dd-chk.prog { color: var(--dim); } .dd-chk.prog .m { color: var(--accent-2); }
.dd-prog { display: grid; gap: 9px; padding-top: 16px; border-top: 1px solid var(--line); }
.dd-prog-top { display: flex; justify-content: space-between; align-items: baseline; font-size: 0.86rem; color: var(--dim); }
.dd-prog-top b { font-size: 1.05rem; color: var(--text); }
.dd-bar { height: 8px; border-radius: 100px; background: rgba(255,255,255,0.08); overflow: hidden; }
.dd-bar i { display: block; height: 100%; border-radius: 100px; background: var(--grad); box-shadow: 0 0 12px var(--glow); }
.dd-prog-sub { font-size: 0.78rem; color: var(--mute); }
.dd-rhead { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; }
.dd-head { font-family: var(--font-sans); font-weight: 600; font-size: 0.92rem; color: var(--dim); }
.dd-now { font-weight: 700; font-size: 1.45rem; color: #67e8f9; line-height: 1; }
.dd-now i { font-style: normal; font-size: 0.78rem; color: var(--mute); font-weight: 600; }
.dd-plot { display: flex; gap: 10px; align-items: stretch; }
.dd-yax { display: flex; flex-direction: column; justify-content: space-between; height: 154px; font-size: 0.66rem; color: var(--mute); text-align: right; flex: none; }
.dd-chart { flex: 1; height: 154px; display: block; }
.dd-chart .grid { stroke: rgba(255,255,255,0.07); stroke-width: 1; }
.dd-chart .area { fill: url(#ddgrad); opacity: 0; animation: ddArea 1s ease forwards 0.7s; }
.dd-chart .line { fill: none; stroke: #5b8dff; stroke-width: 2.6; stroke-linecap: round; stroke-linejoin: round; stroke-dasharray: 600; stroke-dashoffset: 600; animation: ddDraw 1.7s var(--ease) forwards; filter: drop-shadow(0 4px 10px rgba(91,141,255,0.4)); }
.dd-chart .pt { fill: #38bdf8; opacity: 0; animation: ddPt 0.35s ease forwards; }
@keyframes ddDraw { to { stroke-dashoffset: 0; } }
@keyframes ddArea { to { opacity: 1; } }
@keyframes ddPt { to { opacity: 1; } }
.dd-axis { display: flex; justify-content: space-between; font-family: var(--font-sans); font-size: 0.7rem; color: var(--mute); }
.dd-cap { font-size: 0.86rem; color: var(--dim); line-height: 1.5; }
.dd-cap b { color: var(--text); }
.dd-note { display: flex; gap: 9px; align-items: center; font-size: 0.86rem; color: var(--mute); border-top: 1px solid var(--line); padding-top: 13px; margin-top: 4px; }
.dd-note svg { color: #6ff0b6; flex: none; }
.dd-note b { color: var(--accent-2); }
@media (max-width: 720px) { .dash-demo { grid-template-columns: 1fr; } .dd-left { border-right: 0; border-bottom: 1px solid var(--line); } }

/* ===== Demo de ofertas (tomar / agregar / entregar) ===== */
/* La ventana de ofertas es SOLO una foto fija: sin cursor ni animación, no responde a clics. */
#offersDemo { pointer-events: none; user-select: none; }
#offersCursor { display: none; }
.od-body { grid-template-columns: 1fr 1fr; min-height: 380px; }
.od-head { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--mute); margin-bottom: 4px; }
.od-offer, .od-client { border: 1px solid var(--line); border-radius: 13px; background: var(--glass); padding: 14px; display: grid; gap: 10px; position: relative; transition: opacity .5s var(--ease), transform .5s var(--ease), border-color var(--t); }
.od-offer.taken { opacity: 0.45; border-color: rgba(61,220,151,0.35); }
.od-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.od-cli { display: flex; align-items: center; gap: 9px; }
.od-av { width: 32px; height: 32px; border-radius: 50%; background: var(--grad); color: #04122e; font-weight: 700; font-size: 0.72rem; display: grid; place-items: center; flex: none; }
.od-cli b { display: block; font-size: 0.82rem; }
.od-cli span { font-size: 0.68rem; color: var(--mute); font-family: var(--font-mono); }
.od-pay { font-family: var(--font-mono); font-weight: 800; font-size: 1rem; color: #052e18; background: linear-gradient(135deg,#1fe084,#0fb863); padding: 5px 11px; border-radius: 9px; box-shadow: 0 4px 14px rgba(25,217,120,0.3); }
.od-name { font-size: 0.86rem; font-weight: 600; color: var(--text); }
.od-acts { display: flex; gap: 8px; }
.od-btn { flex: 1; border: 0; border-radius: 9px; padding: 9px; font-family: inherit; font-size: 0.8rem; font-weight: 600; cursor: default; transition: transform .14s var(--ease), filter .14s; }
.od-btn.acc { background: linear-gradient(135deg,#1fe084,#0fb863); color: #052e18; }
.od-btn.rej { background: transparent; border: 1px solid rgba(255,120,120,0.45); color: #ff9a9a; }
.od-btn.send { background: var(--grad); color: #04122e; width: 100%; }
.od-btn.press { transform: scale(0.94); filter: brightness(1.1); }
.od-taken { display: none; align-items: center; gap: 6px; justify-content: center; font-size: 0.78rem; font-weight: 600; color: #6ff0b6; font-family: var(--font-mono); }
.od-offer.taken .od-acts { display: none; }
.od-offer.taken .od-taken { display: flex; }
.od-pay.sm { font-size: 0.8rem; padding: 3px 8px; border-radius: 7px; box-shadow: none; }
.od-av.sm { width: 28px; height: 28px; font-size: 0.64rem; }
/* Resumen "para cobrar" + contador */
.od-sum { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap;
  padding: 12px 14px; border-radius: 12px; border: 1px solid rgba(25,217,120,0.28); background: linear-gradient(135deg, rgba(25,217,120,0.12), rgba(56,189,248,0.06)); }
.od-sum-l { display: block; font-size: 0.68rem; font-family: var(--font-mono); letter-spacing: 0.08em; text-transform: uppercase; color: var(--mute); }
.od-sum-v { font-family: var(--font-mono); font-weight: 800; font-size: 1.5rem; color: #2ce98c; line-height: 1.1; text-shadow: 0 0 20px rgba(25,217,120,0.35); }
.od-count { font-family: var(--font-mono); font-size: 0.7rem; color: var(--dim); border: 1px solid var(--line-2); border-radius: 100px; padding: 5px 11px; transition: color var(--t); }
/* Filas compactas de clientes ya entregados */
.od-mini { display: flex; align-items: center; gap: 10px; padding: 9px 11px; border: 1px solid var(--line); border-radius: 11px; background: var(--glass); }
.od-mini-i { flex: 1; min-width: 0; }
.od-mini-i b { display: block; font-size: 0.8rem; }
.od-mini-i span { font-size: 0.68rem; color: var(--mute); }
.od-pill { font-family: var(--font-mono); font-size: 0.66rem; padding: 4px 9px; border-radius: 100px; white-space: nowrap; }
.od-pill.ok { background: rgba(25,217,120,0.14); color: #6ff0b6; }
.od-pill.rev { background: rgba(255,160,70,0.16); color: #ffae6b; }
.od-client { opacity: 1; }
.od-state { font-family: var(--font-mono); font-size: 0.74rem; padding: 6px 11px; border-radius: 100px; align-self: start; background: rgba(255,200,80,0.14); color: #ffce6b; }
.od-state.review { background: rgba(255,160,70,0.16); color: #ffae6b; }
.od-deliver { display: grid; gap: 9px; padding-top: 10px; border-top: 1px solid var(--line); transition: opacity .4s; }
.od-deliver.hide { opacity: 0; height: 0; padding: 0; overflow: hidden; }
.od-file { display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 0.74rem; color: var(--dim); border: 1px solid var(--line); border-radius: 8px; padding: 8px 11px; }
.od-file svg { color: var(--accent-2); }
@media (max-width: 720px) { .od-body { grid-template-columns: 1fr; } }

/* ---------- Explorador de niveles (pestañas interactivas) ---------- */
.levels { border: 1px solid var(--line-2); border-radius: var(--r-lg); background: var(--glass);
  backdrop-filter: blur(12px); overflow: hidden; box-shadow: var(--shadow); }
.levels-tabs { display: grid; grid-template-columns: repeat(3, 1fr); position: relative; }
.ltab { background: none; border: 0; padding: 24px 26px; text-align: left; cursor: pointer; color: var(--dim);
  transition: background var(--t) var(--ease); position: relative; }
.ltab + .ltab::before { content: ""; position: absolute; left: 0; top: 22%; height: 56%; width: 1px; background: var(--line); }
.ltab b { display: block; font-size: 1.1rem; color: var(--text); font-weight: 600; letter-spacing: -0.02em; }
.ltab span { font-family: var(--font-mono); font-size: 0.72rem; color: var(--mute); }
.ltab:hover { background: rgba(255,255,255,0.03); }
.ltab.active b { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.tab-ind { position: absolute; bottom: 0; left: 0; height: 2px; width: 33.333%; background: var(--grad);
  box-shadow: 0 0 14px var(--glow); transition: transform var(--t) var(--ease); }
.lpanel { display: none; grid-template-columns: 1.05fr 1fr; gap: 44px; padding: 40px; }
.lpanel.active { display: grid; animation: panelIn 0.55s var(--ease); }
@keyframes panelIn { from { opacity: 0; transform: translateY(16px); filter: blur(6px); } to { opacity: 1; transform: none; filter: none; } }
.lpanel .tag { display: inline-block; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--accent-2); border: 1px solid var(--line-2); border-radius: 100px; padding: 5px 13px; margin-bottom: 18px; }
.lpanel h3 { font-size: clamp(1.4rem, 2.6vw, 1.9rem); margin-bottom: 14px; }
.lpanel .lead2 { color: var(--dim); font-size: 1.02rem; }
.goal { margin-top: 22px; padding: 16px 18px; border: 1px solid rgba(56,189,248,0.3); border-radius: 13px;
  background: rgba(56,189,248,0.07); font-size: 0.94rem; color: var(--dim); display: flex; gap: 10px; align-items: center; }
.goal svg { flex: none; color: var(--accent-2); }
.goal b { color: var(--accent-2); }
.lpanel .btn { margin-top: 26px; }
.lpanel-modules h5 { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--mute); margin-bottom: 20px; }
.mod-list { display: grid; gap: 16px; }
.mod-list li { display: flex; gap: 14px; align-items: flex-start; }
.mod-list .mi { font-family: var(--font-mono); font-size: 0.76rem; font-weight: 600; color: #04122e; background: var(--grad);
  width: 30px; height: 30px; border-radius: 9px; display: grid; place-items: center; flex: none; box-shadow: 0 6px 16px -8px var(--glow); }
.mod-list b { display: block; font-weight: 600; margin-bottom: 2px; font-size: 0.96rem; }
.mod-list span { color: var(--dim); font-size: 0.88rem; }
.mod-list.inc li { align-items: center; }
.mod-list.inc .mi { width: 24px; height: 24px; border-radius: 7px; }
/* Precio del plan */
.lpanel .price { font-size: 3.1rem; font-weight: 700; letter-spacing: -0.04em; line-height: 1; margin: 2px 0 12px;
  background: var(--grad-text); -webkit-background-clip: text; background-clip: text; color: transparent; }
/* Aparición escalonada de la lista (vivo) */
.lpanel.active .mod-list li { opacity: 0; animation: panelIn 0.5s var(--ease) forwards; }
.lpanel.active .mod-list li:nth-child(1){animation-delay:.04s} .lpanel.active .mod-list li:nth-child(2){animation-delay:.09s}
.lpanel.active .mod-list li:nth-child(3){animation-delay:.14s} .lpanel.active .mod-list li:nth-child(4){animation-delay:.19s}
.lpanel.active .mod-list li:nth-child(5){animation-delay:.24s} .lpanel.active .mod-list li:nth-child(6){animation-delay:.29s}
.lpanel.active .mod-list li:nth-child(7){animation-delay:.34s} .lpanel.active .mod-list li:nth-child(8){animation-delay:.39s}
.lpanel.active .mod-list li:nth-child(9){animation-delay:.44s} .lpanel.active .mod-list li:nth-child(10){animation-delay:.49s}
.lpanel.active .mod-list li:nth-child(11){animation-delay:.54s} .lpanel.active .mod-list li:nth-child(12){animation-delay:.59s}

/* ===== Color distinto por nivel ===== */
/* Nivel 1 — cian · Nivel 2 — violeta/azul · Nivel 3 — dorado (premium) */
.lpanel[data-level="1"] .price { background: linear-gradient(135deg,#38bdf8,#67e8f9); -webkit-background-clip: text; background-clip: text; color: transparent; }
.lpanel[data-level="2"] .price { background: linear-gradient(135deg,#7c8dff,#a78bfa); -webkit-background-clip: text; background-clip: text; color: transparent; }
.lpanel[data-level="3"] .price { background: linear-gradient(135deg,#f5c45e,#f59e0b); -webkit-background-clip: text; background-clip: text; color: transparent; }

.lpanel[data-level="1"] .tag { color: #67e8f9; border-color: rgba(56,189,248,0.4); }
.lpanel[data-level="2"] .tag { color: #a78bfa; border-color: rgba(124,92,255,0.4); }
.lpanel[data-level="3"] .tag { color: #f5c45e; border-color: rgba(245,196,94,0.4); }

.lpanel[data-level="1"] .mod-list .mi { background: linear-gradient(135deg,#38bdf8,#22d3ee); color: #042a33; }
.lpanel[data-level="2"] .mod-list .mi { background: linear-gradient(135deg,#5b8dff,#7c5cff); color: #0a1030; }
.lpanel[data-level="3"] .mod-list .mi { background: linear-gradient(135deg,#f5c45e,#f59e0b); color: #3a2600; }

.lpanel[data-level="1"] .goal { border-color: rgba(56,189,248,0.35); background: rgba(56,189,248,0.07); }
.lpanel[data-level="1"] .goal b, .lpanel[data-level="1"] .goal svg { color: #67e8f9; }
.lpanel[data-level="2"] .goal { border-color: rgba(124,92,255,0.35); background: rgba(124,92,255,0.07); }
.lpanel[data-level="2"] .goal b, .lpanel[data-level="2"] .goal svg { color: #a78bfa; }
.lpanel[data-level="3"] .goal { border-color: rgba(245,196,94,0.35); background: rgba(245,196,94,0.07); }
.lpanel[data-level="3"] .goal b, .lpanel[data-level="3"] .goal svg { color: #f5c45e; }

.lpanel[data-level="1"] .btn-primary { background: linear-gradient(135deg,#38bdf8,#22d3ee); color: #042a33; }
.lpanel[data-level="2"] .btn-primary { background: linear-gradient(135deg,#5b8dff,#7c5cff); color: #fff; }
.lpanel[data-level="3"] .btn-primary { background: linear-gradient(135deg,#f5c45e,#f59e0b); color: #3a2600; }

/* Etiquetas de pestaña SIEMPRE con su color (las 3 visibles a la vez) */
.ltab[data-level="1"] b { color: #38bdf8; }
.ltab[data-level="2"] b { color: #a78bfa; }
.ltab[data-level="3"] b { color: #f5c45e; }
.ltab[data-level="1"].active { background: rgba(56,189,248,0.09); }
.ltab[data-level="2"].active { background: rgba(124,92,255,0.10); }
.ltab[data-level="3"].active { background: rgba(245,196,94,0.10); }
.ltab[data-level="1"].active b { background: linear-gradient(135deg,#38bdf8,#67e8f9); -webkit-background-clip: text; background-clip: text; color: transparent; }
.ltab[data-level="2"].active b { background: linear-gradient(135deg,#7c8dff,#a78bfa); -webkit-background-clip: text; background-clip: text; color: transparent; }
.ltab[data-level="3"].active b { background: linear-gradient(135deg,#f5c45e,#f59e0b); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* Acento de color en el panel activo según el nivel */
.lpanel.active { position: relative; }
.lpanel.active::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; }
.lpanel[data-level="1"].active::before { background: linear-gradient(90deg,#38bdf8,#67e8f9); }
.lpanel[data-level="2"].active::before { background: linear-gradient(90deg,#7c8dff,#a78bfa); }
.lpanel[data-level="3"].active::before { background: linear-gradient(90deg,#f5c45e,#f59e0b); }

/* ---------- Flujo "Cómo funciona" (premium) ---------- */
.flow { position: relative; margin: 52px 0 46px; }
.flow-line { position: absolute; top: 42px; left: 10%; right: 10%; height: 3px; border-radius: 3px;
  background: linear-gradient(90deg, #7c5cff, #5b8dff, #38bdf8); opacity: 0.32; }
.flow-line::after { content: ""; position: absolute; top: -2px; left: 0; width: 120px; height: 7px; border-radius: 7px;
  background: linear-gradient(90deg, transparent, #fff, transparent); filter: blur(1px); box-shadow: 0 0 18px var(--accent-2);
  animation: travel 5s var(--ease) infinite; }
.flow-steps { position: relative; display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.fstep { text-align: center; position: relative; z-index: 1; }
.fstep .ico { width: 86px; height: 86px; margin: 0 auto 18px; border-radius: 26px; display: grid; place-items: center;
  background: linear-gradient(180deg, rgba(13,19,36,0.94), rgba(5,7,15,0.94)); border: 1px solid var(--line-2);
  color: var(--accent-2); position: relative; box-shadow: var(--shadow); animation: floaty 5s var(--ease) infinite; }
.fstep:nth-child(2) .ico{animation-delay:.4s} .fstep:nth-child(3) .ico{animation-delay:.8s} .fstep:nth-child(4) .ico{animation-delay:1.2s} .fstep:nth-child(5) .ico{animation-delay:1.6s}
.fstep .ico::before { content: ""; position: absolute; inset: -1px; border-radius: inherit; padding: 1.5px;
  background: linear-gradient(160deg, var(--accent), transparent 60%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; }
.fstep .ico .num { position: absolute; top: -9px; right: -9px; width: 28px; height: 28px; border-radius: 50%;
  background: var(--grad); color: #04122e; font-weight: 700; font-size: 0.84rem; display: grid; place-items: center; box-shadow: 0 6px 16px -6px var(--glow); }
.fstep h4 { font-size: 1.12rem; margin-bottom: 7px; }
.fstep p { color: var(--dim); font-size: 0.92rem; }
.fstep:hover .ico { transform: translateY(-6px) scale(1.04); }
.fstep .ico { transition: transform var(--t) var(--ease), box-shadow var(--t); }

/* 4 pasos · un color por proceso */
.flow-steps { grid-template-columns: repeat(4, 1fr); }
.flow-line { left: 12%; right: 12%; }
.fstep:nth-child(1) .ico { color: #38bdf8; }
.fstep:nth-child(1) .ico .num { background: linear-gradient(135deg,#38bdf8,#67e8f9); }
.fstep:nth-child(1) .ico::before { background: linear-gradient(160deg,#38bdf8,transparent 60%); }
.fstep:nth-child(2) .ico { color: #7c8dff; }
.fstep:nth-child(2) .ico .num { background: linear-gradient(135deg,#5b8dff,#7c5cff); }
.fstep:nth-child(2) .ico::before { background: linear-gradient(160deg,#7c8dff,transparent 60%); }
.fstep:nth-child(4) .ico { color: #3ddc97; }
.fstep:nth-child(4) .ico .num { background: linear-gradient(135deg,#3ddc97,#22c55e); color: #04231a; }
.fstep:nth-child(4) .ico::before { background: linear-gradient(160deg,#3ddc97,transparent 60%); }

/* Paso "objetivo" destacado (dorado, con pulso premium) */
.goalstep { position: relative; }
.goalstep .step-flag { position: absolute; top: -34px; left: 50%; transform: translateX(-50%); white-space: nowrap;
  font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: 0.1em; text-transform: uppercase; color: #3a2600;
  background: linear-gradient(135deg,#f5c45e,#f59e0b); border-radius: 100px; padding: 5px 12px;
  box-shadow: 0 8px 20px -8px rgba(245,196,94,0.55); }
.goalstep .ico { color: #f5c45e; box-shadow: 0 0 42px -6px rgba(245,196,94,0.5), var(--shadow); animation: goalpulse 2.6s ease-in-out infinite; }
.goalstep .ico .num { background: linear-gradient(135deg,#f5c45e,#f59e0b); color: #3a2600; }
.goalstep .ico::before { background: linear-gradient(160deg,#f5c45e,transparent 55%); }
.goalstep h4 { color: #f5c45e; }
@keyframes goalpulse { 50% { box-shadow: 0 0 60px -2px rgba(245,196,94,0.7), var(--shadow); transform: scale(1.03); } }

/* Gráfico de evolución */
.growth { border: 1px solid var(--line-2); border-radius: var(--r-lg); box-shadow: var(--shadow);
  background: linear-gradient(180deg, rgba(13,19,36,0.7), rgba(5,7,15,0.55)); backdrop-filter: blur(8px); padding: 26px 30px 22px; overflow: hidden; }
.growth-head { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 10px; }
.growth-head h3 { font-size: 1.18rem; }
.growth-tag { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent-2);
  border: 1px solid var(--line-2); border-radius: 100px; padding: 5px 12px; }
.growth-chart svg { width: 100%; height: auto; display: block; }
.growth-axis { display: grid; grid-template-columns: repeat(4, 1fr); margin-top: 8px; }
.growth-axis span { font-family: var(--font-mono); font-size: 0.74rem; color: var(--mute); text-align: center; }

@media (max-width: 820px) {
  .flow-steps { grid-template-columns: repeat(2, 1fr); gap: 28px 16px; }
  .flow-line { display: none; }
  .growth-axis { grid-template-columns: repeat(4, 1fr); }
  .growth-axis span { font-size: 0.64rem; }
}

/* ---------- Camino (journey) con movimiento ---------- */
.journey { position: relative; display: grid; grid-template-columns: repeat(4, 1fr); gap: 26px; margin: 58px 0 50px; }
.journey-line { position: absolute; top: 35px; left: 9%; right: 9%; height: 2px; border-radius: 2px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2)); opacity: 0.28; }
.journey-line::after { content: ""; position: absolute; top: -1px; left: 0; width: 130px; height: 4px; border-radius: 4px;
  background: linear-gradient(90deg, transparent, var(--accent-2), #fff, var(--accent-2), transparent); filter: blur(0.5px);
  box-shadow: 0 0 14px var(--accent-2); animation: travel 4.5s var(--ease) infinite; }
@keyframes travel { 0% { transform: translateX(0); opacity: 0; } 12% { opacity: 1; } 86% { opacity: 1; }
  100% { transform: translateX(calc(100% - 130px)); opacity: 0; } }
.jstep { text-align: center; position: relative; z-index: 1; }
.jnode { width: 72px; height: 72px; margin: 0 auto 22px; border-radius: 20px; display: grid; place-items: center;
  font-family: var(--font-mono); font-weight: 600; font-size: 1.15rem; color: var(--accent-2);
  background: var(--panel); border: 1px solid var(--line-2); position: relative; backdrop-filter: blur(8px);
  animation: floaty 5s var(--ease) infinite; }
.jstep:nth-child(2) .jnode { animation-delay: .4s; } .jstep:nth-child(3) .jnode { animation-delay: .8s; } .jstep:nth-child(4) .jnode { animation-delay: 1.2s; }
.jnode::before { content: ""; position: absolute; inset: -7px; border-radius: 26px; border: 1px solid var(--accent); opacity: 0; animation: ring 3s ease-out infinite; }
.jstep:nth-child(2) .jnode::before { animation-delay: .75s; } .jstep:nth-child(3) .jnode::before { animation-delay: 1.5s; } .jstep:nth-child(4) .jnode::before { animation-delay: 2.25s; }
@keyframes ring { 0% { transform: scale(0.92); opacity: 0.7; } 100% { transform: scale(1.32); opacity: 0; } }
.jstep.dest .jnode { background: var(--grad); color: #04122e; box-shadow: 0 0 46px var(--glow); border-color: transparent; }
.jstep .lbl { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--mute); display: block; margin-bottom: 7px; }
.jstep h4 { font-size: 1.02rem; margin-bottom: 6px; font-weight: 600; }
.jstep p { color: var(--dim); font-size: 0.87rem; }

/* Salidas / outcomes */
.outcomes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.outcome { position: relative; border: 1px solid var(--line); border-radius: var(--r); background: var(--glass);
  padding: 32px; backdrop-filter: blur(8px); overflow: hidden;
  transition: transform var(--t) var(--ease), border-color var(--t), box-shadow var(--t); }
.outcome::before { content: ""; position: absolute; inset: 0; background: radial-gradient(300px 180px at 50% 0%, var(--glow), transparent 70%); opacity: 0; transition: opacity var(--t); }
.outcome:hover { border-color: var(--line-2); box-shadow: var(--shadow); }
.outcome:hover::before { opacity: 1; }
.outcome .icon { width: 48px; height: 48px; border-radius: 13px; display: grid; place-items: center; margin-bottom: 20px; color: #04122e; background: var(--grad); box-shadow: 0 10px 26px -10px var(--glow); }
.outcome h3 { font-size: 1.18rem; margin-bottom: 9px; }
.outcome p { color: var(--dim); font-size: 0.94rem; }

/* ---------- Revelado ---------- */
.reveal { opacity: 0; transform: translateY(34px); filter: blur(8px);
  transition: opacity var(--t-slow) var(--ease-out), transform var(--t-slow) var(--ease-out), filter var(--t-slow) var(--ease-out); }
.reveal.in { opacity: 1; transform: none; filter: none; }
.reveal[data-delay="1"] { transition-delay: 0.08s; } .reveal[data-delay="2"] { transition-delay: 0.16s; }
.reveal[data-delay="3"] { transition-delay: 0.24s; } .reveal[data-delay="4"] { transition-delay: 0.32s; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .reveal { opacity: 1; transform: none; filter: none; } .aurora { display: none; }
  .preview { transform: none; } .candle { opacity: 0.95; transform: none; }
}

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .stats { grid-template-columns: repeat(2, 1fr); }
  .portfolio { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 920px) {
  .nav-links { display: none; }
  .nav-toggle { display: block; }
  .grid-3, .grid-2, .plans { grid-template-columns: 1fr; }
  .compare { grid-template-columns: 1fr; }
  .showcase-grid { grid-template-columns: 1fr; gap: 36px; }
  .showcase-grid.reverse .showcase-text { order: 0; }
  .mock { grid-template-columns: 1fr; } .mock-left { border-right: 0; border-bottom: 1px solid var(--line); }
  .footer-legal { flex-direction: column; }
}
