/* Status FEV — Panel administrativo (pro + responsive) */
:root{
  --accent:#5b8def;
  --radius:14px;
  --radius-sm:10px;
  --danger:#ff5a5f;
  --ok:#2ecc71;
}

/* Tema Dark (por defecto) */
[data-theme="dark"]{
  --bg:#080a0f;
  --surface:#0f131b;
  --surface-2:#141926;
  --surface-3:#1a2030;
  --line:rgba(255,255,255,.07);
  --line-2:rgba(255,255,255,.12);
  --text:#eef1f7;
  --muted:#9099ad;
  --faint:#5f6883;
  --input:#0b0e15;
  --shadow:0 24px 60px -36px rgba(0,0,0,.85);
}

/* Tema Light */
[data-theme="light"]{
  --bg:#f4f6fb;
  --surface:#ffffff;
  --surface-2:#f7f9fd;
  --surface-3:#eef1f7;
  --line:rgba(10,15,30,.08);
  --line-2:rgba(10,15,30,.14);
  --text:#141925;
  --muted:#5a6478;
  --faint:#9aa3b5;
  --input:#ffffff;
  --shadow:0 24px 60px -36px rgba(0,0,0,.12);
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:'Sora',system-ui,sans-serif;background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;line-height:1.5;
}
svg{display:block}

/* ===================== AUTH ===================== */
.auth-main{
  min-height:100vh;min-height:100dvh;display:grid;place-items:center;padding:24px;
  background:
    radial-gradient(70vw 55vh at 50% -15%, color-mix(in srgb,var(--accent) 20%,transparent), transparent 65%),
    radial-gradient(40vw 40vh at 90% 110%, color-mix(in srgb,var(--accent) 10%,transparent), transparent 70%);
}
.auth-card{
  width:100%;max-width:400px;background:var(--surface);border:1px solid var(--line);
  border-radius:22px;padding:42px 36px;box-shadow:var(--shadow);
}
.auth-logo{
  width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:23px;color:#fff;
  background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 35%,#000));
  margin-bottom:20px;box-shadow:0 12px 30px -10px var(--accent);
}
.auth-card h1{font-size:25px;font-weight:800;letter-spacing:-.025em}
.auth-sub{color:var(--muted);font-size:14px;margin-bottom:22px}
.auth-card form{display:flex;flex-direction:column;gap:4px}

/* SSO Button */
.btn-sso{
  display:flex;align-items:center;justify-content:center;gap:12px;
  padding:14px 20px;border-radius:var(--radius-sm);font-size:15px;font-weight:600;
  background:var(--surface-2);color:var(--text);text-decoration:none;
  border:1px solid var(--line-2);transition:.2s;cursor:pointer;margin-top:16px;
}
.btn-sso:hover{
  background:var(--surface-3);border-color:var(--accent);
  transform:translateY(-1px);box-shadow:0 4px 12px -4px var(--accent);
}
.btn-sso svg{width:22px;height:22px;flex-shrink:0}

/* SSO Button Primary (único método de login) */
.btn-sso-primary{
  background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 70%,#000));
  color:#fff;border:none;padding:16px 24px;
  box-shadow:0 4px 14px -4px var(--accent);
}
.btn-sso-primary:hover{
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 90%,#fff),var(--accent));
  box-shadow:0 6px 20px -4px var(--accent);
}

/* Divider */
.divider{
  position:relative;text-align:center;margin:24px 0 20px;
  color:var(--muted);font-size:13px;
}
.divider::before{
  content:"";position:absolute;left:0;top:50%;width:100%;height:1px;
  background:var(--line);z-index:0;
}
.divider span{
  position:relative;background:var(--surface);padding:0 12px;z-index:1;
}

/* ===================== APP SHELL ===================== */
.app{display:flex;min-height:100vh;min-height:100dvh}

/* Topbar móvil (oculto en escritorio) */
.mobile-bar{display:none}
.theme-toggle{display:none}

