/* =====================================================================
   Backup de Red — JR Intercom
   Sistema de diseño · tema oscuro profesional
   ===================================================================== */
:root{
    /* Superficies */
    --bg:#0b1120; --bg2:#0e1628;
    --panel:#141d31; --panel2:#1b2942; --panel3:#22304d;
    --line:#26344f; --line2:#324363;
    /* Texto */
    --text:#e6edf7; --muted:#8da2bf; --muted2:#64748b;
    /* Marca / acentos */
    --accent:#38bdf8; --accent2:#0ea5e9; --accent3:#6366f1;
    --grad:linear-gradient(135deg,#0ea5e9,#6366f1);
    /* Semánticos */
    --ok:#34d399; --okbg:#06281d; --okln:#0c5a40;
    --err:#fb7185; --errbg:#2e1117; --errln:#7f1d2e;
    --warn:#fbbf24; --warnbg:#2a210a; --warnln:#7c5e12;
    --info:#60a5fa; --infobg:#11203b; --infoln:#1e3a6b;
    --radius:14px; --radius-sm:9px;
    --shadow:0 8px 28px rgba(0,0,0,.35);
    --shadow-sm:0 2px 10px rgba(0,0,0,.25);
    --sidebar-w:248px;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
    margin:0;
    font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
    background:
        radial-gradient(1100px 600px at 100% -10%, rgba(99,102,241,.10), transparent 60%),
        radial-gradient(900px 500px at -10% 110%, rgba(14,165,233,.10), transparent 55%),
        var(--bg);
    color:var(--text);line-height:1.55;-webkit-font-smoothing:antialiased;
}
a{color:var(--accent);text-decoration:none}
a:hover{color:var(--accent2)}
::selection{background:rgba(56,189,248,.3)}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-thumb{background:var(--line2);border-radius:8px;border:3px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:#42557a}

/* =====================================================================
   Layout: sidebar + main
   ===================================================================== */
.app{display:flex;min-height:100vh}

.sidebar{
    width:var(--sidebar-w);flex:0 0 var(--sidebar-w);
    background:linear-gradient(180deg,var(--panel),var(--bg2));
    border-right:1px solid var(--line);
    display:flex;flex-direction:column;
    position:sticky;top:0;height:100vh;z-index:40;
}
.sidebar .brand{
    display:flex;align-items:center;gap:11px;
    padding:20px 22px;border-bottom:1px solid var(--line);
}
.sidebar .logo{
    width:38px;height:38px;flex:0 0 38px;border-radius:11px;
    background:var(--grad);display:grid;place-items:center;
    font-size:20px;color:#fff;box-shadow:0 6px 16px rgba(14,165,233,.35);
}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text b{font-size:15px;letter-spacing:.2px}
.brand-text small{font-size:11px;color:var(--muted2);text-transform:uppercase;letter-spacing:.7px}

.nav{flex:1;overflow-y:auto;padding:14px 12px}
.nav-group{margin-bottom:6px}
.nav-group .nav-label{
    font-size:10.5px;text-transform:uppercase;letter-spacing:1px;
    color:var(--muted2);font-weight:700;padding:14px 12px 7px;
}
.nav a{
    display:flex;align-items:center;gap:12px;
    color:var(--muted);padding:10px 12px;border-radius:10px;
    font-size:14px;font-weight:500;margin:2px 0;position:relative;
    transition:background .15s,color .15s;
}
.nav a .ic{width:19px;height:19px;flex:0 0 19px;display:inline-grid;place-items:center;opacity:.85}
.nav a .ic svg{width:18px;height:18px}
.nav a:hover{background:var(--panel2);color:var(--text)}
.nav a.on{background:linear-gradient(90deg,rgba(56,189,248,.16),rgba(99,102,241,.10));color:#fff}
.nav a.on::before{content:"";position:absolute;left:-12px;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--accent)}
.nav a .tag{margin-left:auto;font-size:10px;font-weight:700;background:var(--panel3);color:var(--muted);padding:1px 7px;border-radius:20px}

.sidebar-foot{padding:14px 18px;border-top:1px solid var(--line);font-size:11.5px;color:var(--muted2)}
.sidebar-foot b{color:var(--muted)}

/* Main column */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
    height:64px;display:flex;align-items:center;gap:18px;
    padding:0 28px;border-bottom:1px solid var(--line);
    background:rgba(11,17,32,.72);backdrop-filter:blur(10px);
    position:sticky;top:0;z-index:30;
}
.topbar .page-id{display:flex;flex-direction:column;line-height:1.2}
.topbar .page-id .crumb{font-size:11px;color:var(--muted2);text-transform:uppercase;letter-spacing:.6px}
.topbar .page-id .ptitle{font-size:16px;font-weight:650}
.topbar .spacer{flex:1}
.hamburger{display:none;background:transparent;border:1px solid var(--line);color:var(--text);
    width:38px;height:38px;border-radius:9px;cursor:pointer;font-size:18px}

.userbox{display:flex;align-items:center;gap:11px}
.avatar{
    width:36px;height:36px;border-radius:50%;background:var(--grad);
    display:grid;place-items:center;font-weight:700;color:#fff;font-size:14px;
}
.userbox .meta{display:flex;flex-direction:column;line-height:1.15;text-align:right}
.userbox .uname{font-weight:600;font-size:13.5px}
.urole{font-size:10px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}
.logout{
    display:grid;place-items:center;width:38px;height:38px;border-radius:9px;
    border:1px solid var(--line);color:var(--muted);
}
.logout:hover{border-color:var(--err);color:var(--err)}

.content{padding:28px;max-width:1320px;width:100%;margin:0 auto}
.foot{text-align:center;color:var(--muted2);font-size:12.5px;padding:22px}

/* =====================================================================
   Encabezado de página
   ===================================================================== */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-size:24px;margin:0;font-weight:700;letter-spacing:-.3px}
