/* ═══════════════════════════════════════════════════
   FONTANAR MONUMENTAL — Página pública (tema dorado)
   Estiliza el shell + todo lo que pinta /js/app.js
   ═══════════════════════════════════════════════════ */

@font-face{font-family:'DM Sans';src:url('../assets/fonts/DMSans-Medium.ttf') format('truetype');font-weight:500;font-display:swap;}
@font-face{font-family:'DM Sans';src:url('../assets/fonts/DMSans-SemiBold.ttf') format('truetype');font-weight:600;font-display:swap;}
@font-face{font-family:'DM Sans';src:url('../assets/fonts/DMSans-Black.ttf') format('truetype');font-weight:900;font-display:swap;}

:root{
  --gold:#FDB100;
  --gold-bright:#FFC627;
  --gold-deep:#D98A00;
  --gold-shadow:#A85F00;
  --azul:#1B2D9B;
  --azul-deep:#0E1A6B;
  --rojo:#E11D1D;
  --rojo-deep:#B81212;
  --crema:#FFF7E6;
  --blanco:#FFFFFF;
  --ink:#0E1A6B;
  --muted:#6A4D00;
  --body:'DM Sans',-apple-system,BlinkMacSystemFont,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--body);font-weight:500;color:var(--ink);
  background:var(--gold);line-height:1.5;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
  position:relative;min-height:100vh;
}
/* Fondo tejido dorado */
body::before{
  content:'';position:fixed;inset:0;z-index:-2;
  background:radial-gradient(ellipse 120% 90% at 50% 0%, var(--gold-bright) 0%, var(--gold) 42%, var(--gold-deep) 100%);
}
body::after{
  content:'';position:fixed;inset:0;z-index:-1;pointer-events:none;
  background-image:
    repeating-linear-gradient(45deg, rgba(120,60,0,.05) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(-45deg, rgba(255,240,180,.10) 0 1px, transparent 1px 3px),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.06'/%3E%3C/svg%3E");
  background-size:auto,auto,180px 180px;mix-blend-mode:multiply;opacity:.85;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

/* ═══ TOP BAR ═══ */
.topbar{position:sticky;top:0;z-index:50;background:linear-gradient(180deg,var(--azul-deep),var(--azul));border-bottom:3px solid var(--rojo);box-shadow:0 4px 22px rgba(0,0,0,.28);}
.topbar-inner{max-width:1180px;margin:0 auto;padding:11px 22px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.brand{display:flex;align-items:center;gap:13px;min-width:0;}
.brand .crest-mini{width:46px;height:46px;flex-shrink:0;border-radius:9px;object-fit:cover;border:2px solid var(--gold);box-shadow:0 2px 8px rgba(0,0,0,.35);}
.brand .names{display:flex;flex-direction:column;line-height:1;min-width:0;}
.brand .names .top{font-weight:900;font-size:.66rem;letter-spacing:3.5px;color:var(--gold-bright);}
.brand .names .big{font-weight:900;font-size:1.22rem;letter-spacing:.5px;color:var(--blanco);text-transform:uppercase;white-space:nowrap;}
.bono-chip{display:flex;align-items:center;gap:8px;background:var(--gold);color:var(--azul-deep);font-weight:900;font-size:.82rem;letter-spacing:.5px;padding:8px 16px;border-radius:999px;border:2px solid var(--blanco);text-transform:uppercase;white-space:nowrap;box-shadow:0 3px 0 var(--gold-shadow);}
.bono-chip .star{color:var(--rojo);}

/* ═══ LAYOUT ═══ */
.wrap{max-width:1180px;margin:0 auto;padding:0 22px;}

/* ═══ HERO ═══ */
.hero{padding:46px 0 30px;}
.hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.04fr);gap:40px;align-items:center;}
.poster-frame{position:relative;border-radius:22px;overflow:hidden;border:5px solid var(--crema);box-shadow:0 22px 60px rgba(40,18,0,.45), 0 0 0 3px var(--azul-deep);}
.poster-frame img{width:100%;height:100%;object-fit:cover;}
.poster-frame::after{content:'';position:absolute;inset:0;border-radius:17px;box-shadow:inset 0 0 0 2px rgba(225,29,29,.55);pointer-events:none;}
.action{display:flex;flex-direction:column;gap:18px;}
.kicker{display:inline-flex;align-items:center;gap:9px;align-self:flex-start;background:var(--azul-deep);color:var(--gold-bright);font-weight:900;font-size:.74rem;letter-spacing:2.5px;text-transform:uppercase;padding:8px 15px;border-radius:999px;border:2px dashed rgba(255,214,39,.55);}
.kicker .dot{width:8px;height:8px;border-radius:50%;background:var(--rojo);box-shadow:0 0 0 3px rgba(225,29,29,.3);}
.hero h1{font-weight:900;line-height:.92;letter-spacing:-1px;font-size:clamp(2.5rem,6vw,4.3rem);color:var(--azul-deep);text-transform:uppercase;}
.hero h1 .stroke{color:var(--crema);-webkit-text-stroke:3px var(--azul-deep);paint-order:stroke fill;text-shadow:4px 4px 0 var(--rojo);}
.hero .lead{font-size:1.06rem;font-weight:500;color:#3a2a00;max-width:34ch;}
.hero .lead b{font-weight:900;color:var(--azul-deep);}

/* ═══ Banner del bono (cinta tipo parche) ═══ */
.bono-banner{display:flex;align-items:center;justify-content:center;gap:18px;background:linear-gradient(180deg,var(--azul),var(--azul-deep));color:var(--crema);border:2px dashed var(--gold-bright);border-radius:14px;padding:18px 16px;text-align:center;box-shadow:0 6px 0 var(--azul-deep), 0 14px 30px rgba(14,26,107,.35);}
.bono-banner .star{color:var(--gold-bright);font-size:1.3rem;flex-shrink:0;}
.bono-banner > span:not(.star){display:flex;flex-direction:column;line-height:1.05;}
.bono-banner small{font-weight:600;font-size:.7rem;letter-spacing:3px;color:var(--gold-bright);text-transform:uppercase;margin-bottom:6px;white-space:nowrap;}
.bono-banner strong{font-weight:900;font-size:1.7rem;letter-spacing:.5px;white-space:nowrap;}

/* ═══ Botones ═══ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;border:none;cursor:pointer;font-family:var(--body);font-weight:900;font-size:1.18rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--blanco);background:var(--rojo);padding:18px;border-radius:13px;box-shadow:0 6px 0 var(--rojo-deep), 0 12px 26px rgba(225,29,29,.4);transition:transform .12s ease, box-shadow .12s ease, background .12s;}
.btn:hover{background:#f22b2b;transform:translateY(-2px);box-shadow:0 8px 0 var(--rojo-deep),0 16px 30px rgba(225,29,29,.45);}
.btn:active{transform:translateY(4px);box-shadow:0 2px 0 var(--rojo-deep);}
.btn:disabled{background:#b9a36a;box-shadow:0 6px 0 #8e7c4e;cursor:not-allowed;transform:none;}
.btn.rojo{background:var(--rojo);}
.btn.azul{background:var(--azul);box-shadow:0 6px 0 var(--azul-deep),0 12px 26px rgba(27,45,155,.4);}
.btn.azul:hover{background:#2438bf;box-shadow:0 8px 0 var(--azul-deep),0 16px 30px rgba(27,45,155,.45);}

/* ═══ CÓMO SE JUEGA ═══ */
.steps{padding:24px 0 44px;}
.section-title{text-align:center;font-weight:900;text-transform:uppercase;font-size:clamp(1.7rem,3.6vw,2.6rem);letter-spacing:-.5px;color:var(--azul-deep);margin-bottom:7px;}
.section-sub{text-align:center;font-weight:600;color:#5a4100;margin-bottom:30px;letter-spacing:.3px;}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.step{background:var(--crema);border-radius:16px;border:2px dashed var(--azul);padding:26px 22px;text-align:center;box-shadow:0 10px 26px rgba(60,30,0,.18);}
.step .num{width:58px;height:58px;margin:0 auto 16px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--azul-deep);color:var(--gold-bright);font-weight:900;font-size:1.7rem;border:3px solid var(--gold);box-shadow:0 0 0 3px var(--rojo);}
.step h3{font-weight:900;text-transform:uppercase;font-size:1.18rem;color:var(--azul-deep);margin-bottom:8px;letter-spacing:.5px;}
.step p{font-weight:500;color:#4a3500;font-size:.96rem;}

/* ═══ SECCIÓN JUEGA (contenedor de app.js) ═══ */
.play{padding:6px 0 60px;}
#contenido{max-width:640px;margin:0 auto;}

/* ═══ TARJETA (lo que pinta app.js) ═══ */
.tarjeta{background:var(--crema);border-radius:16px;border:2px dashed var(--azul);box-shadow:0 10px 30px rgba(60,30,0,.22);padding:24px 22px;margin-bottom:18px;}
.tarjeta.estado-info{text-align:center;padding:40px 26px;}
.estado-info h2{font-weight:900;text-transform:uppercase;font-size:1.9rem;letter-spacing:.5px;color:var(--azul-deep);margin-bottom:12px;}
.estado-info p{font-weight:500;color:#3a2a00;margin-bottom:8px;}

/* ═══ PARTIDO ═══ */
.partido{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;margin:6px 0 16px;}
.equipo{display:flex;flex-direction:column;align-items:center;gap:10px;}
.escudo-wrap{width:84px;height:84px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--gold);border:3px solid var(--azul);box-shadow:0 0 0 3px var(--rojo), 0 6px 14px rgba(0,0,0,.25);overflow:hidden;}
.escudo-wrap img{width:54px;height:54px;object-fit:contain;}
.escudo-wrap .placeholder{font-size:34px;}
.equipo h3{font-weight:900;font-size:1.1rem;text-transform:uppercase;letter-spacing:.5px;color:var(--azul-deep);}
.vs{font-weight:900;font-style:italic;font-size:1.9rem;color:var(--rojo);text-shadow:2px 2px 0 rgba(225,29,29,.18);}

/* ═══ COUNTDOWN ═══ */
.countdown{display:flex;align-items:center;justify-content:center;gap:12px;background:var(--azul-deep);border-radius:11px;padding:13px;margin:14px 0;flex-wrap:wrap;}
.countdown .label{font-weight:600;font-size:.66rem;letter-spacing:2.5px;color:var(--gold-bright);text-transform:uppercase;}
.countdown .tiempo{font-weight:900;font-size:1.85rem;letter-spacing:2px;color:var(--blanco);font-variant-numeric:tabular-nums;}

/* ═══ FORMULARIO ═══ */
.form-titulo{font-weight:900;text-transform:uppercase;font-size:1.5rem;letter-spacing:.3px;color:var(--azul-deep);margin-bottom:6px;}
.form-titulo .acento{color:var(--rojo);}
.form-subtitulo{font-weight:500;font-size:.95rem;color:var(--muted);margin-bottom:18px;}
.form-subtitulo b{color:var(--azul);font-weight:900;}
.grupo{margin-bottom:18px;}
.grupo > label{display:block;font-weight:900;font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--azul);margin-bottom:8px;}
input[type=text],input[type=email],input[type=tel],input[type=date],input[type=number],select,textarea{width:100%;padding:13px 14px;border-radius:10px;border:2px solid #D8C79A;background:var(--blanco);font-family:var(--body);font-weight:600;font-size:1rem;color:var(--ink);outline:none;transition:border-color .15s,box-shadow .15s;}
input:focus,select:focus,textarea:focus{border-color:var(--azul);box-shadow:0 0 0 3px rgba(27,45,155,.18);}
input::placeholder{color:#bcae86;}
select option{background:var(--blanco);color:var(--ink);}
input[type=file]{padding:12px;cursor:pointer;font-weight:600;font-size:.9rem;}
input[type=file]::file-selector-button{background:var(--azul);color:var(--blanco);border:none;padding:9px 15px;border-radius:8px;font-family:var(--body);font-weight:900;font-size:.74rem;letter-spacing:1px;text-transform:uppercase;cursor:pointer;margin-right:12px;}
input[type=file]::file-selector-button:hover{background:#2438bf;}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.marcador-grid{display:grid;grid-template-columns:1fr 48px 1fr;align-items:center;gap:10px;}
.marcador-grid input{text-align:center;font-weight:900;font-size:2.2rem;color:var(--azul-deep);border:2px solid var(--azul);border-radius:10px;background:var(--blanco);padding:8px;}
.marcador-grid .sep{text-align:center;font-weight:900;font-style:italic;font-size:2rem;color:var(--rojo);}
.marcador-grid + small{display:block;text-align:center;margin-top:8px;font-weight:600;font-size:.84rem;color:var(--muted);}
.hr-dorado{border:none;height:2px;background:repeating-linear-gradient(90deg,var(--azul) 0 7px,transparent 7px 13px);margin:22px 0;position:relative;}
.checkbox-group{display:flex;align-items:flex-start;gap:11px;margin:12px 0;}
.checkbox-group input{width:20px;height:20px;margin-top:2px;accent-color:var(--azul);flex-shrink:0;}
.checkbox-group label{font-weight:500;font-size:.9rem;color:#3a2a00;}
.checkbox-group a{color:var(--azul);font-weight:700;text-decoration:underline;}

/* ═══ MENSAJES ═══ */
.mensaje{padding:12px 15px;border-radius:9px;font-weight:700;text-align:center;margin:14px 0;}
.mensaje.error{background:rgba(225,29,29,.12);color:var(--rojo-deep);border:2px solid var(--rojo);}
.mensaje.ok{background:rgba(27,45,155,.1);color:var(--azul-deep);border:2px solid var(--azul);}

/* ═══ MODAL PREGUNTA ═══ */
#modal-pregunta{position:fixed;inset:0;z-index:200;background:rgba(8,12,50,.92);display:flex;align-items:center;justify-content:center;padding:18px;animation:fadeIn .25s ease;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.modal-pregunta-card{background:var(--crema);border-radius:18px;border:3px dashed var(--gold-bright);max-width:640px;width:100%;padding:30px 26px;box-shadow:0 30px 80px rgba(0,0,0,.5);}
.modal-timer{text-align:center;margin-bottom:22px;}
.modal-timer .timer-label{font-weight:900;font-size:.74rem;letter-spacing:3px;color:var(--gold-deep);text-transform:uppercase;margin-bottom:6px;}
.modal-timer .timer-valor{font-weight:900;font-size:clamp(3rem,12vw,4.4rem);line-height:1;color:var(--azul-deep);font-variant-numeric:tabular-nums;transition:color .2s;}
.modal-timer .timer-valor.timer-rojo{color:var(--rojo);animation:tick .5s infinite;}
@keyframes tick{0%,100%{transform:scale(1);}50%{transform:scale(1.07);}}
.modal-timer .timer-bar{height:10px;background:#E6D5A8;border-radius:6px;margin-top:14px;overflow:hidden;border:2px solid var(--azul);}
.modal-timer .timer-bar-fill{height:100%;background:linear-gradient(90deg,var(--azul),var(--azul-deep));width:100%;transition:width .1s linear;}
.modal-timer .timer-bar-fill.timer-bar-rojo{background:linear-gradient(90deg,var(--rojo),var(--rojo-deep));}
.modal-pregunta-texto{font-weight:900;text-transform:uppercase;font-size:clamp(1.15rem,3.4vw,1.55rem);text-align:center;color:var(--azul-deep);margin-bottom:22px;line-height:1.25;}
.modal-opciones{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.opcion-modal{display:flex;align-items:center;gap:12px;background:var(--blanco);border:2px solid #D8C79A;border-radius:11px;padding:14px;cursor:pointer;text-align:left;font-family:var(--body);font-weight:600;font-size:1rem;color:var(--ink);transition:transform .12s,border-color .12s,background .12s;}
.opcion-modal:hover:not(:disabled){border-color:var(--azul);background:#FFFDF5;transform:translateY(-2px);}
.opcion-modal:disabled{opacity:.5;cursor:not-allowed;}
.opcion-modal.seleccionada{border-color:var(--azul);background:var(--azul);color:var(--blanco);}
.opcion-modal .letra{width:36px;height:36px;flex-shrink:0;border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--gold);color:var(--azul-deep);font-weight:900;font-size:1.2rem;border:2px solid var(--azul);}
.opcion-modal.seleccionada .letra{background:var(--gold-bright);}
.opcion-modal .opt-texto{flex:1;}

/* ═══ FOOTER ═══ */
.footer{background:linear-gradient(180deg,var(--azul),var(--azul-deep));color:var(--crema);padding:40px 22px 30px;margin-top:20px;border-top:3px solid var(--rojo);}
.footer-inner{max-width:1180px;margin:0 auto;display:flex;flex-wrap:wrap;gap:24px;align-items:center;justify-content:space-between;}
.footer .fbrand{display:flex;align-items:center;gap:14px;}
.footer .fbrand img{width:54px;height:54px;border-radius:10px;border:2px solid var(--gold);}
.footer .fbrand .ft{display:flex;flex-direction:column;line-height:1.1;}
.footer .fbrand .ft .a{font-weight:900;font-size:1.15rem;text-transform:uppercase;color:var(--blanco);}
.footer .fbrand .ft .b{font-weight:600;font-size:.78rem;letter-spacing:1px;color:var(--gold-bright);}
.footer .legal{font-weight:500;font-size:.82rem;color:#BCC6FF;max-width:46ch;}
.footer .legal a{color:var(--gold-bright);text-decoration:underline;}

/* ═══ RESPONSIVE ═══ */
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:26px;}
  .poster-frame{max-width:460px;margin:0 auto;}
  .action{max-width:560px;margin:0 auto;width:100%;}
  .steps-grid{grid-template-columns:1fr;gap:16px;}
}
@media (max-width:560px){
  .bono-chip .lbl-hide{display:none;}
  .brand .names .big{font-size:1.05rem;}
  .row{grid-template-columns:1fr;}
  .modal-opciones{grid-template-columns:1fr;}
  .hero h1 .stroke{-webkit-text-stroke:2px var(--azul-deep);text-shadow:3px 3px 0 var(--rojo);}
}