/* Sidebar */
.sidebar{
  width:256px;flex:none;background:var(--surface);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:20px 14px;position:sticky;top:0;height:100vh;height:100dvh;z-index:40;
}
.side-brand{display:flex;align-items:center;gap:11px;font-weight:800;font-size:18px;padding:6px 10px 22px;letter-spacing:-.02em}
.mark{
  width:34px;height:34px;border-radius:10px;display:grid;place-items:center;color:#fff;font-size:16px;flex:none;
  background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 35%,#000));
  box-shadow:0 8px 20px -8px var(--accent);
}
.sidebar nav{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto}
.nav-label{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);
  padding:16px 12px 7px}
.sidebar nav a{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--radius-sm);
  color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;transition:.16s;position:relative;
}
.nav-ico{width:18px;height:18px;flex:none;display:grid;place-items:center}
.nav-ico svg{width:18px;height:18px}
.sidebar nav a:hover{background:var(--surface-2);color:var(--text)}
.sidebar nav a.on{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--text)}
.sidebar nav a.on::before{content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%);
  width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--accent)}

.side-foot{border-top:1px solid var(--line);padding-top:14px;margin-top:10px;display:flex;flex-direction:column;gap:6px}

/* Theme toggle en sidebar */
.theme-toggle-sidebar{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);
  font-size:13px;color:var(--muted);transition:.16s;cursor:pointer;
  background:none;border:none;width:100%;text-align:left;font-family:inherit;
}
.theme-toggle-sidebar:hover{background:var(--surface-2);color:var(--text)}
.theme-icon{font-size:18px;line-height:1}
.theme-label{flex:1}

.view-public{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);
  font-size:13px;color:var(--muted);text-decoration:none;transition:.16s}
.view-public:hover{background:var(--surface-2);color:var(--text)}
.who{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--line);
  border-radius:12px;padding:9px 11px;margin-top:4px}
.avatar{width:34px;height:34px;border-radius:9px;flex:none;display:grid;place-items:center;font-weight:700;font-size:14px;
  color:#fff;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 40%,#000))}
.who-meta{display:flex;flex-direction:column;flex:1;min-width:0}
.who-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.who-role{font-size:11px;color:var(--faint);text-transform:capitalize}
.logout{color:var(--muted);display:grid;place-items:center;width:32px;height:32px;border-radius:8px;transition:.16s}
.logout svg{width:17px;height:17px}
.logout:hover{color:var(--danger);background:color-mix(in srgb,var(--danger) 12%,transparent)}

/* Content */
.content{flex:1;padding:32px 40px 60px;max-width:1180px;margin:0 auto;width:100%}

/* ===================== PAGE HEAD ===================== */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:26px;flex-wrap:wrap}
.page-head h1{font-size:27px;font-weight:800;letter-spacing:-.025em}
.page-head .sub{color:var(--muted);font-size:14px;margin-top:3px}
.sub-head{font-size:15px;font-weight:700;margin:32px 0 14px;letter-spacing:-.01em}

/* ===================== TOAST / FLASH ===================== */
.toast-wrap{position:fixed;top:18px;right:18px;z-index:100;animation:toastIn .35s cubic-bezier(.2,.9,.3,1)}
.toast{background:var(--surface-2);border:1px solid color-mix(in srgb,var(--accent) 40%,var(--line));
  color:var(--text);padding:13px 18px;border-radius:12px;font-size:14px;box-shadow:var(--shadow);
  border-left:3px solid var(--accent)}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.flash.err{border-left-color:var(--danger);border-color:color-mix(in srgb,var(--danger) 40%,var(--line))}
.flash{background:color-mix(in srgb,var(--danger) 12%,var(--surface));border:1px solid color-mix(in srgb,var(--danger) 35%,transparent);
  color:var(--text);padding:12px 16px;border-radius:11px;margin-bottom:18px;font-size:14px;border-left:3px solid var(--danger)}

/* ===================== FORMS ===================== */
label{font-size:12.5px;font-weight:600;color:var(--muted);margin-top:14px;display:block}
input,select,textarea{
  width:100%;background:var(--input);border:1px solid var(--line);color:var(--text);
  padding:11px 13px;border-radius:var(--radius-sm);font-size:14px;font-family:inherit;margin-top:6px;transition:.16s;
}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 20%,transparent)}
textarea{resize:vertical;min-height:80px}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239099ad' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;padding-right:34px}
.color-input{height:46px;padding:5px;cursor:pointer}
.row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hint{font-size:11.5px;color:var(--faint);margin-top:6px}

