@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/**
 * Ultranet — Premium ISP / NOC panel design system
 * Palette: slate-900 base, blue enterprise accent, glass surfaces
 */
:root {
  /* ─── Semantik tema: varsayılan = koyu (premium NOC) ─── */
  --bg-main: #0f172a;
  --bg-page: #0f172a;
  --bg-sidebar: #111827;
  --bg-card: #1e293b;
  --bg-card-elevated: rgba(30, 41, 59, 0.85);
  --bg-input: rgba(15, 23, 42, 0.65);
  --bg-hover: rgba(59, 130, 246, 0.08);
  --primary: #3b82f6;
  --primary-light: #60a5fa;
  --primary-hover: #2563eb;
  --primary-soft: rgba(59, 130, 246, 0.16);
  --glow: rgba(59, 130, 246, 0.25);
  --glow-strong: rgba(59, 130, 246, 0.45);
  --success: #22c55e;
  --success-dim: rgba(34, 197, 94, 0.15);
  --warning: #facc15;
  --warning-dim: rgba(250, 204, 21, 0.14);
  --danger: #ef4444;
  --danger-dim: rgba(239, 68, 68, 0.14);
  --text: #e2e8f0;
  --text-muted: #94a3b8;
  --border: rgba(255, 255, 255, 0.06);
  --border-light: rgba(255, 255, 255, 0.1);
  --glass-blur: 16px;
  --sidebar-w: 240px;
  --header-h: 60px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --shadow-card: 0 4px 24px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.04);
  --shadow-glow: 0 0 32px var(--glow);
  --transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --accent-teal: #14b8a6;
  --accent-teal-dim: rgba(20, 184, 166, 0.12);
  --purple: #a78bfa;
  --purple-dim: rgba(167, 139, 250, 0.12);

  --main-bg-gradient: radial-gradient(ellipse 120% 80% at 50% -20%, rgba(59, 130, 246, 0.12), transparent 55%);
  --topbar-bg: rgba(15, 23, 42, 0.72);
  --sidebar-shadow: 4px 0 40px rgba(0, 0, 0, 0.35);
  --backdrop-overlay: rgba(0, 0, 0, 0.55);
  --sidebar-footer-bg: rgba(0, 0, 0, 0.15);
  --topbar-btn-bg: rgba(30, 41, 59, 0.8);
  --card-grad-from: var(--bg-card-elevated);
  --card-grad-to: rgba(15, 23, 42, 0.65);
  --card-border-hover: rgba(255, 255, 255, 0.09);
  --stat-card-grad-from: var(--bg-card-elevated);
  --stat-card-grad-to: rgba(15, 23, 42, 0.65);
  --dash-stat-grad-from: rgba(30, 41, 59, 0.92);
  --dash-stat-grad-to: rgba(15, 23, 42, 0.78);
  --dash-stat-icon-grad: linear-gradient(145deg, rgba(59, 130, 246, 0.25), rgba(37, 99, 235, 0.08));
  --dash-icon-inset: inset 0 1px 0 rgba(255, 255, 255, 0.08);
  --status-badge-neutral-bg: rgba(30, 41, 59, 0.65);
  --status-bad-text: #fca5a5;
  --table-head-bg: rgba(15, 23, 42, 0.95);
  --table-row-hover: rgba(59, 130, 246, 0.06);
  --mono-bg: rgba(15, 23, 42, 0.75);
  --mono-border: var(--border);
  --btn-primary-fg: #ffffff;
  --btn-primary-ring: rgba(96, 165, 250, 0.35);
  --btn-secondary-bg: rgba(30, 41, 59, 0.8);
  --btn-secondary-hover-border: rgba(59, 130, 246, 0.25);
  --btn-danger-text: #fecaca;
  --btn-info-bg: rgba(59, 130, 246, 0.14);
  --btn-info-border: rgba(59, 130, 246, 0.3);
  --form-focus-border: rgba(59, 130, 246, 0.55);
  --form-focus-shadow: 0 0 24px rgba(59, 130, 246, 0.12);
  --placeholder-fg: rgba(148, 163, 184, 0.65);
  --scrollbar-track: rgba(15, 23, 42, 0.5);
  --scrollbar-thumb: rgba(148, 163, 184, 0.35);
  --scrollbar-thumb-hover: rgba(59, 130, 246, 0.55);
  --modal-backdrop-bg: rgba(2, 6, 23, 0.72);
  --modal-body-grad-to: rgba(17, 24, 39, 0.95);
  --modal-shadow: 0 24px 64px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(59, 130, 246, 0.1);
  --modal-close-bg: rgba(30, 41, 59, 0.9);
  --toast-shadow: 0 12px 40px rgba(0, 0, 0, 0.45);
  --login-bg-gradient: radial-gradient(ellipse 100% 80% at 50% -30%, rgba(59, 130, 246, 0.22), transparent 50%),
    radial-gradient(ellipse 80% 50% at 100% 100%, rgba(37, 99, 235, 0.12), transparent 45%), var(--bg-page);
  --login-card-grad: linear-gradient(165deg, rgba(30, 41, 59, 0.9) 0%, rgba(17, 24, 39, 0.92) 100%);
  --login-card-shadow: 0 24px 64px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(59, 130, 246, 0.12) inset,
    0 0 48px var(--glow);
  --nav-hover-border: rgba(59, 130, 246, 0.12);
  --nav-hover-glow: 0 0 20px rgba(59, 130, 246, 0.06);
  --nav-active-grad: linear-gradient(90deg, rgba(59, 130, 246, 0.18) 0%, rgba(59, 130, 246, 0.04) 100%);
  --nav-active-border: rgba(59, 130, 246, 0.22);
  --nav-icon-grad: linear-gradient(145deg, rgba(59, 130, 246, 0.22), rgba(37, 99, 235, 0.08));
  --nav-icon-active-grad: linear-gradient(145deg, rgba(96, 165, 250, 0.45), rgba(59, 130, 246, 0.2));
  --crm-panel-shadow: 0 28px 72px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(255, 255, 255, 0.05) inset,
    0 0 80px rgba(59, 130, 246, 0.08);
  --crm-modal-accent-border: rgba(59, 130, 246, 0.18);
  --crm-summary-shadow: var(--shadow-card), 0 0 40px rgba(59, 130, 246, 0.1);
  --crm-header-grad: linear-gradient(180deg, rgba(59, 130, 246, 0.08) 0%, transparent 100%);
  --crm-summary-grad: linear-gradient(165deg, rgba(30, 41, 59, 0.95) 0%, rgba(15, 23, 42, 0.88) 100%);
  --crm-footer-bg: rgba(17, 24, 39, 0.55);
  --form-section-grad: linear-gradient(165deg, rgba(30, 41, 59, 0.72) 0%, rgba(15, 23, 42, 0.55) 100%);
  --form-section-head-bg: rgba(59, 130, 246, 0.06);
  --badge-glow-pill: 0 0 14px currentColor;
  --badge-green-fg: var(--success);
  --badge-red-fg: #fecaca;
  --badge-yellow-fg: #fbbf24;
  --badge-blue-fg: var(--primary-light);
  --badge-gray-fg: var(--text-muted);
  --badge-gray-bg: rgba(148, 163, 184, 0.1);
  --nav-settings-border: rgba(255, 255, 255, 0.06);
  --crm-btn-accent-bg: linear-gradient(135deg, rgba(59, 130, 246, 0.25) 0%, rgba(37, 99, 235, 0.12) 100%);
  --crm-btn-accent-border: rgba(59, 130, 246, 0.45);
  --crm-btn-accent-hover-border: rgba(96, 165, 250, 0.55);
  --form-section-hover-border: rgba(59, 130, 246, 0.15);
  --form-section-hover-shadow: 0 4px 28px rgba(0, 0, 0, 0.2);
  --form-section-focus-border: rgba(59, 130, 246, 0.28);
  --form-section-focus-shadow: 0 0 0 1px rgba(59, 130, 246, 0.15), 0 8px 32px rgba(59, 130, 246, 0.08);
  --form-section-icon-grad: linear-gradient(145deg, rgba(59, 130, 246, 0.25), rgba(37, 99, 235, 0.1));
  --form-section-icon-inset: inset 0 1px 0 rgba(255, 255, 255, 0.06);
  --crm-close-hover-shadow: 0 0 20px rgba(239, 68, 68, 0.2);
  --select-chevron-url: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
}

/**
 * Açık tema — kurumsal SaaS / ISP CRM (soğuk mavi ton, kart + gölge)
 * html ve body sınıfları birlikte (tercih senkronu)
 */
