/* ============================================================================
   COMPONENTS — header, botones, tarjetas, badges, footer
   ========================================================================== */

/* --- Header / nav --- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: var(--glass-bg-strong);
  backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
  border-bottom: 1px solid var(--glass-border);
  box-shadow: var(--shadow-md);
}
.site-header .container { display: flex; align-items: center; gap: var(--sp-5); height: 66px; }
.brand { display: flex; align-items: center; gap: .6rem; font-family: var(--font-display); font-weight: 800; font-size: 1.25rem; color: var(--c-text); }
.brand .chip-logo { width: 28px; height: 28px; color: var(--c-gold); }
.brand b { color: var(--c-gold); }
.nav { display: flex; gap: var(--sp-5); margin-left: auto; align-items: center; }
.nav a { color: var(--c-text-soft); font-size: var(--fs-sm); font-weight: 500; }
.nav a:hover, .nav a.active { color: var(--c-gold); }
.wallet {
  display: inline-flex; align-items: center; gap: .45rem;
  background: var(--glass-bg); backdrop-filter: blur(8px);
  border: 1px solid rgba(30,144,255,.5); box-shadow: var(--glass-hi);
  color: var(--c-gold-soft); padding: .4rem .8rem; border-radius: var(--r-pill);
  font-weight: 700; font-size: var(--fs-sm); font-family: var(--font-mono);
}
.wallet .wallet-coupons { font-family: var(--font-body); font-size: var(--fs-xs); font-weight: 700;
  background: var(--c-gold); color: var(--c-on-gold); padding: 0 .35rem; border-radius: var(--r-pill); margin-left: .15rem; }
.pase-chip { display: inline-flex; align-items: center; font-size: var(--fs-xs); font-weight: 700;
  padding: .3rem .6rem; border-radius: var(--r-pill); background: color-mix(in srgb, var(--c-success) 18%, transparent);
  color: var(--c-success); border: 1px solid var(--c-success); white-space: nowrap; }

/* --- Auth: botón Entrar en header + modal --- */
.auth-btn {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .42rem .9rem; border-radius: var(--r-pill);
  background: var(--glass-bg); border: 1px solid var(--c-border-strong);
  color: var(--c-text); font-size: var(--fs-sm); font-weight: 600; cursor: pointer;
  transition: all .2s;
}
.auth-btn:hover { color: var(--c-gold); border-color: var(--c-gold-soft); transform: translateY(-1px); }
.auth-btn .auth-avatar {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--grad-gold); color: var(--c-on-gold);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800;
}