/* Buttons */
.btn-primary{margin-top:20px;background:var(--accent);color:#fff;border:none;padding:12px 20px;border-radius:var(--radius-sm);
  font-size:14px;font-weight:700;cursor:pointer;transition:.16s;width:100%;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px);box-shadow:0 10px 24px -12px var(--accent)}
.btn-primary svg{width:17px;height:17px}
.btn-head{width:auto;margin:0;padding:10px 18px}
.btn-ghost{display:inline-block;margin-top:10px;text-align:center;width:100%;color:var(--muted);
  text-decoration:none;font-size:13px;padding:9px;border-radius:var(--radius-sm);transition:.16s}
.btn-ghost:hover{background:var(--surface-2);color:var(--text)}
.btn-sm{background:var(--surface-2);border:1px solid var(--line);color:var(--text);padding:7px 13px;
  border-radius:9px;font-size:12.5px;font-weight:600;cursor:pointer;text-decoration:none;transition:.16s;
  display:inline-flex;align-items:center;gap:6px}
.btn-sm:hover{border-color:var(--line-2);background:var(--surface-3)}
.btn-sm.danger{color:var(--danger);border-color:color-mix(in srgb,var(--danger) 25%,transparent)}
.btn-sm.danger:hover{background:color-mix(in srgb,var(--danger) 12%,transparent)}
.inline{display:inline}
.mini-select{width:auto;padding:7px 30px 7px 11px;font-size:12.5px;margin-top:0}

/* ===================== CARDS / PANELS ===================== */
.split{display:grid;grid-template-columns:360px 1fr;gap:24px;align-items:start}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.panel.narrow{max-width:560px}
.panel h2{font-size:16px;font-weight:700;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.panel .panel-sub{font-size:12.5px;color:var(--muted);margin-bottom:6px}
.panel-sticky{position:sticky;top:24px}

/* ===================== DASHBOARD ===================== */
.status-hero{display:flex;align-items:center;gap:16px;
  background:linear-gradient(135deg,color-mix(in srgb,var(--c) 18%,var(--surface)),var(--surface));
  border:1px solid color-mix(in srgb,var(--c) 32%,var(--line));border-radius:var(--radius);
  padding:24px 26px;margin-bottom:22px;box-shadow:var(--shadow)}
.status-hero .dot{width:14px;height:14px;border-radius:50%;background:var(--c);flex:none;
  box-shadow:0 0 0 0 color-mix(in srgb,var(--c) 55%,transparent);animation:hpulse 2.2s infinite}
@keyframes hpulse{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--c) 50%,transparent)}70%{box-shadow:0 0 0 13px transparent}100%{box-shadow:0 0 0 0 transparent}}
.status-hero strong{display:block;font-size:19px;letter-spacing:-.01em}
.status-hero small{color:var(--muted);font-size:13px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:13px;margin-bottom:8px}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px 18px 16px;
  display:flex;flex-direction:column;gap:5px;position:relative;overflow:hidden;transition:.18s}
.stat-card:hover{border-color:var(--line-2);transform:translateY(-2px)}
.stat-card::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--sc,transparent)}
.stat-top{display:flex;align-items:center;gap:8px}
.stat-dot{width:9px;height:9px;border-radius:50%}
.stat-num{font-size:30px;font-weight:800;font-family:'JetBrains Mono',monospace;line-height:1}
.stat-lbl{font-size:12px;color:var(--muted)}

.list-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);
  border-radius:12px;padding:14px 18px;margin-bottom:9px;transition:.16s}
.list-row:hover{border-color:var(--line-2)}
.list-row .grow-sp{margin-left:auto}
.empty-line{padding:18px 0;color:var(--muted)}

/* ===================== STATUS PILL ===================== */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:4px 10px;border-radius:20px;
  background:color-mix(in srgb,var(--pc) 14%,transparent);color:var(--pc);border:1px solid color-mix(in srgb,var(--pc) 30%,transparent)}
.pill i{width:7px;height:7px;border-radius:50%;background:var(--pc)}