html.theme-light,
body.theme-light {
  --bg-main: #f8fafc;
  --bg-page: #f8fafc;
  --bg-sidebar: #f1f5f9;
  --bg-card: #ffffff;
  --bg-card-elevated: #ffffff;
  --bg-input: #ffffff;
  --bg-hover: rgba(37, 99, 235, 0.08);
  --primary: #2563eb;
  --primary-light: #60a5fa;
  --primary-hover: #1d4ed8;
  --primary-soft: rgba(37, 99, 235, 0.1);
  --glow: rgba(37, 99, 235, 0.14);
  --glow-strong: rgba(37, 99, 235, 0.28);
  --text: #0f172a;
  --text-muted: #64748b;
  --border: rgba(15, 23, 42, 0.1);
  --border-light: rgba(15, 23, 42, 0.14);
  --shadow-card: 0 10px 30px rgba(15, 23, 42, 0.08), 0 0 0 1px rgba(15, 23, 42, 0.06);
  --shadow-glow: 0 8px 28px var(--glow);

  --main-bg-gradient: radial-gradient(ellipse 110% 70% at 50% -18%, rgba(37, 99, 235, 0.07), transparent 50%),
    linear-gradient(180deg, #f8fafc 0%, #f1f5f9 45%, #eff6ff 100%);
  --topbar-bg: rgba(255, 255, 255, 0.94);
  --sidebar-shadow: 4px 0 24px rgba(15, 23, 42, 0.06);
  --backdrop-overlay: rgba(15, 23, 42, 0.35);
  --sidebar-footer-bg: rgba(241, 245, 249, 0.97);
  --topbar-btn-bg: #ffffff;
  --card-grad-from: #ffffff;
  --card-grad-to: #f8fafc;
  --card-border-hover: rgba(15, 23, 42, 0.12);
  --stat-card-grad-from: #ffffff;
  --stat-card-grad-to: #f8fafc;
  --dash-stat-grad-from: #ffffff;
  --dash-stat-grad-to: #f1f5f9;
  --dash-stat-icon-grad: linear-gradient(145deg, rgba(37, 99, 235, 0.18), rgba(37, 99, 235, 0.05));
  --dash-icon-inset: inset 0 1px 0 rgba(255, 255, 255, 0.95);
  --status-badge-neutral-bg: rgba(241, 245, 249, 0.98);
  --status-bad-text: #991b1b;
  --table-head-bg: rgba(248, 250, 252, 0.98);
  --table-row-hover: rgba(37, 99, 235, 0.06);
  --mono-bg: rgba(241, 245, 249, 0.95);
  --mono-border: rgba(15, 23, 42, 0.1);
  --btn-primary-fg: #ffffff;
  --btn-primary-ring: rgba(37, 99, 235, 0.28);
  --btn-secondary-bg: #ffffff;
  --btn-secondary-hover-border: rgba(37, 99, 235, 0.22);
  --btn-danger-text: #b91c1c;
  --btn-info-bg: rgba(37, 99, 235, 0.1);
  --btn-info-border: rgba(37, 99, 235, 0.28);
  --form-focus-border: rgba(37, 99, 235, 0.45);
  --form-focus-shadow: 0 0 24px rgba(37, 99, 235, 0.12);
  --placeholder-fg: rgba(100, 116, 139, 0.75);
  --scrollbar-track: #e2e8f0;
  --scrollbar-thumb: #cbd5e1;
  --scrollbar-thumb-hover: rgba(37, 99, 235, 0.4);
  --modal-backdrop-bg: rgba(15, 23, 42, 0.4);
  --modal-body-grad-to: #f8fafc;
  --modal-shadow: 0 24px 48px rgba(15, 23, 42, 0.12), 0 0 0 1px rgba(15, 23, 42, 0.08);
  --modal-close-bg: #ffffff;
  --toast-shadow: 0 12px 32px rgba(15, 23, 42, 0.12);
  --login-bg-gradient: radial-gradient(ellipse 100% 80% at 50% -25%, rgba(37, 99, 235, 0.12), transparent 50%),
    linear-gradient(180deg, #f8fafc 0%, #eff6ff 50%, #f1f5f9 100%);
  --login-card-grad: linear-gradient(165deg, #ffffff 0%, #f8fafc 100%);
  --login-card-shadow: 0 20px 50px rgba(15, 23, 42, 0.1), 0 0 0 1px rgba(15, 23, 42, 0.08), 0 0 40px rgba(37, 99, 235, 0.06);
  --nav-hover-border: rgba(37, 99, 235, 0.15);
  --nav-hover-glow: 0 2px 12px rgba(37, 99, 235, 0.08);
  --nav-active-grad: linear-gradient(90deg, rgba(37, 99, 235, 0.1) 0%, rgba(37, 99, 235, 0.03) 100%);
  --nav-active-border: rgba(37, 99, 235, 0.22);
  --nav-icon-grad: linear-gradient(145deg, rgba(37, 99, 235, 0.18), rgba(37, 99, 235, 0.06));
  --nav-icon-active-grad: linear-gradient(145deg, rgba(96, 165, 250, 0.35), rgba(37, 99, 235, 0.14));
  --crm-panel-shadow: 0 24px 56px rgba(15, 23, 42, 0.12), 0 0 0 1px rgba(15, 23, 42, 0.08);
  --crm-modal-accent-border: rgba(15, 23, 42, 0.12);
  --crm-summary-shadow: var(--shadow-card);
  --crm-header-grad: linear-gradient(180deg, rgba(37, 99, 235, 0.06) 0%, transparent 100%);
  --crm-summary-grad: linear-gradient(165deg, #ffffff 0%, #f8fafc 100%);
  --crm-footer-bg: rgba(241, 245, 249, 0.92);
  --form-section-grad: linear-gradient(165deg, #ffffff 0%, #f8fafc 100%);
  --form-section-head-bg: rgba(37, 99, 235, 0.06);
  --success-dim: #dcfce7;
  --danger-dim: #fee2e2;
  --warning-dim: #fef9c3;
  --badge-glow-pill: 0 1px 3px rgba(15, 23, 42, 0.08);
  --badge-green-fg: #166534;
  --badge-red-fg: #991b1b;
  --badge-yellow-fg: #a16207;
  --badge-blue-fg: #1d4ed8;
  --badge-gray-fg: #475569;
  --badge-gray-bg: #f1f5f9;
  --nav-settings-border: rgba(15, 23, 42, 0.08);
  --crm-btn-accent-bg: linear-gradient(135deg, rgba(37, 99, 235, 0.14) 0%, rgba(37, 99, 235, 0.06) 100%);
  --crm-btn-accent-border: rgba(37, 99, 235, 0.35);
  --crm-btn-accent-hover-border: rgba(37, 99, 235, 0.5);
  --form-section-hover-border: rgba(37, 99, 235, 0.2);
  --form-section-hover-shadow: 0 8px 24px rgba(15, 23, 42, 0.08);
  --form-section-focus-border: rgba(37, 99, 235, 0.35);
  --form-section-focus-shadow: 0 0 0 2px rgba(37, 99, 235, 0.12), 0 10px 30px rgba(37, 99, 235, 0.08);
  --form-section-icon-grad: linear-gradient(145deg, rgba(37, 99, 235, 0.22), rgba(37, 99, 235, 0.08));
  --form-section-icon-inset: inset 0 1px 0 rgba(255, 255, 255, 0.95);
  --crm-close-hover-shadow: 0 4px 20px rgba(239, 68, 68, 0.15);
  --select-chevron-url: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
}

html.theme-light .sidebar,
body.theme-light .sidebar {
  background: linear-gradient(180deg, #f8fafc 0%, var(--bg-sidebar) 100%);
}

html.theme-light .badge-glow,
body.theme-light .badge-glow {
  box-shadow: var(--badge-glow-pill);
}

html.theme-light .badge-green.badge-glow,
body.theme-light .badge-green.badge-glow {
  box-shadow: 0 0 0 1px rgba(34, 197, 94, 0.25), var(--badge-glow-pill);
}

html.theme-light .badge-red.badge-glow,
body.theme-light .badge-red.badge-glow {
  box-shadow: 0 0 0 1px rgba(239, 68, 68, 0.2), var(--badge-glow-pill);
}

html.theme-light .badge-yellow.badge-glow,
body.theme-light .badge-yellow.badge-glow {
  box-shadow: 0 0 0 1px rgba(250, 204, 21, 0.35), var(--badge-glow-pill);
}

html.theme-light .badge-gray.badge-glow,
body.theme-light .badge-gray.badge-glow {
  box-shadow: 0 0 0 1px rgba(71, 85, 105, 0.2), var(--badge-glow-pill);
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 14px;
  scroll-behavior: smooth;
}

body {
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  background: var(--bg-page);
  color: var(--text);
  line-height: 1.55;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}

a {
  color: var(--primary-light);
  text-decoration: none;
  transition: color var(--transition);
}
a:hover {
  color: var(--primary);
}

::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-track {
  background: var(--scrollbar-track);
}
::-webkit-scrollbar-thumb {
  background: var(--scrollbar-thumb);
  border-radius: 99px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--scrollbar-thumb-hover);
}

/* ─── App shell ───────────────────────────────────────── */
.app-layout {
  display: flex;
  min-height: 100vh;
  position: relative;
}
.app-layout.sidebar-open .sidebar-backdrop {
  opacity: 1;
  pointer-events: auto;
}

.sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 95;
  background: var(--backdrop-overlay);
  backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition);
}

.sidebar {
  width: var(--sidebar-w);
  background: var(--bg-sidebar);
  border-right: 1px solid var(--border);
  box-shadow: var(--sidebar-shadow);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  z-index: 100;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  overscroll-behavior: contain;
}

.main-content {
  margin-left: var(--sidebar-w);
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background: var(--main-bg-gradient), var(--bg-page);
}

.topbar {
  height: var(--header-h);
  background: var(--topbar-bg);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 22px;
  position: sticky;
  top: 0;
  z-index: 50;
}

.page-content {
  padding: 24px 26px 32px;
  flex: 1;
}

/* ─── Sidebar brand ───────────────────────────────────── */
.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 22px 18px 18px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.logo-icon {
  width: 42px;
  height: 42px;
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 800;
  color: var(--btn-primary-fg);
  flex-shrink: 0;
  box-shadow: 0 4px 20px var(--glow);
}

.logo-text .brand {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.02em;
}
.logo-text .sub {
  font-size: 10px;
  color: var(--text-muted);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.sidebar-nav {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overflow-anchor: none;
  overscroll-behavior: contain;
  scroll-behavior: auto;
  padding: 10px 0 12px;
}

.nav-single {
  padding: 4px 10px 8px;
}

.nav-settings-sep {
  margin-top: 6px;
  padding-top: 10px;
  border-top: 1px solid var(--nav-settings-border);
}

.nav-group {
  border: none;
  margin: 0;
  padding: 0 10px 6px;
}
.nav-group-summary {
  list-style: none;
  cursor: pointer;
  font-size: 10px;
  font-weight: 700;
  color: var(--text-muted);
  letter-spacing: 0.11em;
  text-transform: uppercase;
  padding: 12px 10px 8px;
  user-select: none;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: color var(--transition);
  scroll-margin: 0;
  scroll-margin-block: 0;
  scroll-margin-inline: 0;
}
.nav-group-summary::-webkit-details-marker {
  display: none;
}
.nav-group-summary::after {
  content: '';
  margin-left: auto;
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid var(--text-muted);
  opacity: 0.7;
  transition: transform var(--transition);
}
.nav-group[open] .nav-group-summary::after {
  transform: rotate(180deg);
}
.nav-group-summary:hover {
  color: var(--text);
}
.nav-group-title {
  flex: 1;
  min-width: 0;
}
.nav-group-body {
  padding-bottom: 4px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 9px 12px 9px 14px;
  margin: 2px 0;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--transition);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  text-decoration: none;
}
.nav-item:hover {
  background: var(--bg-hover);
  color: var(--text);
  border-color: var(--nav-hover-border);
  box-shadow: var(--nav-hover-glow);
}
.nav-item.active {
  background: var(--nav-active-grad);
  color: var(--primary-light);
  border-color: var(--nav-active-border);
  box-shadow: 0 0 24px var(--glow);
}
.nav-item .nav-icon {
  width: 20px;
  height: 20px;
  border-radius: 6px;
  flex-shrink: 0;
  background: var(--nav-icon-grad);
  opacity: 0.9;
}
.nav-item.active .nav-icon {
  background: var(--nav-icon-active-grad);
  box-shadow: 0 0 12px var(--glow);
}

/* Sidebar: ikon glifleri (mask) */
.nav-item .nav-icon,
.nav-group-summary .nav-icon {
  position: relative;
}
.nav-group-summary .nav-icon.nav-icon--group {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  background: var(--nav-icon-grad);
  opacity: 0.95;
}
.nav-group-summary:hover .nav-icon.nav-icon--group {
  opacity: 1;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.06);
}
.nav-icon::after {
  content: '';
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 12px;
  height: 12px;
  background-color: var(--text-muted);
  opacity: 0.92;
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  -webkit-mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-position: center;
  pointer-events: none;
}
.nav-group-summary .nav-icon.nav-icon--group::after {
  width: 11px;
  height: 11px;
}
.nav-item:hover .nav-icon::after {
  background-color: var(--text);
}
.nav-group-summary:hover .nav-icon::after {
  background-color: var(--text);
}
.nav-item.active .nav-icon::after {
  background-color: var(--primary-light);
}

/* —— Simge SVG’leri (24×24, tek path) —— */
.nav-icon.ni-dash::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 4h7v7H4V4zm9 0h7v7h-7V4zM4 13h7v7H4v-7zm9 0h7v7h-7v-7z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 4h7v7H4V4zm9 0h7v7h-7V4zM4 13h7v7H4v-7zm9 0h7v7h-7v-7z'/%3E%3C/svg%3E");
}
.nav-icon.ni-user::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 12a4 4 0 1 0-4-4 4 4 0 0 0 4 4zm-6 10a6 6 0 0 1 12 0H6z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 12a4 4 0 1 0-4-4 4 4 0 0 0 4 4zm-6 10a6 6 0 0 1 12 0H6z'/%3E%3C/svg%3E");
}
.nav-icon.ni-loc::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5z'/%3E%3C/svg%3E");
}
.nav-icon.ni-sub::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M16 7a4 4 0 1 1-8 0 4 4 0 0 1 8 0zM4 21a8 8 0 0 1 16 0H4z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M16 7a4 4 0 1 1-8 0 4 4 0 0 1 8 0zM4 21a8 8 0 0 1 16 0H4z'/%3E%3C/svg%3E");
}
.nav-icon.ni-router::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M6 14h12v5H6v-5zm2-5h8v2H8V9zm3-4h2l1 3h-4l1-3zm-7 9v-2h14v2H4z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M6 14h12v5H6v-5zm2-5h8v2H8V9zm3-4h2l1 3h-4l1-3zm-7 9v-2h14v2H4z'/%3E%3C/svg%3E");
}
.nav-icon.ni-pool::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 3l9 4-9 4-9-4 9-4zm0 8l9 4-9 4-9-4 9-4zm0 8l7.5 3.3L12 22l-7.5-1.7L12 19z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 3l9 4-9 4-9-4 9-4zm0 8l9 4-9 4-9-4 9-4zm0 8l7.5 3.3L12 22l-7.5-1.7L12 19z'/%3E%3C/svg%3E");
}
.nav-icon.ni-ppp::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M13.3 8a4 4 0 0 1 4 4v1h-2v-1a2 2 0 1 0-2 2h2v2h-2a4 4 0 1 1 0-8h2.3zM10.7 8H8a4 4 0 1 0 0 8h2v-2H8a2 2 0 1 1 2-2h2V9a4 4 0 0 0-1.3-1z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M13.3 8a4 4 0 0 1 4 4v1h-2v-1a2 2 0 1 0-2 2h2v2h-2a4 4 0 1 1 0-8h2.3zM10.7 8H8a4 4 0 1 0 0 8h2v-2H8a2 2 0 1 1 2-2h2V9a4 4 0 0 0-1.3-1z'/%3E%3C/svg%3E");
}
.nav-icon.ni-rad::after,
.nav-icon.ni-radgrp::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 3a9 9 0 0 1 9 9h-3a6 6 0 0 0-6-6V3zm0 5a4 4 0 0 1 4 4H9a4 4 0 0 1 4-4zm0 6a2 2 0 1 1 0 4 2 2 0 0 1 0-4z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 3a9 9 0 0 1 9 9h-3a6 6 0 0 0-6-6V3zm0 5a4 4 0 0 1 4 4H9a4 4 0 0 1 4-4zm0 6a2 2 0 1 1 0 4 2 2 0 0 1 0-4z'/%3E%3C/svg%3E");
}
.nav-icon.ni-live::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2a10 10 0 1 0 10 10A10 10 0 0 0 12 2zm0 15a5 5 0 1 1 5-5 5 5 0 0 1-5 5z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2a10 10 0 1 0 10 10A10 10 0 0 0 12 2zm0 15a5 5 0 1 1 5-5 5 5 0 0 1-5 5z'/%3E%3C/svg%3E");
}
.nav-icon.ni-hist::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 4v5.3l3.5 2.1-.85 1.4L11 12.2V6h2z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 4v5.3l3.5 2.1-.85 1.4L11 12.2V6h2z'/%3E%3C/svg%3E");
}
.nav-icon.ni-status::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 15h3l3-5 4 6 3-4h5v2h-4l-3 4-4-6-3 5H4v-2z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 15h3l3-5 4 6 3-4h5v2h-4l-3 4-4-6-3 5H4v-2z'/%3E%3C/svg%3E");
}
.nav-icon.ni-log::after,
.nav-icon.ni-law::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M6 4h9l3 3v13H6V4zm2 8h8v2H8v-2zm0 4h8v2H8v-2z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M6 4h9l3 3v13H6V4zm2 8h8v2H8v-2zm0 4h8v2H8v-2z'/%3E%3C/svg%3E");
}
.nav-icon.ni-ip::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M8 6h2v2H8V6zm4 0h2v2h-2V6zM8 10h2v2H8v-2zm4 0h2v2h-2v-2zM6 17h12v2H6v-2zm1-9h2v2H7V8zm8 0h2v2h-2V8z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M8 6h2v2H8V6zm4 0h2v2h-2V6zM8 10h2v2H8v-2zm4 0h2v2h-2v-2zM6 17h12v2H6v-2zm1-9h2v2H7V8zm8 0h2v2h-2V8z'/%3E%3C/svg%3E");
}
.nav-icon.ni-arch::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 6h16v3H4V6zm2 9h12v7H6v-7zm2-4h8v2H8v-2z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 6h16v3H4V6zm2 9h12v7H6v-7zm2-4h8v2H8v-2z'/%3E%3C/svg%3E");
}
.nav-icon.ni-verify::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2l8 4v6c0 5.25-3.56 9.86-8 11-4.44-1.14-8-5.75-8-11V6l8-4zm-1 12.17L8.83 12l1.42-1.41L11 13.17l4.59-4.58L17 10l-6 6.17z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2l8 4v6c0 5.25-3.56 9.86-8 11-4.44-1.14-8-5.75-8-11V6l8-4zm-1 12.17L8.83 12l1.42-1.41L11 13.17l4.59-4.58L17 10l-6 6.17z'/%3E%3C/svg%3E");
}
.nav-icon.ni-pkg::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2l8 4v6l-8 4-8-4V6l8-4zm8 8.5-8 4-8-4V18l8 4 8-4V10.5z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2l8 4v6l-8 4-8-4V6l8-4zm8 8.5-8 4-8-4V18l8 4 8-4V10.5z'/%3E%3C/svg%3E");
}
.nav-icon.ni-pay::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 7h16v10H4V7zm2 4a4 4 0 0 0 8 0H6zm10 5a2 2 0 1 1 0-4 2 2 0 0 1 0 4z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 7h16v10H4V7zm2 4a4 4 0 0 0 8 0H6zm10 5a2 2 0 1 1 0-4 2 2 0 0 1 0 4z'/%3E%3C/svg%3E");
}
.nav-icon.ni-debt::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 17l6-6 3 3 6-7v6h2V5h-8v2h4.5l-5.5 6.5L10 9 4 15v2z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 17l6-6 3 3 6-7v6h2V5h-8v2h4.5l-5.5 6.5L10 9 4 15v2z'/%3E%3C/svg%3E");
}
.nav-icon.ni-mon::after,
.nav-icon.ni-eye::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 5c-5.52 0-9 5-9 7s3.48 7 9 7 9-5 9-7-3.48-7-9-7zm0 12a5 5 0 1 1 5-5 5 5 0 0 1-5 5z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 5c-5.52 0-9 5-9 7s3.48 7 9 7 9-5 9-7-3.48-7-9-7zm0 12a5 5 0 1 1 5-5 5 5 0 0 1-5 5z'/%3E%3C/svg%3E");
}
.nav-icon.ni-fin::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 8h16v3H4V8zm2 4h12v2H6v-2zm2 4h8v2H8v-2z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M4 8h16v3H4V8zm2 4h12v2H6v-2zm2 4h8v2H8v-2z'/%3E%3C/svg%3E");
}
.nav-icon.ni-net::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2l7.5 4v8L12 18l-7.5-4V6L12 2zm0 2.2L6.5 7.3v5.4L12 16l5.5-3.3V7.3L12 4.2z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 2l7.5 4v8L12 18l-7.5-4V6L12 2zm0 2.2L6.5 7.3v5.4L12 16l5.5-3.3V7.3L12 4.2z'/%3E%3C/svg%3E");
}
.nav-icon.ni-off::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M2.5 4.5l17 17 1.4-1.4-3-3A8.5 8.5 0 0 0 3.5 8.5c0 2 .7 3.8 1.8 5.3l-1.5 1.5a10.5 10.5 0 0 1-2.8-6.8 10.5 10.5 0 0 1 14-9.9l-1.8 1.8A8.5 8.5 0 0 0 6 7.1l-3.5-2.6zm8.3 8.3l6.2 6.2c-1.3 1-3 1.5-4.8 1.5a8.5 8.5 0 0 1-8.2-6.2l2.3-2.3a6 6 0 0 0 4.5 4z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M2.5 4.5l17 17 1.4-1.4-3-3A8.5 8.5 0 0 0 3.5 8.5c0 2 .7 3.8 1.8 5.3l-1.5 1.5a10.5 10.5 0 0 1-2.8-6.8 10.5 10.5 0 0 1 14-9.9l-1.8 1.8A8.5 8.5 0 0 0 6 7.1l-3.5-2.6zm8.3 8.3l6.2 6.2c-1.3 1-3 1.5-4.8 1.5a8.5 8.5 0 0 1-8.2-6.2l2.3-2.3a6 6 0 0 0 4.5 4z'/%3E%3C/svg%3E");
}
.nav-icon.ni-alarm::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 22a2 2 0 0 0 2-2h-4a2 2 0 0 0 2 2zm7-7V11a7 7 0 0 0-5-6.7V3h-4v1.3A7 7 0 0 0 5 11v4l-2 2v1h18v-1l-2-2z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 22a2 2 0 0 0 2-2h-4a2 2 0 0 0 2 2zm7-7V11a7 7 0 0 0-5-6.7V3h-4v1.3A7 7 0 0 0 5 11v4l-2 2v1h18v-1l-2-2z'/%3E%3C/svg%3E");
}
.nav-icon.ni-gear::after {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 15.5A3.5 3.5 0 0 1 8.5 12 3.5 3.5 0 0 1 12 8.5a3.5 3.5 0 0 1 3.5 3.5 3.5 3.5 0 0 1-3.5 3.5m7.43-2.53c.04-.32.07-.64.07-.97 0-.33-.03-.66-.07-1l2.11-1.65c.19-.15.24-.42.12-.64l-2-3.46c-.12-.22-.39-.3-.61-.22l-2.49 1c-.52-.4-1.08-.73-1.69-.98l-.38-2.65A.5.5 0 0 0 14 2h-4a.5.5 0 0 0-.49.42l-.38 2.65c-.61.25-1.17.59-1.69.98l-2.49-1a.5.5 0 0 0-.61.22l-2 3.46c-.12.22-.07.49.12.64L4.57 11c-.05.32-.08.65-.08.97s.03.64.08.96l-2.11 1.65c-.19.15-.24.42-.12.64l2 3.46c.12.22.39.3.61.22l2.49-1c.52.4 1.08.73 1.69.98l.38 2.65c.03.24.24.42.49.42h4c.25 0 .46-.18.49-.42l.38-2.65c.61-.25 1.17-.59 1.69-.98l2.49 1c.22.08.49 0 .61-.22l2-3.46c.12-.22.07-.49-.12-.64L19.43 12.96z'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23000' d='M12 15.5A3.5 3.5 0 0 1 8.5 12 3.5 3.5 0 0 1 12 8.5a3.5 3.5 0 0 1 3.5 3.5 3.5 3.5 0 0 1-3.5 3.5m7.43-2.53c.04-.32.07-.64.07-.97 0-.33-.03-.66-.07-1l2.11-1.65c.19-.15.24-.42.12-.64l-2-3.46c-.12-.22-.39-.3-.61-.22l-2.49 1c-.52-.4-1.08-.73-1.69-.98l-.38-2.65A.5.5 0 0 0 14 2h-4a.5.5 0 0 0-.49.42l-.38 2.65c-.61.25-1.17.59-1.69.98l-2.49-1a.5.5 0 0 0-.61.22l-2 3.46c-.12.22-.07.49.12.64L4.57 11c-.05.32-.08.65-.08.97s.03.64.08.96l-2.11 1.65c-.19.15-.24.42-.12.64l2 3.46c.12.22.39.3.61.22l2.49-1c.52.4 1.08.73 1.69.98l.38 2.65c.03.24.24.42.49.42h4c.25 0 .46-.18.49-.42l.38-2.65c.61-.25 1.17-.59 1.69-.98l2.49 1c.22.08.49 0 .61-.22l2-3.46c.12-.22.07-.49-.12-.64L19.43 12.96z'/%3E%3C/svg%3E");
}

