/* ── MODAL OVERLAYS (shared shell) ─────────────────────────────────────── */
.modal-overlay {
  position:fixed; inset:0;
  background:rgba(0,0,0,0);
  backdrop-filter:blur(0) brightness(1);
  -webkit-backdrop-filter:blur(0) brightness(1);
  z-index:500;
  display:none;
  align-items:center;
  justify-content:center;
  transition:
    background .38s cubic-bezier(.4,0,.2,1),
    backdrop-filter .38s cubic-bezier(.4,0,.2,1),
    -webkit-backdrop-filter .38s cubic-bezier(.4,0,.2,1);
}
.modal-overlay.open {
  display:flex;
  background:rgba(0,0,0,0.58);
  backdrop-filter:blur(16px) brightness(0.72) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) brightness(0.72) saturate(1.4);
}
.modal-shell {
  background:rgba(12,13,20,0.88);
  backdrop-filter:blur(36px) saturate(1.6);
  -webkit-backdrop-filter:blur(36px) saturate(1.6);
  border:1px solid rgba(255,255,255,0.10);
  border-radius:14px;
  max-width:96vw;
  max-height:90vh;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,.75), 0 0 0 1px rgba(255,255,255,0.04) inset;
  opacity:0;
  transform:scale(0.85);
  transform-origin:50% 50%;
  transition:
    transform .32s cubic-bezier(.34,1.18,.64,1),
    opacity .24s cubic-bezier(.4,0,.2,1);
  pointer-events:none;
}
.modal-overlay.open .modal-shell { opacity:1; transform:scale(1); pointer-events:all; }

.modal-header {
  padding:18px 20px 14px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}
.modal-title {
  font-family:'Inter', sans-serif;
  font-weight:600;
  font-size:15px;
  flex:1;
  letter-spacing:.01em;
  color:var(--text);
  word-break:break-word;
}
.modal-badge {
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  letter-spacing:.1em;
  padding:2px 8px;
  border-radius:3px;
  background:var(--accent-dim);
  border:1px solid rgba(0,102,255,0.3);
  color:rgba(160,200,255,.95);
  text-transform:uppercase;
}
.modal-close {
  width:26px; height:26px;
  border-radius:5px;
  background:var(--surface);
  border:1px solid var(--border);
  color:var(--text2);
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:14px;
  flex-shrink:0;
  transition:all .15s;
}
.modal-close:hover { background:var(--surface2); color:var(--text); }

.modal-body { overflow-y:auto; padding:20px; flex:1; }
.modal-body::-webkit-scrollbar { width:3px; }
.modal-body::-webkit-scrollbar-thumb { background:var(--border2); border-radius:2px; }

.modal-footer {
  padding:14px 20px;
  border-top:1px solid var(--border);
  display:flex;
  gap:8px;
  justify-content:flex-end;
  flex-shrink:0;
}

.modal-nav-arrow {
  flex-shrink:0;
  width:42px; height:42px;
  margin:0 14px;
  display:none;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.03));
  border:1px solid rgba(255,255,255,0.16);
  color:rgba(230,235,255,0.85);
  font-family:'JetBrains Mono', monospace;
  font-size:22px;
  font-weight:300;
  line-height:1;
  cursor:pointer;
  user-select:none;
  backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);
  box-shadow:0 8px 28px rgba(0,0,0,0.45), 0 1px 0 rgba(255,255,255,0.14) inset;
  transition:
    background .18s ease,
    border-color .18s ease,
    transform .22s cubic-bezier(.34,1.4,.64,1),
    color .18s ease,
    opacity .18s ease;
}
.modal-overlay.open .modal-nav-arrow.show { display:flex; }
.modal-nav-arrow:hover {
  background:linear-gradient(180deg, rgba(255,255,255,0.16), rgba(255,255,255,0.06));
  border-color:rgba(255,255,255,0.28);
  color:rgba(255,255,255,0.98);
  transform:scale(1.06);
}
.modal-nav-arrow.disabled { opacity:.28; pointer-events:none; }

/* ── FORM CONTROLS ─────────────────────────────────────────────────────── */
.frow { margin-bottom:14px; }
.frow.half { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.flabel {
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--text3);
  margin-bottom:5px;
  display:flex;
  align-items:center;
  gap:4px;
}
.flabel .req { color:var(--red); font-size:10px; }
.flabel .fhint-inline {
  color:var(--text3);
  font-size:9px;
  font-weight:400;
  letter-spacing:0;
  text-transform:none;
}
.finput {
  width:100%;
  background:rgba(255,255,255,0.04);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:6px;
  padding:7px 10px;
  color:var(--text);
  font-family:'Inter', sans-serif;
  font-size:12px;
  outline:none;
  transition:border-color .18s, box-shadow .18s, background .18s;
  resize:none;
}
.finput:focus {
  border-color:rgba(0,102,255,0.45);
  background:rgba(255,255,255,0.07);
  box-shadow:0 0 0 3px rgba(0,102,255,0.1);
}
.finput::placeholder { color:var(--text3); }
select.finput { cursor:pointer; }
select.finput option { background:var(--bg2); }
textarea.finput { min-height:60px; line-height:1.5; }
.finput.invalid {
  border-color:rgba(224,85,85,.5);
  box-shadow:0 0 0 3px rgba(224,85,85,.1);
}
.fhint {
  font-family:'Inter', sans-serif;
  font-size:10px;
  color:var(--text3);
  margin-top:5px;
  line-height:1.45;
}
.fhint.error { color:var(--red); opacity:.9; }

