/* GoalOne · Tecnificación — estilos (paleta del escudo: dorado + azul muy oscuro) */
:root{
  --gold:#F0C020; --gold-2:#F0A000; --gold-soft:rgba(240,192,32,.12);
  --bg:#070a14; --bg-2:#0d1220; --card:#121a2b; --card-2:#0f1626;
  --border:#22304a; --border-2:#2c3c5a;
  --t1:#eef3fb; --t2:#b9c6dd; --t3:#7e8da8; --gray-400:#7e8da8; --gray-500:#5d6a82;
  --green:#2ecc71; --red:#ff6b6b;
  --r-sm:10px; --r-md:14px;
  --sp-sm:14px; --sp-md:20px;
}
*{box-sizing:border-box}
html,body{margin:0;overflow-x:clip;max-width:100vw;width:100%}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--t1);
  -webkit-font-smoothing:antialiased;line-height:1.5}
a{color:var(--gold);text-decoration:none}

/* Header */
.site-header{display:flex;align-items:center;gap:12px;padding:12px 16px;
  background:linear-gradient(180deg,#0d1322,#070a14);border-bottom:2px solid var(--gold);
  position:sticky;top:0;z-index:20}
.site-header .logo{width:46px;height:46px;border-radius:50%}
.site-header h1{font-family:'Barlow Condensed',sans-serif;font-size:1.25rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.5px;margin:0;color:var(--t1)}
.site-header .subtitle{font-size:.72rem;color:var(--gold);font-weight:600;letter-spacing:1px;text-transform:uppercase}

/* Hero */
.hero{position:relative;padding:34px 16px 26px;text-align:center;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background:url('/static/hero.jpg') center/cover;
  opacity:.18;filter:saturate(1.1)}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,var(--bg))}
.hero>*{position:relative;z-index:2}
.hero .escudo{width:88px;height:88px;margin-bottom:10px;filter:drop-shadow(0 6px 24px rgba(240,192,32,.25))}
.hero h2{font-family:'Barlow Condensed',sans-serif;font-size:1.9rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.5px;margin:0 0 6px}
.hero h2 span{color:var(--gold)}
.hero p{color:var(--t2);font-size:.86rem;max-width:440px;margin:0 auto}

/* Layout form */
.form-stage{width:100%;max-width:100vw;padding:0 16px;margin:0 auto}
.form-wrap{width:100%;max-width:520px;margin:0 auto}
form{margin:0 auto}

.section-badge{display:inline-flex;align-items:center;gap:7px;font-size:.7rem;font-weight:700;
  color:var(--gold);background:var(--gold-soft);padding:5px 11px;border-radius:7px;margin:18px 0 8px;
  text-transform:uppercase;letter-spacing:.5px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;
  margin-bottom:var(--sp-md)}

.ef-label{font-size:.7rem;color:var(--t3);display:block;margin-bottom:5px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.ef-input{width:100%;max-width:100%;background:var(--card-2);border:1px solid var(--border-2);
  border-radius:var(--r-sm);padding:11px 12px;color:var(--t1);font-size:16px;outline:none}
.ef-input:focus{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft)}
.ef-input::placeholder{color:var(--gray-500)}
select.ef-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237e8da8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.ef-row{margin-bottom:var(--sp-sm)}
.ef-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-sm);min-width:0}
.ef-grid-2>div{min-width:0}
@media(max-width:480px){.ef-grid-2{grid-template-columns:1fr}}

/* Selector tipo tarjeta (sede / rol) */
.pick{display:grid;gap:10px}
.pick.cols-2{grid-template-columns:1fr 1fr}
@media(max-width:480px){.pick.cols-2{grid-template-columns:1fr}}
.pick label{position:relative;display:block;cursor:pointer}
.pick input{position:absolute;opacity:0}
.pick .opt{border:2px solid var(--border-2);border-radius:var(--r-md);padding:14px;background:var(--card-2);
  transition:.15s;text-align:center}
.pick input:checked + .opt{border-color:var(--gold);background:var(--gold-soft);box-shadow:0 0 0 3px var(--gold-soft)}
.pick .opt .t{font-weight:700;font-size:.95rem;color:var(--t1)}
.pick .opt .s{font-size:.72rem;color:var(--t3);margin-top:3px}
.pick .opt .price{font-family:'Barlow Condensed',sans-serif;font-size:1.5rem;font-weight:800;color:var(--gold);margin-top:6px}

/* Consents */
.consent{display:flex;align-items:flex-start;gap:10px;padding:11px 12px;background:var(--card-2);
  border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:10px;cursor:pointer;font-size:.8rem;color:var(--t2)}
