/* ============================================================
   ISAF HEART BRACKET 2026 — GLOBAL STYLESHEET v3
   Design: Dark editorial · Gold accents · Heart red
   ============================================================ */

/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
img,video{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer}
a{text-decoration:none}

/* ── TOKENS ── */
:root{
  --c-bg:      #07101F;
  --c-bg2:     #0C1829;
  --c-bg3:     #122038;
  --c-bg4:     #1A2D4A;
  --c-heart:   #E8334A;
  --c-heart2:  #C0202F;
  --c-heart3:  rgba(232,51,74,.35);
  --c-gold:    #F4C430;
  --c-gold2:   #FFE080;
  --c-green:   #27AE60;
  --c-white:   #EDE8DC;
  --c-w2:      #B8B0A0;
  --c-gray:    #6A7D9A;
  --c-gray2:   #3D5070;
  --c-border:  rgba(255,255,255,.07);
  --c-border2: rgba(255,255,255,.12);
  --font-d: 'Bebas Neue', sans-serif;
  --font-b: 'DM Sans', sans-serif;
  --font-a: 'Fraunces', serif;
  --r:  8px;
  --rl: 14px;
  --rx: 20px;
  --sh:  0 4px 32px rgba(0,0,0,.5);
  --sh2: 0 0 40px rgba(232,51,74,.2);
  --trans: all .22s ease;
  --max: 1100px;
  --gutter: clamp(16px,4vw,40px);
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--c-bg);
  color:var(--c-white);
  font-family:var(--font-b);
  font-size:16px;
  line-height:1.65;
  overflow-x:hidden;
  min-height:100vh;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--c-bg)}
::-webkit-scrollbar-thumb{background:var(--c-bg4);border-radius:3px}

/* ── LANG TOGGLE ── */
.lang-wrap{display:flex;gap:2px;background:rgba(255,255,255,.06);border:1px solid var(--c-border2);border-radius:20px;padding:3px}
.lb-lang{background:none;border:none;color:var(--c-gray);font-size:11px;font-weight:700;padding:4px 11px;border-radius:14px;letter-spacing:.5px;transition:var(--trans)}
.lb-lang.active{background:var(--c-heart);color:#fff}
.lb-lang:hover:not(.active){color:var(--c-white)}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:300;
  height:62px;display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--gutter);
  background:rgba(7,16,31,.92);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--c-border);
  transition:border-color .3s;
}
.nav.nav-scrolled{border-bottom-color:rgba(232,51,74,.25)}
.nav-logo{display:flex;align-items:center;gap:6px;font-family:var(--font-d);font-size:22px;letter-spacing:2px;color:var(--c-white)}
.nav-logo .hrt{color:var(--c-heart)}
.nav-mid{display:flex;align-items:center;gap:22px}
.nav-mid a{color:var(--c-gray);font-size:14px;font-weight:500;transition:color .2s}
.nav-mid a:hover{color:var(--c-white)}
.nav-cta-link{background:var(--c-heart)!important;color:#fff!important;padding:8px 20px!important;border-radius:var(--r);font-weight:700!important}
.nav-cta-link:hover{background:var(--c-heart2)!important}
.nav-r{display:flex;align-items:center;gap:10px}
.nav-burger{display:none;background:none;border:none;color:var(--c-white);font-size:24px;line-height:1}

/* mobile menu */
.mob-nav{
  display:none;position:fixed;top:62px;left:0;right:0;z-index:299;
  background:var(--c-bg2);border-bottom:1px solid var(--c-border);
  padding:16px var(--gutter);flex-direction:column;gap:12px;
  transform:translateY(-110%);transition:transform .28s ease;
}
.mob-nav.open{transform:translateY(0)}
.mob-nav a{color:var(--c-gray);font-size:16px;padding:8px 0;border-bottom:1px solid var(--c-border)}
.mob-nav .mob-cta{background:var(--c-heart);color:#fff;padding:12px 20px;border-radius:var(--r);text-align:center;font-weight:700;border:none!important}
.mob-lang{display:flex;gap:8px;padding-top:6px}
.mob-lang .lb-lang{padding:8px 16px;font-size:13px}

/* ── LEGAL BANNER ── */
.legal-banner{
  background:rgba(232,51,74,.08);
  border-bottom:1px solid rgba(232,51,74,.2);
  padding:10px var(--gutter);
  text-align:center;
  font-size:13px;
  color:var(--c-w2);
  position:relative;z-index:10;
}
.legal-banner strong{color:var(--c-white)}
.legal-banner a{color:var(--c-gold);margin-left:8px;font-weight:600}

/* ── HERO ── */
.hero{
  min-height:100vh;
  display:flex;align-items:center;justify-content:space-between;
  padding:calc(62px + 60px) var(--gutter) 60px;
  position:relative;overflow:hidden;gap:32px;
  flex-wrap:wrap;
}
/* background atmosphere */
.hero::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 60% 60% at 15% 30%,rgba(232,51,74,.1) 0%,transparent 70%),
    radial-gradient(ellipse 50% 50% at 85% 70%,rgba(244,196,48,.07) 0%,transparent 70%);
}
/* grid */
.hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(var(--c-border) 1px,transparent 1px),
    linear-gradient(90deg,var(--c-border) 1px,transparent 1px);
  background-size:52px 52px;opacity:.5;
}
.hero-content{position:relative;z-index:2;flex:1;min-width:280px;max-width:580px}
.hero-eyebrow{
  display:flex;align-items:center;gap:9px;
  font-size:10px;letter-spacing:3px;color:var(--c-gray);
  text-transform:uppercase;font-weight:700;margin-bottom:20px;
}
.eyebrow-dot{width:8px;height:8px;background:var(--c-heart);border-radius:50%;animation:blink 1.6s ease-in-out infinite;flex-shrink:0}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.2}}
.hero-h1{font-family:var(--font-d);font-size:clamp(58px,10vw,108px);line-height:.88;letter-spacing:2px;margin-bottom:22px}
.hero-h1 em{font-family:var(--font-a);font-style:italic;color:var(--c-gold);font-size:.82em;display:block}
.hero-desc{font-size:clamp(15px,2vw,17px);color:var(--c-gray);line-height:1.75;margin-bottom:12px}
.hero-desc strong{color:var(--c-white)}
.hero-free{font-size:13px;color:var(--c-gold);margin-bottom:28px;display:block;transition:color .2s}
.hero-free:hover{color:var(--c-gold2)}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.hero-trust{display:flex;gap:14px;flex-wrap:wrap;font-size:11px;color:var(--c-gray2)}