/* Custom checkbox */
.checkbox-row {
  display:flex;
  align-items:center;
  gap:8px;
  padding:4px 0;
  font-size:12px;
  color:var(--text2);
  font-family:'Inter', sans-serif;
  cursor:pointer;
  user-select:none;
}
.checkbox-row:hover span { color:var(--text); }
input[type="checkbox"] {
  appearance:none;
  -webkit-appearance:none;
  width:15px; height:15px;
  margin:0; padding:0;
  border-radius:4px;
  background:linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
  border:1px solid rgba(255,255,255,0.18);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.08) inset,
    0 -1px 0 rgba(0,0,0,0.15) inset,
    0 1px 2px rgba(0,0,0,0.25);
  cursor:pointer;
  position:relative;
  flex-shrink:0;
  transition:border-color .16s ease, background .18s ease, box-shadow .18s ease;
}
input[type="checkbox"]:hover {
  border-color:rgba(255,255,255,0.32);
  background:linear-gradient(180deg, rgba(255,255,255,0.12), rgba(255,255,255,0.04));
}
input[type="checkbox"]:focus-visible {
  outline:none;
  border-color:rgba(74,158,255,0.6);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.08) inset,
    0 0 0 3px rgba(74,158,255,0.18);
}
input[type="checkbox"]:checked {
  background:rgba(0,102,255,0.85);
  border-color:rgba(0,102,255,0.6);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.22) inset,
    0 -1px 0 rgba(0,0,0,0.18) inset,
    0 0 12px rgba(0,102,255,0.38);
}
input[type="checkbox"]::after {
  content:'';
  position:absolute;
  left:4px; top:1px;
  width:4px; height:8px;
  border-right:1.8px solid rgba(255,255,255,0.98);
  border-bottom:1.8px solid rgba(255,255,255,0.98);
  transform:rotate(42deg) scale(0);
  transform-origin:center;
  opacity:0;
  transition:transform .22s cubic-bezier(.34,1.5,.64,1), opacity .12s ease;
}
input[type="checkbox"]:checked::after {
  transform:rotate(42deg) scale(1);
  opacity:1;
}
body.theme-light input[type="checkbox"]:checked,
body.theme-grayscale input[type="checkbox"]:checked {
  background:rgba(0,102,255,0.96);
  border-color:rgba(0,102,255,0.72);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.18) inset,
    0 -1px 0 rgba(0,0,0,0.08) inset,
    0 0 10px rgba(0,102,255,0.18);
}
body.theme-light input[type="checkbox"]:checked::after,
body.theme-grayscale input[type="checkbox"]:checked::after {
  border-right-color:rgba(255,255,255,0.98);
  border-bottom-color:rgba(255,255,255,0.98);
}

/* ── BUTTONS ───────────────────────────────────────────────────────────── */
.fbtn {
  padding:7px 16px;
  border-radius:6px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  letter-spacing:.04em;
  cursor:pointer;
  border:1px solid rgba(255,255,255,0.09);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  transition:all .15s;
  user-select:none;
  display:inline-flex;
  align-items:center;
  gap:5px;
  text-decoration:none;
}
.fbtn-cancel { background:var(--surface); color:var(--text2); }
.fbtn-cancel:hover { background:var(--surface2); color:var(--text); }
.fbtn-save {
  background:rgba(0,102,255,0.18);
  color:rgba(160,200,255,.95);
  border-color:rgba(0,102,255,0.35);
}
.fbtn-save:hover {
  background:rgba(0,102,255,0.28);
  border-color:rgba(0,102,255,0.5);
  box-shadow:0 0 20px rgba(0,102,255,0.2);
}
.fbtn-save-alt {
  background:rgba(74,158,255,0.12);
  color:rgba(180,210,255,.9);
  border-color:rgba(74,158,255,0.28);
}
.fbtn-save-alt:hover {
  background:rgba(74,158,255,0.22);
  border-color:rgba(74,158,255,0.45);
  color:rgba(210,225,255,.98);
}
.fbtn-delete {
  background:rgba(224,85,85,.08);
  border-color:rgba(224,85,85,.2);
  color:var(--red);
  margin-right:auto;
}
.fbtn-delete:hover {
  background:rgba(224,85,85,.16);
  border-color:rgba(224,85,85,.4);
}
.fbtn.disabled { opacity:.35; pointer-events:none; cursor:not-allowed; }

/* Dirty-state feedback on modal-shell + save button.
   Triggered when the user attempts to navigate away from an edit modal with
   unsaved field changes — shake the modal, pulse the save button. */