.topbar-menu-toggle {
  display: none !important;
}

.sidebar-footer {
  padding: 14px 16px;
  border-top: 1px solid var(--border);
  background: var(--sidebar-footer-bg);
  flex-shrink: 0;
}

.user-info {
  display: flex;
  align-items: center;
  gap: 10px;
}
.user-avatar {
  width: 36px;
  height: 36px;
  background: linear-gradient(135deg, var(--primary), var(--primary-hover));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: var(--btn-primary-fg);
  flex-shrink: 0;
  box-shadow: 0 2px 12px var(--glow);
}
.user-meta .name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}
.user-meta .role {
  font-size: 11px;
  color: var(--text-muted);
}
.logout-btn {
  margin-left: auto;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.2);
  color: var(--danger);
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  padding: 6px 10px;
  border-radius: var(--radius-sm);
  transition: all var(--transition);
}
.logout-btn:hover {
  background: rgba(239, 68, 68, 0.2);
  box-shadow: 0 0 16px rgba(239, 68, 68, 0.25);
}

.topbar-left {
  display: flex;
  align-items: center;
  gap: 14px;
}
.topbar-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.02em;
}
.topbar-subtitle {
  font-size: 12px;
  color: var(--text-muted);
}
.topbar-right {
  display: flex;
  align-items: center;
  gap: 10px;
}
.topbar-btn {
  width: 38px;
  height: 38px;
  background: var(--topbar-btn-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  cursor: pointer;
  transition: all var(--transition);
  font-size: 15px;
}
.topbar-btn:hover {
  border-color: var(--nav-active-border);
  color: var(--primary-light);
  box-shadow: 0 0 20px var(--glow);
}

/* Tema seçici (layout.js) */
.theme-switcher {
  position: relative;
}
.theme-menu {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  min-width: 180px;
  padding: 6px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  z-index: 120;
}
.theme-menu.open {
  display: block;
}
.theme-menu button {
  display: block;
  width: 100%;
  text-align: left;
  padding: 10px 12px;
  border: none;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transition: background var(--transition);
}
.theme-menu button:hover {
  background: var(--bg-hover);
}
.theme-menu button.active {
  color: var(--primary-light);
  background: var(--bg-hover);
}
.theme-menu-hint {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  padding: 6px 12px 4px;
}

.login-theme-float {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 100;
}

.login-theme-float .theme-menu {
  right: 0;
}

/* ─── Glass cards ─────────────────────────────────────── */
.card {
  background: linear-gradient(155deg, var(--card-grad-from) 0%, var(--card-grad-to) 100%);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 22px;
  box-shadow: var(--shadow-card);
  transition: border-color var(--transition), box-shadow var(--transition);
}
.card:hover {
  border-color: var(--card-border-hover);
}

.card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.card-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  display: flex;
  align-items: center;
  gap: 8px;
  letter-spacing: -0.01em;
}

