/* ===========================================================
   GRANJITA LA TINKA — Visual system
   Official Tinka palette · Verde + Amarillo + Crema
   (Brand manual 2025 V.2 · accessibility-checked contrast)
   =========================================================== */
:root{
  /* Deep-green surface scale anchored on the EXACT brand Verde #006820
     (manual 3.1). Darker steps for gradients; all carry white text >=4.6:1 */
  --navy-900:#00481A; --navy-850:#005A1E; --navy-800:#006820;
  --navy-700:#0A7A2C; --navy-600:#0E8C36; --navy-500:#22A24C;
  /* Interactive accent = brand Verde (links, eyebrows, focus → 7:1 on white) */
  --blue:#006820; --blue-400:#0E9A3E; --blue-200:#A6DDB4;
  /* Brand Rojo (secondary UI / alerts) */
  --red:#E5001F; --red-600:#B80019; --red-glow:rgba(229,0,31,.42);
  /* Brand Amarillo energy. --gold = vivid fill, --gold-2 = pure brand yellow
     (on dark only), --gold-ink = readable gold TEXT on light (5:1) */
  --gold:#FFCB00; --gold-2:#FFED00; --gold-ink:#8A6A00; --gold-soft:#FBF1C2;
  /* Brand Crema (manual 3.1 · exact) */
  --cream:#F5F0D4; --paper:#FFFFFF; --paper-2:#FBF9EC;
  /* Green-tinted ink (all body/muted pass AA on cream & white) */
  --ink:#13251A; --ink-2:#3A4A40; --muted:#5B6961; --muted-2:#879388;
  --line:rgba(19,37,26,.13); --line-2:rgba(19,37,26,.06);
  --win:#0C7A2E; --win-bg:#E3F3E7; --lose:#C0150D; --lose-bg:#FBEAE7;
  --pend:#8A5200; --pend-bg:#FAEFD5;
  --r-sm:8px; --r-md:14px; --r-lg:20px; --r-xl:28px;
  --sh-1:0 1px 2px rgba(7,28,15,.06), 0 2px 8px rgba(7,28,15,.05);
  --sh-2:0 6px 22px rgba(7,28,15,.10), 0 2px 6px rgba(7,28,15,.06);
  --sh-3:0 18px 50px rgba(4,21,11,.30);
  --ff-disp:"Sora",system-ui,sans-serif;
  --ff-body:"DM Sans",system-ui,sans-serif;
  --maxw:1240px;
  --scroll-thumb:rgba(0,104,32,.40); --scroll-thumb-hover:rgba(0,104,32,.66);
}
html[data-theme="dark"]{
  color-scheme:dark;
  --scroll-thumb:rgba(120,212,150,.34); --scroll-thumb-hover:rgba(120,212,150,.60);
  --cream:#05140B; --paper:#0B2113; --paper-2:#081A0E;
  --ink:#EAF4EC; --ink-2:#B8D0BE; --muted:#88A290; --muted-2:#5E7565;
  --line:rgba(255,255,255,.11); --line-2:rgba(255,255,255,.055);
  --blue:#3FC76A; --blue-400:#58D97F; --blue-200:#9FE0B2;
  --gold-ink:#E8C24E;
  --win:#2BC178; --win-bg:rgba(12,122,46,.18); --lose:#F0685A; --lose-bg:rgba(192,21,13,.20);
  --pend:#E8B23E; --pend-bg:rgba(138,82,0,.26);
  --gold-soft:rgba(255,203,0,.15);
  --sh-1:0 1px 2px rgba(0,0,0,.5), 0 2px 8px rgba(0,0,0,.35);
  --sh-2:0 8px 26px rgba(0,0,0,.5), 0 2px 6px rgba(0,0,0,.4);
  --sh-3:0 18px 50px rgba(0,0,0,.6);
}
html[data-theme="dark"] .tinka-chip{background:#fff}
html[data-theme="dark"] .barcode{background:#fff;border-radius:8px;padding:10px 12px}
html{transition:background .25s ease}
body,.card,.topbar,.footer,.btn-outline{transition:background-color .25s ease, border-color .25s ease}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--ff-body); color:var(--ink); background:var(--cream);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}

/* ---------- Brand scrollbars (Verde thumb · "slider" up/down) ---------- */
*{scrollbar-width:thin;scrollbar-color:var(--scroll-thumb) transparent}
*::-webkit-scrollbar{width:12px;height:12px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:var(--scroll-thumb);border-radius:999px;
  border:3px solid transparent;background-clip:content-box;transition:background .15s}
*::-webkit-scrollbar-thumb:hover{background:var(--scroll-thumb-hover);background-clip:content-box}
*::-webkit-scrollbar-thumb:active{background:var(--scroll-thumb-hover);background-clip:content-box}
*::-webkit-scrollbar-corner{background:transparent}
.tnum{font-variant-numeric:tabular-nums; font-feature-settings:"tnum" 1}
h1,h2,h3,h4{font-family:var(--ff-disp); margin:0; letter-spacing:-.02em; line-height:1.05}
a{color:inherit}
button{font-family:inherit;color:inherit}
::selection{background:var(--gold-soft)}

/* ---------- App shell ---------- */
.shell{min-height:100vh; display:flex; flex-direction:column; background:var(--cream)}
.wrap{width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px}

/* ---------- Top bar ---------- */
.topbar{position:sticky; top:0; z-index:40;
  background:linear-gradient(180deg,var(--navy-900),var(--navy-800));
  border-bottom:1px solid rgba(255,255,255,.07); color:#fff;
  box-shadow:0 8px 30px rgba(4,21,11,.18)}
.topbar .row{display:flex; align-items:center; gap:18px; height:66px}
.brand{display:flex; align-items:center; gap:11px; cursor:pointer; user-select:none}
.brand .mark{width:38px;height:38px;border-radius:11px;
  background:radial-gradient(120% 120% at 30% 20%, #ff5247, var(--red) 55%, var(--red-600));
  display:grid;place-items:center; box-shadow:0 4px 14px var(--red-glow), inset 0 1px 0 rgba(255,255,255,.3);
  position:relative}
.brand .mark svg{width:22px;height:22px}
.brand .name{font-family:var(--ff-disp);font-weight:800;font-size:18px;line-height:1;letter-spacing:-.01em}
.brand .name small{display:block;font-family:var(--ff-body);font-weight:600;font-size:10.5px;
  letter-spacing:.22em;color:var(--gold-2);margin-top:3px}
.nav{display:flex; gap:4px; margin-left:6px}
.nav a{display:flex;align-items:center;gap:7px;padding:9px 14px;border-radius:11px;
  font-weight:600;font-size:14px;color:#BCD3C2;cursor:pointer;border:1px solid transparent;
  transition:.16s; white-space:nowrap}
.nav a:hover{color:#fff;background:rgba(255,255,255,.06)}
.nav a.on{color:#fff;background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.14)}
.nav a svg{width:16px;height:16px;opacity:.85}
.topbar .spacer{flex:1}
.live-pill{display:flex;align-items:center;gap:9px;padding:6px 15px 6px 13px;border-radius:999px;flex:none;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);white-space:nowrap}
.live-pill-txt{display:flex;flex-direction:column;line-height:1.05}
.lp-lbl{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#A7C5B0}
.live-pill b{font-family:var(--ff-disp);font-weight:800;font-size:14.5px;color:#fff;letter-spacing:-.01em;margin-top:1px}
.live-dot{width:8px;height:8px;border-radius:50%;background:var(--win);box-shadow:0 0 0 0 rgba(22,163,91,.6);
  animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(22,163,91,.55)}70%{box-shadow:0 0 0 9px rgba(22,163,91,0)}100%{box-shadow:0 0 0 0 rgba(22,163,91,0)}}
.burger{display:none;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);
  color:#fff;border-radius:10px;width:40px;height:40px;cursor:pointer;align-items:center;justify-content:center}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;
  font-family:var(--ff-disp);font-weight:700;font-size:14px;border-radius:12px;padding:12px 20px;
  transition:.15s; letter-spacing:-.01em}
.btn:active{transform:translateY(1px)}
.btn-red{background:linear-gradient(180deg,#f23a30,var(--red));color:#fff;
  box-shadow:0 6px 18px var(--red-glow), inset 0 1px 0 rgba(255,255,255,.25)}
.btn-red:hover{filter:brightness(1.05)}
.btn-gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#4a3500;
  box-shadow:0 6px 18px rgba(255,203,0,.4), inset 0 1px 0 rgba(255,255,255,.5)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.18)}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-outline{background:var(--paper);color:var(--ink);border:1.5px solid var(--line)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue)}
.btn-lg{padding:15px 28px;font-size:15.5px;border-radius:14px}
.btn-sm{padding:8px 14px;font-size:13px;border-radius:10px}

/* ---------- Cards ---------- */
.card{background:var(--paper);border:1px solid var(--line-2);border-radius:var(--r-lg);box-shadow:var(--sh-1)}
.card-pad{padding:22px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:16px}
.section-head .eyebrow{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:6px}
.section-head h2{font-size:26px;font-weight:800}
.section-head p{margin:5px 0 0;color:var(--muted);font-size:14px}
.eyebrow-gold{color:var(--gold-ink)!important}

/* ---------- Animal visuals ---------- */
.an-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;
  font-family:var(--ff-disp);font-weight:800;color:#fff;line-height:1;flex:none;
  box-shadow:inset 0 2px 4px rgba(255,255,255,.25), inset 0 -3px 6px rgba(0,0,0,.18)}
