/* =====================================================================
 * HiperXCAP Design System — fonte única para os 4 projetos do ecossistema
 * Espelha paypix-design-system.vercel.app/hiperxcap/
 * Carregar SEMPRE como último <link>/<style> do <head> para vencer
 * por ordem de fonte qualquer CSS legado dos arquivos individuais.
 * ===================================================================== */

/* ------- Tokens ------------------------------------------------------- */
:root {
  /* Primárias */
  --blue-500:   #0166B3;
  --blue-900:   #1A2F51;
  --blue-950:   #0C1628;
  --orange-500: #F39208;
  --orange-300: #F8AF4F;
  --gray-100:   #EEEEEE;

  /* Secundárias */
  --coral-500:    #EF7E5A;
  --coral-300:    #F4A495;
  --yellow-500:   #F0B909; /* SOMENTE gráficos — nunca vestimenta */
  --beige-500:    #DBC69E;
  --green-500:    #A7C945;
  --green-300:    #B6D37B;
  --teal-500:     #54BBAB;
  --lavender-500: #B4B3BC;
  --purple-500:   #B26F9A; /* erro/danger — substitui vermelho */
  --skyblue-500:  #9ED7EB;

  /* Neutros */
  --white: #FFFFFF;
  --black: #000000;

  /* Feedback semântico */
  --fb-success:    #A7C945;
  --fb-success-bg: rgba(167,201,69,0.12);
  --fb-danger:     #B26F9A;
  --fb-danger-bg:  rgba(178,111,154,0.14);
  --fb-warning:    #F39208;
  --fb-warning-bg: rgba(243,146,8,0.12);
  --fb-info:       #9ED7EB;
  --fb-info-bg:    rgba(158,215,235,0.14);
  --fb-special:    #EF7E5A;
  --fb-special-bg: rgba(239,126,90,0.14);

  /* Gradientes oficiais */
  --grad-blue:    linear-gradient(135deg, #0166B3 0%, #1A2F51 100%);
  --grad-orange:  linear-gradient(135deg, #F39208 0%, #F8AF4F 100%);
  --grad-deep:    linear-gradient(180deg, #1A2F51 0%, #0166B3 100%);
  --grad-special: linear-gradient(135deg, #B26F9A 0%, #EF7E5A 100%);

  /* Sombras e glows */
  --shadow-sm: 0 1px 3px rgba(0,0,0,0.10);
  --shadow-md: 0 4px 12px rgba(0,0,0,0.18);
  --shadow-lg: 0 8px 24px rgba(0,0,0,0.22);
  --glow-orange:    0 0 24px rgba(243,146,8,0.55), 0 0 48px rgba(243,146,8,0.20);
  --glow-orange-sm: 0 0 12px rgba(243,146,8,0.40);
  --glow-blue:      0 0 16px rgba(1,102,179,0.55);
  --glow-coral:     0 0 16px rgba(239,126,90,0.50);
  --glow-green:     0 0 14px rgba(167,201,69,0.50);
  --glow-purple:    0 0 16px rgba(178,111,154,0.50);

  /* Tipografia */
  --font-display: 'Bitner', 'Poppins', system-ui, -apple-system, sans-serif;
  --font-body:    'Poppins', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* Espaçamento 8pt */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  /* Raios — máximo 20px (regra DS) */
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;
  --r-xl: 20px;

  /* Easing */
  --ease-out:    cubic-bezier(0.2, 0.7, 0.2, 1);
  --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);

  /* ===== Aliases legados — mapeiam variáveis dos arquivos antigos
   * para tokens DS. Garante que qualquer var(...) já existente nos
   * 4 HTMLs receba a cor correta sem precisar editar cada uso. */
  --hxcap-blue-500:   var(--blue-500);
  --hxcap-blue-900:   var(--blue-900);
  --hxcap-orange-500: var(--orange-500);
  --hxcap-orange-300: var(--orange-300);
  --hxcap-green-500:  var(--green-500);
  --hxcap-coral-500:  var(--coral-500);
  --hxcap-purple-500: var(--purple-500);

  --pix-teal:        var(--orange-500);
  --pix-teal-light:  var(--orange-300);
  --gold:            var(--orange-500);
  --gold-bright:     var(--orange-300);
  --gold-deep:       var(--orange-500);
  --gold-pale:       var(--orange-300);
  --theme-color:     var(--orange-500);
  --success:         var(--green-500);
  --danger:          var(--purple-500);    /* RED → PURPLE per DS */
  --wa-green:        var(--green-500);

  /* Cores neutras compartilhadas pelos projetos */
  --muted:   #c7d6e8;
  --muted-2: #7e93b0;
  --line:    rgba(243,146,8,0.22);

  /* Gradientes legados → DS */
  --bg-grad: radial-gradient(ellipse at top, #1A2F51 0%, #0a2148 35%, #03152e 100%);
  --beam-color: rgba(243,146,8,0.20);
  --card-grad: linear-gradient(180deg, rgba(26,47,81,0.88) 0%, rgba(12,22,40,0.96) 100%);
  --scenario-grad: linear-gradient(135deg, rgba(26,47,81,0.85), rgba(12,22,40,0.92));
  --accent-border:      rgba(243,146,8,0.32);
  --accent-border-soft: rgba(243,146,8,0.20);
  --accent-glow:        rgba(243,146,8,0.45);
  --shadow-deep: 0 30px 60px rgba(0,0,0,0.6);

  /* Tokens herdados do totem antigo, agora apontam para DS */
  --spp-purple-deep: var(--blue-950);
  --spp-purple:      var(--blue-900);
  --spp-violet:      var(--blue-500);
}

/* ------- Reset leve + base ------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.5;
  color: var(--white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 800;
  margin: 0;
}

/* ------- Helpers globais --------------------------------------------- */
/* Cap de border-radius: nada acima de 20px (regra inegociável DS).
   Sobrescreve pílulas (999px) e cantos exagerados. */
.ds-radius-cap,
[class*="pill"]:not(.ds-allow-pill),
[style*="border-radius: 999"]:not(.ds-allow-pill),
[style*="border-radius:999"]:not(.ds-allow-pill) { border-radius: var(--r-xl) !important; }

/* Container utilitário */
.ds-container { max-width: 1280px; margin: 0 auto; padding: 0 var(--space-6); }

/* ------- Botões ------------------------------------------------------ */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--space-2);
  min-height: 48px;
  padding: 0 var(--space-6);
  border: none; border-radius: var(--r-md);
  font-family: var(--font-body); font-weight: 700; font-size: 16px;
  cursor: pointer; transition: transform .2s var(--ease-out), box-shadow .2s var(--ease-out), background .2s, color .2s;
  white-space: nowrap;
}
.btn--sm { min-height: 40px; padding: 0 var(--space-4); font-size: 14px; }
.btn--lg { min-height: 56px; padding: 0 var(--space-8); font-size: 18px; }
.btn--xl { min-height: 64px; padding: 0 var(--space-10); font-size: 20px; }
.btn-primary   { background: var(--grad-orange); color: var(--blue-950); box-shadow: var(--glow-orange-sm); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: var(--glow-orange); }
.btn-secondary { background: var(--blue-500); color: var(--white); }
.btn-secondary:hover { background: var(--blue-900); }
.btn-outline   { background: transparent; color: var(--orange-500); border: 2px solid var(--orange-500); }
.btn-outline:hover { background: rgba(243,146,8,0.10); }
.btn-success   { background: var(--green-500); color: var(--blue-950); }
.btn-danger    { background: var(--purple-500); color: var(--white); }
.btn-ghost     { background: transparent; color: var(--white); }
.btn-ghost:hover { background: rgba(255,255,255,0.08); }
.btn-link      { background: transparent; color: var(--orange-300); padding: 0; min-height: auto; text-decoration: underline; }
.btn--pulsing  { animation: ds-pulse 1.8s var(--ease-out) infinite; }
@keyframes ds-pulse {
  0%, 100% { box-shadow: var(--glow-orange-sm); }
  50%      { box-shadow: var(--glow-orange); transform: scale(1.02); }
}

/* ------- Cards ------------------------------------------------------- */
.demo-card           { background: var(--white); color: var(--blue-950); border-radius: var(--r-lg); padding: var(--space-6); box-shadow: var(--shadow-md); }
.demo-card--dark     { background: var(--blue-900); color: var(--white); }
.demo-card--neon     { background: var(--blue-900); color: var(--white); box-shadow: var(--glow-blue); }
.demo-card--premium  { background: var(--grad-deep); color: var(--white); }
.demo-card--prize    { background: var(--grad-orange); color: var(--blue-950); box-shadow: var(--glow-orange); }
.demo-card--featured { background: var(--grad-special); color: var(--white); }
.demo-card--coral    { background: var(--coral-500); color: var(--white); }
.demo-card--green    { background: var(--green-500); color: var(--blue-950); }
.demo-card--skyblue  { background: var(--skyblue-500); color: var(--blue-950); }
.demo-card--outline-dashed { background: transparent; border: 2px dashed var(--orange-300); color: var(--white); }

/* ------- Badges ------------------------------------------------------ */
.badge {
  display: inline-flex; align-items: center; gap: var(--space-1);
  padding: 4px var(--space-3);
  font-size: 12px; font-weight: 700; letter-spacing: .04em;
  border-radius: var(--r-sm);
  background: rgba(255,255,255,0.10); color: var(--white);
  text-transform: uppercase;
}
.badge--prize      { background: var(--grad-orange); color: var(--blue-950); }
.badge--live       { background: var(--coral-500); color: var(--white); }
.badge--new        { background: var(--coral-500); color: var(--white); }
.badge--social     { background: var(--green-500); color: var(--blue-950); }
.badge--featured   { background: var(--grad-special); color: var(--white); }
.badge--outline    { background: transparent; border: 1px solid var(--lavender-500); color: var(--white); }
.badge-dot { width: 8px; height: 8px; border-radius: 50%; background: currentColor; animation: ds-blink 1.2s ease-in-out infinite; }
@keyframes ds-blink { 0%,100% { opacity: 1; } 50% { opacity: .35; } }

/* ------- Alerts / Toasts -------------------------------------------- */
.alert {
  display: flex; align-items: flex-start; gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--r-md);
  background: var(--fb-info-bg); color: var(--white);
  border-left: 4px solid var(--fb-info);
}
.alert__icon    { width: 24px; height: 24px; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; }
.alert__title   { font-weight: 700; }
.alert__body    { font-size: 14px; opacity: .9; }
.alert--success { background: var(--fb-success-bg); border-left-color: var(--fb-success); }
.alert--danger  { background: var(--fb-danger-bg);  border-left-color: var(--fb-danger);  }
.alert--warning { background: var(--fb-warning-bg); border-left-color: var(--fb-warning); }
.alert--info    { background: var(--fb-info-bg);    border-left-color: var(--fb-info);    }
.alert--special { background: var(--fb-special-bg); border-left-color: var(--fb-special); }

/* ------- Inputs / Fields -------------------------------------------- */
.field { display: flex; flex-direction: column; gap: 6px; }
.field__label { font-size: 14px; font-weight: 600; color: var(--muted); }
.field__input {
  height: 52px;
  padding: 0 var(--space-4);
  font-family: var(--font-body); font-size: 16px;
  background: var(--white); color: var(--blue-950);
  border: 1.5px solid var(--lavender-500);
  border-radius: var(--r-md);
  outline: none; transition: border-color .15s, box-shadow .15s;
}
.field__input:focus { border-color: var(--orange-500); box-shadow: 0 0 0 4px rgba(243,146,8,0.18); }
.field__input--error { border-color: var(--purple-500); }
.field__hint  { font-size: 12px; color: var(--muted-2); }
.field__error { font-size: 12px; color: var(--purple-500); font-weight: 600; }

/* ------- Loadings --------------------------------------------------- */
.spinner {
  width: 28px; height: 28px;
  border: 3px solid rgba(243,146,8,0.18);
  border-top-color: var(--orange-500);
  border-radius: 50%;
  animation: ds-spin .9s linear infinite;
}
.spinner--blue { border-color: rgba(1,102,179,0.18); border-top-color: var(--blue-500); }
@keyframes ds-spin { to { transform: rotate(360deg); } }
.loading-dots { display: inline-flex; gap: 6px; }
.loading-dots span {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--orange-500);
  animation: ds-dots 1.2s ease-in-out infinite;
}
.loading-dots span:nth-child(2) { animation-delay: .15s; }
.loading-dots span:nth-child(3) { animation-delay: .3s; }
@keyframes ds-dots { 0%,80%,100% { transform: scale(.6); opacity: .4; } 40% { transform: scale(1); opacity: 1; } }
.skeleton {
  height: 14px; border-radius: var(--r-sm);
  background: linear-gradient(90deg, rgba(255,255,255,.06) 25%, rgba(255,255,255,.18) 50%, rgba(255,255,255,.06) 75%);
  background-size: 200% 100%;
  animation: ds-skel 1.4s ease-in-out infinite;
}
.skeleton--short { width: 40%; }
@keyframes ds-skel { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* ------- Cartela de dezenas ---------------------------------------- */
.cartela__grid {
  display: grid; grid-template-columns: repeat(5, minmax(44px,1fr));
  gap: var(--space-2);
}
.dezena {
  min-width: 44px; min-height: 44px;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.08); color: var(--white);
  font-family: var(--font-display); font-weight: 800; font-style: italic; font-size: 18px;
  border: 1px solid rgba(255,255,255,0.10);
}
.dezena.is-chosen { background: var(--orange-500); color: var(--blue-950); }
.dezena.is-drawn  { background: var(--blue-500);   color: var(--white); }
.dezena.is-hit    { background: var(--green-500);  color: var(--blue-950); box-shadow: var(--glow-green); }
.dezena.is-miss   { background: var(--purple-500); color: var(--white); opacity: .9; }