/* Legacy stat cards ( liste sayfaları ) */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}
.stat-card {
  background: linear-gradient(155deg, var(--stat-card-grad-from) 0%, var(--stat-card-grad-to) 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 18px;
  display: flex;
  align-items: flex-start;
  gap: 14px;
  transition: all var(--transition);
  box-shadow: var(--shadow-card);
}
.stat-card:hover {
  transform: translateY(-2px);
  border-color: var(--nav-active-border);
  box-shadow: var(--shadow-card), 0 0 28px var(--glow);
}
.stat-icon {
  width: 46px;
  height: 46px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.stat-icon.primary {
  background: var(--primary-soft);
  color: var(--primary-light);
}
.stat-icon.teal {
  background: var(--accent-teal-dim);
  color: var(--accent-teal);
}
.stat-icon.green {
  background: var(--success-dim);
  color: var(--badge-green-fg);
}
.stat-icon.red {
  background: var(--danger-dim);
  color: var(--badge-red-fg);
}
.stat-icon.blue {
  background: var(--btn-info-bg);
  color: var(--primary-light);
}
.stat-icon.purple {
  background: var(--purple-dim);
  color: var(--purple);
}
.stat-icon.yellow {
  background: var(--warning-dim);
  color: var(--badge-yellow-fg);
}
.stat-label {
  font-size: 11px;
  color: var(--text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 4px;
}
.stat-value {
  font-size: 26px;
  font-weight: 800;
  color: var(--text);
  line-height: 1;
  letter-spacing: -0.03em;
}
.stat-sub {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 6px;
}

/* ─── Dashboard hero + premium stat ───────────────────── */
.dashboard-hero {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 28px;
  padding: 8px 4px 4px;
}
.dashboard-hero__titles h1 {
  font-size: clamp(1.55rem, 3vw, 2rem);
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.03em;
  line-height: 1.15;
}
.dashboard-hero__titles .tagline {
  margin-top: 8px;
  font-size: 13px;
  color: var(--text-muted);
  font-weight: 500;
}
.dashboard-hero__titles .tagline strong {
  color: var(--primary-light);
  font-weight: 600;
}

.status-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid var(--border);
  background: var(--status-badge-neutral-bg);
  backdrop-filter: blur(8px);
  transition: all var(--transition);
}
.status-badge:hover {
  box-shadow: 0 0 20px var(--glow);
}
.status-badge .dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--text-muted);
}
.status-badge.ok {
  border-color: rgba(34, 197, 94, 0.35);
  color: var(--success);
  background: var(--success-dim);
}
.status-badge.ok .dot {
  background: var(--success);
  box-shadow: 0 0 10px var(--success);
  animation: badge-pulse 2.2s ease-in-out infinite;
}
.status-badge.bad {
  border-color: rgba(239, 68, 68, 0.4);
  color: var(--status-bad-text);
  background: var(--danger-dim);
}
.status-badge.bad .dot {
  background: var(--danger);
}
.status-badge.warn {
  border-color: rgba(250, 204, 21, 0.35);
  color: var(--warning);
  background: var(--warning-dim);
}
.status-badge.warn .dot {
  background: var(--warning);
}