/* BALL */
.hero-visual{position:relative;z-index:2;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.ball-wrap{width:clamp(180px,28vw,280px);height:clamp(180px,28vw,280px);position:relative;display:flex;align-items:center;justify-content:center}
.ball-emoji{font-size:clamp(64px,12vw,90px);animation:float 4s ease-in-out infinite;filter:drop-shadow(0 20px 40px rgba(232,51,74,.3));position:relative;z-index:2}
@keyframes float{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-14px) rotate(8deg)}}
.ring{position:absolute;border-radius:50%;border:1px solid;animation:rpulse 3s ease-in-out infinite}
.r1{width:44%;height:44%;border-color:rgba(232,51,74,.2)}
.r2{width:68%;height:68%;border-color:rgba(244,196,48,.12);animation-delay:.4s}
.r3{width:93%;height:93%;border-color:rgba(232,51,74,.07);animation-delay:.8s}
@keyframes rpulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.04);opacity:1}}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-b);font-weight:700;border:none;border-radius:var(--r);transition:var(--trans);white-space:nowrap}
.btn-primary{background:var(--c-heart);color:#fff;padding:clamp(10px,2vw,14px) clamp(20px,4vw,34px);font-size:clamp(14px,2vw,16px)}
.btn-primary:hover{background:var(--c-heart2);transform:translateY(-2px);box-shadow:var(--sh2)}
.btn-secondary{background:transparent;color:var(--c-white);border:1px solid rgba(255,255,255,.18);padding:clamp(10px,2vw,14px) clamp(18px,3vw,30px);font-size:clamp(13px,2vw,15px)}
.btn-secondary:hover{border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.04);transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.05);color:var(--c-gray);border:1px solid var(--c-border);padding:8px 16px;font-size:13px}
.btn-ghost:hover{background:rgba(255,255,255,.09);color:var(--c-white)}
.btn-sm{padding:8px 18px!important;font-size:13px!important}
.btn-xl{padding:clamp(14px,2vw,20px) clamp(32px,5vw,54px)!important;font-size:clamp(15px,2vw,19px)!important}