/* ------- Cupom / bilhete ------------------------------------------- */
.coupon {
  display: flex; align-items: stretch;
  background: var(--white); color: var(--blue-950);
  border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--shadow-md);
}
.coupon--dark     { background: var(--blue-900); color: var(--white); }
.coupon--gradient { background: var(--grad-orange); color: var(--blue-950); }
.coupon__stub { padding: var(--space-5); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; background: rgba(255,255,255,0.04); }
.coupon__stub-label { font-size: 11px; opacity: .7; letter-spacing: .1em; }
.coupon__stub-num   { font-family: var(--font-display); font-style: italic; font-weight: 800; font-size: 28px; color: var(--orange-300); }
.coupon__divider    { width: 1px; background: repeating-linear-gradient(0deg, rgba(255,255,255,.20) 0 6px, transparent 6px 12px); }
.coupon__body       { padding: var(--space-5); flex: 1; display: flex; flex-direction: column; gap: var(--space-2); }
.coupon__brand      { font-size: 12px; letter-spacing: .1em; opacity: .8; }
.coupon__value      { font-family: var(--font-display); font-style: italic; font-weight: 800; font-size: 28px; }
.coupon__meta       { display: flex; gap: var(--space-4); }
.coupon__meta-item  { display: flex; flex-direction: column; gap: 2px; }
.coupon__meta-label { font-size: 11px; opacity: .7; letter-spacing: .08em; }
.coupon__seal {
  position: absolute; top: 8px; right: 8px;
  font-size: 11px; padding: 2px 8px; border-radius: var(--r-sm);
  background: var(--orange-500); color: var(--blue-950); font-weight: 700;
}
.coupon__seal--new      { background: var(--coral-500); color: var(--white); }
.coupon__seal--featured { background: var(--grad-special); color: var(--white); }