.auth-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(8, 12, 24, .6);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  display: grid; place-items: center; padding: var(--sp-4);
  opacity: 0; transition: opacity .2s;
}
.auth-overlay.open { opacity: 1; }
.auth-modal {
  position: relative; width: min(420px, 100%);
  background: var(--c-surface); border: 1px solid var(--c-border-strong);
  border-radius: var(--r-lg); box-shadow: 0 20px 60px rgba(0,0,0,.4);
  padding: var(--sp-6) var(--sp-5);
  transform: translateY(8px) scale(.98);
  transition: transform .25s cubic-bezier(.2,.8,.2,1);
}
.auth-overlay.open .auth-modal { transform: none; }
.auth-close {
  position: absolute; top: .5rem; right: .5rem;
  background: transparent; border: 0; cursor: pointer;
  width: 32px; height: 32px; border-radius: 50%;
  color: var(--c-text-muted); font-size: 22px; line-height: 1;
}
.auth-close:hover { color: var(--c-text); background: var(--c-surface-2); }
.auth-tabs {
  display: flex; gap: .25rem; margin-bottom: var(--sp-4);
  background: var(--c-surface-2); border-radius: var(--r-pill); padding: 4px;
}
.auth-tab {
  flex: 1; padding: .5rem 1rem; border-radius: var(--r-pill); border: 0;
  background: transparent; color: var(--c-text-soft); font-weight: 600; cursor: pointer;
  font-size: var(--fs-sm); transition: all .2s;
}
.auth-tab.active { background: var(--c-bg); color: var(--c-text); box-shadow: var(--shadow-sm); }
.auth-h { font-size: var(--fs-lg); margin: 0 0 var(--sp-4); text-align: center; }
.auth-google {
  width: 100%; display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  padding: .7rem 1rem; border-radius: var(--r-pill); cursor: pointer;
  background: #fff; color: #1f1f1f; border: 1px solid #d1d5db; font-weight: 600;
  font-size: var(--fs-sm); transition: box-shadow .2s, transform .15s;
}
.auth-google:hover { box-shadow: 0 4px 12px rgba(0,0,0,.12); transform: translateY(-1px); }
.auth-sep {
  display: flex; align-items: center; gap: .6rem; margin: var(--sp-4) 0;
  color: var(--c-text-muted); font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: .1em;
}
.auth-sep::before, .auth-sep::after { content: ""; flex: 1; height: 1px; background: var(--c-border); }
.auth-form { display: flex; flex-direction: column; gap: var(--sp-3); }
.auth-row2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
@media (max-width: 420px) { .auth-row2 { grid-template-columns: 1fr; } }
.auth-field { display: flex; flex-direction: column; gap: .25rem; }
.auth-field span { font-size: var(--fs-xs); color: var(--c-text-soft); font-weight: 600; }
.auth-field input {
  padding: .6rem .8rem; border-radius: var(--r-md);
  background: var(--c-bg-2); border: 1px solid var(--c-border-strong);
  color: var(--c-text); font-family: var(--font-body); font-size: var(--fs-md);
  transition: border-color .2s, box-shadow .2s;
}
.auth-field input:focus {
  outline: none; border-color: var(--c-gold);
  box-shadow: 0 0 0 3px rgba(37,99,235,.15);
}
.auth-err {
  margin: .25rem 0 0; padding: .5rem .8rem; border-radius: var(--r-sm);
  background: rgba(226,59,70,.08); border: 1px solid rgba(226,59,70,.3);
  color: var(--c-danger); font-size: var(--fs-sm);
}
.auth-link {
  background: transparent; border: 0; cursor: pointer; padding: 0; margin: .25rem auto 0;
  color: var(--c-gold-soft); font-size: var(--fs-sm); text-decoration: underline;
}

/* --- Theme toggle (sol/luna) --- */
.theme-toggle {
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--glass-bg); backdrop-filter: blur(8px);
  border: 1px solid var(--glass-border); color: var(--c-text-soft);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; transition: color .2s, border-color .2s, transform .2s;
}
.theme-toggle:hover { color: var(--c-gold); border-color: var(--c-gold-soft); transform: scale(1.05); }
.theme-toggle .theme-svg { width: 20px; height: 20px; display: block; }
/* Por defecto (light) mostramos LUNA (el modo al que vas). En dark, SOL. */
.theme-toggle .t-sun  { display: none; }
.theme-toggle .t-moon { display: inline; }
:root[data-theme="dark"] .theme-toggle .t-sun  { display: inline; }
:root[data-theme="dark"] .theme-toggle .t-moon { display: none; }

/* --- Badge de regalos (link a /premios/) --- */
.gift-cta {
  position: relative; display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: 50%;
  background: radial-gradient(circle at 50% 30%, rgba(255,93,162,.15), rgba(30,144,255,.08));
  border: 1px solid rgba(255,211,77,.25);
  transition: transform .2s, box-shadow .25s, border-color .25s;
}
.gift-cta:hover { transform: translateY(-1px) scale(1.05); border-color: rgba(255,211,77,.6);
  box-shadow: 0 0 20px rgba(255,93,162,.4), 0 4px 14px rgba(0,0,0,.4); }
.gift-cta .gift-svg { width: 24px; height: 24px; display: block; }
.gift-cta.has-spins { animation: giftBob 2.4s ease-in-out infinite; }
.gift-cta.has-spins::after {
  content: ""; position: absolute; inset: -3px; border-radius: 50%; pointer-events: none;
  box-shadow: 0 0 0 0 rgba(255,93,162,.55);
  animation: giftPulse 2.2s ease-out infinite;
}
.gift-cta.has-spins .gift-bow { transform-origin: 12px 5px; animation: giftBow 2.4s ease-in-out infinite; }
.gift-cta.has-spins .gift-ribbon { animation: giftShine 3s ease-in-out infinite; }
@keyframes giftBob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
@keyframes giftPulse {
  0% { box-shadow: 0 0 0 0 rgba(255,93,162,.55); }
  70% { box-shadow: 0 0 0 14px rgba(255,93,162,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,93,162,0); }
}
@keyframes giftBow { 0%,100% { transform: rotate(-3deg) scale(1); } 50% { transform: rotate(4deg) scale(1.08); } }
@keyframes giftShine { 0%,100% { filter: drop-shadow(0 0 0 rgba(255,211,77,0)); }
  50% { filter: drop-shadow(0 0 4px rgba(255,211,77,.7)); } }