/* ── TICKER ── */
.ticker{background:var(--c-bg2);border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);padding:18px var(--gutter)}
.ticker-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:center;gap:clamp(16px,4vw,36px);flex-wrap:wrap}
.t-stat{display:flex;align-items:baseline;gap:8px}
.t-num{font-family:var(--font-d);font-size:clamp(28px,5vw,40px);color:var(--c-gold);line-height:1}
.t-lbl{font-size:clamp(11px,1.5vw,14px);color:var(--c-gray)}
.t-sep{color:var(--c-gray2);font-size:18px}

/* ── LAYOUT ── */
.section{padding:clamp(48px,8vw,90px) var(--gutter)}
.wrap{max-width:var(--max);margin:0 auto}
.s-eyebrow{font-family:var(--font-d);font-size:11px;letter-spacing:4px;color:var(--c-heart);margin-bottom:12px}
.s-eyebrow.light{color:rgba(255,255,255,.3)}
.s-title{font-family:var(--font-d);font-size:clamp(32px,5vw,56px);line-height:1;color:var(--c-white);margin-bottom:12px}
.s-title em{font-family:var(--font-a);font-style:italic;color:var(--c-gold)}
.s-sub{color:var(--c-gray);font-size:clamp(14px,2vw,17px);margin-bottom:clamp(28px,5vw,48px);max-width:640px}

/* ── HOW ── */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:clamp(24px,4vw,44px)}
.step-card{background:rgba(255,255,255,.03);border:1px solid var(--c-border);border-radius:var(--rl);padding:clamp(22px,4vw,36px) clamp(18px,3vw,28px);position:relative;overflow:hidden;transition:var(--trans)}
.step-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(232,51,74,.5),transparent);opacity:0;transition:opacity .3s}
.step-card:hover{border-color:rgba(232,51,74,.25);transform:translateY(-4px)}
.step-card:hover::before{opacity:1}
.step-accent{background:rgba(232,51,74,.05);border-color:rgba(232,51,74,.18)}
.step-num{font-family:var(--font-d);font-size:52px;color:rgba(255,255,255,.04);line-height:1;margin-bottom:-6px}
.step-icon{font-size:clamp(28px,4vw,36px);margin-bottom:14px;display:block}
.step-card h3{font-size:clamp(16px,2.5vw,20px);font-weight:700;margin-bottom:10px}
.step-card p{color:var(--c-gray);font-size:clamp(13px,1.8vw,15px);line-height:1.65;margin-bottom:12px}
.step-links{display:flex;flex-direction:column;gap:6px}
.step-link{color:var(--c-gold);font-size:13px;font-weight:600;transition:color .2s}
.step-link:hover{color:var(--c-gold2)}
.step-link-free{color:var(--c-gray);font-size:12px;transition:color .2s}
.step-link-free:hover{color:var(--c-w2)}

/* ── PRIZE TABLE ── */
.prize-section{background:var(--c-bg2);border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border)}
.prize-layout{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:start}
.prize-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.prize-table{width:100%;border-collapse:collapse;min-width:320px}
.prize-table thead tr{background:rgba(244,196,48,.06)}
.prize-table th{font-family:var(--font-d);font-size:12px;letter-spacing:2px;color:var(--c-gold);padding:12px 16px;text-align:left;border-bottom:1px solid rgba(244,196,48,.15)}
.prize-table td{padding:12px 16px;font-size:14px;border-bottom:1px solid var(--c-border);color:var(--c-w2)}
.prize-table tr:last-child td{border-bottom:none}
.prize-table .prize-winner{color:var(--c-gold);font-weight:700;font-size:16px}
.prize-table tr:hover td{background:rgba(255,255,255,.02)}
.prize-note{font-size:11px;color:var(--c-gray);margin-top:10px;font-style:italic}
.prize-art-card{background:rgba(244,196,48,.04);border:1px solid rgba(244,196,48,.25);border-radius:var(--rl);padding:clamp(20px,3vw,30px);text-align:center}
.prize-art-eyebrow{font-family:var(--font-d);font-size:10px;letter-spacing:3px;color:var(--c-gold);margin-bottom:10px}
.prize-art-icon{font-size:clamp(36px,6vw,52px);margin-bottom:14px;display:block}
.prize-art-card h3{font-size:clamp(18px,2.5vw,22px);font-weight:700;margin-bottom:10px}
.prize-art-card p{color:var(--c-gray);font-size:clamp(12px,1.8vw,14px);line-height:1.6;margin-bottom:10px}
.prize-art-value{font-size:12px;font-weight:700;color:var(--c-gold)}