@keyframes badge-pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.55;
  }
}

.dash-stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 16px;
  margin-bottom: 24px;
}

.dash-stat-card {
  position: relative;
  background: linear-gradient(165deg, var(--dash-stat-grad-from) 0%, var(--dash-stat-grad-to) 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 20px 20px 18px;
  overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  box-shadow: var(--shadow-card);
}
.dash-stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--primary), var(--primary-light), var(--primary-hover));
  opacity: 0.85;
}
.dash-stat-card:hover {
  transform: translateY(-3px);
  border-color: var(--nav-active-border);
  box-shadow: var(--shadow-card), 0 0 36px var(--glow), 0 0 1px var(--primary-soft);
}
.dash-stat-card__inner {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}
.dash-stat-card__icon {
  width: 54px;
  height: 54px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  flex-shrink: 0;
  background: var(--dash-stat-icon-grad);
  box-shadow: var(--dash-icon-inset);
}
.dash-stat-card--success .dash-stat-card__icon {
  background: linear-gradient(145deg, var(--success-dim), rgba(34, 197, 94, 0.06));
}
.dash-stat-card--danger .dash-stat-card__icon {
  background: linear-gradient(145deg, var(--danger-dim), rgba(239, 68, 68, 0.06));
}
.dash-stat-card--warn .dash-stat-card__icon {
  background: linear-gradient(145deg, var(--warning-dim), rgba(250, 204, 21, 0.06));
}
.dash-stat-card--neutral .dash-stat-card__icon {
  background: var(--badge-gray-bg);
  border: 1px solid var(--border);
}
.dash-stat-card__label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}
.dash-stat-card__value {
  font-size: 30px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.04em;
  line-height: 1.1;
  margin-top: 6px;
}
.dash-stat-card__trend {
  margin-top: 8px;
  font-size: 11px;
  font-weight: 600;
  color: var(--primary-light);
  opacity: 0.95;
}
.dash-stat-card__trend--muted {
  color: var(--text-muted);
}
.dash-stat-card__trend--up {
  color: var(--success);
}
.dash-stat-card__trend--down {
  color: var(--danger);
}

.dash-lower-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
.dash-col-6 {
  grid-column: span 6;
}
.dash-col-12 {
  grid-column: span 12;
}
@media (max-width: 1100px) {
  .dash-col-6 {
    grid-column: span 12;
  }
}

.table-panel {
  padding: 0;
  overflow: hidden;
}
.table-panel .card-header {
  padding: 18px 22px 0;
  margin-bottom: 0;
}
.table-panel .table-wrap {
  margin-top: 12px;
}

/* ─── Tables (NOC) ───────────────────────────────────── */
.table-wrap {
  overflow-x: auto;
}
table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
thead th {
  position: sticky;
  top: 0;
  z-index: 1;
  background: var(--table-head-bg);
  backdrop-filter: blur(8px);
  color: var(--text-muted);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 12px 16px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
tbody tr {
  border-bottom: 1px solid var(--border);
  transition: background var(--transition);
}
tbody tr:hover {
  background: var(--table-row-hover);
}
tbody tr:last-child {
  border-bottom: none;
}
tbody td {
  padding: 13px 16px;
  color: var(--text);
  vertical-align: middle;
}
.td-muted {
  color: var(--text-muted);
  font-size: 12px;
}
.td-mono {
  font-family: ui-monospace, 'Cascadia Code', 'Consolas', monospace;
  font-size: 12px;
  color: var(--primary-light);
}

/* ─── Buttons ─────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 9px 17px;
  border-radius: var(--radius-md);
  font-size: 13px;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
  border: none;
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
  text-decoration: none;
}
.btn-primary {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-hover) 100%);
  color: var(--btn-primary-fg);
  box-shadow: 0 4px 16px var(--glow);
  border: 1px solid var(--btn-primary-ring);
}
.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 28px var(--glow-strong);
  filter: brightness(1.05);
}
.btn-secondary {
  background: var(--btn-secondary-bg);
  color: var(--text-muted);
  border: 1px solid var(--border);
}
.btn-secondary:hover {
  border-color: var(--btn-secondary-hover-border);
  color: var(--text);
}
.btn-success {
  background: var(--success-dim);
  color: var(--success);
  border: 1px solid rgba(34, 197, 94, 0.35);
}
.btn-danger {
  background: var(--danger-dim);
  color: var(--btn-danger-text);
  border: 1px solid rgba(239, 68, 68, 0.35);
}
.btn-warning {
  background: var(--warning-dim);
  color: var(--warning);
  border: 1px solid rgba(250, 204, 21, 0.35);
}
.btn-info {
  background: var(--btn-info-bg);
  color: var(--primary-light);
  border: 1px solid var(--btn-info-border);
}
.btn-sm {
  padding: 6px 12px;
  font-size: 12px;
}
.btn-lg {
  padding: 13px 26px;
  font-size: 15px;
}
.btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

/* ─── Forms ───────────────────────────────────────────── */
.form-group {
  margin-bottom: 16px;
}
.form-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  margin-bottom: 7px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.form-label .req {
  color: var(--primary-light);
}
.form-control {
  width: 100%;
  background: var(--bg-input);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  color: var(--text);
  font-size: 13px;
  font-family: 'Inter', sans-serif;
  transition: all var(--transition);
  outline: none;
}
.form-control:focus {
  border-color: var(--form-focus-border);
  box-shadow: 0 0 0 3px var(--glow), var(--form-focus-shadow);
}
.form-control::placeholder {
  color: var(--placeholder-fg);
}
.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.form-grid.cols-3 {
  grid-template-columns: 1fr 1fr 1fr;
}
.form-grid .col-span-2 {
  grid-column: span 2;
}
.form-hint {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 5px;
}

/* ─── Badges ─────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 11px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  border: 1px solid transparent;
}
.badge::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.badge-glow {
  box-shadow: 0 0 14px currentColor;
}
.badge-green {
  background: var(--success-dim);
  color: var(--badge-green-fg);
  border-color: rgba(34, 197, 94, 0.35);
}
.badge-red {
  background: var(--danger-dim);
  color: var(--badge-red-fg);
  border-color: rgba(239, 68, 68, 0.35);
}
.badge-yellow {
  background: var(--warning-dim);
  color: var(--badge-yellow-fg);
  border-color: rgba(250, 204, 21, 0.35);
}
.badge-blue {
  background: var(--primary-soft);
  color: var(--badge-blue-fg);
  border-color: rgba(59, 130, 246, 0.35);
}
.badge-primary {
  background: var(--primary-soft);
  color: var(--badge-blue-fg);
  border-color: rgba(59, 130, 246, 0.3);
}
.badge-gray {
  background: var(--badge-gray-bg);
  color: var(--badge-gray-fg);
  border-color: var(--border);
}

/* WireGuard yönetim VPN (panel — müşteri trafiği değil) */
.badge-vpn-on {
  background: var(--primary-soft);
  color: var(--badge-blue-fg);
  border-color: rgba(59, 130, 246, 0.45);
}
.badge-vpn-on.badge-glow {
  box-shadow: 0 0 14px var(--primary-light), 0 0 28px var(--glow);
}
.badge-vpn-off {
  background: var(--danger-dim);
  color: var(--badge-red-fg);
  border-color: rgba(239, 68, 68, 0.4);
}
.badge-vpn-off.badge-glow {
  box-shadow: 0 0 14px rgba(248, 113, 113, 0.65);
}

.dash-mikrotik-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(268px, 1fr));
  gap: 14px;
  margin-bottom: 22px;
}
.dash-mikrotik-card .card-title {
  font-size: 13px;
}
.dash-mikrotik-card .vpn-meta {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 10px;
  line-height: 1.55;
}
.dash-mikrotik-card .vpn-meta strong {
  color: var(--text);
}