.consent input{width:18px;height:18px;accent-color:var(--gold);flex-shrink:0;margin-top:1px}
.consent strong{color:var(--t1)}

/* Resumen importe */
.resumen{background:linear-gradient(180deg,var(--gold-soft),transparent);border:1px solid var(--gold);
  border-radius:var(--r-md);padding:14px 16px;margin-bottom:var(--sp-md)}
.resumen .row{display:flex;justify-content:space-between;font-size:.85rem;color:var(--t2);padding:3px 0}
.resumen .row.total{font-size:1.05rem;color:var(--t1);font-weight:700;border-top:1px solid var(--border);margin-top:6px;padding-top:8px}
.resumen .row.total b{color:var(--gold)}

/* Botón */
.btn{display:block;width:100%;font-family:'Barlow Condensed',sans-serif;font-size:1.2rem;font-weight:800;
  text-transform:uppercase;letter-spacing:1px;padding:15px;border:none;border-radius:var(--r-md);cursor:pointer;
  color:#0a0f1a;background:linear-gradient(135deg,var(--gold),var(--gold-2));margin-bottom:30px;transition:transform .1s}
.btn:active{transform:scale(.98)}

/* Flash */
.flash{padding:11px 14px;border-radius:var(--r-sm);font-size:.84rem;margin:14px auto;max-width:520px}
.flash.error{background:rgba(255,107,107,.12);border:1px solid rgba(255,107,107,.4);color:#ffb3b3}

/* OK page */
.ok-wrap{max-width:480px;margin:0 auto;padding:40px 20px;text-align:center}
.ok-icon{width:76px;height:76px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-2));
  display:flex;align-items:center;justify-content:center;font-size:2rem;color:#0a0f1a;margin:0 auto 18px}
.ok-wrap h2{font-family:'Barlow Condensed',sans-serif;font-size:1.8rem;text-transform:uppercase;margin:0 0 10px}
.ok-wrap p{color:var(--t2);font-size:.9rem}

/* ════════════ ADMIN PANEL ════════════ */
.adm-shell{display:flex;min-height:100vh}
.adm-side{width:230px;background:linear-gradient(180deg,#0b1120,#070a14);border-right:1px solid var(--border);
  position:fixed;top:0;bottom:0;left:0;display:flex;flex-direction:column;z-index:30;transition:transform .2s}
.adm-side .brand{display:flex;align-items:center;gap:10px;padding:18px 16px;border-bottom:1px solid var(--border)}
.adm-side .brand img{width:38px;height:38px;border-radius:50%}
.adm-side .brand b{font-size:1.05rem;letter-spacing:.5px}.adm-side .brand b span{color:var(--gold)}
.adm-nav{flex:1;padding:10px 8px;overflow-y:auto}
.adm-nav a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:9px;color:var(--t2);
  font-size:.88rem;font-weight:500;margin-bottom:3px}
.adm-nav a i{width:18px;text-align:center;color:var(--t3)}
.adm-nav a:hover{background:var(--card)}
.adm-nav a.active{background:var(--gold-soft);color:var(--gold)}.adm-nav a.active i{color:var(--gold)}
.adm-side .foot{padding:12px 16px;border-top:1px solid var(--border);font-size:.78rem}
.adm-main{flex:1;margin-left:230px;min-width:0}
.adm-top{display:flex;align-items:center;gap:12px;padding:16px 24px;border-bottom:1px solid var(--border);
  position:sticky;top:0;background:rgba(7,10,20,.85);backdrop-filter:blur(8px);z-index:20}
.adm-top h1{font-family:'Barlow Condensed',sans-serif;font-size:1.4rem;font-weight:800;text-transform:uppercase;margin:0}
.adm-top .sp{flex:1}
.adm-body{padding:22px 24px 60px;max-width:1200px}
.burger{display:none;background:none;border:none;color:var(--t1);font-size:1.3rem;cursor:pointer}
@media(max-width:820px){
  .adm-side{transform:translateX(-100%)}.adm-side.open{transform:none}
  .adm-main{margin-left:0}.burger{display:block}
}

/* KPIs */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:24px}
.kpi{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px 18px}
.kpi .v{font-family:'Barlow Condensed',sans-serif;font-size:2.1rem;font-weight:800;color:var(--gold);line-height:1}
.kpi .l{font-size:.74rem;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-top:6px}
.kpi.green .v{color:var(--green)} .kpi.blue .v{color:#4aa3ff}

/* Cards/tablas */
.panel{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:20px}
.panel h3{font-family:'Barlow Condensed',sans-serif;font-size:1.15rem;text-transform:uppercase;margin:0 0 14px;color:var(--t1)}
table.tbl{width:100%;border-collapse:collapse;font-size:.86rem}
table.tbl th{text-align:left;color:var(--t3);font-weight:600;font-size:.72rem;text-transform:uppercase;
  padding:9px 10px;border-bottom:1px solid var(--border)}
table.tbl td{padding:11px 10px;border-bottom:1px solid var(--card-2);color:var(--t2)}
table.tbl tr:hover td{background:var(--card-2)}
table.tbl a{color:var(--t1);font-weight:600}

/* Badges de estado */
.badge{display:inline-block;padding:3px 9px;border-radius:99px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.badge.pendiente{background:rgba(255,159,67,.15);color:#ff9f43}
.badge.pendiente_pago{background:rgba(74,163,255,.15);color:#4aa3ff}
.badge.pagado{background:rgba(46,204,113,.15);color:var(--green)}
.badge.confirmado{background:var(--gold-soft);color:var(--gold)}

/* Chips filtro */
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.chips a{padding:7px 14px;border-radius:99px;background:var(--card);border:1px solid var(--border);
  font-size:.8rem;color:var(--t2);font-weight:600}
.chips a.on{background:var(--gold);color:#0a0f1a;border-color:var(--gold)}
.searchbar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.searchbar input{flex:1;min-width:180px}

/* Botones admin */
.btn-sm{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:9px;border:none;cursor:pointer;
  font-size:.82rem;font-weight:700;background:var(--card-2);color:var(--t1);border:1px solid var(--border-2)}
.btn-sm.gold{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#0a0f1a;border:none}
.btn-sm.green{background:rgba(46,204,113,.15);color:var(--green);border-color:rgba(46,204,113,.3)}
.btn-sm.red{background:rgba(255,107,107,.12);color:var(--red);border-color:rgba(255,107,107,.3)}
.btn-sm:active{transform:scale(.97)}

/* Toggle switch */
.cfg-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:1px solid var(--card-2)}
.cfg-row:last-child{border-bottom:none}
.cfg-row .lbl{font-size:.9rem;color:var(--t1);font-weight:600}
.cfg-row .desc{font-size:.76rem;color:var(--t3);margin-top:2px}
.switch{position:relative;width:50px;height:28px;flex-shrink:0}
.switch input{opacity:0;width:0;height:0}
.switch .sl{position:absolute;inset:0;background:var(--card-2);border:1px solid var(--border-2);border-radius:99px;cursor:pointer;transition:.2s}
.switch .sl:before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;background:var(--t3);border-radius:50%;transition:.2s}
.switch input:checked + .sl{background:var(--gold-soft);border-color:var(--gold)}
.switch input:checked + .sl:before{transform:translateX(22px);background:var(--gold)}

.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 20px}
@media(max-width:600px){.detail-grid{grid-template-columns:1fr}}
.detail-grid .k{font-size:.72rem;color:var(--t3);text-transform:uppercase}
.detail-grid .vv{font-size:.92rem;color:var(--t1);margin-bottom:8px}

/* ════════════ Form pro extras ════════════ */
.aviso{background:linear-gradient(90deg,var(--gold),var(--gold-2));color:#0a0f1a;font-weight:700;
  font-size:.85rem;text-align:center;padding:10px 16px;display:flex;align-items:center;justify-content:center;gap:8px}
.plazas{display:inline-block;margin-top:6px;font-size:.7rem;font-weight:700;padding:2px 9px;border-radius:99px;
  background:rgba(46,204,113,.15);color:var(--green)}
.plazas.pocas{background:rgba(255,159,67,.18);color:#ff9f43}
.pick label.full{opacity:.55;cursor:not-allowed}
.pick label.full .opt{border-style:dashed}
.pick .full-tag{display:inline-block;margin-top:6px;font-size:.7rem;font-weight:800;color:var(--red);letter-spacing:1px}
.cat-chip{display:none;align-items:center;gap:8px;margin-top:10px;padding:9px 12px;border-radius:10px;
  background:var(--gold-soft);border:1px solid rgba(240,192,32,.3);color:var(--gold);font-size:.82rem;font-weight:600}
.cat-chip.show{display:flex}
/* Barra fija inferior (checkout feel) */
.stickybar{position:fixed;left:0;right:0;bottom:0;z-index:40;background:rgba(10,14,24,.96);
  backdrop-filter:blur(10px);border-top:1px solid var(--border);padding:10px 16px calc(10px + env(safe-area-inset-bottom));
  display:flex;align-items:center;gap:12px;transform:translateY(120%);transition:transform .25s}
.stickybar.show{transform:none}
.stickybar .info{flex:1;min-width:0}
.stickybar .info .a{font-size:.72rem;color:var(--t3);text-transform:uppercase;letter-spacing:.5px}
.stickybar .info .b{font-family:'Barlow Condensed',sans-serif;font-size:1.3rem;font-weight:800;color:var(--gold);line-height:1}
.stickybar button{font-family:'Barlow Condensed',sans-serif;font-size:1.05rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.5px;padding:13px 22px;border:none;border-radius:11px;cursor:pointer;color:#0a0f1a;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));white-space:nowrap}
.form-wrap{padding-bottom:40px}
/* WhatsApp flotante */
.wa-fab{position:fixed;right:16px;bottom:84px;z-index:35;width:54px;height:54px;border-radius:50%;
  background:#25D366;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.6rem;
  box-shadow:0 8px 24px rgba(37,211,102,.4);text-decoration:none}

/* ════════════ PREMIUM / WOW ════════════ */
/* Aurora de fondo: blobs dorados/azules muy sutiles en movimiento */
body::before{content:"";position:fixed;inset:-20%;z-index:-2;pointer-events:none;
  background:
    radial-gradient(40% 35% at 18% 12%, rgba(240,192,32,.10), transparent 60%),
    radial-gradient(45% 40% at 85% 8%, rgba(74,163,255,.08), transparent 60%),
    radial-gradient(50% 45% at 70% 90%, rgba(240,160,0,.07), transparent 60%);
  animation:aurora 18s ease-in-out infinite alternate}
@keyframes aurora{0%{transform:translate3d(0,0,0) scale(1)}100%{transform:translate3d(0,-3%,0) scale(1.08)}}

/* Barra de progreso superior (se llena al hacer scroll) */
.progressbar{position:fixed;top:0;left:0;height:3px;width:0;z-index:50;
  background:linear-gradient(90deg,var(--gold),var(--gold-2));box-shadow:0 0 12px rgba(240,192,32,.6);transition:width .1s}

/* Hero cinematográfico */
.hero{padding:46px 16px 32px}
.hero::before{opacity:.22;animation:heroZoom 20s ease-in-out infinite alternate}
@keyframes heroZoom{from{transform:scale(1.05)}to{transform:scale(1.15)}}
.hero .escudo{position:relative;animation:float 5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
/* anillo de glow pulsante tras el escudo */
.hero .escudo-wrap{position:relative;display:inline-block;margin-bottom:6px}
.hero .escudo-wrap::after{content:"";position:absolute;inset:-14px;border-radius:50%;z-index:-1;
  background:radial-gradient(circle,rgba(240,192,32,.35),transparent 70%);animation:pulse 3s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.5;transform:scale(.9)}50%{opacity:1;transform:scale(1.12)}}
.hero h2{font-size:2.2rem;background:linear-gradient(120deg,#ffffff 25%,var(--gold) 65%,var(--gold-2));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  text-shadow:0 4px 30px rgba(240,192,32,.15)}
.hero h2 span{-webkit-text-fill-color:initial;color:var(--gold)}

/* Tarjetas con cristal esmerilado + borde con brillo */
.card{background:linear-gradient(180deg,rgba(18,26,43,.85),rgba(15,22,38,.85));backdrop-filter:blur(6px);
  box-shadow:0 8px 30px rgba(0,0,0,.25)}
.section-badge{box-shadow:0 4px 14px rgba(240,192,32,.12)}

/* Selección sede/modalidad con glow dorado */
.pick input:checked + .opt{box-shadow:0 0 0 3px var(--gold-soft),0 8px 28px rgba(240,192,32,.22);
  transform:translateY(-2px)}
.pick .opt{transition:transform .18s,box-shadow .18s,border-color .18s}
@media(hover:hover){.pick label:not(.full):hover .opt{border-color:rgba(240,192,32,.5);transform:translateY(-2px)}}

/* Botón con destello que cruza */
.btn{position:relative;overflow:hidden;box-shadow:0 10px 30px rgba(240,192,32,.3)}
.btn::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-20deg);animation:shine 3.4s ease-in-out infinite}
@keyframes shine{0%,60%{left:-120%}100%{left:130%}}

/* Animación de entrada al hacer scroll (añadida por JS, sin JS todo visible) */
.anim{opacity:0;transform:translateY(22px)}
.anim.in{opacity:1;transform:none;transition:opacity .6s cubic-bezier(.2,.7,.2,1),transform .6s cubic-bezier(.2,.7,.2,1)}

/* Inputs con foco más vivo */
.ef-input:focus{box-shadow:0 0 0 3px var(--gold-soft),0 0 18px rgba(240,192,32,.15)}

/* Resumen con leve brillo */
.resumen{box-shadow:0 8px 30px rgba(240,192,32,.12)}
