/* =====================================================================
   REVEL DOGO 664 — Design System v2 (elevado)
   Fuente de verdad: assets/design-tokens.json
   Esencia: negro carbón + llama naranja + mostaza eléctrica · sticker · brasa.
   ===================================================================== */
:root{
  /* ---- Color ---- */
  --ink:#0E0D0C; --ink-2:#141210;
  --surface-1:#1A1714; --surface-2:#221D19; --surface-3:#2B2521;
  --line:#000; --hairline:rgba(255,255,255,.08);
  --flame:#FF7A1A; --flame-soft:rgba(255,122,26,.16); --ember:#E8590C;
  --mustard:#FFD21E; --bone:#FFF7EF; --ash:#B9B0A6; --char:#000;
  --blood:#E10600; --go:#36D399; --info:#FFB347;

  /* ---- Type ---- */
  --font-display:'Anton','Oswald',Impact,sans-serif;
  --font-body:'Inter',ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  /* ---- Space ---- */
  --s1:4px;--s2:8px;--s3:12px;--s4:16px;--s5:20px;--s6:24px;--s8:32px;--s10:40px;--s12:48px;--s16:64px;

  /* ---- Radius ---- */
  --r-xs:8px;--r-sm:10px;--r-md:14px;--r-lg:20px;--r-xl:28px;--r-pill:999px;

  /* ---- Shadow ---- */
  --sh-sticker:0 4px 0 #000;
  --sh-card:0 10px 30px -12px rgba(0,0,0,.7);
  --sh-lift:0 18px 50px -16px rgba(0,0,0,.85);
  --sh-glow:0 0 0 4px rgba(255,122,26,.18);

  /* ---- Motion ---- */
  --t-fast:120ms cubic-bezier(.2,.7,.3,1);
  --t-base:220ms cubic-bezier(.2,.7,.3,1);

  /* ---- Layout ---- */
  --page-max:1200px; --board-max:1320px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--ink);color:var(--bone);
  line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  min-height:100dvh;
}

/* ---- Fondo: ondas mostaza en movimiento + halo de brasa ---- */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='70'%3E%3Cpath d='M0 22 C20 4 40 4 60 22 S100 40 120 22' fill='none' stroke='%23FFD21E' stroke-width='2.2'/%3E%3C/svg%3E");
  background-size:120px 70px;background-repeat:repeat;opacity:.14;
  animation:waveRun 8s linear infinite;
}
body::after{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:radial-gradient(90% 60% at 50% -10%, var(--flame-soft) 0%, transparent 60%);
}
body>*{position:relative;z-index:1}
@keyframes waveRun{to{background-position:120px 0}}
@media (prefers-reduced-motion:reduce){body::before{animation:none}*{scroll-behavior:auto!important}}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--page-max);margin:0 auto;padding:0 var(--s5)}
.board{max-width:var(--board-max);margin:0 auto;padding:0 var(--s5)}

/* =====================  TIPOGRAFÍA / VOZ  ===================== */
.display{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  line-height:.74;letter-spacing:.05em;color:var(--flame)}
.eyebrow{font-family:var(--font-body);font-weight:600;text-transform:uppercase;
  font-size:13.5px;letter-spacing:.04em;color:var(--flame);
  display:inline-flex;align-items:center;gap:10px}
.section-title{font-family:var(--font-display);font-weight:700;text-transform:uppercase;
  color:var(--flame);line-height:.8;letter-spacing:.03em;font-size:clamp(44px,11vw,103px)}
.sticker{ -webkit-text-stroke:7px var(--line); paint-order:stroke fill; text-shadow:0 5px 16px rgba(0,0,0,.5)}
.muted{color:var(--ash)} .center{text-align:center}