@media (prefers-reduced-motion: reduce) {
  .gift-cta.has-spins, .gift-cta.has-spins::after, .gift-cta.has-spins .gift-bow, .gift-cta.has-spins .gift-ribbon { animation: none; }
}
.gift-badge {
  position: absolute; top: -4px; right: -4px; min-width: 18px; height: 18px; padding: 0 5px;
  border-radius: 9px; background: #e23b46; color: #fff; font-size: 11px; font-weight: 800;
  font-family: var(--font-body); display: inline-flex; align-items: center; justify-content: center;
  border: 2px solid var(--c-bg); box-shadow: 0 2px 6px rgba(0,0,0,.5);
}
:root[data-theme="dark"] .gift-badge { border-color: transparent; box-shadow: 0 0 0 2px rgba(255,255,255,.06), 0 2px 6px rgba(0,0,0,.5); }
.wallet .coin { width: 16px; height: 16px; }
.nav-toggle { display: none; background: none; border: 0; color: var(--c-text); font-size: 1.5rem; cursor: pointer; }

/* --- Botones --- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  font-family: var(--font-body); font-weight: 600; font-size: var(--fs-sm); letter-spacing: .01em;
  padding: .72rem 1.45rem; border-radius: var(--r-pill); border: 1px solid transparent;
  cursor: pointer; transition: transform .16s ease, box-shadow .25s ease, background-position .7s ease, border-color .25s, filter .2s; white-space: nowrap;
}
.btn:active { transform: translateY(1px) scale(.992); }

/* Estilo plano premium (Linear/Vercel/Stripe): color sólido, bisel mínimo,
   sombra contenida, sin barridos ni glows. */