@keyframes modalShake {
  0%, 100% { transform:scale(1) translateX(0); }
  10%, 50%, 90% { transform:scale(1) translateX(-5px); }
  30%, 70% { transform:scale(1) translateX(5px); }
}
@keyframes savePulse {
  0%, 100% { box-shadow:0 0 0 0 rgba(0,102,255,0); }
  50% {
    box-shadow:
      0 0 0 6px rgba(0,102,255,0.28),
      0 0 20px rgba(0,102,255,0.35);
  }
}
.modal-overlay.open .modal-shell.shake {
  animation:modalShake .42s cubic-bezier(.36,.07,.19,.97);
}
.fbtn.pulse { animation:savePulse .9s ease-out 2; }

/* ── TAB STRIP ─────────────────────────────────────────────────────────── */
.tabs {
  display:flex;
  gap:2px;
  border-bottom:1px solid var(--border);
  margin-bottom:22px;
}
.tab {
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.1em;
  padding:10px 18px;
  cursor:pointer;
  color:var(--text3);
  border-bottom:2px solid transparent;
  transition:color .15s, border-color .15s;
  user-select:none;
}
.tab:hover { color:var(--text2); }
.tab.active { color:var(--text); border-bottom-color:var(--accent); }
.tab-panel { display:none; animation:fadeUp .22s cubic-bezier(.4,0,.2,1) both; }
.tab-panel.active { display:block; }

/* ── CARDS ─────────────────────────────────────────────────────────────── */
.card {
  background:rgba(255,255,255,0.025);
  backdrop-filter:blur(18px) saturate(1.3);
  -webkit-backdrop-filter:blur(18px) saturate(1.3);
  border:1px solid var(--border);
  border-radius:10px;
  padding:18px 20px;
  margin-bottom:14px;
}
.card-title {
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text3);
  margin-bottom:12px;
}
.card p {
  font-size:13px;
  color:var(--text2);
  line-height:1.55;
  margin-bottom:10px;
}
.card p strong { color:var(--text); font-weight:500; }
.card p code,
.card p .inline-code {
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  color:var(--accent2);
  background:var(--surface);
  padding:1px 6px;
  border-radius:3px;
}
.card a { color:var(--accent2); text-decoration:none; }
.card a:hover { color:var(--text); text-decoration:underline; }

/* ── DATA TABLE ────────────────────────────────────────────────────────── */
table.data-table {
  width:100%;
  border-collapse:collapse;
  font-size:12px;
}
table.data-table th {
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--text3);
  text-align:left;
  padding:6px 10px;
  border-bottom:1px solid var(--border);
}
table.data-table td {
  padding:8px 10px;
  border-bottom:1px solid var(--border);
  color:var(--text2);
  vertical-align:middle;
}
table.data-table tr:last-child td { border-bottom:none; }
table.data-table tr:hover td { background:rgba(255,255,255,0.02); }
.cell-mono { font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--text3); }
.cell-muted { color:var(--text3); font-size:11px; }
.cell-empty { text-align:center; color:var(--text3); padding:18px; }

/* ── STATUS BADGES ─────────────────────────────────────────────────────── */
.badge {
  font-family:'JetBrains Mono', monospace;
  font-size:9px;
  padding:2px 7px;
  border-radius:3px;
  letter-spacing:.06em;
  text-transform:uppercase;
  border:1px solid transparent;
  display:inline-flex;
  align-items:center;
}
.badge-active {
  background:rgba(74,158,255,0.12);
  color:var(--accent2);
  border-color:rgba(74,158,255,0.3);
}
.badge-inactive {
  background:var(--red-dim);
  color:var(--red);
  border-color:rgba(224,85,85,0.3);
}
.badge-admin {
  background:rgba(0,102,255,0.14);
  color:rgba(160,200,255,.95);
  border-color:rgba(0,102,255,0.3);
}
.badge-org {
  background:rgba(74,158,255,0.12);
  color:var(--accent2);
  border-color:rgba(74,158,255,0.3);
}
.badge-user {
  background:var(--surface2);
  color:var(--text2);
  border-color:var(--border);
}

/* ── TOAST ─────────────────────────────────────────────────────────────── */
.toast {
  position:fixed;
  top:60px; right:20px;
  padding:10px 16px;
  border-radius:8px;
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  letter-spacing:.02em;
  z-index:1100;
  opacity:0;
  transform:translateY(-8px);
  transition:opacity .22s, transform .22s;
  pointer-events:none;
  box-shadow:0 8px 28px rgba(0,0,0,0.5);
  backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);
}
.toast.show { opacity:1; transform:translateY(0); }
.toast-success {
  background:rgba(74,158,255,0.18);
  border:1px solid rgba(74,158,255,0.4);
  color:rgba(210,225,255,0.98);
}
.toast-error {
  background:rgba(224,85,85,0.18);
  border:1px solid rgba(224,85,85,0.4);
  color:rgba(255,210,210,0.98);
}