/* =====================  TOPBAR  ===================== */
.nav{position:sticky;top:0;z-index:50;background:rgba(8,7,6,.86);backdrop-filter:blur(12px) saturate(1.1);
  -webkit-backdrop-filter:blur(12px) saturate(1.1);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px clamp(16px,4vw,28px);border-bottom:1px solid #232323}
.nav .brand{font-family:var(--font-display);color:var(--flame);
  font-size:clamp(18px,5vw,24px);letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}
.nav .brand b{color:var(--bone)}
.nav .links{display:flex;gap:16px;align-items:center}
.nav .links a:not(.btn){font-size:14px;font-weight:500;text-transform:uppercase;letter-spacing:.02em;color:var(--bone);transition:color var(--t-fast)}
.nav .links a:not(.btn):hover{color:var(--flame)}
@media(max-width:680px){.nav .links a:not(.btn){display:none}}

/* =====================  BOTONES  ===================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-body);font-weight:700;font-size:14px;text-transform:uppercase;
  letter-spacing:.02em;padding:12px 18px;border-radius:var(--r-md);
  border:1px solid transparent;cursor:pointer;line-height:1;
  transition:transform var(--t-fast),filter var(--t-fast),background var(--t-fast),border-color var(--t-fast)}
.btn:active{transform:translateY(1px) scale(.99)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(255,210,30,.55)}
.btn-primary{background:linear-gradient(180deg,#FF8A2E,var(--flame));color:var(--char);box-shadow:var(--sh-sticker)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-ghost{background:transparent;border-color:rgba(255,247,239,.35);color:var(--bone)}
.btn-ghost:hover{border-color:var(--flame);color:var(--flame)}
.btn-success{background:var(--go);color:#06281c;box-shadow:var(--sh-sticker)}
.btn-warn{background:var(--mustard);color:var(--char);box-shadow:var(--sh-sticker)}
.btn-danger{background:transparent;border-color:rgba(225,6,0,.6);color:#ff6a64}
.btn-danger:hover{background:rgba(225,6,0,.12)}
.btn-lg{font-size:16px;padding:15px 22px}
.btn-sm{font-size:12.5px;padding:9px 12px;border-radius:var(--r-sm)}
.btn-block{width:100%}
.btn[disabled]{opacity:.45;pointer-events:none}

/* =====================  PILLS / SEGMENTOS  ===================== */
.pill{font-family:var(--font-body);font-weight:600;font-size:14px;text-transform:uppercase;
  letter-spacing:.02em;padding:10px 16px;border-radius:var(--r-pill);
  border:1px solid rgba(255,255,255,.2);background:transparent;color:var(--ash);
  cursor:pointer;transition:var(--t-fast)}
.pill:hover{border-color:rgba(255,122,26,.6);color:var(--bone)}
.pill.active{background:var(--flame);color:var(--char);border-color:var(--flame)}
.seg{display:flex;gap:8px}.seg .pill{flex:1}

/* =====================  CARDS (glass)  ===================== */
.card{position:relative;background:linear-gradient(180deg,var(--surface-2),var(--surface-1));
  border:1px solid var(--hairline);border-radius:var(--r-lg);padding:var(--s5);box-shadow:var(--sh-card)}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06)}

/* =====================  CAMPOS  ===================== */
.field{width:100%;background:var(--ink-2);border:1px solid rgba(255,255,255,.14);
  color:var(--bone);border-radius:var(--r-md);padding:14px 15px;
  font-family:var(--font-body);font-size:16px;transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.field::placeholder{color:rgba(185,176,166,.7)}
.field:focus{outline:none;border-color:var(--flame);box-shadow:0 0 0 3px rgba(255,122,26,.18)}
label.lbl{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--ash);margin:0 0 6px 2px;font-weight:600}

/* =====================  TAGS / BADGES  ===================== */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;padding:4px 10px;border-radius:var(--r-pill);line-height:1}
.tag-flame{background:var(--flame);color:var(--char)}
.tag-mustard{background:var(--mustard);color:var(--char)}
.tag-go{background:var(--go);color:#06281c}
.tag-soft{background:transparent;border:1px solid rgba(185,176,166,.5);color:var(--ash)}
.tag-live{background:rgba(54,211,153,.14);color:var(--go);border:1px solid rgba(54,211,153,.45)}
.tag-demo{background:rgba(255,210,30,.14);color:var(--mustard);border:1px solid rgba(255,210,30,.45)}

/* =====================  MARQUEE  ===================== */
.marquee{background:var(--flame);color:var(--char);overflow:hidden;
  border-top:1px solid #000;border-bottom:1px solid #000;padding:8px 0}
.marquee .track{display:inline-flex;gap:28px;white-space:nowrap;animation:scrollx 22s linear infinite;
  font-family:var(--font-display);text-transform:uppercase;letter-spacing:.06em;font-size:18px}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =====================  TOAST  ===================== */
.toast-host{position:fixed;left:50%;bottom:calc(20px + env(safe-area-inset-bottom));transform:translateX(-50%);
  z-index:90;display:flex;flex-direction:column;gap:8px;align-items:center;width:max-content;max-width:92vw}
.toast{background:var(--surface-3);border:1px solid var(--line);color:var(--bone);
  border-radius:var(--r-pill);padding:11px 18px;font-size:14px;font-weight:600;box-shadow:var(--sh-lift);
  display:flex;align-items:center;gap:9px;animation:toastIn .22s cubic-bezier(.2,.7,.3,1)}
.toast.ok{border-color:rgba(54,211,153,.6)} .toast.warn{border-color:rgba(255,210,30,.6)}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* =====================  SPINNER / SKELETON  ===================== */
.spin{width:18px;height:18px;border-radius:50%;border:2.5px solid rgba(255,255,255,.2);border-top-color:var(--flame);animation:spin .7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* =====================  PULSO (nuevo)  ===================== */
@keyframes pulseFlame{0%,100%{box-shadow:0 0 0 0 rgba(255,122,26,.55)}50%{box-shadow:0 0 0 10px rgba(255,122,26,0)}}
.pulse{animation:pulseFlame 1.6s ease-out infinite}