.btn-gold {
  color: var(--c-on-gold);
  background: var(--c-gold);
  border-color: var(--c-gold-deep);
  box-shadow: 0 1px 2px rgba(15,23,42,.10);
}
.btn-gold:hover { background: #1d4ed8; box-shadow: 0 2px 4px rgba(15,23,42,.14); }
.btn-gold:active { background: #1e40af; box-shadow: 0 1px 1px rgba(15,23,42,.16) inset; }

.btn-ghost { background: transparent; border-color: var(--c-border-strong); color: var(--c-text); box-shadow: none; }
.btn-ghost:hover { background: var(--c-surface-2); border-color: var(--c-gold-soft); color: var(--c-gold); }
:root[data-theme="dark"] .btn-ghost { background: transparent; border-color: rgba(255,255,255,.22); color: var(--c-text); }
:root[data-theme="dark"] .btn-ghost:hover { background: rgba(255,255,255,.05); border-color: rgba(147,197,253,.55); color: var(--c-gold-soft); }

.btn-felt { background: var(--c-felt); color: #fff; border-color: var(--c-felt-dark); box-shadow: 0 1px 2px rgba(0,0,0,.18); }
.btn-felt:hover { background: var(--c-felt-light); }

.btn-sm { padding: .48rem .95rem; font-size: var(--fs-xs); }
.btn-lg { padding: .92rem 1.9rem; font-size: var(--fs-md); }
.btn:disabled { opacity: .45; cursor: not-allowed; transform: none; filter: none; }

/* --- Enlace "volver" en simuladores --- */
.sim-back { display: inline-flex; align-items: center; gap: .35rem; margin-bottom: var(--sp-2);
  font-size: var(--fs-sm); color: var(--c-text-muted); }
.sim-back:hover { color: var(--c-gold); }
.sim-back [data-ic] { display: inline-flex; transform: rotate(90deg); }

/* --- Tarjetas --- */
.card {
  background: var(--glass-bg);
  backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border); border-radius: var(--r-lg);
  padding: var(--sp-5); box-shadow: var(--shadow-glass); position: relative; overflow: hidden;
  transition: transform .2s, border-color .2s, box-shadow .2s;
}
.card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 45%;
  background: linear-gradient(180deg, rgba(255,255,255,.07), transparent); pointer-events: none; }
.card:hover { transform: translateY(-5px); border-color: color-mix(in srgb, var(--c-gold) 50%, transparent);
  box-shadow: var(--shadow-md), 0 0 0 1px color-mix(in srgb, var(--c-gold) 22%, transparent), var(--glass-hi); }
.card h3 { margin-bottom: var(--sp-2); }
.card .icon { font-size: 2rem; margin-bottom: var(--sp-3); display: inline-flex; color: var(--c-gold); }
.card-link::after { content: "→"; margin-left: .4rem; color: var(--c-gold); }

/* --- Badges / pills --- */
.badge { display: inline-block; font-size: var(--fs-xs); font-weight: 700; padding: .2rem .6rem; border-radius: var(--r-pill); letter-spacing: .04em; }
.badge-free { background: rgba(46,204,113,.15); color: var(--c-success); border: 1px solid rgba(46,204,113,.4); }
.badge-premium { background: color-mix(in srgb, var(--c-gold) 14%, transparent); color: var(--c-gold-soft); border: 1px solid var(--c-gold-deep); }
.badge-soon { background: var(--c-surface-2); color: var(--c-text-muted); border: 1px solid var(--c-border); }

/* --- Hero --- */
.hero { position: relative; overflow: hidden; min-height: 82vh; display: flex; align-items: center; padding-block: var(--sp-8);
  /* fade-out inferior para que no se vea "corte" al pasar a la siguiente sección */
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 88%, transparent 100%);
          mask-image: linear-gradient(to bottom, #000 0%, #000 88%, transparent 100%);
}
.hero::before { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(90deg, rgba(247,249,253,.85) 0%, rgba(247,249,253,.45) 42%, transparent 72%); }
:root[data-theme="dark"] .hero::before {
  background: linear-gradient(90deg, rgba(10,20,40,.85) 0%, rgba(10,20,40,.4) 42%, transparent 72%);
}
:root[data-theme="dark"] .hero-orb-a { background: radial-gradient(closest-side, #2563eb, transparent 70%); opacity: .35; }
:root[data-theme="dark"] .hero-orb-b { background: radial-gradient(closest-side, #0ea5e9, transparent 72%); opacity: .35; }
/* Orbes abstractos suaves en el hero (sustituyen a la gráfica de antes) */
.hero-orbs { position: absolute; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.hero-orb { position: absolute; border-radius: 50%; filter: blur(70px); opacity: .55; }
.hero-orb-a { width: 520px; height: 520px; right: -6%; top: -12%;
  background: radial-gradient(closest-side, #93c5fd, transparent 70%);
  animation: orbFloatA 16s ease-in-out infinite; }
.hero-orb-b { width: 380px; height: 380px; right: 18%; bottom: -8%;
  background: radial-gradient(closest-side, #7dd3fc, transparent 72%);
  animation: orbFloatB 22s ease-in-out infinite; }
@keyframes orbFloatA { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-2%, 3%) scale(1.04); } }
@keyframes orbFloatB { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(3%, -4%) scale(.96); } }
@media (prefers-reduced-motion: reduce) { .hero-orb-a, .hero-orb-b { animation: none; } }
.hero-inner { position: relative; z-index: 2; }
.hero-text { max-width: 60ch; }
.hero-text h1 { font-size: var(--fs-hero); max-width: 15ch; }
.hero-text p.lead { font-size: var(--fs-lg); color: var(--c-text-soft); max-width: 52ch; margin-top: var(--sp-4); }
.hero .cta-row { margin-top: var(--sp-6); display: flex; gap: var(--sp-4); flex-wrap: wrap; }

/* badges de stats flotantes */
.hero-badges { position: absolute; inset: 0; z-index: 2; pointer-events: none; }
.hero-badge { position: absolute; display: inline-flex; align-items: center; gap: .45rem;
  background: var(--glass-bg); backdrop-filter: blur(10px); border: 1px solid var(--glass-border);
  border-radius: var(--r-pill); padding: .45rem .85rem; font-size: var(--fs-sm); color: var(--c-text-soft);
  box-shadow: var(--shadow-glass); animation: floaty 6s ease-in-out infinite; white-space: nowrap; }
.hero-badge b { color: var(--c-gold); font-family: var(--font-mono); }
.hero-badge b.pos { color: var(--c-success); }
.hero-badge.b1 { top: 16%; right: 7%; animation-delay: 0s; }
.hero-badge.b2 { top: 33%; right: 24%; animation-delay: 1.1s; }
.hero-badge.b3 { top: 30%; right: 5%; animation-delay: .5s; }
.hero-badge.b4 { top: 50%; right: 16%; animation-delay: 1.7s; }
@keyframes floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }

@media (max-width: 820px) {
  .hero { min-height: 88vh; }
  .hero-text h1, .hero-text p.lead { max-width: none; }
  .hero-badge.b2, .hero-badge.b4 { display: none; }
  .hero-badge.b1 { top: 9%; right: 5%; }
  .hero-badge.b3 { top: 18%; right: 6%; }
}

/* Texto con brillo dorado */
.shimmer {
  /* En modo claro: degradado azul→cian→azul que se desliza. Contraste OK sobre blanco. */
  background: linear-gradient(100deg, #1d4ed8, #2563eb 38%, #38bdf8 50%, #2563eb 62%, #1d4ed8);
  background-size: 220% auto; -webkit-background-clip: text; background-clip: text; color: transparent;
  animation: shimmer 4.5s linear infinite;
}
@keyframes shimmer { to { background-position: 220% center; } }
@media (prefers-reduced-motion: reduce) { .shimmer { animation: none; } }

/* --- Footer --- */
.site-footer { border-top: 1px solid var(--c-border-strong); margin-top: var(--sp-10); background: var(--c-bg-2); box-shadow: 0 -1px 0 rgba(15,23,42,.04); }
:root[data-theme="dark"] .site-footer { box-shadow: 0 -1px 0 rgba(255,255,255,.04); }
.site-footer .container { padding-block: var(--sp-6); }
.site-footer .cols { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: var(--sp-6); }
.site-footer a { color: var(--c-text-soft); font-size: var(--fs-sm); display: block; padding: .2rem 0; }
.disclaimer { margin-top: var(--sp-5); padding-top: var(--sp-4); border-top: 1px solid var(--c-border); font-size: var(--fs-xs); color: var(--c-text-muted); }
@media (max-width: 820px){ .site-footer .cols { grid-template-columns: 1fr; } }

/* --- CTAs de afiliado (alta conversión) --- */
.aff-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--sp-5); margin-top: var(--sp-5); }
.aff-card { position: relative; display: flex; flex-direction: column; gap: var(--sp-3);
  background: var(--glass-bg); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border); border-top: 3px solid var(--bc); border-radius: var(--r-lg);
  padding: var(--sp-5); box-shadow: var(--shadow-glass); transition: transform .2s, box-shadow .2s; }
.aff-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
.aff-top { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
.aff-logo { font-family: var(--font-display); font-weight: 800; font-size: 1.5rem; color: var(--bc); filter: brightness(1.35); }
.aff-logo svg { height: 1.35em; width: auto; display: inline-block; vertical-align: middle;
  color: var(--c-text); /* currentColor en wordmarks: contraste AA en ambos temas */ }
.aff-logo:has(svg) { filter: none; }
.aff-tag { flex: none; white-space: nowrap; font-size: var(--fs-xs); color: var(--c-text-soft);
  background: var(--c-surface-2); border: 1px solid var(--c-border); border-radius: var(--r-pill); padding: .18rem .7rem; }
.aff-card h3 { font-size: var(--fs-lg); }
.aff-points { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .35rem; }
.aff-points li { display: flex; align-items: center; gap: .5rem; font-size: var(--fs-sm); color: var(--c-text-soft); }
.aff-points .ico { color: var(--c-success); flex: none; }
.aff-btn { margin-top: auto; width: 100%; }
.aff-legal { font-size: .7rem; color: var(--c-text-muted); margin: 0; }

/* Anuncio grande (banner ancho premium) */
.aff-ad { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-5); flex-wrap: wrap;
  position: relative; overflow: hidden;
  background:
    linear-gradient(100deg, color-mix(in srgb, var(--bc) 26%, transparent), transparent 60%),
    var(--glass-bg-strong);
  backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border); border-left: 5px solid var(--bc);
  border-radius: var(--r-lg); padding: var(--sp-5) var(--sp-6); box-shadow: var(--shadow-glass);
  transition: transform .18s, box-shadow .18s; }
.aff-ad::after { content: ""; position: absolute; right: -10%; top: -50%; width: 40%; height: 200%;
  background: radial-gradient(closest-side, color-mix(in srgb, var(--bc) 40%, transparent), transparent); filter: blur(30px); pointer-events: none; }
.aff-ad:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.aff-ad-main { display: flex; align-items: center; gap: var(--sp-5); position: relative; z-index: 1; }
.aff-logo-xl { font-size: 2.4rem; line-height: 1; }
.aff-ad-kicker { display: block; font-size: var(--fs-xs); letter-spacing: .12em; text-transform: uppercase; color: var(--c-gold-soft); font-weight: 700; }
.aff-ad-txt h3 { font-size: var(--fs-xl); margin: .15rem 0; color: var(--c-text); }
.aff-ad-txt p { font-size: var(--fs-sm); color: var(--c-text-soft); margin: 0; }
.aff-ad-btn { position: relative; z-index: 1; }
@media (max-width: 640px) { .aff-ad-main { flex-direction: column; align-items: flex-start; gap: var(--sp-3); } .aff-ad-btn { width: 100%; } }

.aff-banner { display: flex; align-items: center; gap: var(--sp-4);
  background: var(--glass-bg); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur);
  border: 1px solid var(--glass-border); border-left: 4px solid var(--bc); border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4); box-shadow: var(--shadow-glass); transition: transform .15s; }
