/* ====== Dashboard ====== */
body.admin{padding-bottom:0}

/* Login */
.login-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:radial-gradient(120% 120% at 20% 0%,rgba(90,63,214,.35),transparent 55%),radial-gradient(120% 120% at 100% 100%,rgba(232,49,42,.28),transparent 55%),var(--bg)}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:34px 30px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:var(--shadow);text-align:center}
.login-card img{filter:drop-shadow(0 6px 16px rgba(245,179,1,.3))}
.login-card h1{font-size:20px;font-weight:900;margin-top:4px}
.login-card input{width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:12px 14px;color:var(--text);font-size:15px;margin-top:8px}
.login-card input:focus{outline:none;border-color:var(--gold)}
.login-card button{width:100%;border:0;border-radius:10px;background:var(--gold);color:#1a1300;font-weight:800;padding:12px;font-size:15px}
.login-card .hint{min-height:0}

/* Top bar */
.adm-top{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:14px;padding:10px 18px;background:rgba(10,10,14,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.adm-top .brand strong{font-size:15px}
.adm-top-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.ghost-btn{background:var(--card);border:1px solid var(--line);color:var(--text);padding:7px 13px;border-radius:9px;font-size:13px;font-weight:600}
.ghost-btn:hover{border-color:var(--gold)}
.burger{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:var(--card);border:1px solid var(--line);color:#fff;font-size:20px}
.burger:hover{border-color:var(--gold)}

/* Body layout — el menú es un drawer (hamburguesa) en TODOS los anchos */
.adm-body{display:block;min-height:calc(100vh - 56px)}
.adm-nav{
  position:fixed;top:56px;left:0;bottom:0;width:268px;z-index:46;
  display:flex;flex-direction:column;gap:3px;padding:10px 12px 30px;
  border-right:1px solid var(--line);background:var(--bg2);box-shadow:var(--shadow);
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  transform:translateX(-100%);transition:transform .25s ease;
}
.adm-nav.open{transform:none}
.adm-nav .nav-close{align-self:flex-end;width:34px;height:34px;background:var(--card);border:1px solid var(--line);color:var(--muted);border-radius:9px;font-size:15px;margin-bottom:2px}
.adm-nav .nav-close:hover{color:#fff;border-color:var(--gold)}
.adm-nav .nav-group{font-size:10px;letter-spacing:1.2px;text-transform:uppercase;color:#6f6f86;font-weight:800;padding:12px 14px 4px}
.adm-nav button[data-tab]{display:flex;align-items:center;gap:9px;text-align:left;background:none;border:0;color:var(--muted);padding:10px 14px;border-radius:10px;font-size:14px;font-weight:600;width:100%}
.adm-nav button[data-tab]:hover{background:var(--card);color:var(--text)}
.adm-nav button[data-tab].active{background:var(--gold);color:#1a1300}
.badge{background:var(--red);color:#fff;border-radius:999px;font-size:11px;padding:1px 7px;margin-left:auto;font-weight:800}
.adm-overlay{position:fixed;inset:56px 0 0 0;background:rgba(0,0,0,.55);z-index:45;opacity:0;pointer-events:none;transition:opacity .25s}
.adm-overlay.open{opacity:1;pointer-events:auto}
.adm-main{padding:24px;max-width:1040px;margin:0 auto}

/* Headings */
.adm-main h2{font-size:22px;font-weight:900;margin-bottom:4px}
.adm-main .sub{color:var(--muted);font-size:14px;margin-bottom:20px}

/* Cards / stats */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:24px}
.stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px}
.stat .n{font-size:32px;font-weight:900;color:var(--gold)}
.stat .l{font-size:13px;color:var(--muted);margin-top:2px}

.panel{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;margin-bottom:20px}
.panel h3{font-size:16px;font-weight:800;margin-bottom:14px}

/* Forms */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:6px;color:#d6d6e2}
.field input,.field textarea,.field select{width:100%;background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:10px 12px;color:var(--text);font-size:14px;font-family:inherit}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold)}
.field textarea{resize:vertical;min-height:70px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.check{display:flex;align-items:center;gap:8px;font-size:14px}
.check input{width:auto}
.btn{border:0;border-radius:10px;background:var(--gold);color:#1a1300;font-weight:800;padding:11px 20px;font-size:14px}
.btn:hover{filter:brightness(1.06)}
.btn.sec{background:var(--card2);color:var(--text);border:1px solid var(--line)}
.btn.danger{background:#2a1213;color:#ff8a82;border:1px solid #4a1e1c}
.btn.sm{padding:7px 12px;font-size:12.5px}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}

/* Lists / items */
.item{display:flex;gap:12px;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:10px}
.item .it-main{flex:1;min-width:0}
.item .it-main h4{font-size:15px;font-weight:800;display:flex;align-items:center;gap:8px}
.item .it-main p{margin:4px 0 0;font-size:13px;color:#cdcdda;white-space:pre-wrap;word-break:break-word}
.item .it-meta{font-size:12px;color:var(--muted);margin-top:4px}
.item .it-actions{display:flex;flex-direction:column;gap:6px;flex:0 0 auto}
.chip{font-size:10px;font-weight:800;padding:2px 8px;border-radius:6px;text-transform:uppercase}
.chip.breaking{background:var(--red);color:#fff}.chip.promo{background:var(--blue);color:#fff}.chip.alert{background:var(--gold);color:#1a1300}
.chip.on{background:var(--ok);color:#04210f}.chip.off{background:#333;color:#aaa}
.empty{color:var(--muted);font-size:14px;padding:20px;text-align:center}

/* Schedule editor */
.sched-edit-row{display:grid;grid-template-columns:1fr 1fr 1.4fr 1.4fr auto;gap:8px;margin-bottom:8px;align-items:center}
.sched-edit-row input{background:var(--bg2);border:1px solid var(--line);border-radius:8px;padding:8px 10px;color:var(--text);font-size:13px}
.icon-btn{background:#2a1213;color:#ff8a82;border:1px solid #4a1e1c;border-radius:8px;width:36px;height:36px;font-size:15px}

/* Sparkline de estadísticas */
.spark{display:flex;align-items:flex-end;gap:2px;height:120px;background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:10px}
.spark-bar{flex:1;min-width:3px;background:linear-gradient(180deg,var(--gold),rgba(245,179,1,.3));border-radius:2px 2px 0 0}

.toast-host{position:fixed;right:20px;bottom:20px;z-index:80;display:flex;flex-direction:column;gap:10px}
.atoast{background:#16161f;border:1px solid var(--line);border-left:4px solid var(--ok);color:#fff;padding:12px 18px;border-radius:10px;box-shadow:var(--shadow);font-size:14px;animation:slideIn .3s}
.atoast.err{border-left-color:var(--red)}

/* Responsive */
@media(max-width:560px){
  .adm-nav{width:86vw;max-width:300px}
  .row2,.row3{grid-template-columns:1fr}
  .adm-main{padding:16px}
  .sched-edit-row{grid-template-columns:1fr 1fr;gap:6px}
  .adm-top-right .live-pill{display:none}
  .adm-top .brand strong{font-size:14px}
  .ghost-btn{padding:6px 10px;font-size:12px}
}

/* Radio Pachachaca responsive fixes */
.login-screen,.login-screen *{box-sizing:border-box}
.login-screen{width:100%;overflow-x:hidden}
.login-card{width:min(360px,calc(100vw - 32px));max-width:calc(100vw - 32px);padding:30px 20px;margin:0 auto}
.login-card input,.login-card button{max-width:100%}
.login-card h1{line-height:1.15;overflow-wrap:anywhere}
@media(max-width:420px){.login-screen{padding:16px}.login-card{width:100%;max-width:100%;padding:28px 18px;border-radius:16px}.login-card img{width:78px;height:78px}.login-card h1{font-size:19px}.login-card .muted{font-size:13px}}

@media(max-width:600px){
  body.admin{width:100vw;max-width:100vw;overflow-x:hidden}
  .login-screen{position:relative;display:block;min-height:100dvh;overflow:hidden;padding:0!important}
  .login-card{position:absolute!important;left:16px!important;right:16px!important;top:50%!important;transform:translateY(-50%)!important;width:auto!important;max-width:none!important;margin:0!important}
}