/* ─── Modal ───────────────────────────────────────────── */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: var(--modal-backdrop-bg);
  backdrop-filter: blur(8px);
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.28s ease;
}
.modal-backdrop.open {
  opacity: 1;
  pointer-events: all;
}
.modal {
  background: linear-gradient(165deg, var(--bg-card) 0%, var(--modal-body-grad-to) 100%);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-xl);
  padding: 26px;
  width: 100%;
  max-width: 560px;
  max-height: 90vh;
  overflow-y: auto;
  transform: translateY(18px) scale(0.98);
  transition: transform 0.28s ease;
  box-shadow: var(--modal-shadow);
}
.modal-backdrop.open .modal {
  transform: translateY(0) scale(1);
}
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.modal-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}
.modal-close {
  background: var(--modal-close-bg);
  border: 1px solid var(--border);
  color: var(--text-muted);
  width: 32px;
  height: 32px;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
}
.modal-close:hover {
  color: var(--danger);
  border-color: rgba(239, 68, 68, 0.4);
}
.modal-footer {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 22px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 18px;
  flex-wrap: wrap;
}
.search-box {
  position: relative;
  flex: 1;
  min-width: 220px;
  max-width: 380px;
}
.search-box .search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  font-size: 14px;
}
.search-box input {
  padding-left: 36px;
}

.empty-state {
  text-align: center;
  padding: 56px 24px;
  color: var(--text-muted);
}
.empty-state .icon {
  font-size: 48px;
  margin-bottom: 14px;
  opacity: 0.35;
}
.empty-state .title {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}
.status-dot.online {
  background: var(--success);
  box-shadow: 0 0 8px var(--success);
  animation: pulse 2s infinite;
}
.status-dot.offline {
  background: var(--danger);
}
.status-dot.unknown {
  background: var(--text-muted);
}
@keyframes pulse {
  0%,
  100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}

.page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 22px;
  gap: 16px;
  flex-wrap: wrap;
}
.page-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.03em;
}
.page-subtitle {
  font-size: 13px;
  color: var(--text-muted);
  margin-top: 4px;
}

.content-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.content-grid.cols-3 {
  grid-template-columns: 1fr 1fr 1fr;
}
.content-grid .full {
  grid-column: 1 / -1;
}

.alert {
  padding: 12px 16px;
  border-radius: var(--radius-md);
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  border: 1px solid var(--border);
}
.alert-success {
  background: var(--success-dim);
  border-color: rgba(34, 197, 94, 0.35);
  color: var(--success);
}
.alert-danger {
  background: var(--danger-dim);
  border-color: rgba(239, 68, 68, 0.35);
  color: #fecaca;
}

#toast-container {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.toast {
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  padding: 12px 18px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 500;
  box-shadow: var(--toast-shadow);
  animation: slideIn 0.3s ease;
  min-width: 260px;
  max-width: 380px;
}
.toast.success {
  border-left: 3px solid var(--success);
  color: var(--success);
}
.toast.error {
  border-left: 3px solid var(--danger);
  color: var(--btn-danger-text);
}
.toast.warning {
  border-left: 3px solid var(--warning);
  color: var(--warning);
}
.toast.info {
  border-left: 3px solid var(--primary-light);
  color: var(--primary-light);
}
@keyframes slideIn {
  from {
    transform: translateX(100%);
    opacity: 0;
  }
  to {
    transform: translateX(0);
    opacity: 1;
  }
}

.spinner {
  width: 20px;
  height: 20px;
  border: 2px solid var(--border);
  border-top-color: var(--primary-light);
  border-radius: 50%;
  animation: spin 0.65s linear infinite;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
.loading-overlay {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 56px;
}

.mono {
  font-family: ui-monospace, 'Cascadia Code', 'Consolas', monospace;
  font-size: 12px;
  background: var(--mono-bg);
  padding: 4px 9px;
  border-radius: 6px;
  color: var(--primary-light);
  border: 1px solid var(--mono-border);
}

/* ─── Login (premium dark) ───────────────────────────── */
.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: var(--login-bg-gradient);
}
.login-card {
  width: 100%;
  max-width: 420px;
  background: var(--login-card-grad);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 38px;
  box-shadow: var(--login-card-shadow);
  backdrop-filter: blur(20px);
}
.login-brand {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 30px;
}
.login-brand .logo-icon {
  width: 52px;
  height: 52px;
  font-size: 22px;
}
.login-brand h1 {
  font-size: 20px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.02em;
}
.login-brand p {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 5px;
}

.section-anchor {
  scroll-margin-top: 88px;
}

.mobile-only {
  display: none;
}

.nav-badge {
  margin-left: auto;
  background: var(--primary);
  color: var(--btn-primary-fg);
  font-size: 9px;
  font-weight: 800;
  padding: 2px 7px;
  border-radius: 99px;
}

@media (max-width: 768px) {
  .sidebar-backdrop {
    display: block;
  }
  .sidebar {
    transform: translateX(-100%);
  }
  .sidebar.open {
    transform: translateX(0);
    box-shadow: 16px 0 48px rgba(0, 0, 0, 0.55);
  }
  .main-content {
    margin-left: 0;
  }
  .form-grid {
    grid-template-columns: 1fr;
  }
  .content-grid {
    grid-template-columns: 1fr;
  }
  .stats-grid {
    grid-template-columns: 1fr 1fr;
  }
  .page-content {
    padding: 16px;
  }
  .topbar-menu-toggle {
    display: flex !important;
  }
}

@media (max-width: 480px) {
  .stats-grid {
    grid-template-columns: 1fr;
  }
  .dash-stats-grid {
    grid-template-columns: 1fr;
  }
}

/* ─── Müşteri CRM — premium oluşturma / düzen paneli ───────────────── */
.modal.modal-crm {
  max-width: min(1150px, calc(100vw - 24px));
  width: 100%;
  max-height: min(940px, calc(100vh - 20px));
  padding: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: var(--radius-xl);
  border: 1px solid var(--crm-modal-accent-border);
  box-shadow: var(--crm-panel-shadow);
}

/* Form, gövde + footer ile sütun flex: içerik uzayınca gövdede scroll */
.modal.modal-crm > form {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
}

.modal-crm-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 26px 18px;
  border-bottom: 1px solid var(--border);
  background: var(--crm-header-grad);
  flex-shrink: 0;
}

.modal-crm-titleblock h2 {
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--text);
  letter-spacing: -0.03em;
  line-height: 1.2;
}

.modal-crm-titleblock p {
  margin-top: 6px;
  font-size: 13px;
  color: var(--text-muted);
  max-width: 520px;
  line-height: 1.5;
}

.modal-crm-close {
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--modal-close-bg);
  color: var(--text-muted);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--transition);
}

.modal-crm-close:hover {
  color: var(--danger);
  border-color: rgba(239, 68, 68, 0.4);
  box-shadow: var(--crm-close-hover-shadow);
}

.modal-crm-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 20px 24px 8px;
  display: grid;
  grid-template-columns: 1fr min(300px, 34%);
  gap: 22px;
  align-items: start;
  -webkit-overflow-scrolling: touch;
}

.modal-crm-main {
  display: flex;
  flex-direction: column;
  gap: 18px;
  min-width: 0;
  min-height: 0;
}

.modal-crm-aside {
  position: sticky;
  top: 0;
}

.crm-summary-card {
  background: var(--crm-summary-grad);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 18px 18px 16px;
  box-shadow: var(--crm-summary-shadow);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.crm-summary-card:hover {
  border-color: var(--nav-active-border);
}

.crm-summary-card__title {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--primary-light);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.crm-summary-card__title::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--primary);
  box-shadow: 0 0 12px var(--glow);
  animation: badge-pulse 2.5s ease-in-out infinite;
}

.crm-summary-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}

.crm-summary-row:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.crm-summary-row .k {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
}

.crm-summary-row .v {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  word-break: break-word;
}

.modal-crm-footer {
  flex-shrink: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 24px 20px;
  border-top: 1px solid var(--border);
  background: var(--crm-footer-bg);
}

.btn-crm-secondary {
  background: var(--btn-secondary-bg);
  border: 1px solid var(--border);
  color: var(--text-muted);
}

.btn-crm-secondary:hover {
  border-color: var(--btn-secondary-hover-border);
  color: var(--text);
}

.btn-crm-accent {
  background: var(--crm-btn-accent-bg);
  border: 1px solid var(--crm-btn-accent-border);
  color: var(--primary-light);
}

.btn-crm-accent:hover {
  box-shadow: 0 0 28px var(--glow);
  border-color: var(--crm-btn-accent-hover-border);
}

.form-section-card {
  background: var(--form-section-grad);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 0;
  overflow: hidden;
  transition: border-color var(--transition), box-shadow var(--transition);
}

.form-section-card:hover {
  border-color: var(--form-section-hover-border);
  box-shadow: var(--form-section-hover-shadow);
}