.subtitle{color:var(--muted);font-size:14px;margin-top:3px}

/* =====================================================================
   KPI cards
   ===================================================================== */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:22px}
.kpi{
    background:linear-gradient(180deg,var(--panel),var(--bg2));
    border:1px solid var(--line);border-radius:var(--radius);
    padding:18px 20px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);
    transition:transform .15s,border-color .15s;
}
.kpi:hover{transform:translateY(-2px);border-color:var(--line2)}
.kpi .kpi-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.kpi .kpi-ic{
    width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
    background:var(--panel2);color:var(--accent);flex:0 0 42px;
}
.kpi .kpi-ic svg{width:22px;height:22px}
.kpi.k-ok .kpi-ic{background:var(--okbg);color:var(--ok)}
.kpi.k-warn .kpi-ic{background:var(--warnbg);color:var(--warn)}
.kpi.k-info .kpi-ic{background:var(--infobg);color:var(--info)}
.kpi.k-purple .kpi-ic{background:rgba(99,102,241,.14);color:#a5b4fc}
.kpi .kpi-label{font-size:12.5px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px}
.kpi .kpi-val{font-size:30px;font-weight:800;letter-spacing:-.5px;margin-top:6px;line-height:1}
.kpi .kpi-sub{font-size:12.5px;color:var(--muted2);margin-top:7px}
.kpi .kpi-sub .up{color:var(--ok)} .kpi .kpi-sub .down{color:var(--err)}

/* =====================================================================
   Grilla de paneles / gráficos
   ===================================================================== */
.grid{display:grid;gap:18px}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.span-2{grid-column:span 2}

.panel{
    background:var(--panel);border:1px solid var(--line);
    border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
}
.panel-head{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    padding:16px 20px;border-bottom:1px solid var(--line);
}
.panel-head h2,.panel-head h3{margin:0;font-size:15px;font-weight:650}
.panel-head .hint{font-size:12px;color:var(--muted2)}
.panel-body{padding:20px}
.chart-box{position:relative;height:280px}
.chart-box.sm{height:230px}

/* Toolbar (filtros, búsqueda) */
.toolbar{
    display:flex;align-items:center;gap:10px;flex-wrap:wrap;
    background:var(--panel);border:1px solid var(--line);
    border-radius:var(--radius);padding:14px 16px;margin-bottom:18px;box-shadow:var(--shadow-sm);
}
.toolbar .grow{flex:1;min-width:160px}
.search{
    display:flex;align-items:center;gap:9px;background:var(--bg);border:1px solid var(--line);
    border-radius:10px;padding:0 12px;height:40px;
}
.search input{background:transparent;border:0;color:var(--text);width:100%;font-size:14px;outline:none}
.search svg{width:17px;height:17px;color:var(--muted2);flex:0 0 17px}

/* =====================================================================
   Tablas
   ===================================================================== */
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{
    text-align:left;background:var(--panel2);color:var(--muted);
    font-weight:700;padding:12px 18px;border-bottom:1px solid var(--line);
    font-size:11px;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;
}
tbody td{padding:13px 18px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr{transition:background .12s}
tbody tr:hover{background:var(--panel2)}
.t-name{font-weight:600;color:var(--text)}
.t-sub{font-size:12px;color:var(--muted2);margin-top:1px}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12.5px}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;padding:3px 10px;border-radius:20px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;border:1px solid transparent}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.badge-on,.badge-ok{background:var(--okbg);color:var(--ok);border-color:var(--okln)}
.badge-off,.badge-err{background:var(--errbg);color:var(--err);border-color:var(--errln)}
.badge-warn{background:var(--warnbg);color:var(--warn);border-color:var(--warnln)}
.badge-info{background:var(--infobg);color:var(--info);border-color:var(--infoln)}
.badge-admin{background:rgba(99,102,241,.15);color:#a5b4fc;border-color:#3b3f7a}
.badge-oper{background:var(--panel3);color:var(--muted)}
.row-actions{display:flex;gap:7px;flex-wrap:wrap}

/* =====================================================================
   Botones
   ===================================================================== */
.btn{
    display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-size:14px;font-weight:600;
    padding:10px 17px;border-radius:10px;border:1px solid transparent;
    background:var(--grad);color:#fff;line-height:1;white-space:nowrap;
    box-shadow:0 4px 14px rgba(14,165,233,.25);transition:transform .12s,box-shadow .12s,opacity .12s;
}
.btn svg{width:16px;height:16px}
.btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(14,165,233,.4);color:#fff}
.btn:active{transform:translateY(0)}
.btn-sm{padding:7px 12px;font-size:12.5px;border-radius:8px;box-shadow:none}
.btn-ghost{background:transparent;border-color:var(--line2);color:var(--text);box-shadow:none}
.btn-ghost:hover{background:var(--panel2);color:var(--text);box-shadow:none}
.btn-danger{background:transparent;border-color:var(--errln);color:var(--err);box-shadow:none}
.btn-danger:hover{background:var(--err);color:#1a0008;box-shadow:none}

/* =====================================================================
   Formularios
   ===================================================================== */
.form-wrap{max-width:620px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 20px}
.form-grid .full{grid-column:1 / -1}
.field{margin-bottom:17px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:7px;font-weight:600}
.field input,.field select,.field textarea{
    width:100%;background:var(--bg);border:1px solid var(--line);color:var(--text);
    padding:11px 13px;border-radius:10px;font-size:14px;font-family:inherit;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(56,189,248,.15)}
.field .hint{font-size:12px;color:var(--muted2);margin-top:6px}
.field .err-msg{font-size:12px;color:var(--err);margin-top:6px;font-weight:600}
.form-actions{display:flex;gap:11px;margin-top:24px}
.checkbox{display:flex;align-items:center;gap:9px;cursor:pointer}
.checkbox input{width:auto;accent-color:var(--accent2)}

/* =====================================================================
   Alertas
   ===================================================================== */
.alert{display:flex;align-items:center;gap:10px;padding:13px 17px;border-radius:11px;margin-bottom:18px;font-size:14px;border:1px solid transparent;box-shadow:var(--shadow-sm)}
.alert::before{font-weight:800;font-size:15px}
.alert-success{background:var(--okbg);color:var(--ok);border-color:var(--okln)}
.alert-success::before{content:"✓"}
.alert-error{background:var(--errbg);color:var(--err);border-color:var(--errln)}
.alert-error::before{content:"!"}

/* =====================================================================
   Timeline / actividad reciente
   ===================================================================== */
.timeline{list-style:none;margin:0;padding:4px 0}
.timeline li{display:flex;gap:13px;padding:11px 20px;border-bottom:1px solid var(--line)}
.timeline li:last-child{border-bottom:none}
.tl-ic{
    width:34px;height:34px;flex:0 0 34px;border-radius:50%;display:grid;place-items:center;
    background:var(--panel2);color:var(--muted);font-size:15px;font-weight:700;
}
.tl-ic.ok{background:var(--okbg);color:var(--ok)}
.tl-ic.err{background:var(--errbg);color:var(--err)}
.tl-ic.info{background:var(--infobg);color:var(--info)}
.tl-ic.warn{background:var(--warnbg);color:var(--warn)}
.tl-body{flex:1;min-width:0}
.tl-body .tl-txt{font-size:13.5px}
.tl-body .tl-txt b{font-weight:650}
.tl-body .tl-meta{font-size:11.5px;color:var(--muted2);margin-top:2px}

/* =====================================================================
   Estados vacíos
   ===================================================================== */
.empty{padding:50px 20px;text-align:center;color:var(--muted)}
.empty .em-ic{font-size:34px;opacity:.5;margin-bottom:8px}

/* =====================================================================
   Login
   ===================================================================== */
.login-page{min-height:100vh;display:grid;place-items:center;padding:24px}
.login-card{
    width:100%;max-width:400px;background:linear-gradient(180deg,var(--panel),var(--bg2));
    border:1px solid var(--line);border-radius:20px;padding:38px 34px;box-shadow:var(--shadow);
}
.login-card .brand{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:6px}
.login-card .logo{
    width:54px;height:54px;border-radius:15px;background:var(--grad);
    display:grid;place-items:center;font-size:28px;color:#fff;box-shadow:0 8px 22px rgba(14,165,233,.4);
}
.login-card .brand b{font-size:19px;letter-spacing:.2px}
.login-sub{text-align:center;color:var(--muted);font-size:13.5px;margin:2px 0 26px}
.login-card .btn{width:100%;justify-content:center;padding:13px;font-size:15px;margin-top:4px}
.login-foot{text-align:center;color:var(--muted2);font-size:12px;margin-top:22px}

/* =====================================================================
   Vista de configuración (backup)
   ===================================================================== */
.config-view{
    margin:0;padding:18px 20px;max-height:68vh;overflow:auto;
    font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
    font-size:12.5px;line-height:1.55;color:#cdd9ec;white-space:pre;
    background:#070c17;border-radius:var(--radius);
}
.cell-msg{max-width:320px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--muted);font-size:12.5px}

/* Backup run bar */
.backup-run{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.backup-run select{flex:0 1 320px;background:var(--bg);border:1px solid var(--line);color:var(--text);padding:10px 13px;border-radius:10px;font-size:14px}

/* Definición clave/valor (fichas) */
.dl{display:grid;grid-template-columns:auto 1fr;gap:0}
.dl dt{color:var(--muted2);font-size:12.5px;padding:9px 18px;border-bottom:1px solid var(--line);text-transform:uppercase;letter-spacing:.3px;font-weight:600}
.dl dd{margin:0;padding:9px 18px;border-bottom:1px solid var(--line);font-size:14px}
.dl dt:last-of-type,.dl dd:last-of-type{border-bottom:none}

/* =====================================================================
   Tarjetas de equipo (sección Backups agrupada por equipo)
   ===================================================================== */
.eq-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:16px}
.eq-card{
    display:block;background:linear-gradient(180deg,var(--panel),var(--bg2));
    border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;
    box-shadow:var(--shadow-sm);transition:transform .15s,border-color .15s;color:var(--text);
}
.eq-card:hover{transform:translateY(-3px);border-color:var(--accent2);color:var(--text)}
.ec-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:15px}
.ec-icon{width:44px;height:44px;flex:0 0 44px;border-radius:12px;background:var(--panel2);color:var(--accent);display:grid;place-items:center}
.ec-icon svg{width:23px;height:23px}
.ec-head{flex:1;min-width:0}
.ec-name{font-weight:700;font-size:16px;letter-spacing:-.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ec-sub{font-size:12.5px;color:var(--muted2);margin-top:2px}
.ec-last{font-size:12.5px;color:var(--muted);margin-bottom:13px;display:flex;align-items:center;gap:7px}
.ec-stats{display:flex;gap:22px;border-top:1px solid var(--line);padding-top:14px}
.ec-stat .n{font-size:19px;font-weight:800;line-height:1}
.ec-stat .l{font-size:10.5px;color:var(--muted2);text-transform:uppercase;letter-spacing:.5px;margin-top:3px}
.ec-go{margin-left:auto;align-self:center;color:var(--muted2)}
.eq-card:hover .ec-go{color:var(--accent)}

/* Banner de automatización */
.auto-banner{
    display:flex;align-items:center;gap:15px;
    background:var(--panel);border:1px solid var(--line);border-left:4px solid var(--muted2);
    border-radius:var(--radius);padding:15px 20px;margin-bottom:18px;box-shadow:var(--shadow-sm);
}
.auto-banner.on{border-left-color:var(--ok)}
.auto-banner.off{border-left-color:var(--warn)}
.ab-ic{width:42px;height:42px;flex:0 0 42px;border-radius:12px;display:grid;place-items:center;background:var(--panel2);color:var(--muted)}
.auto-banner.on .ab-ic{background:var(--okbg);color:var(--ok)}
.auto-banner.off .ab-ic{background:var(--warnbg);color:var(--warn)}
.ab-ic svg{width:22px;height:22px}
.ab-body{flex:1;min-width:0}
.ab-body .ab-title{font-weight:650;font-size:14.5px}
.ab-body .ab-sub{font-size:12.5px;color:var(--muted);margin-top:2px}

/* Pasos / ayuda (módulo cron) */
.help-box{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius);padding:18px 20px;font-size:13.5px;color:var(--muted)}
.help-box b{color:var(--text)}
.help-box code{background:var(--panel2);padding:2px 7px;border-radius:6px;font-family:ui-monospace,monospace;font-size:12px;color:var(--accent)}
.inline-form{display:flex;gap:8px;align-items:center}
.inline-form input[type=number]{width:84px;background:var(--bg);border:1px solid var(--line);color:var(--text);padding:7px 10px;border-radius:8px;font-size:14px}

/* =====================================================================
   Responsive
   ===================================================================== */
@media (max-width:920px){
    .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:transform .22s ease;box-shadow:var(--shadow)}
    body.nav-open .sidebar{transform:translateX(0)}
    body.nav-open::after{content:"";position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:35}
    .hamburger{display:grid;place-items:center}
    .span-2{grid-column:auto}
    .userbox .meta{display:none}
}
@media (max-width:640px){
    .content{padding:18px}
    .topbar{padding:0 16px}
    .form-grid{grid-template-columns:1fr}
    .page-head h1{font-size:20px}
}