/* ===================== ITEMS / LIST ===================== */
.list-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.count-chip{font-size:11.5px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);
  padding:3px 10px;border-radius:20px;font-weight:600}
.item{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:15px 0;border-bottom:1px solid var(--line)}
.item:last-child{border-bottom:none}
.item-main{display:flex;align-items:center;gap:12px;min-width:0}
.item-main .nm{display:flex;flex-direction:column;min-width:0}
.item-main strong{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.item-sub{display:flex;align-items:center;gap:8px;margin-top:3px}
.tag{font-size:10.5px;background:var(--surface-2);border:1px solid var(--line);padding:2px 9px;border-radius:20px;
  color:var(--muted);text-transform:capitalize}
.status-dot{width:9px;height:9px;border-radius:50%;flex:none}
.item-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.muted{color:var(--muted)}

/* Empty state */
.empty-state{text-align:center;padding:46px 20px;color:var(--muted)}
.empty-state .es-ico{width:46px;height:46px;margin:0 auto 14px;border-radius:13px;display:grid;place-items:center;
  background:var(--surface-2);border:1px solid var(--line);color:var(--faint)}
.empty-state .es-ico svg{width:22px;height:22px}

/* ===================== INCIDENTES ===================== */
.checks{display:flex;flex-direction:column;gap:4px;max-height:190px;overflow:auto;background:var(--input);
  border:1px solid var(--line);border-radius:var(--radius-sm);padding:8px;margin-top:6px}
.chk{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text);font-weight:400;margin:0;
  padding:7px 8px;border-radius:8px;cursor:pointer;transition:.12s}
.chk:hover{background:var(--surface-2)}
.chk input{width:auto;margin:0}
.incident-block{border:1px solid var(--line);border-radius:var(--radius);padding:17px 18px;margin-bottom:13px;background:var(--surface-2)}
.incident-block.is-resolved{opacity:.62}
.ib-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:9px}
.ib-head strong{font-size:15px}
.ib-head .grow-sp{margin-left:auto}
.impact-pill{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 9px;
  border-radius:20px;color:#fff;background:var(--c,#888)}
.mini-timeline{list-style:none;font-size:13px;display:flex;flex-direction:column;gap:9px;margin:10px 0;
  border-left:2px solid var(--line);padding-left:14px}
.mini-timeline li{color:var(--muted);position:relative}
.mini-timeline li::before{content:"";position:absolute;left:-19px;top:5px;width:8px;height:8px;border-radius:50%;
  background:var(--accent);border:2px solid var(--surface-2)}
.mini-timeline b{color:var(--accent)}
.mini-timeline time{display:block;font-size:11px;color:var(--faint);font-family:'JetBrains Mono',monospace;margin-top:3px}
.update-form{display:flex;gap:8px;margin:12px 0 4px;align-items:center;flex-wrap:wrap}
.update-form select{width:auto;margin:0;flex:none}
.update-form input{margin:0;flex:1;min-width:140px}
.update-form .btn-sm{margin:0}
.ib-actions{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--line)}