.form-section-card:focus-within {
  border-color: var(--form-section-focus-border);
  box-shadow: var(--form-section-focus-shadow);
}

.form-section-head {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  background: var(--form-section-head-bg);
}

.form-section-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
  background: var(--form-section-icon-grad);
  box-shadow: var(--form-section-icon-inset);
}

.form-section-head h3 {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: -0.02em;
}

.form-section-head span {
  display: block;
  font-size: 11px;
  color: var(--text-muted);
  font-weight: 500;
  margin-top: 2px;
}

.form-section-body {
  padding: 18px 18px 20px;
}

.form-grid-premium {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px 18px;
}

.form-grid-premium .full {
  grid-column: 1 / -1;
}

@media (max-width: 640px) {
  .form-grid-premium {
    grid-template-columns: 1fr;
  }
  .form-grid-premium .full {
    grid-column: 1;
  }
}

.form-control-lg {
  padding: 12px 15px;
  font-size: 14px;
  border-radius: var(--radius-md);
}

.form-textarea-premium {
  min-height: 120px;
  resize: vertical;
  line-height: 1.55;
}

.status-select-wrap {
  position: relative;
}

.status-select-wrap .status-preview {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  z-index: 1;
}

select.form-control.form-select-status {
  padding-right: 140px;
  cursor: pointer;
  font-weight: 600;
  appearance: none;
  background-image: var(--select-chevron-url);
  background-repeat: no-repeat;
  background-position: right 14px center;
}

.modal-crm .form-control:focus {
  animation: form-focus-glow 0.35s ease;
}

@keyframes form-focus-glow {
  from {
    box-shadow: 0 0 0 0 var(--glow);
  }
  to {
    box-shadow: 0 0 0 3px var(--glow), 0 0 28px var(--glow-strong);
  }
}

.form-label-premium {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.form-label-premium .req {
  color: var(--primary-light);
  font-weight: 800;
}

@media (max-width: 900px) {
  .modal-crm-body {
    grid-template-columns: 1fr;
  }
  .modal-crm-aside {
    position: relative;
    order: -1;
  }
}

/* ─── ISP Log Merkezi ─────────────────────────────────────────────────────── */
.log-hub-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  align-items: flex-end;
  padding: 14px 16px;
  margin-bottom: 16px;
  border-radius: var(--radius-md);
  background: linear-gradient(165deg, var(--bg-card-elevated) 0%, var(--bg-card) 100%);
  border: 1px solid var(--border);
  box-shadow: 0 0 24px rgba(59, 130, 246, 0.06);
  position: sticky;
  top: 0;
  z-index: 5;
}
.log-hub-filters .form-group {
  margin: 0;
  min-width: 120px;
}
.log-hub-filters .form-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 4px;
}
.log-hub-table-wrap {
  max-height: min(72vh, 920px);
  overflow: auto;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  box-shadow: inset 0 0 40px rgba(59, 130, 246, 0.03);
}
.log-hub-table-wrap table {
  margin: 0;
  min-width: 720px;
}
.log-hub-table-wrap thead th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: var(--bg-card);
  box-shadow: 0 1px 0 var(--border);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 11px 12px;
  white-space: nowrap;
}
.log-hub-table-wrap tbody tr:hover {
  background: var(--bg-hover);
  box-shadow: 0 0 16px rgba(96, 165, 250, 0.08);
}
.log-hub-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}
.log-hub-meta {
  font-size: 13px;
  color: var(--text-muted);
  margin-bottom: 10px;
}
.badge-log-online {
  box-shadow: 0 0 12px rgba(34, 197, 94, 0.35);
}
.badge-log-offline {
  opacity: 0.85;
}

/* ISS günlük arşiv tablosu */
.iss-archive-panel {
  margin-top: 24px;
  padding: 18px 20px 22px;
}
.iss-archive-head {
  margin-bottom: 14px;
}
.iss-archive-hint code {
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--bg-card-elevated);
  border: 1px solid var(--border);
}
.iss-archive-table tbody tr.iss-archive-row:hover {
  background: var(--bg-hover);
}
.iss-col-num {
  width: 44px;
  text-align: right;
  color: var(--text-muted);
  font-variant-numeric: tabular-nums;
}
.iss-archive-name {
  max-width: 420px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.iss-size {
  font-size: 12px;
  color: var(--text-muted);
  white-space: nowrap;
}
.iss-badges {
  white-space: nowrap;
}
.iss-badge {
  display: inline-flex;
  align-items: center;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 2px 7px;
  border-radius: 4px;
  vertical-align: middle;
}
.iss-badge-gz {
  background: rgba(59, 130, 246, 0.18);
  color: var(--accent, #60a5fa);
  border: 1px solid rgba(59, 130, 246, 0.35);
}
.iss-badge-zip {
  background: rgba(234, 179, 8, 0.15);
  color: #eab308;
  border: 1px solid rgba(234, 179, 8, 0.35);
}
.iss-badge-tsa-ok {
  background: rgba(34, 197, 94, 0.18);
  color: #22c55e;
  border: 1px solid rgba(34, 197, 94, 0.35);
}
.iss-badge-tsa-no {
  background: var(--bg-card-elevated);
  color: var(--text-muted);
  border: 1px solid var(--border);
}
.iss-actions {
  white-space: normal;
  min-width: 220px;
}
.iss-actions .btn {
  margin-bottom: 4px;
}
.iss-detail-modal {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.iss-detail-modal[hidden] {
  display: none;
}
.iss-detail-dialog {
  position: relative;
  max-width: 640px;
  width: 100%;
  max-height: 85vh;
  overflow: auto;
  padding: 20px 22px;
}
.iss-detail-close {
  position: absolute;
  top: 12px;
  right: 14px;
  border: none;
  background: transparent;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  color: var(--text-muted);
}
.iss-detail-pre {
  font-size: 12px;
  margin: 0;
  max-height: 60vh;
  overflow: auto;
}

/* --------------------------------------------------------------------------
   Premium location onboarding (ISP CRM / NOC) — matches locations.html
   -------------------------------------------------------------------------- */
.loc-onboard-backdrop {
  --loc-accent: linear-gradient(135deg, #5b8cff 0%, #8b5cf6 45%, #22d3ee 100%);
  --loc-card-bg: rgba(255, 255, 255, 0.06);
  --loc-card-border: rgba(255, 255, 255, 0.12);
  --loc-glow: 0 0 0 1px rgba(255, 255, 255, 0.06), 0 18px 48px rgba(37, 99, 235, 0.12),
    0 0 80px rgba(139, 92, 246, 0.08);

  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 10px 12px 14px;
  overflow-y: auto;
  box-sizing: border-box;
  background: radial-gradient(1200px 700px at 15% 0%, rgba(37, 99, 235, 0.18), transparent 60%),
    radial-gradient(900px 500px at 100% 20%, rgba(139, 92, 246, 0.14), transparent 55%),
    rgba(7, 10, 20, 0.55);
  backdrop-filter: blur(6px);
}

html:not([data-theme="dark"]) .loc-onboard-backdrop {
  --loc-card-bg: rgba(255, 255, 255, 0.78);
  --loc-card-border: rgba(15, 23, 42, 0.1);
  --loc-glow: 0 0 0 1px rgba(15, 23, 42, 0.06), 0 18px 42px rgba(15, 23, 42, 0.08),
    0 0 70px rgba(59, 130, 246, 0.1);

  background: radial-gradient(1000px 600px at 10% 0%, rgba(59, 130, 246, 0.12), transparent 58%),
    radial-gradient(800px 480px at 100% 15%, rgba(139, 92, 246, 0.08), transparent 55%),
    rgba(248, 250, 252, 0.88);
}

.loc-onboard-shell {
  position: relative;
  max-width: min(1280px, 100%);
  width: 100%;
  margin: 0 auto;
  border-radius: 20px;
  border: 1px solid var(--loc-card-border);
  background: var(--loc-card-bg);
  box-shadow: var(--loc-glow);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  overflow: hidden;
  max-height: min(calc(100vh - 20px), calc(100dvh - 20px));
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.loc-onboard-header {
  position: relative;
  flex-shrink: 0;
  padding: 20px 48px 16px 24px;
  border-bottom: 1px solid var(--border);
}

.loc-onboard-close {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 40px;
  height: 40px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.04);
  color: var(--text-muted);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s ease, border-color 0.15s ease, background 0.15s ease;
}

.loc-onboard-close:hover {
  color: var(--text);
  border-color: rgba(91, 140, 255, 0.45);
  background: rgba(91, 140, 255, 0.08);
}

.loc-onboard-kicker {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}

.loc-onboard-title {
  margin: 0 0 8px;
  font-size: clamp(1.2rem, 2.2vw, 1.65rem);
  font-weight: 750;
  letter-spacing: -0.02em;
  background: var(--loc-accent);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.loc-onboard-lead {
  margin: 0;
  font-size: 14px;
  color: var(--text-muted);
  max-width: 62ch;
  line-height: 1.55;
}

.loc-onboard-form {
  flex: 1;
  min-height: 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.loc-onboard-body {
  flex: 1;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(260px, 340px);
  gap: 20px;
  padding: 16px 24px 12px;
  align-items: start;
}

.loc-onboard-main {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.loc-onboard-aside {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 14px;
  align-self: start;
}

/* Glass panels (modal sections + rails) */
.glass-panel {
  backdrop-filter: blur(10px) saturate(130%);
  -webkit-backdrop-filter: blur(10px) saturate(130%);
}

.glass-panel-inner {
  background: rgba(91, 140, 255, 0.04);
  border: 1px solid rgba(91, 140, 255, 0.2);
  border-radius: 14px;
}

html:not([data-theme="dark"]) .glass-panel-inner {
  background: rgba(59, 130, 246, 0.06);
}

.loc-glow {
  box-shadow: 0 0 0 1px rgba(91, 140, 255, 0.12), 0 12px 40px rgba(37, 99, 235, 0.1);
}

.loc-card {
  border-radius: 16px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.02);
  padding: 18px 18px 16px;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.08);
  transition: border-color 0.2s ease, box-shadow 0.25s ease, transform 0.2s ease;
}

html:not([data-theme="dark"]) .loc-card {
  background: rgba(255, 255, 255, 0.95);
}

.loc-card:hover {
  border-color: rgba(91, 140, 255, 0.45);
  box-shadow: 0 14px 40px rgba(37, 99, 235, 0.12), 0 0 0 1px rgba(91, 140, 255, 0.18);
  transform: translateY(-1px);
}

.loc-card-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 14px;
}

.loc-card-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  background: linear-gradient(145deg, rgba(91, 140, 255, 0.22), rgba(139, 92, 246, 0.18));
  border: 1px solid rgba(255, 255, 255, 0.12);
  flex-shrink: 0;
}

.loc-card-icon--gen::before {
  content: "◎";
}
.loc-card-icon--addr::before {
  content: "📍";
}
.loc-card-icon--net::before {
  content: "🛰";
}
.loc-card-icon--cgnat::before {
  content: "⇄";
}
.loc-card-icon--ops::before {
  content: "⚙";
}

.loc-card-title {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}

.loc-card-desc {
  margin: 2px 0 0;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
}

.loc-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 14px;
}

.loc-form-grid .form-group {
  min-width: 0;
}

.loc-span-2 {
  grid-column: span 2;
}

.loc-input-premium {
  transition: border-color 0.15s ease, box-shadow 0.2s ease;
}

.loc-input-premium:focus {
  border-color: rgba(91, 140, 255, 0.55);
  box-shadow: 0 0 0 3px rgba(91, 140, 255, 0.12);
}

.loc-map-placeholder {
  margin-top: 16px;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 20px;
  border-radius: 14px;
  border: 1px dashed rgba(91, 140, 255, 0.38);
  background: linear-gradient(100deg, rgba(91, 140, 255, 0.07), transparent 55%);
}

.loc-map-pin {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  background: linear-gradient(145deg, rgba(91, 140, 255, 0.35), rgba(139, 92, 246, 0.25));
  box-shadow: 0 8px 24px rgba(37, 99, 235, 0.2);
  flex-shrink: 0;
}

.loc-pool-toggle {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 10px;
}

.loc-radio-tile {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.03);
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.2s ease;
}

html:not([data-theme="dark"]) .loc-radio-tile {
  background: rgba(248, 250, 252, 0.9);
}

.loc-radio-tile:has(input:checked) {
  border-color: rgba(91, 140, 255, 0.55);
  background: rgba(91, 140, 255, 0.1);
  box-shadow: 0 0 0 1px rgba(91, 140, 255, 0.15);
}

.loc-radio-tile input {
  accent-color: #5b8cff;
}

.loc-pool-select-wrap,
.loc-pool-custom-wrap {
  margin-top: 4px;
}

.loc-helper {
  font-size: 11px;
  color: var(--text-muted);
  margin: 6px 0 0;
  line-height: 1.35;
}

.loc-check-row {
  display: flex;
  align-items: center;
}

.loc-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  cursor: pointer;
}