/* ── SCORING ── */
.score-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(clamp(140px,18vw,180px),1fr));gap:12px;margin-top:clamp(20px,3vw,36px)}
.sc-item{background:rgba(255,255,255,.03);border:1px solid var(--c-border);border-radius:var(--r);padding:clamp(16px,2.5vw,24px) clamp(12px,2vw,18px);text-align:center}
.sc-hl{border-color:rgba(244,196,48,.28);background:rgba(244,196,48,.05)}
.sc-pts{font-family:var(--font-d);font-size:clamp(36px,5vw,48px);color:var(--c-gold);line-height:1;margin-bottom:6px}
.sc-label{font-size:clamp(11px,1.5vw,13px);color:var(--c-gray);line-height:1.4}

/* ── MISSION ── */
.mission{background:var(--c-bg2);border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border)}
.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,6vw,72px);align-items:center}
.mission-text h2{font-family:var(--font-d);font-size:clamp(30px,4.5vw,50px);line-height:1;margin-bottom:18px}
.mission-text p{color:var(--c-gray);font-size:clamp(13px,1.8vw,16px);line-height:1.75;margin-bottom:14px}
.mission-text p strong{color:var(--c-white)}
.art-frame{border:2px solid rgba(244,196,48,.2);border-radius:var(--rl);aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.015)}
.art-inner{text-align:center;padding:28px}
.art-hrt{font-size:clamp(40px,7vw,60px);color:var(--c-heart);display:block;margin-bottom:14px;animation:hbeat 2s ease-in-out infinite}
@keyframes hbeat{0%,100%{transform:scale(1)}14%{transform:scale(1.1)}28%{transform:scale(1)}42%{transform:scale(1.1)}}
.art-cap{font-size:14px;color:var(--c-gray);font-style:italic}
.art-cap span{display:block;font-size:11px;color:var(--c-gray2);margin-top:4px}

/* ── TIMELINE ── */
.timeline-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:clamp(20px,3vw,36px);counter-reset:tl}
.tl-item{background:rgba(255,255,255,.03);border:1px solid var(--c-border);border-radius:var(--r);padding:clamp(18px,2.5vw,24px);position:relative;counter-increment:tl}
.tl-item::before{content:counter(tl);font-family:var(--font-d);font-size:40px;color:rgba(255,255,255,.04);position:absolute;top:8px;right:12px;line-height:1}
.tl-dot{width:32px;height:32px;background:var(--c-heart);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;margin-bottom:12px}
.tl-item h4{font-size:15px;font-weight:700;margin-bottom:6px}
.tl-item p{font-size:13px;color:var(--c-gray);line-height:1.5}

/* ── LEGAL SECTION ── */
.legal-section{background:rgba(232,51,74,.04);border:1px solid rgba(232,51,74,.15);border-radius:var(--rl);padding:clamp(24px,4vw,40px)}
.legal-section h3{font-family:var(--font-d);font-size:clamp(22px,3vw,30px);margin-bottom:12px}
.legal-section p{font-size:clamp(13px,1.8vw,15px);color:var(--c-gray);line-height:1.7;margin-bottom:12px}
.legal-section p strong{color:var(--c-white)}
.legal-rules-box{background:rgba(0,0,0,.3);border-left:3px solid var(--c-heart);padding:14px 18px;border-radius:0 var(--r) var(--r) 0;font-size:12px;color:var(--c-gray);line-height:1.7;margin-top:16px}

/* ── FINAL CTA ── */
.final-cta{text-align:center;position:relative;overflow:hidden;padding:clamp(60px,10vw,110px) var(--gutter)}
.cta-bg-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-d);font-size:clamp(80px,16vw,200px);color:rgba(255,255,255,.012);letter-spacing:10px;pointer-events:none;white-space:nowrap;user-select:none}
.cta-inner{position:relative;z-index:1}
.cta-inner h2{font-family:var(--font-d);font-size:clamp(42px,8vw,88px);line-height:.9;margin-bottom:14px}
.cta-inner p{color:var(--c-gray);font-size:clamp(15px,2vw,18px);margin-bottom:36px}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:10px}
.cta-note{font-size:11px;color:var(--c-gray2)}