/* ===================== RESPONSIVE ===================== */
@media(max-width:980px){
  .split{grid-template-columns:1fr}
  .panel-sticky{position:static}
}
@media(max-width:820px){
  .mobile-bar{
    display:flex;align-items:center;justify-content:space-between;gap:12px;
    position:sticky;top:0;z-index:50;
    background:color-mix(in srgb,var(--surface) 92%,transparent);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--line);padding:12px 16px;
  }
  .mb-brand{
    font-weight:800;font-size:16px;display:flex;align-items:center;gap:9px;
    flex:1;min-width:0;overflow:hidden;
  }
  .mb-brand span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .mb-brand .mark{width:28px;height:28px;font-size:13px;flex-shrink:0}
  .theme-toggle{
    color:var(--muted);display:grid;place-items:center;width:36px;height:36px;
    border-radius:9px;flex-shrink:0;transition:.2s;cursor:pointer;
    background:none;border:none;font-size:18px;font-family:inherit;
  }
  .theme-toggle:hover{background:var(--surface-2)}
  .mb-ext{
    color:var(--muted);display:grid;place-items:center;width:36px;height:36px;
    border-radius:9px;flex-shrink:0;transition:.2s;
  }
  .mb-ext:hover{background:var(--surface-2)}
  .mb-ext svg{width:19px;height:19px}
  .hamburger{
    width:38px;height:38px;border:1px solid var(--line);background:var(--surface-2);
    border-radius:9px;display:flex;flex-direction:column;justify-content:center;
    align-items:center;gap:4px;cursor:pointer;transition:.2s;flex-shrink:0;
  }
  .hamburger:hover{background:var(--surface-3)}
  .hamburger span{width:17px;height:2px;background:var(--text);border-radius:2px;transition:.25s}
  body.nav-open .hamburger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  body.nav-open .hamburger span:nth-child(2){opacity:0}
  body.nav-open .hamburger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

  .app{display:block}
  .sidebar{
    position:fixed;top:0;left:0;height:100vh;height:100dvh;width:270px;
    transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);
    box-shadow:0 0 60px rgba(0,0,0,.6);z-index:45;
  }
  body.nav-open .sidebar{transform:none}
  .theme-toggle-sidebar{display:none}
  .overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:40;opacity:0;visibility:hidden;transition:.28s}
  body.nav-open .overlay{opacity:1;visibility:visible}
  .content{padding:22px 18px 50px}
  .side-brand{padding:14px 10px 20px}
  .sidebar nav a{font-size:13.5px;padding:9px 12px}
  .nav-label{font-size:10px;padding:14px 12px 6px}
  .view-public{font-size:12.5px;padding:8px 12px}
  .who{padding:10px}
  .who-name{font-size:12.5px}
  .who-role{font-size:10.5px}
  .page-head h1{font-size:23px}
  .toast-wrap{top:auto;bottom:18px;right:18px;left:18px}
  .toast{text-align:center}
}
/* Tablet (768px - 900px) */
@media(max-width:900px){
  .content{padding:24px 20px 50px;max-width:100%}
  .page-head h1{font-size:26px}
  .cards{grid-template-columns:repeat(2,1fr);gap:14px}
}

/* Móvil grande (560px - 768px) */
@media(max-width:768px){
  .content{padding:20px 18px 46px}
  .page-head{gap:14px}
  .page-head h1{font-size:24px}
  .panel{padding:20px}
  .row-2{grid-template-columns:1fr;gap:14px}
  .form-group label{font-size:13px}
  input[type="text"],input[type="email"],input[type="password"],input[type="number"],
  textarea,select{font-size:14px;padding:10px 13px}
  .btn,.btn-sec{font-size:14px;padding:11px 18px}
  .btn-sm{font-size:12px;padding:6px 11px}
  .stat-card h3{font-size:15px}
  .stat-val{font-size:26px}
  .item-main strong{font-size:14px}
  .item-meta{font-size:12px}
}

/* Móvil (max-width: 560px) */
@media(max-width:560px){
  .content{padding:18px 14px 44px}
  .page-head{flex-direction:column;align-items:flex-start;gap:12px}
  .page-head h1{font-size:22px}
  .btn-head{width:100%;justify-content:center}
  .panel{padding:16px;border-radius:12px}
  .form-group label{font-size:12.5px}
  input[type="text"],input[type="email"],input[type="password"],input[type="number"],
  textarea,select{font-size:13.5px;padding:9px 12px}
  .btn,.btn-sec{font-size:13.5px;padding:10px 16px}
  .btn-sm{font-size:11.5px;padding:5px 10px}
  .row-2{grid-template-columns:1fr;gap:12px}
  .cards{grid-template-columns:1fr;gap:12px}
  .stat-card{padding:16px}
  .stat-card h3{font-size:13.5px}
  .stat-val{font-size:24px}
  .item{flex-direction:column;align-items:flex-start;gap:10px}
  .item-actions{width:100%;justify-content:flex-start;flex-wrap:wrap}
  .item-main{width:100%}
  .item-main strong{white-space:normal;font-size:13.5px}
  .item-meta{font-size:11.5px}
  .mini-select{width:100%;font-size:12px}
  .list-row{flex-wrap:wrap;gap:8px}
  .list-row strong{flex:1 1 100%;order:2;font-size:13.5px}
  .list-row .grow-sp{margin-left:0;order:3}
  .list-row .btn-sm{order:4}
  .ib-box{padding:14px}
  .ib-head h3{font-size:14px}
  .ib-status{font-size:11px;padding:3px 8px}
  .ib-impact{font-size:10px}
  .ib-meta{font-size:11px}
  .update-item{padding:12px;gap:10px}
  .update-st{font-size:11px}
  .update-body{font-size:13px}
  .update-time{font-size:10.5px}
  textarea{min-height:100px}
  .who{padding:12px;gap:10px}
  .who-name{font-size:13px}
  .who-role{font-size:10.5px}
  .avatar{width:34px;height:34px;font-size:13px}
  .modal-box{padding:22px;max-width:340px}
  .modal-title{font-size:17px}
  .modal-message{font-size:13.5px;margin-bottom:20px}
  .modal-btn{padding:10px 18px;font-size:13px}
}