/* ------- Live broadcast --------------------------------------------- */
.live-broadcast {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: 6px var(--space-3); border-radius: var(--r-sm);
  background: var(--coral-500); color: var(--white); font-weight: 700; font-size: 13px;
  text-transform: uppercase; letter-spacing: .08em;
}
.live-broadcast__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--white); animation: ds-blink 1.1s ease-in-out infinite; }

/* ------- Countdown -------------------------------------------------- */
.countdown__num {
  font-family: var(--font-display); font-style: italic; font-weight: 800;
  font-size: 44px; color: var(--orange-500);
  text-shadow: var(--glow-orange-sm);
  line-height: 1;
}
.countdown__num--sm { font-size: 18px; }
.countdown__sep     { color: var(--orange-300); font-weight: 700; }

/* ------- Reveal card ------------------------------------------------- */
.reveal-card {
  padding: var(--space-6); border-radius: var(--r-lg);
  background: rgba(255,255,255,0.05);
  color: var(--white); text-align: center;
}
.reveal-card--locked { border: 2px dashed var(--orange-500); }
.reveal-card--open   { background: rgba(167,201,69,0.18); border: 1px solid var(--green-500); }

/* ------- Stepper + qty picker -------------------------------------- */
.qty-picker { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-3); }
.qty-option {
  padding: var(--space-4);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(255,255,255,0.10);
  color: var(--white); text-align: center; cursor: pointer;
  transition: all .15s var(--ease-out);
}
.qty-option--active, .qty-option.active { background: var(--orange-500); color: var(--blue-950); border-color: var(--orange-500); box-shadow: var(--glow-orange-sm); }
.qty-chip { display: inline-block; padding: 2px 8px; font-size: 10px; font-weight: 700; border-radius: var(--r-sm); background: var(--coral-500); color: var(--white); text-transform: uppercase; }
.qty-chip--popular { background: var(--coral-500); }
.qty-chip--top     { background: var(--grad-orange); color: var(--blue-950); }
.stepper { display: inline-flex; align-items: center; gap: var(--space-3); }
.stepper__btn {
  width: 44px; height: 44px;
  border-radius: var(--r-md);
  border: 1.5px solid var(--orange-500);
  background: transparent; color: var(--orange-500);
  font-size: 22px; cursor: pointer;
}
.stepper__val { font-family: var(--font-display); font-style: italic; font-weight: 800; font-size: 28px; min-width: 48px; text-align: center; color: var(--white); }