/* ── FOOTER ── */
.footer{background:var(--c-bg2);border-top:1px solid var(--c-border);padding:clamp(28px,4vw,44px) var(--gutter)}
.footer-inner{max-width:var(--max);margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.footer-brand{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700}
.footer-hrt{color:var(--c-heart);font-size:20px}
.footer-links{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}
.footer-links a{color:var(--c-gray);font-size:13px;transition:color .2s}
.footer-links a:hover{color:var(--c-white)}
.footer-legal{font-size:11px;color:var(--c-gray2);line-height:1.8;max-width:580px}

/* ────────────────────────────────
   QUINIELA APP PAGE
──────────────────────────────── */
.q-body{background:#0D0D0D;padding-top:62px}

/* ACCESS GATE — fondo con imagen de Isabella */
.gate{
  min-height:calc(100vh - 62px);
  display:flex;align-items:center;justify-content:center;
  padding:clamp(24px,5vw,48px) var(--gutter);
  position:relative;
  overflow:hidden;
  background:#0D0D0D;
}
.gate-img-bg{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;
  object-fit:cover;object-position:center top;
  opacity:.22;
  pointer-events:none;
}
.gate-overlay{
  position:absolute;inset:0;z-index:1;
  background:radial-gradient(ellipse 100% 100% at 50% 40%,
    rgba(13,13,13,.4) 0%,rgba(13,13,13,.88) 70%,rgba(13,13,13,.96) 100%);
}
.gate-card{
  position:relative;z-index:2;
  background:rgba(15,15,15,.88);
  border:1px solid rgba(232,160,192,.18);
  border-radius:16px;
  padding:clamp(28px,5vw,48px) clamp(22px,4vw,40px);
  max-width:400px;width:100%;text-align:center;
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
.gate-hrt{font-size:48px;color:#E8A0C0;margin-bottom:16px;animation:hbeat 2s ease-in-out infinite}
.gate-card h2{font-family:'Playfair Display',Georgia,serif;font-size:28px;font-weight:900;letter-spacing:1px;margin-bottom:4px;color:#FFFFFF}
.gate-card .gate-sub{color:#C9A84C;font-size:13px;font-weight:600;margin-bottom:20px;display:block}
.gate-card .gate-desc{color:var(--c-gray);font-size:14px;margin-bottom:22px}
.gate-group{display:flex;gap:8px;margin-bottom:6px}
.gate-input{flex:1;background:rgba(255,255,255,.06);border:1px solid var(--c-border2);border-radius:var(--r);padding:11px 14px;color:var(--c-white);font-family:var(--font-b);font-size:13px;font-weight:700;letter-spacing:2px;outline:none;transition:border-color .2s}
.gate-input:focus{border-color:var(--c-heart)}
.gate-input::placeholder{color:var(--c-gray);font-weight:400;letter-spacing:0}
.gate-err{min-height:18px;font-size:12px;color:#FF5E74;margin-bottom:12px}
.gate-div{display:flex;align-items:center;gap:10px;color:var(--c-gray2);font-size:12px;margin:16px 0}
.gate-div::before,.gate-div::after{content:'';flex:1;height:1px;background:var(--c-border)}
.gate-donate-btn{width:100%;justify-content:center;padding:13px;font-size:15px;margin-bottom:8px}
.gate-note-txt{font-size:10px;color:var(--c-gray2);margin-bottom:14px;display:block}
.gate-free-link{color:var(--c-gold);font-size:12px;font-weight:600;display:block;margin-bottom:10px;transition:color .2s}
.gate-free-link:hover{color:var(--c-gold2)}
.gate-demo-btn{background:none;border:none;color:var(--c-gray);font-size:12px;text-decoration:underline;font-family:var(--font-b);transition:color .2s}
.gate-demo-btn:hover{color:var(--c-w2)}

/* PLAYER HEADER */
.player-hdr{background:var(--c-bg2);border-bottom:1px solid var(--c-border);padding:clamp(10px,2vw,16px) var(--gutter);display:flex;align-items:center;gap:clamp(12px,2vw,20px);flex-wrap:wrap}
.p-av{width:42px;height:42px;background:var(--c-heart);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-size:20px;color:#fff;flex-shrink:0}
.p-info{flex:1;min-width:120px}
.p-name{font-size:15px;font-weight:700}
.p-code{font-size:10px;color:var(--c-gray);letter-spacing:1.5px;font-family:monospace}
.p-stats{display:flex;gap:clamp(14px,3vw,24px)}
.pst{text-align:center}
.pst-n{font-family:var(--font-d);font-size:clamp(22px,3.5vw,28px);color:var(--c-gold);line-height:1}
.pst-l{font-size:9px;color:var(--c-gray);text-transform:uppercase;letter-spacing:1px}
.p-actions{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.btn-share{background:rgba(255,255,255,.06);border:1px solid var(--c-border2);color:var(--c-white);padding:9px 16px;border-radius:var(--r);font-size:12px;font-weight:600;transition:var(--trans)}
.btn-share:hover{background:rgba(255,255,255,.1)}
.nav-donate-btn{background:#C4658F;color:#fff;padding:8px 14px;border-radius:var(--r);font-size:12px;font-weight:700;transition:background .2s;white-space:nowrap}
.nav-donate-btn:hover{background:#E8A0C0;color:#0D0D0D}
.nav-pts{font-family:'Playfair Display',Georgia,serif;font-size:18px;color:#C9A84C;font-weight:700}
.nav-app-title{font-family:'Playfair Display',Georgia,serif;font-size:13px;font-weight:700;letter-spacing:1px;position:absolute;left:50%;transform:translateX(-50%);white-space:nowrap;pointer-events:none}

/* PHASE TABS */
.phase-bar{background:var(--c-bg2);border-bottom:1px solid var(--c-border);position:sticky;top:62px;z-index:100}
.ptabs{display:flex;overflow-x:auto;scrollbar-width:none;padding:0 8px}
.ptabs::-webkit-scrollbar{display:none}
.ptab{flex-shrink:0;background:none;border:none;border-bottom:3px solid transparent;color:var(--c-gray);font-family:var(--font-b);font-size:clamp(11px,1.5vw,13px);font-weight:600;padding:clamp(10px,1.5vw,14px) clamp(12px,2vw,18px) clamp(8px,1.2vw,11px);transition:var(--trans);display:flex;align-items:center;gap:5px;white-space:nowrap}
.ptab:hover{color:var(--c-white)}
.ptab.active{color:var(--c-white);border-bottom-color:var(--c-heart)}
.ptab-cnt{font-size:9px;background:rgba(255,255,255,.08);padding:2px 5px;border-radius:8px;color:var(--c-gray)}
.ptab.active .ptab-cnt{background:rgba(232,51,74,.2);color:#FF8099}
.ptab-tabla{margin-left:auto}

/* CONTENT */
.q-content{max-width:880px;margin:0 auto;padding:clamp(16px,3vw,26px) clamp(12px,2vw,18px) 100px}
.phase-view{display:none}
.phase-view.active{display:block}
.view-hdr{margin-bottom:clamp(14px,2.5vw,22px)}
.view-hdr h3{font-size:clamp(18px,3vw,23px);font-weight:700;margin-bottom:5px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.view-hdr p{color:var(--c-gray);font-size:13px}
.mult-badge{font-size:11px;background:rgba(244,196,48,.14);color:var(--c-gold);padding:3px 10px;border-radius:14px;border:1px solid rgba(244,196,48,.24);font-weight:600}

/* MATCH CARDS */
.match-list{display:flex;flex-direction:column;gap:10px}
.grp-hdr{font-family:var(--font-d);font-size:12px;letter-spacing:3px;color:var(--c-gray2);padding:8px 0 4px;border-bottom:1px solid var(--c-border);margin:10px 0 4px}
.match-card{background:rgba(255,255,255,.03);border:1px solid var(--c-border);border-radius:var(--r);overflow:hidden;position:relative;transition:border-color .2s}
.match-card:hover{border-color:var(--c-border2)}
.match-card.done{border-color:rgba(39,174,96,.2)}
.match-meta{display:flex;align-items:center;justify-content:space-between;padding:7px clamp(10px,2vw,14px);background:rgba(255,255,255,.02);border-bottom:1px solid var(--c-border);font-size:10px;color:var(--c-gray2);letter-spacing:.3px}
.match-pts-b{font-size:9px;background:rgba(244,196,48,.1);color:var(--c-gold);padding:2px 7px;border-radius:6px;font-weight:700}
.match-teams{display:flex;align-items:center;padding:clamp(8px,1.5vw,13px);gap:clamp(6px,1.5vw,10px)}
.team-blk{flex:1;display:flex;align-items:center;gap:clamp(6px,1.5vw,10px);padding:clamp(7px,1.5vw,10px) clamp(8px,1.5vw,12px);border-radius:7px;border:2px solid transparent;transition:var(--trans);min-width:0;cursor:pointer}
.team-blk:hover{background:rgba(232,51,74,.06);border-color:rgba(232,51,74,.15)}
.team-blk.sel{background:rgba(232,51,74,.1);border-color:var(--c-heart)}
.team-blk.right{flex-direction:row-reverse}
.t-flag{font-size:clamp(20px,3.5vw,28px);flex-shrink:0}
.t-name{font-size:clamp(11px,1.8vw,14px);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}
.team-blk.right .t-name{text-align:right}
.vs-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}
.vs-txt{font-family:var(--font-d);font-size:17px;color:var(--c-gray2);letter-spacing:2px}
.score-row{display:flex;align-items:center;justify-content:center;gap:clamp(5px,1vw,8px);padding:clamp(7px,1.2vw,10px) clamp(10px,2vw,14px) clamp(10px,1.5vw,14px);border-top:1px solid var(--c-border)}
.sc-lbl{font-size:10px;color:var(--c-gray2);letter-spacing:.8px;margin-right:2px}
.sc-in{width:42px;background:rgba(255,255,255,.06);border:1px solid var(--c-border2);border-radius:6px;padding:5px;color:var(--c-white);font-family:var(--font-d);font-size:22px;text-align:center;outline:none;transition:border-color .2s;-moz-appearance:textfield}
.sc-in::-webkit-outer-spin-button,.sc-in::-webkit-inner-spin-button{-webkit-appearance:none}
.sc-in:focus{border-color:var(--c-gold)}
.sc-dash{font-family:var(--font-d);font-size:20px;color:var(--c-gray2)}
.sc-bonus{font-size:11px;color:var(--c-gold);animation:pop .3s ease}
@keyframes pop{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}
.done-chk{position:absolute;top:8px;right:9px;width:18px;height:18px;background:var(--c-green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;font-weight:700;opacity:0;transition:opacity .3s}
.match-card.done .done-chk{opacity:1}

/* CHAMPION */
.champ-zone{background:linear-gradient(135deg,rgba(244,196,48,.08),rgba(232,51,74,.06));border:2px solid rgba(244,196,48,.38);border-radius:var(--rl);padding:clamp(24px,4vw,40px);text-align:center;margin-top:20px}
.champ-trophy{font-size:clamp(48px,8vw,64px);display:block;margin-bottom:14px}
.champ-lbl{font-family:var(--font-d);font-size:13px;letter-spacing:4px;color:var(--c-gold);margin-bottom:8px}
.champ-name{font-family:var(--font-d);font-size:clamp(30px,5vw,40px)}
.champ-flag{font-size:clamp(30px,5vw,40px);display:block;margin-bottom:6px}

/* SAVE BAR */
.save-bar{position:fixed;bottom:0;left:0;right:0;background:var(--c-bg2);border-top:1px solid var(--c-border2);padding:clamp(9px,1.5vw,13px) var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:14px;z-index:80}
.save-info{flex:1;min-width:0}
.save-txt{font-size:11px;color:var(--c-gray);display:block;margin-bottom:5px}
.save-track{background:rgba(255,255,255,.08);height:4px;border-radius:4px;overflow:hidden}
.save-fill{height:100%;background:linear-gradient(90deg,var(--c-heart),var(--c-gold));border-radius:4px;transition:width .4s ease;width:0}
.btn-save{background:var(--c-heart);color:#fff;border:none;border-radius:var(--r);padding:clamp(9px,1.5vw,12px) clamp(16px,2.5vw,24px);font-family:var(--font-b);font-weight:700;font-size:13px;transition:var(--trans);white-space:nowrap}
.btn-save:hover{background:var(--c-heart2);transform:translateY(-1px)}

/* LEADERBOARD */
.lb-table{background:rgba(255,255,255,.02);border:1px solid var(--c-border);border-radius:var(--rl);overflow:hidden}
.lb-row{display:flex;align-items:center;padding:clamp(10px,2vw,14px) clamp(14px,2.5vw,20px);gap:clamp(10px,2vw,14px);border-bottom:1px solid var(--c-border);transition:background .15s}
.lb-row:last-child{border-bottom:none}
.lb-row:hover{background:rgba(255,255,255,.03)}
.lb-row.me{background:rgba(232,51,74,.07);border-left:3px solid var(--c-heart)}
.lb-rank{font-family:var(--font-d);font-size:clamp(16px,2.5vw,20px);width:28px;text-align:center;flex-shrink:0}
.lb-rank.gold{color:var(--c-gold)}
.lb-rank.silver{color:var(--c-w2)}
.lb-rank.bronze{color:#CD7F32}
.lb-av{width:34px;height:34px;border-radius:50%;background:var(--c-bg4);display:flex;align-items:center;justify-content:center;font-family:var(--font-d);font-size:15px;color:var(--c-gray);flex-shrink:0}
.lb-info{flex:1;min-width:0}
.lb-name{font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lb-code{font-size:10px;color:var(--c-gray2);font-family:monospace}
.lb-pts{font-family:var(--font-d);font-size:clamp(18px,3vw,24px);color:var(--c-gold)}
.lb-ptsl{font-size:9px;color:var(--c-gray2)}
.lb-note{padding:14px;text-align:center;font-size:12px;color:var(--c-gray);border-top:1px solid var(--c-border)}
.lb-note a{color:var(--c-gold)}
.lb-me-tag{font-size:10px;color:var(--c-heart)}

/* MODALS */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.82);display:flex;align-items:center;justify-content:center;z-index:500;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(6px);padding:24px}
.modal-ov.open{opacity:1;pointer-events:all}
.modal-box{background:var(--c-bg3);border:1px solid var(--c-border2);border-radius:var(--rl);padding:clamp(28px,5vw,42px) clamp(22px,4vw,34px);max-width:420px;width:100%;text-align:center;transform:scale(.95);transition:transform .28s}
.modal-ov.open .modal-box{transform:scale(1)}
.modal-icon{font-size:52px;margin-bottom:14px;display:block}
.modal-box h2{font-family:var(--font-d);font-size:28px;letter-spacing:2px;color:var(--c-gold);margin-bottom:10px}
.modal-box p{color:var(--c-gray);font-size:14px;line-height:1.65;margin-bottom:16px}
.share-opts{display:flex;gap:9px;justify-content:center;margin-top:8px}
.s-opt{flex:1;padding:11px;border-radius:var(--r);border:none;font-family:var(--font-b);font-size:13px;font-weight:700;transition:var(--trans)}
.s-wa{background:#25D366;color:#fff}.s-wa:hover{background:#1daa57}
.s-cp{background:rgba(255,255,255,.08);color:var(--c-white);border:1px solid var(--c-border2)}.s-cp:hover{background:rgba(255,255,255,.13)}

/* TOAST */
.toast{position:fixed;bottom:clamp(16px,3vw,28px);left:50%;transform:translateX(-50%) translateY(80px);background:var(--c-bg3);border:1px solid rgba(244,196,48,.3);color:var(--c-white);padding:11px 24px;border-radius:28px;font-size:13px;font-weight:500;z-index:999;transition:transform .28s;pointer-events:none;white-space:nowrap;box-shadow:var(--sh)}
.toast.show{transform:translateX(-50%) translateY(0)}

/* UTILS */
.hidden{display:none!important}
.mt-16{margin-top:16px}
.text-center{text-align:center}
.text-gold{color:var(--c-gold)}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .prize-layout{grid-template-columns:1fr}
  .mission-grid{grid-template-columns:1fr;gap:32px}
  .art-frame{max-width:300px;margin:0 auto}
}

@media(max-width:768px){
  .nav-mid{display:none}
  .nav-burger{display:block}
  .mob-nav{display:flex}
  .t-sep{display:none}
  .hero{padding-top:calc(62px + 80px + 40px)}
  .hero-visual{order:-1;margin-bottom:8px}
  .hero-content{text-align:center}
  .hero-actions{justify-content:center}
  .hero-trust{justify-content:center}
  .p-stats{gap:14px}
  .p-actions{width:100%}
  .btn-share{width:100%}
  .score-grid{grid-template-columns:repeat(2,1fr)}
  /* Fix nav overlap in quiniela mobile */
  .nav-app-title{display:none}
  .nav-pts{font-size:14px}
  .nav-donate-btn{padding:7px 10px;font-size:11px}
}

@media(max-width:480px){
  :root{--gutter:14px}
  .hero-h1{font-size:clamp(50px,14vw,72px)}
  .score-grid{grid-template-columns:repeat(2,1fr)}
  .save-bar{gap:10px}
  .hero-visual{margin-top:0}
  .ball-wrap{width:160px;height:160px}
}