/* ===================== UPTIME HISTORY PAGE ===================== */
/* Selector de componentes */
.component-selector{
  display:flex;flex-direction:column;gap:8px;margin-top:14px;
}
.comp-option{
  padding:12px 14px;border-radius:var(--radius-sm);
  background:var(--input);border:1px solid var(--line);
  color:var(--text);text-decoration:none;font-size:14px;font-weight:500;
  transition:.2s;cursor:pointer;display:block;
}
.comp-option:hover{
  background:var(--surface-2);border-color:var(--line-2);
  transform:translateX(2px);
}
.comp-option.active{
  background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 70%,#000));
  border-color:var(--accent);color:#fff;font-weight:600;
  box-shadow:0 4px 12px -4px var(--accent);
}

/* Tabla de uptime */
.uptime-table{
  width:100%;border-collapse:collapse;font-size:14px;
  background:var(--input);border-radius:var(--radius-sm);overflow:hidden;
}
.uptime-table thead{
  background:var(--surface-2);
}
.uptime-table th{
  padding:14px 16px;text-align:left;font-weight:600;font-size:13px;
  color:var(--muted);border-bottom:1px solid var(--line);
}
.uptime-table td{
  padding:14px 16px;border-bottom:1px solid var(--line);
}
.uptime-table tbody tr:last-child td{
  border-bottom:none;
}
.uptime-table tbody tr:hover{
  background:var(--surface-2);
}

/* Acciones inline en tabla */
.inline-actions{
  display:flex;gap:8px;align-items:center;justify-content:flex-end;
}
.inline-actions .inline{
  display:flex;align-items:center;gap:8px;
}

/* Alert success */
.alert{
  padding:14px 18px;border-radius:var(--radius-sm);margin-bottom:20px;
  font-size:14px;font-weight:500;
}
.alert.success{
  background:color-mix(in srgb,var(--ok) 15%,transparent);
  border:1px solid color-mix(in srgb,var(--ok) 30%,transparent);
  color:var(--ok);
}

/* Responsive uptime history */
@media(max-width:768px){
  .uptime-table{font-size:13px}
  .uptime-table th,.uptime-table td{padding:12px 14px}
  .inline-actions{flex-wrap:wrap;gap:6px}
}

@media(max-width:560px){
  .uptime-table{font-size:12px;display:block;overflow-x:auto}
  .uptime-table th,.uptime-table td{padding:10px 12px;white-space:nowrap}
  .comp-option{font-size:13px;padding:10px 12px}
  .alert{font-size:13px;padding:12px 14px}
}

/* Móvil pequeño (max-width: 375px) */
@media(max-width:375px){
  .content{padding:16px 12px 40px}
  .page-head h1{font-size:20px}
  .panel{padding:14px}
  .cards{gap:10px}
  .stat-card{padding:14px}
  .stat-card h3{font-size:13px}
  .stat-val{font-size:22px}
  input[type="text"],input[type="email"],input[type="password"],input[type="number"],
  textarea,select{font-size:13px;padding:8px 11px}
  .btn,.btn-sec{font-size:13px;padding:9px 14px}
  .btn-sm{font-size:11px;padding:4px 9px}
  .item-main strong{font-size:13px}
  .ib-head h3{font-size:13.5px}
  .modal-box{padding:20px;max-width:300px}
  .sidebar{width:260px}
  .auth-card{padding:32px 26px;max-width:360px}
  .auth-logo{width:48px;height:48px;font-size:21px;margin-bottom:16px}
  .auth-card h1{font-size:23px}
  .auth-sub{font-size:13px}
  .btn-sso{font-size:13px;padding:11px 18px}
}

