@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --navy900:#0d1b2a; --navy800:#15233A; --navy700:#1c2e47; --navy600:#243a59;
  --teal:#1AC4C4; --teal2:#1499BE; --gold:#E7B85C; --green:#3ECf8E;
  --ink:#e8eef5; --muted:#8aa0b8; --line:rgba(255,255,255,.08);
}
*{box-sizing:border-box}
body{
  margin:0; font-family:'Hanken Grotesk',system-ui,sans-serif; color:var(--ink);
  background:radial-gradient(1200px 600px at 80% -10%, #1a3050 0%, var(--navy900) 55%);
  min-height:100vh; -webkit-font-smoothing:antialiased;
}
h1,h2,h3{font-family:'Bricolage Grotesque',sans-serif;margin:0}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none}
input,select,textarea{font-family:inherit}
.wrap{max-width:1080px;margin:0 auto;padding:22px 18px 40px}
code{background:var(--navy900);padding:1px 6px;border-radius:5px;font-size:.9em}

/* top bar */
.top{display:flex;align-items:center;gap:18px;padding:13px 18px;border-bottom:1px solid var(--line);
  background:rgba(13,27,42,.65);backdrop-filter:blur(8px);position:sticky;top:0;z-index:30}
.brand{display:flex;align-items:center;gap:11px}
.brand.center{flex-direction:column;gap:8px;margin-bottom:20px}
.logo{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-weight:800;
  font-family:'Bricolage Grotesque';background:linear-gradient(135deg,var(--teal),var(--teal2));color:#06303a}
.logo.big{width:56px;height:56px;font-size:22px;border-radius:14px}
.brandtxt strong{display:block;font-size:15px}
.brandtxt small{color:var(--muted);font-size:11.5px;letter-spacing:.4px;text-transform:uppercase}
.topnav{display:flex;gap:4px;margin-right:auto;flex-wrap:wrap}
.topnav a{color:var(--muted);padding:8px 14px;border-radius:8px;font-weight:600;font-size:14px}
.topnav a.on,.topnav a:hover{color:var(--ink);background:var(--navy700)}
.session{display:flex;align-items:center;gap:12px}
.who{font-size:13.5px;color:var(--ink)}
.logout{color:var(--muted);font-size:13px;border:1px solid var(--line);padding:6px 12px;border-radius:8px}
.logout:hover{color:var(--ink);border-color:var(--teal)}
.foot{text-align:center;color:var(--muted);font-size:11.5px;padding:18px;border-top:1px solid var(--line)}

/* login */
.loginwrap{min-height:100vh;display:grid;place-items:center;padding:20px}
.logincard{background:var(--navy800);border:1px solid var(--line);border-radius:18px;padding:30px;width:100%;max-width:380px;box-shadow:0 30px 80px rgba(0,0,0,.45)}
.form{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--muted);font-weight:600}
.form input{background:var(--navy900);border:1px solid var(--line);border-radius:10px;padding:12px 14px;color:var(--ink);font-size:15px;outline:none}
.form input:focus{border-color:var(--teal)}
.alert{background:rgba(231,93,93,.14);border:1px solid rgba(231,93,93,.4);color:#f0a0a0;padding:10px 14px;border-radius:10px;font-size:13.5px;margin-bottom:6px}

/* hostess */
.hosthead{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:18px}
.hosthead h1{font-size:30px;font-weight:800;letter-spacing:-.5px}
.sub{color:var(--muted);margin:4px 0 0;font-size:13.5px}
.cap{text-transform:capitalize}
.todaycount{text-align:right;background:var(--navy800);border:1px solid var(--line);border-radius:14px;padding:10px 18px}
.todaycount strong{display:block;font-family:'Bricolage Grotesque';font-size:30px;color:var(--teal);line-height:1;font-variant-numeric:tabular-nums}
.todaycount span{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted)}
.searchrow{display:flex;gap:10px;margin-bottom:14px}
.search{flex:1;background:var(--navy800);border:1px solid var(--line);border-radius:12px;padding:15px 18px;color:var(--ink);font-size:16px;outline:none}
.search:focus{border-color:var(--teal)}
.search::placeholder{color:var(--muted)}
.newbtn{background:var(--navy700);color:var(--ink);border:1px solid var(--line);border-radius:12px;padding:0 20px;font-weight:600;font-size:14px;white-space:nowrap}
.newbtn:hover{border-color:var(--teal)}
.flash{background:rgba(62,207,142,.14);border:1px solid rgba(62,207,142,.4);color:var(--green);padding:12px 16px;border-radius:11px;margin-bottom:12px;font-weight:600;font-size:14px}