.an-avatar{display:inline-block;border-radius:16px;overflow:hidden;flex:none;position:relative;
  background:radial-gradient(120% 110% at 50% 18%, var(--blue) 0%, #0A5C22 60%, #04340F 100%)}
.an-avatar img{width:100%;height:100%;object-fit:contain;object-position:center bottom;display:block;padding:6%}
.an-avatar.ph{display:grid;place-items:center}
.an-avatar .ph-num{font-family:var(--ff-disp);font-weight:800;color:#fff;opacity:.95;line-height:1}
.an-avatar .ph-name{position:absolute;bottom:6px;left:0;right:0;text-align:center;
  font-size:9px;font-weight:700;letter-spacing:.06em;color:rgba(255,255,255,.7);text-transform:uppercase}
.an-chip{display:inline-flex;align-items:center;gap:8px;padding:5px 11px 5px 5px;border-radius:999px;
  background:var(--paper);border:1px solid var(--line);font-weight:700;font-size:13px;box-shadow:var(--sh-1)}

/* ---------- Tables ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl th{text-align:left;font-family:var(--ff-disp);font-weight:700;font-size:11.5px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--muted);padding:11px 14px;border-bottom:1px solid var(--line)}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--line-2);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover{background:var(--paper-2)}
.tbl .rt{text-align:right}

/* ---------- Pills / tags ---------- */
.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;
  font-size:12px;font-weight:700;letter-spacing:.01em}
.tag-win{background:var(--win-bg);color:var(--win)}
.tag-lose{background:var(--lose-bg);color:var(--lose)}
.tag-pend{background:var(--pend-bg);color:var(--pend)}
.tag-blue{background:#E4F4E7;color:var(--blue)}
.tag-gold{background:var(--gold-soft);color:#8a6500}

/* ---------- Grid helpers ---------- */
.grid{display:grid;gap:18px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

/* ---------- Stat figure ---------- */
.figure{font-family:var(--ff-disp);font-weight:800;letter-spacing:-.03em;line-height:.95}
.kpi{padding:18px}
.kpi .lbl{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.kpi .val{font-family:var(--ff-disp);font-weight:800;font-size:30px;margin-top:8px;letter-spacing:-.02em}
.kpi .sub{font-size:12.5px;color:var(--muted);margin-top:4px}

/* bar */
.bar-track{height:8px;border-radius:999px;background:var(--line);overflow:hidden}
.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--blue-400))}

/* ---------- Countdown ---------- */
.cd-unit{display:flex;flex-direction:column;align-items:center}
.cd-box{font-family:var(--ff-disp);font-weight:800;letter-spacing:-.03em;color:#fff;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.14);border-radius:16px;
  display:grid;place-items:center;box-shadow:inset 0 1px 0 rgba(255,255,255,.18), 0 10px 30px rgba(0,0,0,.25);
  position:relative;overflow:hidden}
.cd-box::after{content:"";position:absolute;left:0;right:0;top:50%;height:1px;background:rgba(0,0,0,.25)}
.cd-sep{font-family:var(--ff-disp);font-weight:800;color:rgba(255,255,255,.45)}
.cd-lbl{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-200);margin-top:9px}

/* ---------- utility ---------- */
.muted{color:var(--muted)}
.mono{font-variant-numeric:tabular-nums;font-family:var(--ff-disp)}
.divider{height:1px;background:var(--line);margin:18px 0}
.scrollx{overflow-x:auto}
.hide{display:none!important}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .nav{display:none}
  .burger{display:flex}
  .g-4{grid-template-columns:repeat(2,1fr)}
  .g-3{grid-template-columns:1fr}
}
@media (max-width:680px){
  .wrap{padding:0 16px}
  .g-2,.g-4{grid-template-columns:1fr}
  .section-head h2{font-size:22px}
}

/* ---------- Hero ---------- */
.hero{position:relative;color:#fff;padding-top:40px;padding-bottom:22px;
  background:linear-gradient(180deg,var(--navy-800) 0%,var(--navy-850) 60%,var(--navy-900) 100%)}
.hero-bg{position:absolute;inset:0;height:100%;overflow:hidden;
  background:
    radial-gradient(900px 400px at 88% -10%, rgba(10,124,44,.55), transparent 60%),
    radial-gradient(700px 360px at 6% 8%, rgba(229,0,31,.30), transparent 60%);
  pointer-events:none}
.hero-bg::after{content:"";position:absolute;inset:0;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.10) 1px, transparent 1.4px);
  background-size:26px 26px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 75%);mask-image:linear-gradient(180deg,#000,transparent 75%)}
.hero-inner{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;padding-bottom:34px}
.hero-title{font-size:46px;font-weight:800;line-height:1.02;letter-spacing:-.03em;
  text-shadow:0 2px 20px rgba(0,0,0,.25)}
.hero-sub{margin:16px 0 0;font-size:15.5px;color:#B3CDBC;max-width:460px;line-height:1.55}
.hero-chips{display:flex;gap:10px;margin-top:26px;flex-wrap:wrap}
.hchip{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:13px;
  padding:11px 16px;display:flex;flex-direction:column;line-height:1.1}
.hchip b{font-family:var(--ff-disp);font-weight:800;font-size:21px;color:var(--gold-2)}
.hchip span{font-size:11.5px;color:#A7C5B0;font-weight:600;margin-top:3px}

.lastres{padding:20px;background:var(--paper)}
.lastres-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.lastres-body{display:flex;gap:18px;align-items:center}
.lastres-info{flex:1;min-width:0;color:var(--ink)}
.lastres-num{font-family:var(--ff-disp);font-weight:800;font-size:15px;color:var(--muted);letter-spacing:.04em}
.lastres-name{font-family:var(--ff-disp);font-weight:800;font-size:34px;letter-spacing:-.02em;line-height:1;margin-top:2px}
.lastres-win{display:flex;align-items:center;gap:7px;margin-top:12px;font-size:14.5px;color:var(--ink-2)}
.lastres-win b{font-size:18px}
.lastres-foot{display:flex;align-items:center;justify-content:space-between;margin-top:18px;
  padding-top:16px;border-top:1px solid var(--line)}
.lastres-foot .muted{display:block;font-size:11.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.lastres-foot b{font-family:var(--ff-disp);font-size:18px;color:var(--ink)}

.strip{margin-top:8px;padding:16px 18px;color:var(--ink);position:relative;z-index:2;
  box-shadow:0 -2px 0 rgba(255,255,255,.04), var(--sh-2)}
.strip-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;
  font-family:var(--ff-disp);font-weight:700;font-size:14px}
.strip-head .muted{font-weight:600;font-size:12.5px}
.strip-rail{display:flex;gap:10px;padding-bottom:4px}
.strip-cell{flex:none;width:74px;display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:10px 6px;border-radius:14px;border:1px solid var(--line-2);background:var(--paper-2)}
.strip-cell.latest{border-color:var(--gold);background:var(--gold-soft);box-shadow:0 4px 14px rgba(255,203,0,.25)}
.strip-cell.pend{opacity:.85;border-style:dashed}
.strip-hr{font-size:11px;font-weight:700;color:var(--muted)}
.strip-num{font-family:var(--ff-disp);font-weight:800;font-size:14px}
.strip-clock{width:50px;height:50px;display:grid;place-items:center;color:var(--muted-2);
  border-radius:13px;background:var(--paper);border:1px dashed var(--line)}

@media (max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:26px}
  .hero-left,.hero-right{min-width:0}
  .hero-title{font-size:34px}
}
@media (max-width:680px){
  .hero-title{font-size:28px}
  .lastres-name{font-size:26px}
  /* shrink live countdown so the hero never overflows narrow phones */
  .hero .cd-box{width:64px!important;height:72px!important;font-size:34px!important}
  .hero .cd-sep{font-size:28px!important}
}
@media (max-width:400px){
  .hero .cd-box{width:54px!important;height:62px!important;font-size:28px!important}
  .hero .cd-sep{font-size:22px!important}
}

/* ---------- Cinematic reveal ---------- */
.reveal{position:fixed;inset:0;z-index:90;display:flex;flex-direction:column;align-items:center;
  justify-content:flex-start;padding:30px 20px;overflow:hidden;
  background:radial-gradient(120% 100% at 50% 30%, #053A18 0%, #03250F 45%, #021A0A 100%);
  animation:revealIn .35s ease both}
@keyframes revealIn{from{opacity:0.55}to{opacity:1}}
.reveal-confetti{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:6}
.reveal-flash{position:absolute;inset:0;background:#fff;opacity:0;pointer-events:none;z-index:5}
.reveal-flash.on{animation:flash .6s ease-out}
@keyframes flash{0%{opacity:0}12%{opacity:.85}100%{opacity:0}}
.reveal-x{position:absolute;top:18px;right:18px;z-index:8;width:44px;height:44px;border-radius:12px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:#fff;cursor:pointer;
  display:grid;place-items:center}
.reveal-x:hover{background:rgba(255,255,255,.16)}
.reveal-top{position:relative;z-index:7;display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:6px}
.reveal-hour{color:#A7C5B0;font-size:14px;font-weight:600}
.reveal-stage{position:relative;z-index:7;flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;width:100%}
.reveal-cue{color:#cdd8ef;font-family:var(--ff-disp);font-weight:700;font-size:20px;margin-bottom:22px;
  letter-spacing:-.01em;animation:cuePulse 1.6s ease-in-out infinite}
@keyframes cuePulse{0%,100%{opacity:.7}50%{opacity:1}}

.reel-window{position:relative;width:200px;overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 22%,#000 78%,transparent);
  mask-image:linear-gradient(180deg,transparent,#000 22%,#000 78%,transparent)}
.reel-strip{display:flex;flex-direction:column;align-items:center;will-change:transform}
.reel-cell{display:flex;align-items:center;justify-content:center;width:100%}
.reel-marker{position:absolute;left:-8px;right:-8px;top:50%;height:172px;transform:translateY(-50%);
  border:2px solid rgba(255,203,0,.55);border-radius:30px;box-shadow:0 0 40px rgba(255,203,0,.25) inset;pointer-events:none}

.rays{position:absolute;width:760px;height:760px;border-radius:50%;z-index:-1;
  background:repeating-conic-gradient(from 0deg, color-mix(in srgb, var(--rc, #006820) 60%, #fff) 0deg 7deg, transparent 7deg 14deg);
  opacity:.20;animation:spinRays 16s linear infinite;
  -webkit-mask-image:radial-gradient(circle,#000 0%,transparent 62%);mask-image:radial-gradient(circle,#000 0%,transparent 62%)}
@keyframes spinRays{to{transform:rotate(360deg)}}

.win-card{display:flex;flex-direction:column;align-items:center;text-align:center;color:#fff}
.win-card.pop{animation:winPop .65s cubic-bezier(.2,1.5,.4,1) both}
.win-card.in{animation:winPop .5s cubic-bezier(.2,1.4,.4,1) both}
@keyframes winPop{0%{transform:scale(.5);opacity:.4}60%{opacity:1}100%{transform:scale(1);opacity:1}}
.win-avatar{filter:drop-shadow(0 24px 50px rgba(0,0,0,.5));position:relative}
.win-avatar::after{content:"";position:absolute;inset:-10px;border-radius:40px;
  box-shadow:0 0 0 3px rgba(255,255,255,.18), 0 0 60px 6px rgba(255,203,0,.4);pointer-events:none}
.win-num{font-family:var(--ff-disp);font-weight:800;color:var(--gold-2);font-size:17px;letter-spacing:.1em;margin-top:18px}
.win-name{font-family:var(--ff-disp);font-weight:800;font-size:54px;letter-spacing:-.03em;line-height:1;margin-top:4px;
  text-shadow:0 4px 30px rgba(0,0,0,.4)}
.win-stats{display:flex;align-items:center;gap:26px;margin-top:26px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);border-radius:18px;padding:18px 30px;
  animation:fadeUp .5s ease .15s both}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.ws{display:flex;flex-direction:column;align-items:center;gap:6px}
.ws-lbl{font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#A7C5B0}
.ws-val{font-family:var(--ff-disp);font-weight:800;font-size:30px;letter-spacing:-.02em;color:#fff}
.ws-div{width:1px;height:42px;background:rgba(255,255,255,.18)}
.reveal-actions{position:relative;z-index:7;display:flex;gap:12px;margin-bottom:8px;flex-wrap:wrap;justify-content:center;
  animation:fadeUp .5s ease .3s both}
@media (max-width:680px){
  .win-name{font-size:38px}
  .win-stats{gap:16px;padding:14px 18px}
  .ws-val{font-size:23px}
  .reel-window{width:170px}
}

/* ---------- Segmented control ---------- */
.seg{display:inline-flex;background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:4px;gap:2px;box-shadow:var(--sh-1)}
.seg button{border:none;background:none;cursor:pointer;font-family:var(--ff-disp);font-weight:700;font-size:13.5px;
  padding:8px 16px;border-radius:9px;color:var(--muted)}
.seg button.on{background:var(--navy-800);color:#fff}

/* ---------- Day tabs ---------- */
.daytabs{display:flex;gap:8px;margin:6px 0 22px;padding-bottom:4px}
.daytab{flex:none;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;
  background:var(--paper);border:1px solid var(--line);border-radius:13px;padding:10px 16px;min-width:74px}
.daytab .dt-dow{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--muted);letter-spacing:.06em}
.daytab .dt-day{font-family:var(--ff-disp);font-weight:700;font-size:14px}
.daytab.on{background:var(--navy-800);border-color:var(--navy-800)}
.daytab.on .dt-dow{color:var(--gold-2)}
.daytab.on .dt-day{color:#fff}

/* ---------- Results grid ---------- */
.res-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.res-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;text-align:center}
.res-card.pend{background:var(--paper-2);border-style:dashed}
.res-card-hr{width:100%;display:flex;align-items:center;justify-content:space-between;gap:6px;
  font-family:var(--ff-disp);font-weight:700;font-size:13px;color:var(--ink-2)}
.res-card-name{font-size:13px;font-weight:700;margin-top:2px}
.res-card-name b{color:var(--blue)}
.res-card-win{font-size:11.5px;color:var(--muted);font-weight:600}
.res-pending{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--muted-2);
  padding:18px 0;font-size:12px;font-weight:600}
.matriz td,.matriz th{white-space:nowrap}
.mtx-cell{display:inline-flex}
.mtx-pend{color:var(--muted-2);font-weight:700}
@media (max-width:1100px){.res-grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:680px){.res-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:420px){.res-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- Distribution chart ---------- */
.distchart{position:relative;display:flex;align-items:flex-end;gap:3px;height:200px;padding-top:18px}
.dist-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;min-width:0}
.dist-bar{width:100%;max-width:22px;border-radius:5px 5px 0 0;min-height:3px;transition:height .5s ease}
.dist-val{font-size:9.5px;font-weight:700;color:var(--muted);margin-bottom:3px}
.dist-lbl{font-size:9px;color:var(--muted-2);margin-top:5px;font-weight:600}
.dist-avg{position:absolute;left:0;right:0;border-top:1.5px dashed var(--red);opacity:.5}
.dist-avg span{position:absolute;right:0;top:-9px;font-size:9px;color:var(--red);font-weight:700;background:var(--paper);padding:0 4px}
@media (max-width:680px){.distchart{height:150px}.dist-val{display:none}.dist-lbl{font-size:7px}}

/* ---------- Ticket checker ---------- */
.ticket-search{padding:22px}
.ts-row{display:flex;gap:12px}
.ts-input{flex:1;display:flex;align-items:center;gap:10px;padding:0 16px;border:1.5px solid var(--line);
  border-radius:13px;background:var(--paper-2);color:var(--muted)}
.ts-input:focus-within{border-color:var(--blue);background:var(--paper)}
.ts-input input{flex:1;border:none;background:none;outline:none;font-family:var(--ff-disp);font-weight:700;
  font-size:17px;letter-spacing:.02em;color:var(--ink);padding:15px 0}
.ts-samples{display:flex;align-items:center;gap:8px;margin-top:14px;flex-wrap:wrap}
.ts-chip{border:1px solid var(--line);background:var(--paper);border-radius:999px;padding:6px 13px;cursor:pointer;
  font-family:var(--ff-disp);font-weight:700;font-size:12.5px;color:var(--blue);font-variant-numeric:tabular-nums}
.ts-chip:hover{border-color:var(--blue);background:#E9F6EC}

.ticket-detail{overflow:hidden}
.td-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:22px 24px;color:#fff}
.td-head.win{background:linear-gradient(120deg,#0f7a45,var(--win))}
.td-head.lose{background:linear-gradient(120deg,#26352B,#16201A)}
.td-head.pend{background:linear-gradient(120deg,#A86A00,#754700)}
.td-code{font-family:var(--ff-disp);font-weight:800;font-size:24px;letter-spacing:.02em}
.td-type{font-size:13px;opacity:.9;margin-top:3px;font-weight:600}
.td-status{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.td-st-lbl{font-family:var(--ff-disp);font-weight:800;font-size:16px}
.td-prize{font-family:var(--ff-disp);font-weight:800;font-size:30px;letter-spacing:-.02em}
.td-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-2);border-bottom:1px solid var(--line)}
.td-mi{background:var(--paper);padding:16px 20px;display:flex;flex-direction:column;gap:5px}
.td-mi .muted{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.td-mi b{font-size:14px}
.td-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 24px;
  background:var(--paper-2);border-top:1px solid var(--line);flex-wrap:wrap}
/* tripleta inside ticket */
.td-tri{padding:22px 24px}
.td-tri-info{margin-bottom:18px}
.td-tri-animals{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.td-tri-an{display:flex;flex-direction:column;align-items:center;gap:8px;padding:18px 12px;border-radius:16px;
  border:1.5px solid var(--line);background:var(--paper-2)}
.td-tri-an.hit{border-color:var(--win);background:var(--win-bg)}
.td-tri-an.miss{border-color:var(--line);opacity:.6}
.td-tri-name{font-family:var(--ff-disp);font-weight:700;font-size:15px}
.td-tri-badge{font-size:12px;font-weight:700;padding:4px 12px;border-radius:999px}
.td-tri-badge.hit{background:var(--win);color:#fff}
.td-tri-badge.miss{background:var(--lose-bg);color:var(--lose)}
.td-tri-badge.wait{background:var(--pend-bg);color:var(--pend)}
@media (max-width:680px){
  .td-meta{grid-template-columns:repeat(2,1fr)}
  .ts-row{flex-direction:column}
  .td-prize{font-size:24px}
}

/* ---------- Tripleta ---------- */
.tri-rules{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:6px;margin-bottom:22px}
.tri-rule{position:relative;display:flex;align-items:center;gap:12px;padding:16px 18px}
.tri-rn{width:32px;height:32px;border-radius:50%;flex:none;display:grid;place-items:center;
  font-family:var(--ff-disp);font-weight:800;color:#4a3500;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));box-shadow:0 3px 8px rgba(255,203,0,.4)}
.tri-rule b{display:block;font-family:var(--ff-disp);font-size:14px;letter-spacing:-.01em}
.tri-rule span{display:block;font-size:12px;color:var(--muted);margin-top:2px}
.tri-arrow{position:absolute;right:-9px;top:50%;transform:translateY(-50%);color:var(--muted-2);font-weight:700;z-index:1}

.tri-layout{display:grid;grid-template-columns:1.3fr .7fr;gap:20px;align-items:start}
.tri-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:18px}
.tri-slot{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;border-radius:16px;cursor:pointer}
.tri-slot.filled{background:var(--gold-soft);border:1.5px solid var(--gold)}
.tri-slot.empty{border:2px dashed var(--line);background:var(--paper-2);color:var(--muted-2)}
.tri-slot.empty span{font-size:32px;font-weight:300;line-height:1;height:68px;display:grid;place-items:center}
.tri-slot-name{font-family:var(--ff-disp);font-weight:700;font-size:13px}

.tri-stake{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:end}
.stake-input{display:flex;align-items:center;gap:6px;margin-top:8px;border:1.5px solid var(--line);border-radius:12px;
  padding:0 14px;background:var(--paper-2)}
.stake-input:focus-within{border-color:var(--gold-ink)}
.stake-input span{font-family:var(--ff-disp);font-weight:800;color:var(--muted);font-size:18px}
.stake-input input{width:100%;border:none;background:none;outline:none;font-family:var(--ff-disp);font-weight:800;
  font-size:24px;padding:12px 0;color:var(--ink)}
.stake-quick{display:flex;gap:6px;margin-top:10px}
.stake-quick button{flex:1;border:1px solid var(--line);background:var(--paper);border-radius:9px;padding:7px 0;cursor:pointer;
  font-family:var(--ff-disp);font-weight:700;font-size:12.5px;color:var(--muted)}
.stake-quick button.on{background:var(--navy-800);color:#fff;border-color:var(--navy-800)}
.tri-payout{background:linear-gradient(135deg,var(--navy-800),var(--navy-700));border-radius:14px;padding:14px 18px;color:#fff}
.tri-payout .muted{color:#A7C5B0!important}
.tri-payout-val{font-family:var(--ff-disp);font-weight:800;font-size:30px;color:var(--gold-2);letter-spacing:-.02em;margin:4px 0 2px}

.tri-pick-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}
.tri-search{border:1.5px solid var(--line);border-radius:10px;padding:8px 13px;font-family:var(--ff-body);font-size:13px;outline:none;width:140px;background:var(--paper);color:var(--ink)}
.tri-search:focus{border-color:var(--blue)}
.tri-pickgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:8px;max-height:340px;overflow-y:auto;padding:2px}
.tri-pick{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;border-radius:13px;cursor:pointer;
  border:1.5px solid var(--line);background:var(--paper)}
.tri-pick:hover{border-color:var(--blue-200);background:var(--paper-2)}
.tri-pick.on{border-color:var(--gold);background:var(--gold-soft);box-shadow:0 0 0 2px rgba(255,203,0,.25)}
.tri-pick-num{font-family:var(--ff-disp);font-weight:800;font-size:12px;color:var(--muted)}
.tri-pick-name{font-size:11px;font-weight:700;text-align:center;line-height:1.1}
.tri-prog-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:11px;background:var(--paper-2)}

@media (max-width:980px){
  .tri-rules{grid-template-columns:repeat(2,1fr)}
  .tri-arrow{display:none}
  .tri-layout{grid-template-columns:1fr}
}
@media (max-width:680px){
  .tri-rules{grid-template-columns:1fr}
  .tri-stake{grid-template-columns:1fr}
}

/* ---------- Footer ---------- */
.footer{margin-top:auto;background:linear-gradient(180deg,var(--navy-850),var(--navy-900));color:#fff;padding:32px 0 28px}
.foot-inner{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}
.foot-links{display:flex;gap:6px;flex-wrap:wrap;justify-content:center}
.foot-links a{color:#B3CDBC;font-size:13.5px;font-weight:600;cursor:pointer;padding:6px 12px;border-radius:9px}
.foot-links a:hover{color:#fff;background:rgba(255,255,255,.07)}
.foot-legal{color:#8AA593;font-size:12px;line-height:1.6;margin:4px 0 0;max-width:560px}
.foot-dev{color:#5B7364;font-size:11px;margin:10px 0 0}
.foot-dev a{color:#8AA593;text-decoration:none;border-bottom:1px solid rgba(138,165,147,.35);transition:color .15s,border-color .15s}
.foot-dev a:hover{color:#FFED00;border-color:rgba(255,237,0,.5)}

/* ---------- Brand co-lock + logo chip ---------- */
.brand-div{width:1px;height:28px;background:rgba(255,255,255,.16);margin:0 4px;flex:none}
.tinka-chip{display:inline-flex;align-items:center;background:#fff;border-radius:9px;padding:6px 11px;
  box-shadow:0 2px 10px rgba(0,0,0,.22);flex:none}
.tinka-chip img{height:22px;display:block}
@media (max-width:520px){.brand-div,.tinka-chip{display:none}}

/* ---------- Animal KPI ---------- */
.kpi-animal{display:flex;align-items:center;justify-content:space-between;gap:12px}
.kpi-animal-txt{min-width:0}
.kpi-animal.clickable{cursor:pointer;transition:.15s}
.kpi-animal.clickable:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}

/* ---------- Roster ---------- */
.roster-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(116px,1fr));gap:12px}
.roster-cell{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 10px;border-radius:16px;
  border:1px solid var(--line-2);background:var(--paper);cursor:pointer;transition:.15s;text-align:center}
.roster-cell:hover{border-color:var(--blue-200);box-shadow:var(--sh-2);transform:translateY(-3px)}
.roster-num{font-family:var(--ff-disp);font-weight:800;font-size:12px;color:var(--muted);letter-spacing:.04em}
.roster-name{font-family:var(--ff-disp);font-weight:700;font-size:13px;line-height:1.1}
.roster-meta{font-size:11px;color:var(--muted);font-weight:600}

/* ---------- Animal detail drawer ---------- */
.drawer-wrap{position:fixed;inset:0;z-index:80;display:flex;justify-content:flex-end;overflow:hidden}
.drawer-scrim{position:absolute;inset:0;background:rgba(4,21,11,.5);backdrop-filter:blur(2px)}
.drawer{position:relative;width:440px;max-width:94vw;height:100%;background:var(--cream);overflow-y:auto;
  box-shadow:-24px 0 70px rgba(4,21,11,.4);animation:drawerIn .34s cubic-bezier(.2,.8,.2,1) both}
@keyframes drawerIn{from{transform:translateX(28px)}to{transform:none}}
.drawer-hero{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px;padding:30px 24px 26px;color:#fff}
.drawer-x{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:11px;cursor:pointer;
  background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);color:#fff;display:grid;place-items:center}
.drawer-x:hover{background:rgba(255,255,255,.28)}
.drawer-fav{position:absolute;top:16px;left:16px;z-index:2}
.drawer-fav .favstar{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);color:#fff;width:40px;height:40px;justify-content:center}
.drawer-fav .favstar.on{color:var(--gold-2)}
.drawer-fav .favstar:hover{background:rgba(255,255,255,.28)}
.drawer-id{text-align:center}
.drawer-num{font-family:var(--ff-disp);font-weight:800;font-size:14px;letter-spacing:.1em;opacity:.92}
.drawer-name{font-family:var(--ff-disp);font-weight:800;font-size:36px;letter-spacing:-.02em;line-height:1;margin-top:3px;
  text-shadow:0 3px 18px rgba(0,0,0,.3)}
.drawer-body{padding:22px}
.dstat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:8px}
.dstat{background:var(--paper);border:1px solid var(--line-2);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:3px}
.dstat-lbl{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.dstat b{font-family:var(--ff-disp);font-weight:800;font-size:26px;letter-spacing:-.02em}
.dstat-sub{font-size:11.5px;color:var(--muted-2);font-weight:600}
.dsection{margin-top:18px}
.dsection-h{font-family:var(--ff-disp);font-weight:700;font-size:13px;color:var(--ink-2);margin-bottom:12px;
  letter-spacing:.02em;text-transform:uppercase;font-size:11.5px;letter-spacing:.1em;color:var(--blue)}
.dbars{display:flex;align-items:flex-end;gap:4px;height:80px;background:var(--paper);border:1px solid var(--line-2);
  border-radius:12px;padding:10px}
.dbar-col{flex:1;height:100%;display:flex;align-items:flex-end;justify-content:center}
.dbar{width:100%;max-width:14px;border-radius:4px 4px 0 0;min-height:3px;opacity:.9}
.dbet{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dbet>div{background:var(--paper);border:1px solid var(--line-2);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:4px}
.dbet b{font-family:var(--ff-disp);font-weight:800;font-size:17px}
.dapp-list{display:flex;flex-direction:column;gap:7px}
.dapp{display:flex;align-items:center;gap:10px;background:var(--paper);border:1px solid var(--line-2);
  border-radius:10px;padding:8px 12px;font-weight:700;font-size:13px}
.dapp .muted{margin-left:auto;font-weight:600}
@media (max-width:680px){.drawer-name{font-size:30px}}

/* ---------- Results filter bar ---------- */
.filterbar{padding:18px;margin-bottom:16px}
.fb-search{display:flex;align-items:center;gap:10px;padding:0 14px;border:1.5px solid var(--line);border-radius:12px;
  background:var(--paper-2);color:var(--muted);margin-bottom:14px}
.fb-search:focus-within{border-color:var(--blue);background:var(--paper)}
.fb-search input{flex:1;border:none;background:none;outline:none;font-family:var(--ff-body);font-size:15px;padding:13px 0;color:var(--ink)}
.fb-clear{border:none;background:none;cursor:pointer;color:var(--muted-2);font-size:14px;padding:4px 6px}
.fb-clear:hover{color:var(--ink)}
.fb-row{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.fb-field{display:flex;flex-direction:column;gap:5px;flex:1;min-width:150px}
.fb-field label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.fb-field select,.fb-field input{border:1.5px solid var(--line);border-radius:10px;padding:10px 12px;
  font-family:var(--ff-body);font-size:14px;background:var(--paper);color:var(--ink);outline:none;width:100%}
.fb-field select:focus,.fb-field input:focus{border-color:var(--blue)}
.fb-reset{align-self:flex-end;height:42px}
.fb-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px;padding-top:14px;border-top:1px solid var(--line-2)}
.fb-chip{border:1px solid var(--line);background:var(--paper);border-radius:999px;padding:7px 15px;cursor:pointer;
  font-family:var(--ff-disp);font-weight:700;font-size:12.5px;color:var(--muted)}
.fb-chip:hover{border-color:var(--blue-200)}
.fb-chip.on{background:var(--navy-800);color:#fff;border-color:var(--navy-800)}

.res-summary{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.rs-item{flex:1;min-width:130px;background:var(--paper);border:1px solid var(--line-2);border-radius:14px;padding:13px 16px;
  display:flex;flex-direction:column;gap:4px;box-shadow:var(--sh-1)}
.rs-item span{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.rs-item b{font-family:var(--ff-disp);font-weight:800;font-size:18px;letter-spacing:-.01em;display:flex;align-items:center;gap:7px}
.rs-top{cursor:pointer}
.rs-top:hover{border-color:var(--blue-200);box-shadow:var(--sh-2)}
.res-note{background:var(--pend-bg);color:var(--pend);border-radius:12px;padding:11px 16px;font-size:13px;font-weight:600;margin-bottom:16px}
.res-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-top:1px solid var(--line);background:var(--paper-2)}
.res-foot .muted{font-size:13px;font-weight:600}

/* day navigator */
.day-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:18px}
.day-arrow{width:44px;height:44px;border-radius:12px;border:1px solid var(--line);background:var(--paper);cursor:pointer;
  font-size:24px;line-height:1;color:var(--ink);box-shadow:var(--sh-1)}
.day-arrow:hover:not(:disabled){border-color:var(--blue);color:var(--blue)}
.day-arrow:disabled{opacity:.4;cursor:not-allowed}
.day-nav-center{display:flex;flex-direction:column;align-items:center;gap:6px}
.day-nav-center input{border:1.5px solid var(--line);border-radius:10px;padding:8px 12px;font-family:var(--ff-body);font-size:14px;text-align:center;background:var(--paper);color:var(--ink)}
.day-nav-label{font-family:var(--ff-disp);font-weight:800;font-size:18px;letter-spacing:-.01em}

/* filtered card states */
.res-card.dim{opacity:.32}
.res-card.hit{border-color:var(--gold);box-shadow:0 0 0 2px rgba(255,203,0,.3)}
.mtx-cell.dim{opacity:.22}

@media (max-width:680px){
  .fb-field{min-width:calc(50% - 6px)}
  .rs-item{min-width:calc(50% - 6px)}
}

/* ---------- Nav badge ---------- */
.nav-badge{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;
  background:var(--red);color:#fff;font-family:var(--ff-disp);font-weight:800;font-size:11px;margin-left:2px}
@media (max-width:1180px){.live-pill{display:none}}

/* ---------- Notification banner ---------- */
.notif-banner{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:16px;border:1px solid var(--line);
  background:var(--paper);box-shadow:var(--sh-1);margin-bottom:22px}
.notif-banner.on{background:var(--win-bg);border-color:rgba(22,163,91,.3)}
.notif-banner.off{background:var(--lose-bg);border-color:rgba(192,57,43,.25)}
.nb-icon{width:44px;height:44px;border-radius:12px;flex:none;display:grid;place-items:center;background:var(--navy-800);color:#fff}
.notif-banner.on .nb-icon{background:var(--win)}
.notif-banner.off .nb-icon{background:var(--lose)}
.nb-txt{flex:1;display:flex;flex-direction:column;gap:2px}
.nb-txt b{font-family:var(--ff-disp);font-weight:800;font-size:15px}
.nb-txt span{font-size:12.5px;color:var(--muted)}

/* ---------- Mis Tickets cards ---------- */
.mt-card{overflow:hidden}
.mt-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 20px;color:#fff}
.mt-head.win{background:linear-gradient(120deg,#0f7a45,var(--win))}
.mt-head.lose{background:linear-gradient(120deg,#26352B,#16201A)}
.mt-head.pend{background:linear-gradient(120deg,#A86A00,#754700)}
.mt-code{font-family:var(--ff-disp);font-weight:800;font-size:19px;letter-spacing:.02em}
.mt-sub{font-size:12px;opacity:.92;margin-top:2px}
.mt-head-r{display:flex;align-items:center;gap:12px}
.mt-st{font-family:var(--ff-disp);font-weight:800;font-size:14px}
.mt-prize{font-family:var(--ff-disp);font-weight:800;font-size:22px;letter-spacing:-.02em}
.mt-x{width:32px;height:32px;border-radius:9px;border:1px solid rgba(255,255,255,.3);background:rgba(255,255,255,.14);
  color:#fff;cursor:pointer;display:grid;place-items:center;flex:none}
.mt-x:hover{background:rgba(255,255,255,.26)}
.mt-next{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;
  background:var(--navy-800);color:#fff;flex-wrap:wrap}
.mt-next-r{display:flex;flex-direction:column;align-items:flex-end}
.mt-next .cd-lbl{color:var(--blue-200)}
.mt-plays{padding:8px 20px 4px}
.mt-play{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line-2)}
.mt-play:last-child{border-bottom:none}
.mt-play-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.mt-play-info b{font-size:14px}
.mt-play-info span{font-size:12px}
.mt-play-res{display:flex;flex-direction:column;align-items:center;gap:3px}
.mt-play-end{display:flex;flex-direction:column;align-items:flex-end;gap:4px;min-width:74px}
.mt-play-end b{font-family:var(--ff-disp);font-size:14px}
.mt-play.win{background:linear-gradient(90deg,transparent,var(--win-bg));margin:0 -20px;padding:12px 20px;border-radius:0}
.mt-tri{padding:16px 20px}
.mt-tri-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.mt-tri-an{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:14px;border:1.5px solid var(--line);background:var(--paper-2)}
.mt-tri-an.hit{border-color:var(--win);background:var(--win-bg)}
.mt-tri-an.miss{opacity:.55}
.mt-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;background:var(--paper-2);border-top:1px solid var(--line)}

/* ---------- Toasts ---------- */
.toast-stack{position:fixed;right:20px;top:84px;z-index:95;display:flex;flex-direction:column;gap:10px;max-width:360px}
.toast{display:flex;align-items:center;gap:12px;padding:14px;border-radius:16px;background:var(--paper);cursor:pointer;
  box-shadow:0 16px 40px rgba(4,21,11,.28);border:1px solid var(--line);animation:toastIn .35s cubic-bezier(.2,.9,.3,1) both}
.toast.win{border-left:5px solid var(--win)}
.toast.lose{border-left:5px solid var(--muted-2)}
@keyframes toastIn{from{transform:translateX(40px) translateY(8px);opacity:0}to{transform:none;opacity:1}}
.toast-txt{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.toast-txt b{font-family:var(--ff-disp);font-weight:800;font-size:14.5px;letter-spacing:-.01em}
.toast-txt span{font-size:12.5px;color:var(--muted);line-height:1.35}
.toast-x{width:26px;height:26px;border-radius:8px;border:none;background:var(--paper-2);color:var(--muted);cursor:pointer;
  display:grid;place-items:center;flex:none;align-self:flex-start}
.toast-x:hover{background:var(--line);color:var(--ink)}
@media (max-width:560px){.toast-stack{left:14px;right:14px;max-width:none;top:78px}}

/* ---------- Tripleta: retail how-to ---------- */
.tri-retail{padding:22px;margin-bottom:22px;background:var(--paper)}
.tri-retail-head{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;flex-wrap:wrap;margin-bottom:18px}
.tri-retail-mult{flex:none;display:flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,var(--navy-800),var(--navy-700));
  color:#fff;border-radius:16px;padding:12px 22px;text-align:center}
.tri-retail-mult span{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#A7C5B0}
.tri-retail-mult b{font-family:var(--ff-disp);font-weight:800;font-size:34px;color:var(--gold-2);line-height:1;margin:2px 0}
.tri-retail-mult small{font-size:11.5px;color:#A7C5B0}
.tri-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.tri-step{position:relative;display:flex;flex-direction:column;gap:4px;padding:16px 14px;border-radius:14px;
  background:var(--paper-2);border:1px solid var(--line-2)}
.tri-step-ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;margin-bottom:6px;
  background:var(--gold-soft);color:#8a6500}
.tri-step-n{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-ink)}
.tri-step b{font-family:var(--ff-disp);font-size:14px;letter-spacing:-.01em}
.tri-step span{font-size:12px;color:var(--muted);line-height:1.4}
.tri-retail-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}

/* daily board */
.tri-board{display:flex;flex-wrap:wrap;gap:8px}
.tri-board-an{display:flex;flex-direction:column;align-items:center;gap:3px;border:none;background:none;cursor:pointer;padding:0}
.tri-board-an .tnum{font-family:var(--ff-disp);font-weight:800;font-size:11px;color:var(--muted)}
.tri-board-an:hover{transform:translateY(-2px)}

/* slot hit + verdict */
.tri-slot.filled.hit{background:var(--win-bg);border-color:var(--win)}
.tri-verdict{border-radius:14px;padding:14px 16px;margin-top:16px;display:flex;flex-direction:column;gap:3px}
.tri-verdict b{font-family:var(--ff-disp);font-weight:800;font-size:15px}
.tri-verdict span{font-size:12.5px}
.tri-verdict.win{background:var(--win-bg);color:var(--win)}
.tri-verdict.pend{background:var(--pend-bg);color:var(--pend)}
.tri-verdict.lose{background:var(--lose-bg);color:var(--lose)}

/* popular trios */
.tri-pop{display:flex;align-items:stretch;gap:6px;width:100%;border:1px solid var(--line);background:var(--paper);border-radius:13px;overflow:hidden}
.tri-pop:hover{border-color:var(--gold-ink)}
.tri-pop-main{flex:1;min-width:0;display:flex;align-items:center;gap:12px;text-align:left;cursor:pointer;border:none;background:none;padding:10px 12px}
.tri-pop-main:hover{background:var(--gold-soft)}
.tri-pop-play{flex:none;width:44px;border:none;border-left:1px solid var(--line);background:var(--gold-soft);color:#8a6500;cursor:pointer;display:grid;place-items:center}
.tri-pop-play:hover{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#4a3500}
.tri-pop-ans{display:flex}
.tri-pop-ans>*{margin-left:-8px;box-shadow:0 0 0 2px var(--paper);border-radius:9px}
.tri-pop-ans>*:first-child{margin-left:0}
.tri-pop-meta{display:flex;flex-direction:column;gap:2px;min-width:0}

@media (max-width:980px){
  .tri-steps{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:680px){
  .tri-steps{grid-template-columns:1fr}
}

/* Tripleta-of-day surfaces (Inicio/Resultados) */

/* Tripleta coverage chart */
.cov-chart{margin-top:14px}
.cov-grid{position:relative;display:flex;align-items:flex-end;gap:6px;height:128px}
.cov-col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;min-width:0}
.cov-val{font-size:10.5px;font-weight:800;color:var(--ink-2);margin-bottom:4px;font-variant-numeric:tabular-nums}
.cov-bar{width:100%;max-width:22px;border-radius:6px 6px 0 0;min-height:4px;
  background:linear-gradient(180deg,var(--blue-400),var(--blue));transition:height .55s cubic-bezier(.2,.8,.2,1);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.25)}
.cov-bar.today{background:linear-gradient(180deg,var(--gold-2),var(--gold));box-shadow:0 4px 12px rgba(255,203,0,.45)}
.cov-avgline{position:absolute;left:-2px;right:-2px;border-top:2px dashed var(--blue);opacity:.5;z-index:1;pointer-events:none}
.cov-avgline span{position:absolute;right:0;top:-9px;font-size:9px;font-weight:800;color:var(--blue);
  background:var(--paper);padding:1px 5px;border-radius:5px;box-shadow:0 0 0 1px var(--line-2)}
.cov-labels{display:flex;gap:6px;margin-top:8px;padding-top:8px;border-top:1px solid var(--line-2)}
.cov-lab{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:1px}
.cov-lab b{font-size:11px;font-weight:800;color:var(--ink-2);font-variant-numeric:tabular-nums}
.cov-lab span{font-size:8.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted-2)}
.cov-lab.today b,.cov-lab.today span{color:var(--gold-ink)}

/* Tripleta next-day callout + combo rows */
.tri-nextday{display:flex;align-items:center;gap:12px;margin-bottom:22px;padding:13px 18px;border-radius:14px;
  background:var(--gold-soft);color:#7a5a00;border:1px solid rgba(255,203,0,.4)}
.tri-nextday svg{flex:none;color:var(--gold-ink)}
.tri-nextday b{color:#5e4500}
.tri-nextday span{font-size:13.5px;line-height:1.45}
.combo-row{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:11px;background:var(--paper-2);
  border:1px solid var(--line-2)}
.combo-row.clk{cursor:pointer}
.combo-row.clk:hover{border-color:var(--blue-200);background:var(--paper)}
.combo-rank{width:16px;flex:none;text-align:right;font-size:12px;color:var(--muted)}
.combo-ans{display:flex;flex:none}
.combo-ans>*{margin-left:-9px;box-shadow:0 0 0 2px var(--paper-2);border-radius:9px}
.combo-row.clk:hover .combo-ans>*{box-shadow:0 0 0 2px var(--paper)}
.combo-ans>*:first-child{margin-left:0}
.combo-names{flex:1;min-width:0;font-size:12px;font-weight:700;line-height:1.2;
  overflow:hidden;text-overflow:ellipsis}
.combo-count{flex:none;font-family:var(--ff-disp);font-weight:800;font-size:16px;letter-spacing:-.02em}
.combo-count small{font-size:10px;font-weight:700;color:var(--muted);letter-spacing:0}

/* ---------- Detail drawer play CTAs ---------- */
.dplay{display:flex;flex-direction:column;gap:9px;padding:16px;margin-bottom:18px;border-radius:16px;
  background:linear-gradient(180deg,var(--gold-soft),transparent);border:1px solid var(--line)}
.dplay-lbl{font-family:var(--ff-disp);font-weight:800;font-size:13.5px;color:var(--ink-2);margin-bottom:2px}
.dplay .btn{width:100%}

/* ---------- Theme toggle ---------- */
.theme-toggle{width:40px;height:40px;border-radius:11px;flex:none;cursor:pointer;display:grid;place-items:center;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:#fff;transition:.16s}
.theme-toggle:hover{background:rgba(255,255,255,.16)}

/* ---------- Header action cluster ---------- */
.top-actions{display:flex;gap:6px;flex:none}
.top-act{display:flex;align-items:center;gap:7px;padding:9px 13px;border-radius:11px;cursor:pointer;position:relative;
  font-family:var(--ff-disp);font-weight:700;font-size:13.5px;color:#BCD3C2;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10);transition:.16s;white-space:nowrap}
.top-act:hover{color:#fff;background:rgba(255,255,255,.13)}
.top-act.on{color:#fff;background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.22)}
.top-act svg{width:16px;height:16px;opacity:.9;flex:none}
.top-act.accent{color:#fff;background:linear-gradient(180deg,rgba(255,203,0,.22),rgba(255,203,0,.12));border-color:rgba(255,203,0,.4)}
.top-act.accent:hover{background:linear-gradient(180deg,rgba(255,203,0,.32),rgba(255,203,0,.18))}
.top-act.accent.on{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#4a3500;border-color:transparent}
.top-act .nav-badge{position:absolute;top:-5px;right:-5px;margin:0;box-shadow:0 0 0 2px var(--navy-850)}
.top-sep{width:1px;height:26px;background:rgba(255,255,255,.16);flex:none;margin:0 2px}

@media (max-width:1240px){
  .top-act span{display:none}
  .top-act{padding:9px;width:40px;height:40px;justify-content:center}
}
@media (max-width:980px){
  .top-actions,.top-sep,.theme-toggle{display:none}
}

/* ---------- Mis Tickets section headers ---------- */
.mt-section-h{display:flex;align-items:center;justify-content:space-between;margin:0 2px 12px;
  font-family:var(--ff-disp);font-weight:800;font-size:15px;color:var(--ink-2)}
.mt-section-h .muted{font-weight:700}

/* ---------- Barcode ---------- */
.barcode{display:flex;justify-content:center;align-items:center;width:100%}
.barcode svg{max-width:100%;height:auto}

/* ---------- Play builder modal ---------- */
.builder{position:fixed;inset:0;z-index:92;display:flex;align-items:flex-end;justify-content:center;padding:0}
.builder-scrim{position:absolute;inset:0;background:rgba(6,12,28,.62);backdrop-filter:blur(3px)}
.builder-panel{position:relative;width:100%;max-width:640px;max-height:94vh;display:flex;flex-direction:column;
  background:var(--cream);border-radius:24px 24px 0 0;box-shadow:0 -20px 70px rgba(0,0,0,.5);
  animation:sheetUp .4s cubic-bezier(.2,.9,.25,1) both}
@keyframes sheetUp{from{transform:translateY(40px)}to{transform:none}}
@media (min-width:720px){
  .builder{align-items:center;padding:24px}
  .builder-panel{border-radius:24px;max-height:90vh}
}
.builder-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:22px 24px 14px;
  background:linear-gradient(180deg,var(--navy-800),var(--navy-700));color:#fff;border-radius:24px 24px 0 0;flex:none}
@media (min-width:720px){.builder-head{border-radius:24px 24px 0 0}}
.builder-head h3{color:#fff}
.builder-x{width:40px;height:40px;border-radius:11px;flex:none;cursor:pointer;display:grid;place-items:center;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);color:#fff}
.builder-x:hover{background:rgba(255,255,255,.26)}
.builder-body{padding:20px 24px;overflow-y:auto;flex:1}
.builder-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 24px;
  border-top:1px solid var(--line);background:var(--paper);flex:none}
.builder-foot .btn{flex:none}
.bld-total{display:flex;flex-direction:column;line-height:1.1}
.bld-total .muted{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.bld-total b{font-family:var(--ff-disp);font-weight:800;font-size:26px;color:var(--ink)}

.bld-seg{display:flex;gap:4px;background:var(--paper-2);border:1px solid var(--line);border-radius:13px;padding:4px;margin-bottom:12px}
.bld-seg button{flex:1;border:none;background:none;cursor:pointer;font-family:var(--ff-disp);font-weight:700;font-size:14.5px;
  padding:11px 0;border-radius:10px;color:var(--muted)}
.bld-seg button.on{background:var(--red);color:#fff;box-shadow:0 4px 12px var(--red-glow)}
.bld-hint{font-size:13px;color:var(--muted);margin:0 0 18px;line-height:1.45}
.bld-label{font-family:var(--ff-disp);font-weight:800;font-size:13.5px;margin:18px 0 10px;color:var(--ink-2)}
.bld-lock-note{font-family:var(--ff-body);font-weight:600;font-size:12px;color:var(--muted-2)}

.bld-days{display:flex;gap:8px;padding-bottom:4px}
.bld-day{flex:none;width:64px;display:flex;flex-direction:column;align-items:center;gap:1px;cursor:pointer;
  border:1.5px solid var(--line);background:var(--paper);border-radius:13px;padding:9px 0}
.bld-day-tag{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.bld-day-num{font-family:var(--ff-disp);font-weight:800;font-size:19px;color:var(--ink)}
.bld-day-mon{font-size:10.5px;font-weight:600;color:var(--muted)}
.bld-day.on{background:var(--navy-800);border-color:var(--navy-800)}
.bld-day.on .bld-day-tag{color:var(--gold-2)}
.bld-day.on .bld-day-num,.bld-day.on .bld-day-mon{color:#fff}
.bld-day.off{opacity:.4;cursor:not-allowed}

.bld-hours{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.bld-hour{display:flex;flex-direction:column;align-items:center;gap:3px;cursor:pointer;padding:10px 4px;border-radius:12px;
  border:1.5px solid var(--line);background:var(--paper);font-family:var(--ff-disp);font-weight:700;font-size:13px;color:var(--ink)}
.bld-hour-st{font-family:var(--ff-body);font-size:10px;font-weight:700;color:var(--muted-2);display:flex;align-items:center;gap:3px}
.bld-hour-st.open{color:var(--win)}
.bld-hour.on{background:var(--blue);border-color:var(--blue);color:#fff}
.bld-hour.on .bld-hour-st{color:rgba(255,255,255,.85)}
.bld-hour.off{opacity:.45;cursor:not-allowed;background:var(--paper-2)}
.bld-hour.off .bld-hour-st{color:var(--lose)}

.bld-animals{display:grid;grid-template-columns:repeat(auto-fill,minmax(82px,1fr));gap:8px;max-height:300px;overflow-y:auto;padding:2px}
.bld-an{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;padding:9px 4px;border-radius:12px;
  border:1.5px solid var(--line);background:var(--paper)}
.bld-an:hover{border-color:var(--blue-200)}
.bld-an.on{border-color:var(--gold);background:var(--gold-soft);box-shadow:0 0 0 2px rgba(255,203,0,.25)}
.bld-an.dim{opacity:.4}
.bld-an-num{font-family:var(--ff-disp);font-weight:800;font-size:11px;color:var(--muted)}
.bld-an-name{font-size:10.5px;font-weight:700;text-align:center;line-height:1.1;color:var(--ink)}

.bld-cart{margin-top:18px;border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper)}
.bld-cart-h{padding:11px 14px;font-family:var(--ff-disp);font-weight:800;font-size:13px;background:var(--paper-2);border-bottom:1px solid var(--line-2)}
.bld-cart-row{display:flex;align-items:center;gap:11px;padding:10px 14px;border-bottom:1px solid var(--line-2)}
.bld-cart-row:last-child{border-bottom:none}
.bld-cart-info{flex:1;min-width:0;display:flex;flex-direction:column}
.bld-cart-info b{font-size:13.5px}
.bld-cart-info .muted{font-size:11.5px}
.bld-cart-amt{font-family:var(--ff-disp);font-weight:700;font-size:13.5px}
.bld-cart-x{width:26px;height:26px;border-radius:8px;border:none;cursor:pointer;display:grid;place-items:center;
  background:var(--paper-2);color:var(--muted)}
.bld-cart-x:hover{background:var(--lose-bg);color:var(--lose)}

.bld-warn{background:var(--pend-bg);color:var(--pend);border-radius:12px;padding:12px 14px;font-size:13px;font-weight:600;margin-bottom:6px}
.bld-tri-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.bld-tri-slot{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 8px;border-radius:14px}
.bld-tri-slot.filled{background:var(--gold-soft);border:1.5px solid var(--gold);cursor:pointer}
.bld-tri-slot.filled span{font-family:var(--ff-disp);font-weight:700;font-size:12.5px}
.bld-tri-slot.empty{border:2px dashed var(--line);background:var(--paper-2);min-height:96px;justify-content:center}
.bld-tri-plus{font-size:30px;font-weight:300;color:var(--muted-2)}

/* generated ticket */
.bld-ticket{background:var(--paper);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.bld-ticket-top{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px dashed var(--line)}
.bld-ticket-plays{padding:6px 18px}
.bld-ticket-play{display:flex;align-items:center;gap:11px;padding:11px 0;border-bottom:1px solid var(--line-2)}
.bld-ticket-play:last-child{border-bottom:none}
.bld-ticket-play b{font-size:14px}
.bld-ticket-tri{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:18px}
.bld-ticket-trian{display:flex;flex-direction:column;align-items:center;gap:7px}
.bld-ticket-trian span{font-family:var(--ff-disp);font-weight:700;font-size:13px}
.bld-ticket-tot{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--paper-2);
  border-top:1px solid var(--line-2);border-bottom:1px solid var(--line-2)}
.bld-ticket-tot span{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.bld-ticket-tot b{font-family:var(--ff-disp);font-weight:800;font-size:22px;color:var(--ink)}
.bld-barcode-wrap{padding:22px 18px 16px;display:flex;flex-direction:column;align-items:center;gap:8px}
.bld-code{font-family:var(--ff-disp);font-weight:800;font-size:22px;letter-spacing:.12em;color:var(--ink)}
.bld-payload{font-size:11px;color:var(--muted-2);letter-spacing:.08em}
.bld-ticket-note{display:flex;align-items:flex-start;gap:9px;padding:14px 18px;background:var(--gold-soft);
  color:#7a5a00;font-size:12.5px;line-height:1.45}
html[data-theme="dark"] .bld-ticket-note{color:var(--gold-2)}
.bld-ticket-note svg{flex:none;margin-top:2px;color:var(--gold-ink)}

/* prepared card */
.prep-card{overflow:hidden}
.prep-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line-2)}
.prep-code{font-family:var(--ff-disp);font-weight:800;font-size:15px;letter-spacing:.08em}
.prep-x{width:28px;height:28px;border-radius:8px;border:1px solid var(--line);background:var(--paper);color:var(--muted);
  cursor:pointer;display:grid;place-items:center;flex:none}
.prep-x:hover{background:var(--lose-bg);color:var(--lose);border-color:transparent}
.prep-body{display:flex;align-items:center;gap:16px;padding:16px;flex-wrap:wrap}
.prep-ans{display:flex;gap:10px;flex:none}
.prep-an{display:flex;flex-direction:column;align-items:center;gap:3px}
.prep-an-hr{font-family:var(--ff-disp);font-weight:700;font-size:10px;color:var(--muted)}
.prep-barcode{flex:1;min-width:180px;display:flex;flex-direction:column;align-items:center;gap:4px}
.prep-barcode .barcode svg{max-height:54px}
.prep-payload{font-size:10px;color:var(--muted-2);letter-spacing:.06em}
.prep-foot{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--paper-2);border-top:1px solid var(--line-2)}
@media (max-width:560px){.prep-body{flex-direction:column;align-items:stretch}.prep-ans{justify-content:center}}

/* ---------- Live bet ticker (ambient activity) ---------- */
.livebet-stack{position:fixed;right:20px;bottom:20px;z-index:80;max-width:320px}
.livebet{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:15px;cursor:pointer;
  background:var(--paper);border:1px solid var(--line);box-shadow:0 12px 32px rgba(4,21,11,.22);
  position:relative;overflow:hidden;animation:livebetIn .42s cubic-bezier(.2,.9,.3,1) both;transition:transform .14s ease, box-shadow .14s ease}
.livebet:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(4,21,11,.3)}
.livebet.out{animation:livebetOut .42s ease forwards}
@keyframes livebetIn{from{transform:translateX(34px) translateY(6px);opacity:0}to{transform:none;opacity:1}}
@keyframes livebetOut{to{transform:translateX(34px);opacity:0}}
.livebet::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold)}
.livebet-ava{flex:none}
.livebet-tri{display:flex;gap:2px}
.livebet-tri>*{box-shadow:0 0 0 1.5px var(--paper);border-radius:6px}
.livebet-txt{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.livebet-top{display:flex;align-items:center;justify-content:space-between;gap:7px}
.livebet-tag{display:flex;align-items:center;gap:6px;font-size:9.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--win)}
.livebet-city{font-size:10.5px;font-weight:600;color:var(--muted-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.livebet-bet{font-size:13px;color:var(--ink-2);line-height:1.3}
.livebet-bet .hl{font-weight:700;color:var(--ink)}
.livebet-bet b{color:var(--win);font-weight:800}
.livebet-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:1px}
.livebet-round{font-size:10.5px;font-weight:700;letter-spacing:.03em;color:var(--blue)}
.livebet-cta{display:flex;align-items:center;gap:2px;font-family:var(--ff-disp);font-size:11px;font-weight:800;color:var(--red)}
.livebet-pulse{width:7px;height:7px;border-radius:50%;background:var(--win);
  box-shadow:0 0 0 0 rgba(22,163,91,.5);animation:pulse 2s infinite}
html[data-theme="dark"] .livebet{box-shadow:0 12px 32px rgba(0,0,0,.5)}
@media (max-width:560px){
  .livebet-stack{right:12px;left:auto;bottom:12px;max-width:calc(100vw - 24px)}
}

/* ---------- Physical ticket notice ---------- */
.phys-notice{display:flex;align-items:center;gap:16px;padding:18px 20px;border-radius:16px;margin-bottom:22px;
  background:linear-gradient(120deg,var(--navy-800),var(--navy-700));color:#fff;
  border:1px solid rgba(255,203,0,.4);box-shadow:var(--sh-2);position:relative;overflow:hidden}
.phys-notice::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--gold-2),var(--gold))}
.phys-ic{width:52px;height:52px;border-radius:14px;flex:none;display:grid;place-items:center;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#4a3500;
  box-shadow:0 6px 18px rgba(255,203,0,.4)}
.phys-txt{display:flex;flex-direction:column;gap:4px}
.phys-txt b{font-family:var(--ff-disp);font-weight:800;font-size:17px;letter-spacing:-.01em}
.phys-txt span{font-size:13px;color:#cdd8ef;line-height:1.5}
.phys-txt strong{color:var(--gold-2);font-weight:700}
@media (max-width:560px){
  .phys-notice{flex-direction:row;align-items:flex-start}
  .phys-ic{width:44px;height:44px}
  .phys-txt b{font-size:15px}
}

/* mobile slide menu */
.msheet{position:fixed;inset:0;z-index:60;display:none}
.msheet.open{display:block}
.msheet .scrim{position:absolute;inset:0;background:rgba(4,21,11,.5);backdrop-filter:blur(2px)}
.msheet .panel{position:absolute;top:0;right:0;bottom:0;width:80%;max-width:320px;
  background:var(--navy-800);padding:22px;display:flex;flex-direction:column;gap:6px;
  box-shadow:-20px 0 60px rgba(0,0,0,.4)}
.msheet .panel a{color:#cdd8ef;font-weight:600;font-size:16px;padding:14px 12px;border-radius:12px;cursor:pointer}
.msheet .panel a.on,.msheet .panel a:hover{background:rgba(255,255,255,.08);color:#fff}

/* ============ EXTRAS ============ */
/* favorite star */
.favstar{display:inline-flex;align-items:center;gap:7px;border:none;background:none;cursor:pointer;color:var(--muted-2);
  padding:4px;border-radius:9px;transition:.14s;font-family:var(--ff-disp);font-weight:700;font-size:13px}
.favstar:hover{color:var(--gold-ink)}
.favstar.on{color:var(--gold-ink)}
.favstar.on svg{filter:drop-shadow(0 2px 6px rgba(255,203,0,.5))}
.favstar.btnish{border:1px solid var(--line);padding:8px 13px;background:var(--paper)}
.favstar.btnish.on{border-color:var(--gold);background:var(--gold-soft)}
/* favorite highlight ring on avatars/cells */
.fav-ring{position:relative}
.fav-mark{position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;background:var(--gold);
  display:grid;place-items:center;box-shadow:0 2px 6px rgba(255,203,0,.5);z-index:2}
.fav-mark svg{width:11px;height:11px;color:#4a3500}

/* tendencias */
.tend-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:14px}
.tend-fun{font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted-2);
  background:var(--paper-2);border:1px solid var(--line);border-radius:999px;padding:5px 11px;white-space:nowrap}
.tend-seg{display:inline-flex;background:var(--paper-2);border:1px solid var(--line);border-radius:11px;padding:3px;gap:2px;margin-bottom:12px;flex-wrap:wrap}
.tend-seg button{border:none;background:none;cursor:pointer;font-family:var(--ff-disp);font-weight:700;font-size:12.5px;
  padding:7px 13px;border-radius:8px;color:var(--muted)}
.tend-seg button.on{background:var(--navy-800);color:#fff}
.tend-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.tend-card{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:13px;border:1px solid var(--line-2);background:var(--paper-2)}
.tend-an{position:relative;border:none;background:none;cursor:pointer;padding:0;flex:none}
.tend-rank{position:absolute;top:-6px;left:-6px;width:20px;height:20px;border-radius:50%;background:var(--gold);
  color:#4a3500;font-family:var(--ff-disp);font-weight:800;font-size:11px;display:grid;place-items:center}
.tend-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.tend-info b{font-size:13.5px}
.tend-info span{font-size:11px}
.tend-play{width:34px;height:34px;flex:none;border-radius:10px;border:none;cursor:pointer;display:grid;place-items:center;
  background:var(--gold-soft);color:#8a6500}
.tend-play:hover{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#4a3500}
@media (max-width:560px){.tend-grid{grid-template-columns:1fr}}

/* heatmap */
.heat{margin-top:6px}
.heat-row{display:flex;gap:4px}
.heat-cell-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0}
.heat-cell{width:100%;aspect-ratio:1;border-radius:7px;display:grid;place-items:center;font-family:var(--ff-disp);
  font-weight:800;font-size:12px;border:1px solid var(--line-2)}
.heat-h{font-size:9px;font-weight:700;color:var(--muted-2);font-variant-numeric:tabular-nums}
.heat-legend{margin-top:10px;font-size:12.5px;color:var(--muted)}
.heat-legend b{color:var(--ink)}

/* comparador */
.cmp-pickgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:7px;margin-bottom:16px;max-height:220px;overflow-y:auto;padding:2px}
.cmp-pick{display:flex;align-items:center;gap:8px;padding:7px 9px;border-radius:11px;border:1.5px solid var(--line);background:var(--paper);cursor:pointer;font-size:12px;font-weight:700;text-align:left}
.cmp-pick span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmp-pick.on{border-color:var(--blue);background:#E4F4E7}
html[data-theme="dark"] .cmp-pick.on{background:rgba(10,124,44,.2)}
.cmp-cols{display:flex;gap:12px;align-items:stretch}
.cmp-col{flex:1;min-width:0;border:1px solid var(--line);border-top:3px solid var(--cmp);border-radius:14px;padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:9px;background:var(--paper-2)}
.cmp-top{border:none;background:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:7px}
.cmp-top b{font-family:var(--ff-disp);font-size:14px}
.cmp-stat{width:100%;display:flex;align-items:center;justify-content:space-between;font-size:12px}
.cmp-stat .muted{font-size:11px}
.cmp-stat b{font-family:var(--ff-disp);font-size:14px}
.cmp-barbox{width:34px;height:70px;background:var(--line-2);border-radius:7px;display:flex;align-items:flex-end;overflow:hidden}
.cmp-barbox .cmp-bar{width:100%;border-radius:7px 7px 0 0;transition:height .5s ease}
.cmp-spark{width:100%;height:38px;display:flex;align-items:flex-end;gap:2px;margin-top:2px}
.cmp-spark span{flex:1;border-radius:2px 2px 0 0;min-height:3px}
.cmp-add{flex:none;width:90px;border:2px dashed var(--line);border-radius:14px;background:var(--paper-2);cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--muted);font-weight:700;font-size:12px}
.cmp-add span{font-size:28px;font-weight:300;line-height:1}
@media (max-width:560px){.cmp-spark{height:28px}.cmp-col{padding:10px 7px}}

/* onboarding / responsable modal */
.onb{position:fixed;inset:0;z-index:96;display:flex;align-items:center;justify-content:center;padding:20px}
.onb-scrim{position:absolute;inset:0;background:rgba(4,9,20,.78);backdrop-filter:blur(4px)}
.onb-card{position:relative;width:100%;max-width:440px;background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:30px 28px 22px;
  text-align:center;box-shadow:var(--sh-3);animation:sheetUp .4s cubic-bezier(.2,.9,.25,1) both}
.onb-illo{width:84px;height:84px;border-radius:24px;margin:0 auto 18px;display:grid;place-items:center;color:#fff;
  background:linear-gradient(160deg,var(--red),var(--red-600));box-shadow:0 12px 30px var(--red-glow)}
.onb-step{font-family:var(--ff-disp);font-weight:800;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-ink)}
.onb-card h3{font-size:24px;font-weight:800;margin:8px 0 10px}
.onb-card p{font-size:14.5px;color:var(--muted);line-height:1.55;margin:0 0 18px}
.onb-dots{display:flex;gap:7px;justify-content:center;margin-bottom:20px}
.onb-dots span{width:8px;height:8px;border-radius:50%;background:var(--line)}
.onb-dots span.on{background:var(--red);width:22px;border-radius:5px}
.onb-actions{display:flex;align-items:center;justify-content:space-between;gap:10px}
.resp-list{text-align:left;margin:0 0 14px;padding-left:20px;color:var(--ink-2);font-size:13.5px;line-height:1.7}
.resp-line{background:var(--paper-2);border:1px solid var(--line);border-radius:12px;padding:11px 14px;font-size:13px;color:var(--muted);margin-bottom:18px}
.resp-line b{color:var(--ink);font-family:var(--ff-disp)}
.foot-resp{background:none;border:none;cursor:pointer;color:#B3CDBC;font-size:13.5px;font-weight:600;padding:6px 12px;border-radius:9px;font-family:var(--ff-body)}
.foot-resp:hover{color:#fff;background:rgba(255,255,255,.07)}

/* share button */
.share-btn{display:inline-flex;align-items:center;gap:8px}

/* near-miss / racha banner */
.nearmiss{display:flex;align-items:center;gap:13px;padding:13px 16px;border-radius:14px;margin:0 16px 14px;
  background:linear-gradient(120deg,var(--gold-soft),transparent);border:1px solid rgba(255,203,0,.4)}
.nearmiss-ic{width:40px;height:40px;border-radius:11px;flex:none;display:grid;place-items:center;
  background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#4a3500}
.nearmiss-txt{flex:1;min-width:0}
.nearmiss-txt b{font-family:var(--ff-disp);font-weight:800;font-size:14px;display:block}
.nearmiss-txt span{font-size:12.5px;color:var(--ink-2)}
.roster-cell{position:relative}
.roster-fav{position:absolute;top:6px;right:6px;z-index:2}
.roster-fav .favstar{padding:3px}

/* mis números (favoritos en Inicio) */
.misnum-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}
.misnum-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.misnum-card{display:flex;align-items:center;gap:12px;padding:11px 13px;border-radius:14px;border:1px solid var(--line-2);background:var(--paper-2)}
.misnum-an{border:none;background:none;cursor:pointer;padding:0;flex:none}
.misnum-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.misnum-row{display:flex;align-items:center;justify-content:space-between;gap:6px}
.misnum-row b{font-family:var(--ff-disp);font-weight:800;font-size:14px}
.misnum-info span{font-size:11.5px}
.misnum-play{width:34px;height:34px;flex:none;border-radius:10px;border:none;cursor:pointer;display:grid;place-items:center;
  background:var(--gold-soft);color:#8a6500}
.misnum-play:hover{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#4a3500}
@media (max-width:880px){.misnum-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.misnum-grid{grid-template-columns:1fr}}
.livebet.fav::before{background:var(--gold-2);width:4px}
.livebet.fav .livebet-tag{color:var(--gold-ink)}

/* ===========================================================
   PROPUESTA · Cabecera Amarilla (manual "look & feel")
   Amarillo #FFED00 header + Verde content + logo Tinka 2025.
   Scoped to .topbar so the footer and body stay untouched.
   =========================================================== */
.topbar{
  background:linear-gradient(180deg,#FFEF33 0%,#FFE400 100%);
  border-bottom:1px solid rgba(0,72,26,.20);
  color:#00481A;
  box-shadow:0 6px 22px rgba(0,72,26,.16);
}
.topbar .brand .name{color:#00481A}
.topbar .brand .name small{color:#0A7A2C}
.topbar .brand-div{background:rgba(0,72,26,.24)}
/* logo 2025 sits directly on the yellow (transparent PNG) — no white chip */
.topbar .tinka-chip{background:transparent;box-shadow:none;padding:0;border-radius:0}
.topbar .tinka-chip img{height:30px}
.topbar .nav a{color:#0A6E27}
.topbar .nav a svg{opacity:.95}
.topbar .nav a:hover{color:#00481A;background:rgba(0,72,26,.10)}
.topbar .nav a.on{color:#00481A;background:rgba(0,72,26,.13);border-color:rgba(0,72,26,.20)}
.topbar .live-pill{background:rgba(0,72,26,.07);border-color:rgba(0,72,26,.20)}
.topbar .lp-lbl{color:#2C7A41}
.topbar .live-pill b{color:#00481A}
.topbar .theme-toggle,
.topbar .burger,
.topbar .top-act{color:#0A5E22;background:rgba(0,72,26,.07);border-color:rgba(0,72,26,.16)}
.topbar .theme-toggle:hover,
.topbar .burger:hover,
.topbar .top-act:hover{color:#00481A;background:rgba(0,72,26,.13)}
.topbar .top-act{color:#0A5E22}
.topbar .top-sep{background:rgba(0,72,26,.18)}
.topbar .top-act.accent{color:#00481A;
  background:linear-gradient(180deg,rgba(0,72,26,.13),rgba(0,72,26,.06));border-color:rgba(0,72,26,.22)}
.topbar .top-act.accent:hover{background:linear-gradient(180deg,rgba(0,72,26,.20),rgba(0,72,26,.10))}
.topbar .top-act.accent.on{background:#00481A;color:#FFED00;border-color:transparent}
.topbar .top-act .nav-badge,
.topbar .nav .nav-badge{box-shadow:0 0 0 2px #FFE400}



/* ===========================================================
   Compra online (checkout · pago · recibo)
   =========================================================== */
/* dual action footer in builder */
.bld-foot-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end;flex:1}
.builder-foot.bld-foot-buy .btn-outline{padding-left:15px;padding-right:15px}
@media (max-width:560px){
  .builder-foot{flex-wrap:wrap}
  .builder-foot .bld-total{order:-1}
  .bld-foot-actions{width:100%}
  .bld-foot-actions .btn{flex:1;justify-content:center}
}

/* order summary */
.pay-order{background:var(--paper-2);border:1px solid var(--line-2);border-radius:var(--r-md);padding:14px 16px;margin-bottom:20px}
.pay-order-h{font-family:var(--ff-disp);font-weight:800;font-size:13px;letter-spacing:.02em;margin-bottom:10px}
.pay-order-row{display:flex;align-items:center;gap:11px;padding:7px 0;border-bottom:1px solid var(--line-2)}
.pay-order-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.pay-order-info b{font-size:14px}
.pay-order-info span{font-size:12px}
.pay-order-amt{font-family:var(--ff-disp);font-weight:700;font-size:13.5px}
.pay-order-tot{display:flex;align-items:center;justify-content:space-between;padding-top:11px;margin-top:4px}
.pay-order-tot span{font-weight:700;color:var(--ink-2)}
.pay-order-tot b{font-family:var(--ff-disp);font-weight:800;font-size:22px;letter-spacing:-.02em}

/* payment methods */
.pay-methods{display:flex;flex-direction:column;gap:10px;margin:10px 0 4px}
.pay-method{display:flex;align-items:center;gap:13px;width:100%;text-align:left;cursor:pointer;
  padding:13px 15px;border:1.5px solid var(--line);border-radius:var(--r-md);background:var(--paper);transition:.15s}
.pay-method:hover{border-color:var(--blue-200)}
.pay-method.on{border-color:var(--blue);background:color-mix(in srgb, var(--blue) 7%, var(--paper))}
.pay-method-ic{width:42px;height:42px;flex:none;border-radius:12px;display:grid;place-items:center;
  background:var(--paper-2);border:1px solid var(--line-2);color:var(--blue)}
.pay-method.on .pay-method-ic{background:var(--blue);color:#fff;border-color:transparent}
.pay-method-txt{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.pay-method-txt b{font-family:var(--ff-disp);font-weight:700;font-size:15px}
.pay-method-txt span{font-size:12.5px}
.pay-radio{width:20px;height:20px;flex:none;border-radius:50%;border:2px solid var(--line);position:relative;transition:.15s}
.pay-radio.on{border-color:var(--blue)}
.pay-radio.on::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--blue)}

/* recharge */
.pay-recharge{margin-top:14px;padding:14px 16px;border-radius:var(--r-md);background:var(--gold-soft);border:1px solid rgba(255,203,0,.45)}
.pay-recharge-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.pay-recharge-top b{font-family:var(--ff-disp);font-weight:800;font-size:14px;color:#5e4500}
.pay-recharge-top .muted{color:#7a5a00!important;font-weight:700}
.pay-recharge-btns{display:flex;gap:8px;margin-top:11px}
.pay-recharge-btns button{flex:1;border:1.5px solid rgba(120,90,0,.25);background:var(--paper);border-radius:10px;
  padding:9px 0;cursor:pointer;font-family:var(--ff-disp);font-weight:800;font-size:13.5px;color:var(--gold-ink)}
.pay-recharge-btns button:hover{background:#fff;border-color:var(--gold-ink)}
.pay-recharge-note{display:block;margin-top:9px;font-size:11.5px;color:#7a5a00;font-weight:600}

.pay-aux{margin-top:13px;font-size:12.5px;color:var(--muted);line-height:1.5;background:var(--paper-2);
  border:1px solid var(--line-2);border-radius:12px;padding:12px 14px}
.pay-aux.full{grid-column:1/-1}
.pay-card{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
.pay-card-field{display:flex;flex-direction:column;gap:5px}
.pay-card-field.full{grid-column:1/-1}
.pay-card-field label{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.pay-card-field input{border:1.5px solid var(--line);border-radius:11px;padding:11px 13px;font-family:var(--ff-disp);
  font-weight:700;font-size:15px;background:var(--paper);color:var(--ink);outline:none;width:100%}
.pay-card-field input:focus{border-color:var(--blue)}

/* receipt */
.pay-done{align-items:center;text-align:center;display:flex;flex-direction:column}
.pay-done-check{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;margin:8px auto 4px;
  background:radial-gradient(120% 120% at 30% 20%, #2bd07a, var(--win) 60%, #0a6a26);
  box-shadow:0 12px 30px rgba(12,122,46,.4), inset 0 1px 0 rgba(255,255,255,.4);animation:winPop .5s cubic-bezier(.2,1.4,.4,1) both}
.pay-done-h{font-size:24px;font-weight:800;margin:10px 0 6px}
.pay-done-sub{font-size:14px;color:var(--muted);line-height:1.55;margin:0 auto 18px;max-width:380px}
.pay-done-card{width:100%;text-align:left;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--paper)}
.pay-done-meta{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-2)}
.pay-done-meta>div{background:var(--paper);padding:13px 16px;display:flex;flex-direction:column;gap:3px}
.pay-done-meta .muted{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.pay-done-meta b{font-family:var(--ff-disp);font-weight:800;font-size:15px}
.pay-done-plays{padding:8px 16px;border-top:1px solid var(--line-2)}
.pay-done-play{display:flex;align-items:center;gap:11px;padding:8px 0;border-bottom:1px solid var(--line-2)}
.pay-done-play:last-child{border-bottom:none}
.pay-done-cd{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;
  background:linear-gradient(120deg,var(--navy-800),var(--navy-700));color:#fff;flex-wrap:wrap}
.pay-done-cd .cd-lbl{color:var(--blue-200)}

/* paid badge in Mis tickets */
.mt-paid{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;
  background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.3);
  font-family:var(--ff-disp);font-weight:800;font-size:11px;letter-spacing:.02em}


/* ===========================================================
   Hoja de compartir (Compartir resultado · Invita y gana)
   =========================================================== */
.share-sheet{position:fixed;inset:0;z-index:120;display:flex;align-items:flex-end;justify-content:center}
@media (min-width:560px){.share-sheet{align-items:center}}
.share-scrim{position:absolute;inset:0;background:rgba(4,21,11,.62);backdrop-filter:blur(3px);animation:fadeIn .2s ease both}
.share-card{position:relative;width:100%;max-width:468px;background:var(--paper);border-radius:22px 22px 0 0;
  box-shadow:var(--sh-3);max-height:92vh;overflow-y:auto;animation:sheetUp .3s cubic-bezier(.2,.9,.3,1) both}
@media (min-width:560px){.share-card{border-radius:var(--r-lg);animation:winPop .32s cubic-bezier(.2,1.2,.4,1) both}}
.share-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  padding:20px 22px 14px;border-bottom:1px solid var(--line-2);position:sticky;top:0;background:var(--paper);z-index:2}
.share-body{padding:18px 22px 24px;display:flex;flex-direction:column;gap:16px}

.share-preview{border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);
  background:var(--navy-900);aspect-ratio:4/5;display:grid;place-items:center}
.share-preview img{width:100%;height:100%;object-fit:cover;display:block}
.share-preview-load{display:flex;align-items:center;gap:9px;color:var(--blue-200);font-weight:600;font-size:14px}

.share-invite{display:flex;flex-direction:column;align-items:center;text-align:center;gap:9px;
  padding:22px 18px;border-radius:var(--r-md);border:1px dashed var(--line);background:var(--paper-2)}
.share-invite-ic{width:60px;height:60px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--navy-800),var(--navy-700));color:#fff;margin-bottom:2px}
.share-invite b{font-family:var(--ff-disp);font-weight:800;font-size:15px}
.share-invite .muted{font-size:12.5px;max-width:320px;line-height:1.5}
.share-refcode{display:inline-flex;align-items:center;gap:10px;cursor:pointer;
  font-family:var(--ff-disp);font-weight:800;font-size:23px;letter-spacing:.08em;color:var(--blue);
  background:color-mix(in srgb,var(--blue) 9%,var(--paper));border:1.5px solid var(--blue-200);
  border-radius:13px;padding:9px 16px;transition:.15s}
.share-refcode:hover{border-color:var(--blue)}
.share-refcode.ok{background:var(--win-bg);border-color:var(--win);color:var(--win)}
.share-refcode svg{opacity:.7}

.share-msg{font-size:13.5px;line-height:1.55;color:var(--ink-2);background:var(--paper-2);
  border:1px solid var(--line-2);border-radius:13px;padding:13px 15px;text-wrap:pretty}

.share-channels{display:grid;grid-template-columns:repeat(4,1fr);gap:9px}
.share-ch{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;
  padding:13px 6px;border:1.5px solid var(--line);border-radius:15px;background:var(--paper);
  cursor:pointer;font-family:var(--ff-disp);font-weight:700;font-size:11.5px;color:var(--ink);
  transition:.15s;min-height:74px;text-align:center}
.share-ch svg{color:var(--blue)}
.share-ch:hover{border-color:var(--blue-200);transform:translateY(-1px)}
.share-ch.wa{background:#25D366;border-color:#25D366;color:#fff}
.share-ch.wa svg{color:#fff}
.share-ch.wa:hover{background:#1ebe5a;border-color:#1ebe5a}

.share-refrow{display:flex;align-items:center;gap:12px;padding:13px 15px;border-radius:13px;
  background:var(--gold-soft);border:1px solid rgba(255,203,0,.4)}
.share-refrow>div{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.share-refrow b{font-family:var(--ff-disp);font-weight:800;font-size:13.5px;color:#5e4500}
.share-refrow .muted{font-size:12px;color:#7a5a00!important}
.share-refrow .tnum{color:#5e4500}
.share-legal{font-size:11px;color:var(--muted-2);text-align:center;margin:2px 0 0;line-height:1.4}

@keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}


/* compartir en tarjeta de resultado (Resultados · Por día) */
.res-card{position:relative}
.res-share{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:9px;
  display:grid;place-items:center;cursor:pointer;border:1px solid var(--line);
  background:var(--paper);color:var(--blue);opacity:0;transform:translateY(-2px);transition:.15s;z-index:2}
.res-card:hover .res-share,.res-share:focus-visible{opacity:1;transform:translateY(0)}
.res-share:hover{border-color:var(--blue);background:color-mix(in srgb,var(--blue) 8%,var(--paper))}
@media (hover:none){.res-share{opacity:1;transform:none}}


/* botón Compartir por WhatsApp (detalle del animalito) */
.btn-share-wa{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:#25D366;border:1px solid #25D366;color:#fff}
.btn-share-wa:hover{background:#1ebe5a;border-color:#1ebe5a}
.btn-share-wa svg{flex:none}


/* ===========================================================
   Mejoras: barra en vivo · recordatorios · buscador · foco
   =========================================================== */
/* Barra en vivo global (vistas distintas a Inicio) */
.livebar{position:sticky;top:var(--topbar-h,66px);z-index:39;background:var(--paper);
  border-bottom:1px solid var(--line);backdrop-filter:saturate(1.2) blur(6px)}
.livebar-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:9px 24px;flex-wrap:wrap}
.livebar-tag{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.livebar-last{display:inline-flex;align-items:center;gap:9px;cursor:pointer;background:none;border:0;
  padding:4px 6px;border-radius:10px;color:var(--ink);transition:.15s}
.livebar-last:hover{background:var(--paper-2)}
.livebar-last b{font-family:var(--ff-disp);font-weight:700;font-size:14px}
.livebar-last .livebar-hr{font-size:12px}
.livebar-next{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.livebar-next .livebar-tag{margin-right:2px}
.livebar-bell{display:inline-flex;align-items:center;gap:6px;cursor:pointer;border:1.5px solid var(--line);
  background:var(--paper);color:var(--ink-2);border-radius:999px;padding:6px 12px;
  font-family:var(--ff-disp);font-weight:700;font-size:12.5px;transition:.15s}
.livebar-bell:hover{border-color:var(--gold);color:var(--ink)}
.livebar-bell.on{background:var(--gold-soft);border-color:var(--gold);color:var(--gold-ink)}
.livebar-play{padding-left:16px;padding-right:16px}
/* Countdown on white livebar — override the dark-bg defaults */
.livebar .cd-box{color:var(--ink);background:var(--paper-2);border-color:var(--line);
  box-shadow:var(--sh-1)}
.livebar .cd-box::after{background:var(--line)}
.livebar .cd-sep{color:var(--muted-2)}
.livebar .cd-lbl{color:var(--muted)}
@media (max-width:640px){
  .livebar-inner{padding:8px 16px;gap:8px}
  .livebar-last .livebar-hr{display:none}
  .livebar-bell span{display:none}
  .livebar-bell{padding:7px}
}

/* Campana "Avísame" en el hero */
.hero-bell{display:inline-flex;align-items:center;gap:8px;cursor:pointer;
  border:1.5px solid rgba(255,255,255,.35);background:rgba(255,255,255,.08);color:#fff;
  border-radius:999px;padding:0 18px;height:48px;font-family:var(--ff-disp);font-weight:700;font-size:14.5px;transition:.15s}
.hero-bell:hover{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.6)}
.hero-bell.on{background:var(--gold);border-color:var(--gold);color:#3a2b00}

/* Buscador de animalitos (roster) */
.roster-search{position:relative;display:flex;align-items:center;margin:2px 0 18px;max-width:440px}
.roster-search>svg{position:absolute;left:14px;color:var(--muted);pointer-events:none}
.roster-search input{width:100%;border:1.5px solid var(--line);border-radius:13px;
  padding:12px 40px 12px 42px;font-family:var(--ff-body);font-size:14.5px;background:var(--paper);
  color:var(--ink);outline:none;transition:.15s}
.roster-search input:focus{border-color:var(--blue);box-shadow:0 0 0 4px color-mix(in srgb,var(--blue) 14%,transparent)}
.roster-search-clear{position:absolute;right:8px;width:28px;height:28px;border:0;border-radius:8px;
  background:var(--paper-2);color:var(--muted);cursor:pointer;font-size:13px}
.roster-search-clear:hover{background:var(--line-2);color:var(--ink)}

/* #11 Accesibilidad: foco visible y consistente para teclado */
:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:6px}
.btn:focus-visible,.top-act:focus-visible,.nav a:focus-visible,.fb-chip:focus-visible,
.roster-cell:focus-visible,.livebar-bell:focus-visible,.hero-bell:focus-visible,
.share-ch:focus-visible,.bld-an:focus-visible{outline:3px solid var(--blue);outline-offset:2px}
.hero-bell:focus-visible,.btn-ghost:focus-visible{outline-color:#fff}