.aff-banner:hover { transform: translateY(-2px); }
.aff-banner .aff-logo { font-size: 1.1rem; }
.aff-bmsg { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.aff-bmsg b { color: var(--c-text); font-size: var(--fs-sm); }
.aff-bmsg small { color: var(--c-text-muted); font-size: var(--fs-xs); }
.aff-banner .aff-go { margin-left: auto; white-space: nowrap; }
@media (max-width: 560px) { .aff-banner { flex-wrap: wrap; } .aff-banner .aff-go { margin-left: 0; } }

/* --- Página de workflow (n8n + Telegram) --- */
.wf-layout { display: grid; grid-template-columns: minmax(0, 1fr) 280px; gap: var(--sp-6); margin-top: var(--sp-5); align-items: start; }
.wf-side { position: sticky; top: 84px; display: flex; flex-direction: column; gap: var(--sp-3); }
@media (max-width: 940px) { .wf-layout { grid-template-columns: 1fr; } .wf-side { position: static; } }

/* --- Diagramas (Mermaid) --- */
/* Tarjeta SIEMPRE clara (también en dark) para que el texto oscuro de los
   nodos blancos de Mermaid se lea bien en ambos temas. */
.diagram { margin: var(--sp-6) calc(var(--sp-6) * -1); padding: var(--sp-6) var(--sp-5);
  text-align: center; overflow-x: auto;
  background: #f5f7fc; border: 1px solid #d7deec; border-radius: var(--r-lg);
  box-shadow: var(--glass-hi); }
/* No estirar: respetar el tamaño natural del SVG (evita el zoom excesivo en
   diagramas pequeños), solo limitar el ancho máximo y centrar. */
.diagram svg { max-width: 100%; height: auto; display: inline-block; margin-inline: auto; }
.diagram svg .node rect, .diagram svg .node polygon, .diagram svg .node circle { stroke-width: 1.4px; }
/* Forzar tinta oscura en TODO el texto del diagrama (las labels HTML heredan el
   color del tema y en dark salían blancas sobre los nodos blancos). */
.diagram text, .diagram tspan,
.diagram .nodeLabel, .diagram .edgeLabel, .diagram .label,
.diagram foreignObject div, .diagram foreignObject span,
.diagram .actor, .diagram .messageText, .diagram .loopText { color: #0f172a !important; fill: #0f172a !important; }
.diagram .edgeLabel, .diagram .edgeLabel rect, .diagram .edgeLabel foreignObject div { background-color: #f5f7fc !important; }
@media (max-width: 720px) {
  .diagram { margin-inline: calc(var(--sp-2) * -1); padding: var(--sp-4) var(--sp-3); }
}

/* --- Cupones (descuento ganado en la ruleta) --- */
.coupon-banner { display: flex; flex-wrap: wrap; gap: .5rem; align-items: center;
  padding: var(--sp-3) var(--sp-4); margin-bottom: var(--sp-4);
  background: color-mix(in srgb, var(--c-gold) 10%, var(--c-surface));
  border: 1px solid var(--c-gold-deep); border-radius: var(--r-md); font-size: var(--fs-sm); }
.coupon-chip { display: inline-flex; align-items: center; padding: .2rem .6rem; border-radius: var(--r-pill);
  background: var(--c-gold); color: var(--c-on-gold); font-weight: 700; font-size: var(--fs-xs); }

/* --- Orden de la rueda (fichas de números, sustituye al bloque de código) --- */
.wheel-order { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center;
  margin: var(--sp-5) 0; padding: var(--sp-4); border-radius: var(--r-lg);
  background: var(--glass-bg); border: 1px solid var(--glass-border); }
.wheel-order .wn { display: inline-flex; align-items: center; justify-content: center;
  min-width: 2em; height: 2em; padding: 0 .4em; border-radius: 999px;
  font-weight: 700; font-size: .95rem; font-variant-numeric: tabular-nums;
  color: #fff; box-shadow: 0 1px 2px rgba(0,0,0,.25); }
.wheel-order .wn.red   { background: #c0392b; }
.wheel-order .wn.black { background: #1f2733; }
.wheel-order .wn.green { background: #15723f; }

/* --- Glosario: términos con tooltip (funciona en toda la web) --- */
.term { border-bottom: 1px dotted var(--c-gold); cursor: help; position: relative; color: var(--c-gold-soft); font-weight: 600; }
.term .term-pop { position: absolute; left: 0; bottom: 135%; width: 270px; max-width: 80vw;
  background: var(--c-surface-2); color: var(--c-text); border: 1px solid var(--c-gold-deep); border-radius: var(--r-md);
  padding: .75rem .9rem; font-size: var(--fs-sm); font-weight: 400; line-height: 1.6; box-shadow: var(--shadow-md);
  opacity: 0; visibility: hidden; transform: translateY(6px); transition: opacity .18s, transform .18s; z-index: 40; pointer-events: none; }
.term:hover .term-pop, .term:focus-within .term-pop, .term.open .term-pop { opacity: 1; visibility: visible; transform: none; }

/* --- Entrada suave de página --- */
@media (prefers-reduced-motion: no-preference) {
  main { animation: pageIn .5s ease; }
  @keyframes pageIn { from { opacity: 0; } to { opacity: 1; } }
}

/* --- Toast (avisos de bits/ganancias) --- */
.toast-wrap { position: fixed; bottom: 20px; left: 50%; transform: translateX(-50%); z-index: 100; display: flex; flex-direction: column; gap: .5rem; align-items: center; }
.toast { background: var(--c-surface-2); border: 1px solid var(--c-gold-deep); color: var(--c-text); padding: .7rem 1.1rem; border-radius: var(--r-pill); box-shadow: var(--shadow-md); font-size: var(--fs-sm); animation: reveal .3s; }
.toast.win { border-color: var(--c-success); color: var(--c-success); }
.toast.lose { border-color: var(--c-danger); color: var(--c-danger); }

/* --- Nav responsive --- */
@media (max-width: 880px) {
  .nav { position: fixed; inset: 66px 0 auto 0; flex-direction: column; background: var(--c-bg-2); padding: var(--sp-5); border-bottom: 1px solid var(--c-border); display: none; }
  .nav.open { display: flex; }
  .nav-toggle { display: block; margin-left: auto; }
}