.list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.card{display:flex;align-items:center;gap:14px;background:var(--navy800);border:1px solid var(--line);border-radius:14px;padding:15px 17px}
.card:hover{border-color:rgba(26,196,196,.35)}
.card.vip{border-left:3px solid var(--gold)}
.card.frecuente{border-left:3px solid var(--teal)}
.cardmain{flex:1;min-width:0}
.name{font-weight:700;font-size:16.5px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.meta{display:flex;align-items:center;gap:7px;flex-wrap:wrap;color:var(--muted);font-size:12.5px;margin-top:5px}
.dot{opacity:.4}
.cross{color:var(--teal);font-weight:600}
.note{max-width:340px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tag{font-size:11px;font-weight:700;padding:2px 9px;border-radius:20px}
.tag.vip{background:rgba(231,184,92,.16);color:var(--gold)}
.tag.freq{background:rgba(26,196,196,.15);color:var(--teal)}
.cardaction{flex-shrink:0}
.reg{background:linear-gradient(135deg,var(--teal),var(--teal2));color:#06303a;font-weight:700;font-size:14px;padding:12px 20px;border-radius:11px}
.reg:hover{filter:brightness(1.07)} .reg:active{transform:scale(.97)}
.donewrap{display:flex;flex-direction:column;align-items:flex-end;gap:3px}
.done{color:var(--green);font-weight:700;font-size:14px}
.again{background:none;color:var(--muted);font-size:11.5px;text-decoration:underline;padding:0}
.again:hover{color:var(--ink)}
.empty{color:var(--muted);text-align:center;padding:28px;background:var(--navy800);border:1px dashed var(--line);border-radius:14px}
.empty button{background:none;color:var(--teal);text-decoration:underline;font-size:14px;padding:0}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(5,12,22,.7);backdrop-filter:blur(3px);display:none;place-items:center;z-index:50;padding:18px}
.overlay.show{display:grid}
[hidden]{display:none!important}
.modal{background:var(--navy800);border:1px solid var(--line);border-radius:18px;padding:24px;width:100%;max-width:560px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.modal h2{font-size:22px;margin-bottom:16px;font-weight:800}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.field{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted);font-weight:600}
.field.full{grid-column:1/-1}
.field input,.field textarea{background:var(--navy900);border:1px solid var(--line);border-radius:9px;padding:10px 12px;color:var(--ink);font-size:14.5px;outline:none}
.field input:focus,.field textarea:focus{border-color:var(--teal)}
.dup{margin-top:14px;background:rgba(231,184,92,.1);border:1px solid rgba(231,184,92,.4);border-radius:11px;padding:12px 14px;color:var(--gold);font-size:13.5px}
.dup button{margin-top:6px;background:var(--gold);color:#3a2a06;font-weight:700;padding:7px 14px;border-radius:8px;font-size:13px}
.check{display:flex;align-items:center;gap:9px;margin-top:16px;font-size:14px}
.check input{width:17px;height:17px;accent-color:var(--teal)}
.modalbtns{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}
.ghost{background:transparent;color:var(--muted);border:1px solid var(--line);border-radius:10px;padding:11px 20px;font-weight:600}
.primary{background:linear-gradient(135deg,var(--teal),var(--teal2));color:#06303a;border-radius:10px;padding:11px 22px;font-weight:700;font-size:14px}
.primary:disabled{opacity:.4;cursor:not-allowed}

/* admin */
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}
.kpi{background:var(--navy800);border:1px solid var(--line);border-radius:14px;padding:18px}
.kpi strong{display:block;font-family:'Bricolage Grotesque';font-size:34px;line-height:1;font-variant-numeric:tabular-nums}
.kpi span{font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--muted);margin-top:6px;display:block}
.kpi.vip strong{color:var(--gold)} .kpi.freq strong{color:var(--teal)}
.panel{background:var(--navy800);border:1px solid var(--line);border-radius:16px;padding:22px}
.panel h3{font-size:17px;margin-bottom:6px}
.rule{color:var(--muted);font-size:13px;margin:8px 0 0;line-height:1.5}
.rule strong{color:var(--ink)}
.bars{display:flex;flex-direction:column;gap:11px;margin-top:14px}
.barrow{display:flex;align-items:center;gap:12px}
.barlbl{width:120px;font-size:13.5px;font-weight:600}
.bartrack{flex:1;height:14px;background:var(--navy900);border-radius:8px;overflow:hidden}
.barfill{height:100%;background:linear-gradient(90deg,var(--teal2),var(--teal));border-radius:8px}
.barval{width:34px;text-align:right;font-variant-numeric:tabular-nums;font-weight:700;color:var(--teal)}
.tablewrap{overflow-x:auto;margin-top:14px}
.table{width:100%;border-collapse:collapse;font-size:13.5px;min-width:680px}
.table th{text-align:left;color:var(--muted);font-weight:600;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;padding:8px 10px;border-bottom:1px solid var(--line)}
.table td{padding:12px 10px;border-bottom:1px solid var(--line);vertical-align:top}
.tnote{color:var(--muted);font-size:12px;margin-top:3px;max-width:260px}
.tcontact{display:flex;flex-direction:column;gap:2px}
.muted{color:var(--muted)}
.num{font-variant-numeric:tabular-nums;font-weight:700;color:var(--teal)}
.toggle{background:var(--navy700);border:1px solid var(--line);color:var(--muted);border-radius:7px;padding:5px 14px;font-weight:600;font-size:13px}
.toggle.on{background:rgba(231,184,92,.18);border-color:rgba(231,184,92,.5);color:var(--gold)}
.vipgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px;margin-top:14px}
.vipcard{background:var(--navy900);border:1px solid rgba(231,184,92,.3);border-radius:13px;padding:15px}
.vipname{font-weight:700;color:var(--gold);font-size:15px;margin-bottom:7px}
.viprow{font-size:13px}
.vipstats{display:flex;gap:8px;flex-wrap:wrap;margin-top:9px;font-size:11.5px}
.vipstats span{background:var(--navy700);padding:3px 9px;border-radius:20px}
.vipstats .cross{background:rgba(26,196,196,.15);color:var(--teal)}
.vipstats .manual{background:rgba(231,184,92,.15);color:var(--gold)}
.vipnote{color:var(--muted);font-size:12px;margin-top:9px;border-top:1px solid var(--line);padding-top:8px}
.inlineform{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0 18px}
.inlineform input,.inlineform select{background:var(--navy900);border:1px solid var(--line);border-radius:9px;padding:10px 12px;color:var(--ink);font-size:14px;flex:1;min-width:130px;outline:none}
.inlineform input:focus{border-color:var(--teal)}
.simplelist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.simplelist li{display:flex;justify-content:space-between;align-items:center;background:var(--navy900);border:1px solid var(--line);border-radius:11px;padding:13px 16px}
.simplelist li div{display:flex;flex-direction:column;gap:2px}
.simplelist li div span{font-size:12.5px}
.pill{background:rgba(26,196,196,.13);color:var(--teal);font-size:12px;font-weight:600;padding:4px 12px;border-radius:20px}
.pill.adm{background:rgba(231,184,92,.15);color:var(--gold)}

@media(max-width:760px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid2{grid-template-columns:1fr}
  .top{flex-wrap:wrap;gap:12px}
  .hosthead h1{font-size:24px}
  .card{flex-direction:column;align-items:stretch;gap:12px}
  .cardaction{align-self:stretch}
  .reg{width:100%}
  .donewrap{align-items:center}
}

/* acciones por fila (reset de contraseña en Usuarios) */
.rowactions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.resetform{display:flex;gap:6px;margin:0}
.resetform input{background:var(--navy900);border:1px solid var(--line);border-radius:8px;padding:7px 10px;color:var(--ink);font-size:13px;width:150px;outline:none}
.resetform input:focus{border-color:var(--teal)}
.ghost.small{padding:7px 12px;font-size:13px}
@media(max-width:760px){
  .simplelist li{flex-direction:column;align-items:flex-start;gap:10px}
  .rowactions{width:100%}
  .resetform{flex:1}
  .resetform input{flex:1;width:auto}
}