/* Auth responsive general */
@media(max-width:560px){
  .auth-main{padding:20px}
  .auth-card{padding:36px 30px;max-width:380px}
  .auth-logo{width:50px;height:50px;font-size:22px}
  .auth-card h1{font-size:24px}
  .auth-sub{font-size:13.5px;margin-bottom:20px}
  .btn-sso{font-size:13.5px}
  .divider{margin:18px 0;font-size:12px}
}

/* Marca con logo institucional */
.mark-img{width:34px;height:34px;border-radius:9px;object-fit:contain;flex:none}
.mb-brand .mark-img{width:28px;height:28px}
.auth-logo-img{width:180px;height:auto;display:block;margin-bottom:18px}

/* Modal de confirmación */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;z-index:9999;
  opacity:0;visibility:hidden;transition:.25s;
}
.modal-overlay.show{opacity:1;visibility:visible}
.modal-box{
  background:var(--surface-2);border:1px solid var(--line-2);border-radius:16px;
  padding:26px;max-width:440px;width:90%;box-shadow:0 24px 60px -20px rgba(0,0,0,.8);
  transform:scale(.94);transition:.25s;
}
.modal-overlay.show .modal-box{transform:scale(1)}
.modal-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.modal-icon{font-size:26px}
.modal-title{font-size:19px;font-weight:700;color:var(--text)}
.modal-message{font-size:14.5px;color:var(--muted);margin-bottom:22px;line-height:1.7}
.modal-actions{display:flex;gap:10px;justify-content:flex-end}
.modal-btn{
  padding:11px 22px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;
  cursor:pointer;transition:.18s;border:1px solid var(--line);font-family:inherit;
}
.cancel-btn{background:var(--surface-3);color:var(--text)}
.cancel-btn:hover{background:var(--surface);border-color:var(--line-2)}
.confirm-btn{background:var(--danger);color:#fff;border-color:var(--danger)}
.confirm-btn:hover{background:#e04545;transform:translateY(-1px);box-shadow:0 8px 20px -8px var(--danger)}

/* Touch-friendly improvements */
@media(pointer:coarse){
  .btn,.btn-sec,.btn-sm{min-height:44px}
  .hamburger{min-width:44px;min-height:44px}
  .mb-ext{min-width:44px;min-height:44px}
  .sidebar nav a{min-height:44px}
  .logout{min-width:40px;min-height:40px}
  input[type="text"],input[type="email"],input[type="password"],
  input[type="number"],textarea,select{min-height:44px}
}

/* ===================== VAULT FEV SPECIFIC STYLES ===================== */

/* Stats Grid */
.stats-grid{
  display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  margin-bottom:28px;
}
.stat-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;text-align:center;
}
.stat-icon{font-size:32px;margin-bottom:8px;}
.stat-value{font-size:28px;font-weight:800;color:var(--text);margin-bottom:4px;}
.stat-label{font-size:13px;color:var(--muted);}

/* Category List */
.category-list{display:flex;flex-direction:column;gap:12px;}
.category-item{
  display:flex;align-items:center;gap:12px;padding:12px;border-radius:var(--radius-sm);
  background:var(--surface-2);transition:.2s;
}
.category-item:hover{background:var(--surface-3);}
.category-icon{font-size:24px;flex:none;}
.category-name{flex:1;font-size:14px;font-weight:600;}
.category-count{
  font-size:14px;font-weight:700;color:var(--accent);
  min-width:32px;text-align:right;
}

/* Document List */
.document-list{display:flex;flex-direction:column;gap:12px;}
.document-item{
  display:flex;align-items:center;gap:12px;padding:14px;border-radius:var(--radius-sm);
  background:var(--surface-2);transition:.2s;
}
.document-item:hover{background:var(--surface-3);}
.document-icon{font-size:28px;flex:none;}
.document-info{flex:1;min-width:0;}
.document-title{font-size:14px;font-weight:600;margin-bottom:4px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.document-meta{font-size:12px;color:var(--muted);}

/* Document Grid */
.document-grid{
  display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
}
.document-card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px;text-align:center;transition:.2s;
}
.document-card:hover{
  border-color:var(--accent);transform:translateY(-2px);
  box-shadow:0 12px 30px -12px var(--accent);
}
.document-card__icon{font-size:42px;margin-bottom:12px;}
.document-card__title{
  font-size:15px;font-weight:700;margin-bottom:8px;
  overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.document-card__meta{
  font-size:12px;color:var(--muted);margin-bottom:16px;line-height:1.6;
}
.document-card__actions{display:flex;gap:8px;justify-content:center;}

/* Document Detail */
.document-detail{
  display:grid;gap:24px;grid-template-columns:1fr 350px;
}
.document-detail__main{display:flex;flex-direction:column;gap:24px;}
.document-detail__sidebar{display:flex;flex-direction:column;gap:24px;}
@media(max-width:1024px){
  .document-detail{grid-template-columns:1fr;}
}

.detail-list{display:grid;gap:12px;}
.detail-list dt{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;}
.detail-list dd{font-size:14px;color:var(--text);font-weight:500;}

.actions-list{display:flex;flex-wrap:wrap;gap:10px;}

/* Shares List */
.shares-list{display:flex;flex-direction:column;gap:12px;}
.share-item{
  display:flex;align-items:center;gap:12px;padding:12px;
  background:var(--surface-2);border-radius:var(--radius-sm);
}
.share-info{flex:1;min-width:0;}
.share-token{
  font-family:var(--font-mono,'monospace');font-size:12px;
  color:var(--accent);margin-bottom:4px;
}
.share-meta{font-size:11px;color:var(--muted);line-height:1.5;}

/* Filters */
.filters{margin-bottom:24px;}
.filters-form{
  display:flex;gap:10px;flex-wrap:wrap;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);padding:16px;
}
.filters-form .input{flex:1;min-width:200px;}

/* Badges */
.badge{
  display:inline-block;padding:4px 10px;border-radius:6px;
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;
}
.badge--success{background:rgba(16,185,129,.15);color:#34d399;}
.badge--warning{background:rgba(245,158,11,.15);color:#fbbf24;}
.badge--danger{background:rgba(239,68,68,.15);color:#f87171;}

/* Empty State */
.empty-state{
  text-align:center;padding:60px 20px;color:var(--muted);font-size:14px;
}

/* Forms */
.form{max-width:700px;}
.form-group{margin-bottom:20px;}
.form-group label{
  display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text);
}
.form-group small{
  display:block;font-size:12px;color:var(--faint);margin-top:6px;
}
.form-actions{
  display:flex;gap:12px;justify-content:flex-end;margin-top:32px;
  padding-top:24px;border-top:1px solid var(--line);
}

/* Modal Overlay (actualizado para formularios) */
.modal{
  position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;z-index:9999;
  opacity:0;visibility:hidden;transition:.25s;
}
.modal.show{opacity:1;visibility:visible;}
.modal__overlay{position:absolute;inset:0;cursor:pointer;}
.modal__content{
  position:relative;background:var(--surface-2);border:1px solid var(--line-2);
  border-radius:16px;max-width:500px;width:90%;box-shadow:0 24px 60px -20px rgba(0,0,0,.8);
  transform:scale(.94);transition:.25s;
}
.modal.show .modal__content{transform:scale(1);}
.modal__header{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 26px 20px;border-bottom:1px solid var(--line);
}
.modal__title{font-size:18px;font-weight:700;}
.modal__close{
  background:none;border:none;font-size:28px;color:var(--muted);
  cursor:pointer;width:36px;height:36px;display:grid;place-items:center;
  border-radius:8px;transition:.2s;
}
.modal__close:hover{background:var(--surface-3);color:var(--text);}
.modal__body{padding:24px 26px;}
.modal__footer{
  padding:16px 26px;border-top:1px solid var(--line);
  display:flex;gap:10px;justify-content:flex-end;
}
