/* /var/www/asile/admin/styles.css */
:root{
  --bg:#0b0f14; --panel:#111826; --muted:#2a3441; --text:#e5e7eb;
  --accent:#2aa6ff; --accent-2:#60a5fa; --danger:#ef4444; --ok:#22c55e;
  --warn:#eab308;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font:14px/1.5 system-ui,Segoe UI,Arial}
a{color:var(--accent);text-decoration:none}
.container{max-width:1200px;margin:0 auto;padding:16px}
/* ====== NAVBAR + DROPDOWNS (fix stay-open, clickables) ====== */
.topbar, header { position: relative; z-index: 100; overflow: visible; }

.navbar { display: flex; gap: 18px; align-items: center; }
.navbar > li { position: relative; list-style: none; }
.navbar > li > a {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 12px; border-radius: 10px;
  color: var(--text-main);
}
.navbar > li > a:hover { background: var(--bg-hover); color: var(--accent); }

/* --- Submenu container --- */
.navbar .has-sub { position: relative; }
.navbar .has-sub > .submenu {
  position: absolute; top: calc(100% + 6px); left: 0;
  min-width: 220px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 6px;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  /* hidden by default */
  display: block;       /* keep layout stable */
  opacity: 0; visibility: hidden; transform: translateY(6px);
  pointer-events: none;
  transition: opacity .15s ease, transform .15s ease, visibility .15s ease;
  z-index: 3000;
}

/* Keep submenu open on hover OR when any child has focus (keyboard/touch) */
.navbar .has-sub:hover > .submenu,
.navbar .has-sub:focus-within > .submenu {
  opacity: 1; visibility: visible; transform: translateY(0);
  pointer-events: auto;
}

/* submenu items */
.navbar .submenu li { list-style: none; }
.navbar .submenu a {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 10px; border-radius: 10px;
  color: var(--text-main); white-space: nowrap;
}
.navbar .submenu a:hover { background: var(--bg-hover); color: var(--accent); }

/* Avoid losing hover while moving cursor: remove gaps around dropdown */
.navbar .has-sub { padding-bottom: 0; }
.navbar .has-sub > a { margin-bottom: 0; }

/* --- Mobile / narrow screens: show dropdowns as inline lists --- */
@media (max-width: 900px) {
  .navbar { flex-direction: column; align-items: stretch; gap: 6px; }
  .navbar .has-sub > .submenu {
    position: static;
    border: 1px solid var(--border);
    border-radius: 10px;
    margin-top: 6px;
    opacity: 1; visibility: visible; transform: none; pointer-events: auto;
    padding: 4px;
  }
  .navbar .submenu a { padding: 10px 12px; }
}


.card{background:var(--panel);border:1px solid var(--muted);border-radius:14px;padding:14px}
.grid{display:grid;gap:16px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:900px){.grid-3,.grid-2{grid-template-columns:1fr}}

.kpi{display:flex;align-items:center;gap:10px}
.kpi .value{font-size:22px;font-weight:700}
.kpi .label{opacity:.8}

/* Tables */
.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{padding:10px;border-bottom:1px solid var(--muted)}
.table th{text-align:left;opacity:.8}

/* Forms */
input,select,textarea{width:100%;padding:10px;background:#0f1621;color:var(--text);border:1px solid var(--muted);border-radius:10px}
label{display:block;margin:10px 0 6px}
.btn{padding:10px 14px;border-radius:10px;border:1px solid var(--muted);background:#0e1520;color:var(--text);cursor:pointer}
.btn:hover{background:#122033}
.btn.primary{border-color:transparent;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
.btn.danger{background:var(--danger);border-color:#b91c1c}
.btn.warn{background:var(--warn);color:#0b0f14}

/* Modal */
.modal.hidden{display:none}
.modal{position:fixed;inset:0;display:grid;place-items:center}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.6)}
.modal-content{position:relative;background:#0f1621;border:1px solid var(--muted);border-radius:14px;max-width:600px;width:96%;padding:16px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px}

/* Pills & badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid var(--muted);background:#0e1520}

/* Login */
.login-body{display:grid;place-items:center;min-height:100vh}
.login-card{background:var(--panel);border:1px solid var(--muted);border-radius:14px;padding:20px;max-width:520px}