.loc-check input {
  accent-color: #5b8cff;
}

/* Sağ: özet */
.loc-summary {
  border-radius: 16px;
  border: 1px solid var(--border);
  padding: 16px;
  background: linear-gradient(160deg, rgba(91, 140, 255, 0.1), rgba(0, 0, 0, 0));
}

html:not([data-theme="dark"]) .loc-summary {
  background: linear-gradient(165deg, rgba(91, 140, 255, 0.12), rgba(255, 255, 255, 0.98));
}

.loc-summary-title {
  margin: 0 0 12px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 700;
  color: var(--text-muted);
}

.loc-summary-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.loc-summary-list li {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}

.loc-summary-list li:last-child {
  border-bottom: none;
}

.loc-summary-list .k {
  color: var(--text-muted);
  flex-shrink: 0;
}

.loc-summary-list .v {
  text-align: right;
  font-weight: 600;
  word-break: break-word;
}

/* Mini kartlar: MikroTik + havuz */
.loc-mini-card {
  border-radius: 16px;
  border: 1px solid var(--border);
  padding: 14px 16px;
  background: rgba(0, 0, 0, 0.12);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

html:not([data-theme="dark"]) .loc-mini-card {
  background: rgba(255, 255, 255, 0.96);
}

.loc-mini-card:hover {
  border-color: rgba(91, 140, 255, 0.35);
  box-shadow: 0 8px 28px rgba(37, 99, 235, 0.08);
}

.loc-mini-title {
  margin: 0 0 10px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: var(--text-muted);
}

.loc-mini-muted {
  margin: 0;
  font-size: 13px;
  color: var(--text-muted);
}

.loc-mini-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  font-size: 12px;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
}

.loc-mini-row:last-child {
  border-bottom: none;
}

.loc-mini-row span:first-child {
  color: var(--text-muted);
}

.loc-mini-footer {
  margin: 12px 0 0;
  font-size: 11px;
  color: var(--text-muted);
}

.loc-pool-cidr {
  margin: 0 0 12px;
  font-size: 15px;
  font-weight: 700;
}

.loc-pool-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.loc-pool-stats > div {
  text-align: center;
  padding: 8px 6px;
  border-radius: 10px;
  background: rgba(91, 140, 255, 0.08);
  border: 1px solid var(--border);
}

.loc-pool-stats .n {
  display: block;
  font-size: 16px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.loc-pool-stats .l {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin-top: 2px;
}

@media (max-width: 380px) {
  .loc-pool-stats {
    grid-template-columns: 1fr;
  }
}

.loc-onboard-footer {
  flex-shrink: 0;
  z-index: 2;
  padding: 12px 24px 14px;
  border-top: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(7, 10, 20, 0.2), rgba(7, 10, 20, 0.72));
  backdrop-filter: blur(12px);
}

html:not([data-theme="dark"]) .loc-onboard-footer {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0.92));
}

.loc-footer-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
}

.loc-footer-actions .btn-secondary:first-child {
  margin-right: auto;
}

@media (max-width: 900px) {
  .loc-onboard-body {
    grid-template-columns: 1fr;
    padding: 14px 14px 10px;
  }
}

@media (max-width: 640px) {
  .loc-form-grid {
    grid-template-columns: 1fr;
  }
  .loc-span-2 {
    grid-column: span 1;
  }
}

@media (max-width: 600px) {
  .loc-footer-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .loc-footer-actions .btn,
  .loc-footer-actions .btn-secondary {
    width: 100%;
    text-align: center;
  }
  .loc-footer-actions .btn-secondary:first-child {
    margin-right: 0;
  }
}

/* ─── Ayarlar merkezi ───────────────────────────────────── */
.settings-shell {
  display: grid;
  grid-template-columns: minmax(200px, 260px) 1fr;
  gap: 22px;
  align-items: start;
  max-width: 1400px;
  margin: 0 auto;
}
.settings-nav {
  position: sticky;
  top: 72px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 12px;
  border-radius: var(--radius-lg);
  background: var(--bg-card);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
}
.settings-nav button {
  text-align: left;
  width: 100%;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  border: none;
  background: transparent;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
}
.settings-nav button:hover {
  background: var(--bg-hover);
  color: var(--text);
}
.settings-nav button.active {
  background: var(--primary-soft);
  color: var(--primary);
}
.settings-main {
  min-width: 0;
}
.settings-pane {
  display: none;
}
.settings-pane.active {
  display: block;
}
.settings-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  margin-bottom: 16px;
  box-shadow: var(--shadow-card);
  overflow: hidden;
}
.settings-card-h {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(59, 130, 246, 0.04) 0%, transparent 100%);
}
.settings-card-h .title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
}
.settings-card-b {
  padding: 16px 18px;
}
.settings-kv {
  display: grid;
  grid-template-columns: minmax(160px, 220px) 1fr;
  gap: 8px 16px;
  font-size: 13px;
  line-height: 1.55;
}
@media (max-width: 640px) {
  .settings-kv {
    grid-template-columns: 1fr;
  }
}
.settings-kv dt {
  color: var(--text-muted);
  font-weight: 600;
}
.settings-kv dd {
  margin: 0;
  color: var(--text);
  word-break: break-word;
}
.settings-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.settings-test-out {
  margin-top: 12px;
  padding: 12px;
  border-radius: var(--radius-md);
  background: var(--mono-bg);
  border: 1px solid var(--border);
  font: 12px/1.45 ui-monospace, SFMono-Regular, Menlo, monospace;
  white-space: pre-wrap;
  max-height: 240px;
  overflow: auto;
}
.settings-stat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 10px;
  margin-top: 12px;
}
.settings-stat {
  padding: 12px;
  border-radius: var(--radius-md);
  background: var(--bg-page);
  border: 1px solid var(--border);
}
.settings-stat .l {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.settings-stat .v {
  font-size: 18px;
  font-weight: 800;
  margin-top: 4px;
}
@media (max-width: 900px) {
  .settings-shell {
    grid-template-columns: 1fr;
  }
  .settings-nav {
    position: static;
    flex-direction: row;
    flex-wrap: wrap;
  }
  .settings-nav button {
    width: auto;
    flex: 1 1 40%;
  }
}