/* ------- Número do título ------------------------------------------ */
.titulo-num {
  font-family: 'JetBrains Mono', 'IBM Plex Mono', ui-monospace, monospace;
  font-weight: 700; letter-spacing: .04em;
  display: inline-flex; align-items: baseline; gap: 2px;
}
.titulo-num--sm { font-size: 14px; }
.titulo-num--lg { font-size: 28px; }
.titulo-num__part--serie { color: var(--orange-500); }
.titulo-num__part--seq   { color: var(--skyblue-500); }

/* ------- Stack de prêmios ------------------------------------------ */
.premio-stack { display: flex; flex-direction: column; gap: var(--space-3); }
.premio-row {
  display: flex; align-items: center; gap: var(--space-4);
  padding: var(--space-4); border-radius: var(--r-md);
  background: var(--blue-900); color: var(--white);
}
.premio-row--gold   { background: var(--grad-orange); color: var(--blue-950); box-shadow: var(--glow-orange-sm); }
.premio-row--silver { background: linear-gradient(135deg, rgba(180,179,188,0.5), rgba(180,179,188,0.15)); }
.premio-row--base   { background: var(--blue-900); }
.premio-row__icon   { width: 40px; height: 40px; border-radius: var(--r-md); background: rgba(0,0,0,0.18); display: inline-flex; align-items: center; justify-content: center; }
.premio-row__info   { flex: 1; }
.premio-row__cat    { font-size: 12px; opacity: .8; text-transform: uppercase; letter-spacing: .08em; }
.premio-row__value  { font-family: var(--font-display); font-style: italic; font-weight: 800; font-size: 22px; }
.premio-row__badge  { padding: 2px 8px; border-radius: var(--r-sm); font-size: 11px; font-weight: 700; background: var(--coral-500); color: var(--white); }
.premio-row__badge--new   { background: var(--coral-500); }
.premio-row__badge--acum  { background: var(--skyblue-500); color: var(--blue-950); }
.premio-row__badge--multi { background: var(--orange-500); color: var(--blue-950); }

/* ------- Causa social ----------------------------------------------- */
.causa-card { background: var(--grad-special); color: var(--white); padding: var(--space-6); border-radius: var(--r-lg); }
.causa-stat { display: inline-flex; flex-direction: column; gap: 2px; padding: var(--space-3) var(--space-4); background: rgba(0,0,0,0.18); border-radius: var(--r-md); }

/* ===== Globais que vencem CSS legado ================================= */
/* Garante que TODOS os botões nativos não usem o vermelho proibido */
button { font-family: var(--font-body); }

/* Texto sobre fundo claro nunca pode ser claro (regra dark-first) */
.demo-card, .coupon:not(.coupon--dark):not(.coupon--gradient),
.demo-card--skyblue, .demo-card--green, .demo-card--prize { color: var(--blue-950); }
