* { box-sizing: border-box; margin: 0; padding: 0; }
:root, [data-theme="dark"] {
  --bg-deep: #020617;
  --bg-panel: #0f172a;
  --bg-panel-2: #1e293b;
  --bg-elev: #334155;
  --border: #334155;
  --border-soft: #1e293b;
  --text: #e2e8f0;
  --text-dim: #94a3b8;
  --text-faint: #64748b;
  --accent: #06b6d4;
  --accent-hover: #22d3ee;
  --accent-soft: rgba(6, 182, 212, 0.15);
  --orange: #f59e0b;
  --orange-soft: rgba(245, 158, 11, 0.15);
  --green: #10b981;
  --green-soft: rgba(16, 185, 129, 0.15);
  --red: #ef4444;
  --red-soft: rgba(239, 68, 68, 0.15);
  --yellow: #eab308;
  --purple: #9333ea;
  --blue: #2563eb;
  --shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
  --radius: 6px;
  --radius-sm: 4px;
}

/* === LIGHT THEME === */
[data-theme="light"] {
  --bg-deep: #f1f5f9;
  --bg-panel: #ffffff;
  --bg-panel-2: #f8fafc;
  --bg-elev: #e2e8f0;
  --border: #cbd5e1;
  --border-soft: #e2e8f0;
  --text: #0f172a;
  --text-dim: #475569;
  --text-faint: #94a3b8;
  --accent: #0284c7;
  --accent-hover: #0369a1;
  --accent-soft: rgba(2, 132, 199, 0.1);
  --orange: #ea580c;
  --orange-soft: rgba(234, 88, 12, 0.1);
  --green: #059669;
  --green-soft: rgba(5, 150, 105, 0.1);
  --red: #dc2626;
  --red-soft: rgba(220, 38, 38, 0.1);
  --yellow: #ca8a04;
  --purple: #7c3aed;
  --blue: #2563eb;
  --shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
  --radius: 6px;
  --radius-sm: 4px;
}
[data-theme="light"] body {
  background: var(--bg-deep);
}
/* Logo me ngjyre me te thelle, te dukshme ne sfond te bardhe */
[data-theme="light"] .topbar-brand {
  background: linear-gradient(135deg, #c2410c 0%, #ea580c 50%, #c2410c 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: none;
}
/* Logs panel - sfond i bardhe ne vend te te erret */
[data-theme="light"] .logs-wrap,
[data-theme="light"] #logs-list,
[data-theme="light"] .logs-container,
[data-theme="light"] .panel-logs,
[data-theme="light"] .file-info {
  background: #ffffff !important;
  color: #1e293b !important;
}
[data-theme="light"] .log-entry,
[data-theme="light"] .log-line {
  background: #ffffff !important;
  color: #1e293b !important;
}
/* Logs ngjyrat sipas tipit (me te thella per sfond te bardhe) */
[data-theme="light"] .log-entry.info,
[data-theme="light"] .log-line.info { color: #0369a1 !important; }
[data-theme="light"] .log-entry.success,
[data-theme="light"] .log-line.success { color: #047857 !important; }
[data-theme="light"] .log-entry.warning,
[data-theme="light"] .log-entry.warn,
[data-theme="light"] .log-line.warning,
[data-theme="light"] .log-line.warn { color: #b45309 !important; }
[data-theme="light"] .log-entry.error,
[data-theme="light"] .log-line.error { color: #b91c1c !important; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  background: var(--bg-deep); color: var(--text);
  font-size: 13px; line-height: 1.4;
  height: 100vh; overflow: hidden;
}
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, select, textarea { font-family: inherit; }
input:focus, select:focus, textarea:focus { outline: none; }

/* LOGIN */
#login-screen {
  position: fixed; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background:
    radial-gradient(ellipse at top, rgba(6, 182, 212, 0.08), transparent 60%),
    radial-gradient(ellipse at bottom, rgba(245, 158, 11, 0.05), transparent 60%),
    var(--bg-deep);
  z-index: 1000;
}
.login-card {
  width: 100%; max-width: 380px;
  background: linear-gradient(180deg, var(--bg-panel) 0%, var(--bg-panel-2) 100%);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 36px 32px;
  box-shadow: var(--shadow);
}
.login-title {
  font-size: 28px; font-weight: 800; letter-spacing: 6px;
  text-align: center;
  background: linear-gradient(135deg, var(--orange) 0%, #fbbf24 50%, var(--orange) 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  margin-bottom: 6px;
}
.login-subtitle {
  text-align: center; color: var(--text-dim); font-size: 12px;
  margin-bottom: 24px; padding-bottom: 18px;
  border-bottom: 1px solid var(--border-soft);
}
.login-field { margin-bottom: 14px; }
.login-field label {
  display: block; font-size: 11px; font-weight: 600;
  letter-spacing: 1.2px; color: var(--text-dim); margin-bottom: 6px;
}
.login-field input {
  width: 100%; padding: 10px 12px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 13px;
}
.login-field input:focus { border-color: var(--accent); }

/* Remember me checkbox — custom styled */
.login-remember {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 4px 0 14px;
  cursor: pointer;
  user-select: none;
  font-size: 12px;
  color: var(--text-dim);
  transition: color 0.15s;
}
.login-remember:hover { color: var(--text); }
.login-remember input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}
.login-remember-box {
  width: 18px; height: 18px;
  flex-shrink: 0;
  background: var(--bg-deep);
  border: 1.5px solid var(--border);
  border-radius: 4px;
  position: relative;
  transition: all 0.15s;
}
.login-remember:hover .login-remember-box { border-color: var(--accent); }
.login-remember input:checked + .login-remember-box {
  background: var(--accent);
  border-color: var(--accent);
}
.login-remember input:checked + .login-remember-box::after {
  content: '';
  position: absolute;
  left: 5px; top: 1px;
  width: 5px; height: 10px;
  border: solid #00141a;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.login-remember-text {
  flex: 1;
  letter-spacing: 0.2px;
}

.login-btn {
  width: 100%; padding: 12px; margin-top: 8px;
  background: var(--accent); color: #00141a;
  font-weight: 700; letter-spacing: 2px; font-size: 13px;
  border-radius: var(--radius-sm);
}
.login-btn:hover { background: var(--accent-hover); }
.login-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.login-error {
  margin-top: 12px; padding: 8px 10px;
  background: var(--red-soft); border: 1px solid var(--red);
  border-radius: var(--radius-sm); color: #fca5a5; font-size: 12px; display: none;
}
.login-error.show { display: block; }
.login-footer {
  margin-top: 22px; padding-top: 18px;
  border-top: 1px solid var(--border-soft);
  text-align: center;
}
.login-footer-text {
  font-style: italic; color: var(--text-dim); font-size: 11px; margin-bottom: 10px;
}
.login-footer-tags {
  display: flex; justify-content: center; gap: 12px;
  font-size: 11px; color: var(--text-dim);
}

/* APP SHELL */
#app-screen { display: none; flex-direction: column; height: 100vh; }
#app-screen.show { display: flex; }

.topbar {
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center;
  background: var(--bg-panel);
  border-bottom: 1px solid var(--border);
  padding: 8px 16px; height: 50px;
  flex-shrink: 0;
}
.topbar-tabs { display: flex; gap: 6px; padding: 0 4px; }

/* ============================================================
   NAVBAR TABS — Glass Morphism + Automotive accent
   Each tab has its own color identity (cyan/orange/purple/red)
   ============================================================ */
.tab-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px 6px 13px;
  height: 36px;
  font-size: 11.5px; font-weight: 800; letter-spacing: 1.4px;
  color: var(--text-dim);
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-family: inherit;
}

/* Icon + label structure */
.tab-icon {
  font-size: 15px;
  filter: grayscale(0.4) brightness(0.85);
  transition: all 0.25s ease;
  z-index: 2;
  position: relative;
}
.tab-label {
  z-index: 2;
  position: relative;
  transition: all 0.25s ease;
}

/* Glow layer (decorative, behind content) */
.tab-glow {
  position: absolute;
  inset: 0;
  border-radius: 8px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
  z-index: 1;
}

/* Bottom accent line (animated underline) */
.tab-btn::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) scaleX(0);
  width: calc(100% - 24px);
  height: 2px;
  border-radius: 2px;
  transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 2;
}

/* === HOVER STATES === */
.tab-btn:hover {
  color: var(--text);
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(255, 255, 255, 0.15);
  transform: translateY(-1px);
}
.tab-btn:hover .tab-icon {
  filter: grayscale(0) brightness(1.1);
  transform: scale(1.1);
}
.tab-btn:hover::after { transform: translateX(-50%) scaleX(1); }

/* === COLOR VARIANTS === */
/* Cyan - Workspace */
.tab-btn[data-tab-color="cyan"]:hover { color: #67e8f9; }
.tab-btn[data-tab-color="cyan"]:hover .tab-glow {
  opacity: 1;
  background: radial-gradient(circle at center, rgba(6, 182, 212, 0.20) 0%, transparent 70%);
}
.tab-btn[data-tab-color="cyan"]::after { background: linear-gradient(90deg, transparent, #06b6d4, transparent); }

/* Orange - Tools */
.tab-btn[data-tab-color="orange"]:hover { color: #fbbf24; }
.tab-btn[data-tab-color="orange"]:hover .tab-glow {
  opacity: 1;
  background: radial-gradient(circle at center, rgba(245, 158, 11, 0.20) 0%, transparent 70%);
}
.tab-btn[data-tab-color="orange"]::after { background: linear-gradient(90deg, transparent, #f59e0b, transparent); }

/* Purple - Info */
.tab-btn[data-tab-color="purple"]:hover { color: #c4b5fd; }
.tab-btn[data-tab-color="purple"]:hover .tab-glow {
  opacity: 1;
  background: radial-gradient(circle at center, rgba(139, 92, 246, 0.20) 0%, transparent 70%);
}
.tab-btn[data-tab-color="purple"]::after { background: linear-gradient(90deg, transparent, #8b5cf6, transparent); }

/* Red - Admin */
.tab-btn[data-tab-color="red"]:hover { color: #fca5a5; }
.tab-btn[data-tab-color="red"]:hover .tab-glow {
  opacity: 1;
  background: radial-gradient(circle at center, rgba(239, 68, 68, 0.20) 0%, transparent 70%);
}
.tab-btn[data-tab-color="red"]::after { background: linear-gradient(90deg, transparent, #ef4444, transparent); }

/* === ACTIVE STATE — strong, glowing === */
.tab-btn.active {
  color: var(--text);
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.06);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.08),
    0 4px 14px rgba(0, 0, 0, 0.25);
}
.tab-btn.active .tab-icon {
  filter: grayscale(0) brightness(1.2);
  transform: scale(1.15);
}
.tab-btn.active::after { transform: translateX(-50%) scaleX(1); height: 2.5px; }

/* Active color glow */
.tab-btn.active[data-tab-color="cyan"] {
  color: #22d3ee;
  background: linear-gradient(180deg, rgba(6, 182, 212, 0.15) 0%, rgba(6, 182, 212, 0.04) 100%);
  border-color: rgba(6, 182, 212, 0.45);
  box-shadow: inset 0 1px 0 rgba(6, 182, 212, 0.15), 0 4px 14px rgba(6, 182, 212, 0.20);
}
.tab-btn.active[data-tab-color="cyan"] .tab-glow {
  opacity: 1;
  background: radial-gradient(circle at 50% 100%, rgba(6, 182, 212, 0.30) 0%, transparent 60%);
}

.tab-btn.active[data-tab-color="orange"] {
  color: #fbbf24;
  background: linear-gradient(180deg, rgba(245, 158, 11, 0.15) 0%, rgba(245, 158, 11, 0.04) 100%);
  border-color: rgba(245, 158, 11, 0.45);
  box-shadow: inset 0 1px 0 rgba(245, 158, 11, 0.15), 0 4px 14px rgba(245, 158, 11, 0.20);
}
.tab-btn.active[data-tab-color="orange"] .tab-glow {
  opacity: 1;
  background: radial-gradient(circle at 50% 100%, rgba(245, 158, 11, 0.30) 0%, transparent 60%);
}

.tab-btn.active[data-tab-color="purple"] {
  color: #c4b5fd;
  background: linear-gradient(180deg, rgba(139, 92, 246, 0.15) 0%, rgba(139, 92, 246, 0.04) 100%);
  border-color: rgba(139, 92, 246, 0.45);
  box-shadow: inset 0 1px 0 rgba(139, 92, 246, 0.15), 0 4px 14px rgba(139, 92, 246, 0.20);
}
.tab-btn.active[data-tab-color="purple"] .tab-glow {
  opacity: 1;
  background: radial-gradient(circle at 50% 100%, rgba(139, 92, 246, 0.30) 0%, transparent 60%);
}

.tab-btn.active[data-tab-color="red"] {
  color: #fca5a5;
  background: linear-gradient(180deg, rgba(239, 68, 68, 0.15) 0%, rgba(239, 68, 68, 0.04) 100%);
  border-color: rgba(239, 68, 68, 0.45);
  box-shadow: inset 0 1px 0 rgba(239, 68, 68, 0.15), 0 4px 14px rgba(239, 68, 68, 0.20);
}
.tab-btn.active[data-tab-color="red"] .tab-glow {
  opacity: 1;
  background: radial-gradient(circle at 50% 100%, rgba(239, 68, 68, 0.30) 0%, transparent 60%);
}

/* Active pulse animation - subtle breathing effect */
.tab-btn.active::before {
  content: "";
  position: absolute;
  top: 6px; right: 8px;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 8px currentColor;
  animation: tab-pulse 2s ease-in-out infinite;
  z-index: 3;
}
@keyframes tab-pulse {
  0%, 100% { opacity: 0.85; transform: scale(1); }
  50% { opacity: 0.35; transform: scale(0.7); }
}

.topbar-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  transition: transform 0.3s ease;
  user-select: none;
}
.topbar-brand:hover { transform: scale(1.02); }
.brand-logo {
  flex-shrink: 0;
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  filter: drop-shadow(0 2px 8px rgba(6, 182, 212, 0.25));
}
.topbar-brand:hover .brand-logo {
  transform: rotate(-5deg) scale(1.05);
}
.brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}
.brand-title {
  font-size: 19px;
  font-weight: 900;
  letter-spacing: 4px;
  font-family: Impact, "Arial Black", sans-serif;
  background: linear-gradient(135deg, var(--orange) 0%, #fbbf24 50%, var(--orange) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.brand-subtitle {
  font-size: 8.5px;
  font-weight: 700;
  letter-spacing: 5.2px;
  color: #06b6d4;
  margin-top: 5px;
  font-family: Arial, sans-serif;
}

.topbar-right {
  display: flex; align-items: center; gap: 8px;
  justify-self: end;
}
.sub-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: 4px;
  font-size: 11px; font-weight: 600;
  background: var(--bg-elev); border: 1px solid var(--border);
}
.sub-badge.tokens { color: var(--green); border-color: rgba(16, 185, 129, 0.3); }
.sub-badge.tokens.warn { color: var(--orange); border-color: rgba(245, 158, 11, 0.3); }
.sub-badge.tokens.danger { color: var(--red); border-color: rgba(239, 68, 68, 0.3); }
.sub-badge.daily { color: var(--text-dim); }
.sub-badge.expiry { color: var(--text-faint); }
.sub-badge.expiry.warn { color: #fcd34d; background: #451a03; border-color: var(--orange); font-weight: 700; }
.sub-badge.expiry.expired {
  color: #fca5a5; background: #7f1d1d; border-color: var(--red); font-weight: 700;
  animation: pulse 1.5s infinite;
}

.status-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: 20px; font-size: 11px; font-weight: 700;
  letter-spacing: 1px; color: var(--green);
}
.status-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }

/* === USER CARD — avatar + name + role + online dot === */
.user-card {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 4px 12px 4px 4px;
  background: linear-gradient(135deg, rgba(6, 182, 212, 0.08) 0%, rgba(245, 158, 11, 0.06) 100%);
  border: 1px solid rgba(6, 182, 212, 0.25);
  border-radius: 22px;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  user-select: none;
  position: relative;
}
.user-card:hover {
  border-color: rgba(6, 182, 212, 0.55);
  background: linear-gradient(135deg, rgba(6, 182, 212, 0.14) 0%, rgba(245, 158, 11, 0.10) 100%);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(6, 182, 212, 0.20);
}
.user-card:active { transform: translateY(0); }
.user-card-chev {
  color: var(--text-faint);
  margin-left: 2px;
  transition: transform 0.2s;
  flex-shrink: 0;
}
.user-card.is-open .user-card-chev { transform: rotate(180deg); color: var(--accent); }
.user-avatar-wrap {
  position: relative;
  flex-shrink: 0;
}
.user-avatar {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #06b6d4 0%, #f59e0b 100%);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 12px;
  color: #0a0e1a;
  letter-spacing: 0.5px;
  box-shadow: 0 2px 8px rgba(6, 182, 212, 0.30);
  font-family: inherit;
}
.user-online-dot {
  position: absolute;
  bottom: -1px; right: -1px;
  width: 10px; height: 10px;
  background: #10b981;
  border: 2px solid var(--bg);
  border-radius: 50%;
  box-shadow: 0 0 8px #10b981;
}
.user-online-dot::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: 50%;
  background: #10b981;
  animation: user-pulse-dot 2s ease-in-out infinite;
}
@keyframes user-pulse-dot {
  0%, 100% { transform: scale(1); opacity: 0.9; }
  50% { transform: scale(1.8); opacity: 0; }
}
.user-info {
  line-height: 1.15;
  display: flex;
  flex-direction: column;
}
.user-name {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text);
}
.user-role-text {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: var(--orange);
  text-transform: uppercase;
}
.user-role-text[data-role="staff"],
.user-role-text[data-role="client"] {
  color: var(--accent);
}

/* === LOGOUT BUTTON — power-off style === */
.logout-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: rgba(239, 68, 68, 0.08);
  border: 1px solid rgba(239, 68, 68, 0.30);
  border-radius: 8px;
  color: #fca5a5;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  cursor: pointer;
  transition: all 0.2s ease;
  font-family: inherit;
}
.logout-btn:hover {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(239, 68, 68, 0.6);
  color: #fff;
  box-shadow: 0 0 12px rgba(239, 68, 68, 0.30);
  transform: translateY(-1px);
}
.logout-btn:active { transform: translateY(0); }
.logout-btn svg { flex-shrink: 0; }

/* ============================================================
   PROFILE DROPDOWN MENU — opens when user-card is clicked
   Uses position:fixed so it never gets clipped by parent overflow
   ============================================================ */
.profile-menu {
  position: fixed;
  top: 56px;       /* below 50px topbar + 6px breathing room */
  right: 16px;
  min-width: 240px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4), 0 4px 12px rgba(6, 182, 212, 0.10);
  padding: 6px;
  z-index: 99999;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s linear 0.18s;
}
.profile-menu.show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s linear 0s;
}
.profile-menu-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
}
.profile-menu-avatar {
  width: 38px; height: 38px;
  border-radius: 50%;
  background: linear-gradient(135deg, #06b6d4 0%, #f59e0b 100%);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 13px;
  color: #0a0e1a;
  letter-spacing: 0.5px;
  box-shadow: 0 2px 10px rgba(6, 182, 212, 0.30);
  flex-shrink: 0;
}
.profile-menu-info { flex: 1; min-width: 0; }
.profile-menu-name {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.profile-menu-meta {
  font-size: 9.5px;
  letter-spacing: 0.5px;
  color: var(--text-faint);
  margin-top: 2px;
  text-transform: uppercase;
  font-weight: 700;
}
.profile-menu-divider {
  height: 1px;
  background: var(--border);
  margin: 4px 6px;
}
.profile-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 12px;
  background: transparent;
  border: none;
  border-radius: 7px;
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  transition: all 0.12s ease;
}
.profile-menu-item:hover {
  background: rgba(6, 182, 212, 0.08);
  color: var(--accent);
}
.profile-menu-icon {
  font-size: 14px;
  width: 20px;
  text-align: center;
  flex-shrink: 0;
}
.profile-menu-label { flex: 1; }
.profile-menu-logout {
  color: #fca5a5;
}
.profile-menu-logout:hover {
  background: rgba(239, 68, 68, 0.10);
  color: #fff;
}

/* ============================================================
   PROFILE / PASSWORD / SERVICE — modal helpers
   ============================================================ */
.modal-hint {
  font-size: 10px;
  color: var(--text-faint);
  margin: -10px 0 14px 0;
  font-style: italic;
}
.profile-preview {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 16px;
}
.profile-preview-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, #06b6d4 0%, #f59e0b 100%);
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 13px;
  color: #0a0e1a;
  letter-spacing: 0.5px;
  flex-shrink: 0;
}
.profile-preview-info { flex: 1; min-width: 0; }
.profile-preview-label {
  font-size: 9px;
  letter-spacing: 1px;
  color: var(--text-faint);
  text-transform: uppercase;
  font-weight: 700;
}
.profile-preview-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  margin-top: 1px;
}

/* Password strength indicator */
.pass-strength {
  margin: -8px 0 12px 0;
}
.pass-strength-bar {
  height: 4px;
  background: var(--bg-deep);
  border-radius: 2px;
  overflow: hidden;
}
.pass-strength-fill {
  height: 100%;
  width: 0%;
  background: var(--text-faint);
  transition: all 0.25s ease;
  border-radius: 2px;
}
.pass-strength-fill[data-level="weak"]   { background: #ef4444; width: 33%; }
.pass-strength-fill[data-level="medium"] { background: #f59e0b; width: 66%; }
.pass-strength-fill[data-level="strong"] { background: #10b981; width: 100%; }
.pass-strength-label {
  font-size: 9.5px;
  letter-spacing: 0.5px;
  color: var(--text-faint);
  margin-top: 4px;
  font-weight: 700;
  text-transform: uppercase;
}

/* Service info modal — logo upload */
.service-logo-row {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 16px;
}
.service-logo-preview {
  width: 76px; height: 76px;
  background: var(--bg-deep);
  border: 2px dashed var(--border);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  overflow: hidden;
  position: relative;
}
.service-logo-preview img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
.service-logo-preview.has-logo {
  border-style: solid;
  border-color: rgba(6, 182, 212, 0.4);
  background: rgba(6, 182, 212, 0.04);
}
.service-logo-placeholder {
  font-size: 32px;
  opacity: 0.4;
}
.service-logo-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
  min-width: 0;
}
.service-logo-actions .modal-btn {
  width: auto;
  align-self: flex-start;
  padding: 7px 14px;
  font-size: 11px;
}
.service-info-note {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  padding: 10px 12px;
  background: rgba(6, 182, 212, 0.06);
  border: 1px solid rgba(6, 182, 212, 0.20);
  border-radius: 8px;
  font-size: 10.5px;
  color: var(--text-dim);
  line-height: 1.5;
  margin-bottom: 14px;
}
.service-info-note > span:first-child {
  font-size: 14px;
  flex-shrink: 0;
}

.action-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 16px;
  background: var(--bg-panel-2);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.action-select {
  padding: 6px 10px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 12px;
  min-width: 140px;
}
.action-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text);
  font-size: 12px; font-weight: 600; letter-spacing: 0.5px;
}
.action-btn:hover { background: var(--bg-elev); border-color: var(--accent); }

.action-bar-spacer { flex: 1; }
.file-status {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11px; color: var(--text-dim);
}
.file-status-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--text-faint); }
.file-status.has-file .file-status-dot { background: var(--green); }
.file-status.has-file { color: var(--green); }
.method-pill {
  padding: 2px 8px; border-radius: 10px;
  font-size: 10px; font-weight: 700; letter-spacing: 0.5px;
}
.method-pill.OBD { background: rgba(37, 99, 235, 0.2); color: #60a5fa; border: 1px solid #2563eb; }
.method-pill.Bench { background: rgba(234, 88, 12, 0.2); color: #fb923c; border: 1px solid #ea580c; }
.method-pill.Boot { background: rgba(147, 51, 234, 0.2); color: #c084fc; border: 1px solid #9333ea; }

.main { flex: 1; overflow: hidden; display: flex; flex-direction: column; }
.tab-content { display: none; flex: 1; overflow: hidden; }
.tab-content.active { display: flex; flex-direction: column; }

.panel {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.panel-header {
  padding: 10px 14px;
  background: var(--bg-panel-2);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  flex-shrink: 0;
  gap: 10px;
}
/* === PERMISSION LIST (user create + edit) === */
.perm-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 4px 0;
}
.perm-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 8px 10px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 7px;
  cursor: pointer;
  transition: all 0.15s ease;
}
.perm-row:hover {
  border-color: rgba(6, 182, 212, 0.4);
  background: var(--bg-panel-2);
}
.perm-row.checked {
  background: rgba(16, 185, 129, 0.06);
  border-color: rgba(16, 185, 129, 0.35);
}
.perm-row.disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.perm-row input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
  cursor: pointer;
  accent-color: #10b981;
}
.perm-icon {
  font-size: 14px;
  flex-shrink: 0;
}
.perm-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
  flex: 1;
}
.perm-label {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
}
.perm-desc {
  font-size: 9.5px;
  color: var(--text-faint);
  line-height: 1.3;
}
.perm-hint {
  font-size: 10px;
  color: var(--text-faint);
  font-style: italic;
  margin-top: 6px;
  padding: 0 2px;
}

/* ============================================================
   ACCESS TREE — unified tabs + permissions widget
   ============================================================ */
.access-tree-wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Quick Setup Templates */
.access-templates {
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.06) 0%, rgba(6, 182, 212, 0.04) 100%);
  border: 1px solid rgba(245, 158, 11, 0.20);
  border-radius: 8px;
  padding: 10px 12px;
}
.access-templates-label {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.5px;
  color: var(--orange);
  margin-bottom: 8px;
}
.access-templates-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6px;
}
.access-template-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 8px 6px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s ease;
  font-family: inherit;
  color: var(--text-dim);
}
.access-template-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: var(--bg-panel-2);
  transform: translateY(-1px);
}
.access-template-btn.active {
  background: rgba(6, 182, 212, 0.10);
  border-color: var(--accent);
  color: var(--accent);
}
.access-template-icon { font-size: 18px; }
.access-template-label {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.5px;
}

/* Accordion sections */
.access-tree {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.access-section {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  transition: border-color 0.2s ease;
}
.access-section.on { border-color: rgba(6, 182, 212, 0.30); }
.access-section.off { opacity: 0.55; }

/* Section colors when ON */
.access-section.on[data-color="cyan"]   { border-color: rgba(6, 182, 212, 0.35); }
.access-section.on[data-color="orange"] { border-color: rgba(245, 158, 11, 0.35); }
.access-section.on[data-color="purple"] { border-color: rgba(139, 92, 246, 0.35); }

.access-section-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  cursor: default;
  background: var(--bg-panel-2);
  border-bottom: 1px solid var(--border);
}
.access-section.off .access-section-head { background: var(--bg-elev); border-bottom-color: transparent; }

/* Toggle switch (modern iOS-style) */
.access-toggle {
  position: relative;
  display: inline-block;
  flex-shrink: 0;
  cursor: pointer;
}
.access-toggle input {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
}
.access-toggle-track {
  display: block;
  width: 32px; height: 18px;
  background: var(--bg-deep);
  border-radius: 18px;
  border: 1px solid var(--border);
  position: relative;
  transition: all 0.2s ease;
}
.access-toggle-thumb {
  position: absolute;
  top: 1px; left: 1px;
  width: 14px; height: 14px;
  background: var(--text-faint);
  border-radius: 50%;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.access-toggle input:checked ~ .access-toggle-track {
  background: var(--accent);
  border-color: var(--accent);
}
.access-toggle input:checked ~ .access-toggle-track .access-toggle-thumb {
  left: 15px;
  background: #fff;
}

.access-section-info {
  flex: 1;
  min-width: 0;
}
.access-section-title {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1px;
  color: var(--text);
}
.access-section-icon { font-size: 14px; }
.access-section.off .access-section-title { color: var(--text-faint); }
.access-section-desc {
  font-size: 10px;
  color: var(--text-faint);
  margin-top: 2px;
}
.access-status {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1.2px;
  padding: 2px 7px;
  border-radius: 10px;
  background: var(--bg-deep);
  color: var(--text-faint);
}
.access-section.on .access-status {
  background: rgba(16, 185, 129, 0.15);
  color: #34d399;
}

/* Section body — nested permissions */
.access-section-body {
  padding: 8px 10px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.access-section.off .access-section-body {
  opacity: 0.4;
  pointer-events: none;
  filter: grayscale(0.5);
}
.access-section-empty {
  padding: 8px 10px;
  font-size: 10px;
  color: var(--text-faint);
  font-style: italic;
  text-align: center;
}

/* Individual permission row inside section */
.access-perm {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 7px 9px;
  background: var(--bg-deep);
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.15s ease;
}
.access-perm:hover { background: var(--bg-panel); border-color: var(--border); }
.access-perm.checked {
  background: rgba(16, 185, 129, 0.06);
  border-color: rgba(16, 185, 129, 0.30);
}
.access-perm input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
  cursor: pointer;
  accent-color: #10b981;
}
.access-perm-icon {
  font-size: 13px;
  flex-shrink: 0;
  margin-top: 1px;
}
.access-perm-text {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
  flex: 1;
}
.access-perm-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
}
.access-perm-desc {
  font-size: 9.5px;
  color: var(--text-faint);
  line-height: 1.3;
}
.panel-title {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 11.5px;
  font-weight: 800;
  letter-spacing: 1.8px;
  color: var(--accent);
  position: relative;
  padding-left: 11px;
}
.panel-title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 16px;
  background: linear-gradient(180deg, var(--accent) 0%, #0891b2 100%);
  border-radius: 2px;
}

/* Color variants — set via data-accent="..." */
.panel-title[data-accent="orange"] { color: #fbbf24; }
.panel-title[data-accent="orange"]::before {
  background: linear-gradient(180deg, #f59e0b 0%, #d97706 100%);
}
.panel-title[data-accent="cyan"] { color: #22d3ee; }
.panel-title[data-accent="cyan"]::before {
  background: linear-gradient(180deg, #06b6d4 0%, #0891b2 100%);
}
.panel-title[data-accent="green"] { color: #34d399; }
.panel-title[data-accent="green"]::before {
  background: linear-gradient(180deg, #10b981 0%, #059669 100%);
}
.panel-title[data-accent="purple"] { color: #c4b5fd; }
.panel-title[data-accent="purple"]::before {
  background: linear-gradient(180deg, #8b5cf6 0%, #7c3aed 100%);
}
.panel-title[data-accent="red"] { color: #fca5a5; }
.panel-title[data-accent="red"]::before {
  background: linear-gradient(180deg, #ef4444 0%, #dc2626 100%);
}

/* LIVE indicator (used on STAFF ACTIVITY) */
.panel-title-live {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-left: 8px;
  padding: 2px 7px;
  background: rgba(16, 185, 129, 0.12);
  border: 1px solid rgba(16, 185, 129, 0.25);
  border-radius: 10px;
  font-size: 8px;
  font-weight: 800;
  letter-spacing: 1px;
  color: #10b981;
}
.panel-title-live::before {
  content: "";
  width: 5px; height: 5px;
  background: #10b981;
  border-radius: 50%;
  box-shadow: 0 0 6px #10b981;
  animation: panel-live-pulse 1.5s ease-in-out infinite;
}
@keyframes panel-live-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.7); }
}
.panel-meta { font-size: 11px; color: var(--text-dim); }

/* === BRAND STATS PILLS — replaces panel-meta in workspace === */
/* When panel header has only stats (no title), make it more compact */
.panel-header-stats-only {
  padding: 7px 12px;
  justify-content: flex-start;
}
.brand-stats-pills {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.panel-header-stats-only .brand-stats-pills {
  justify-content: flex-start;
  flex: 1;
}
.brand-stat-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 8px;
  border-radius: 14px;
  transition: all 0.2s ease;
  cursor: default;
}
.brand-stat-pill:hover {
  transform: translateY(-1px);
  filter: brightness(1.15);
}
.brand-stat-icon {
  font-size: 12px;
  line-height: 1;
  flex-shrink: 0;
}
.brand-stat-text {
  display: flex;
  flex-direction: column;
  line-height: 1;
}
.brand-stat-num {
  font-size: 12px;
  font-weight: 800;
  font-family: monospace;
  letter-spacing: 0.3px;
  line-height: 1.1;
}
.brand-stat-label {
  font-size: 7.5px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-top: 1px;
}

/* Color variants */
.brand-stat-cyan {
  background: rgba(6, 182, 212, 0.08);
  border: 1px solid rgba(6, 182, 212, 0.25);
}
.brand-stat-cyan .brand-stat-num { color: #22d3ee; }
.brand-stat-cyan .brand-stat-label { color: #06b6d4; }

.brand-stat-orange {
  background: rgba(245, 158, 11, 0.08);
  border: 1px solid rgba(245, 158, 11, 0.25);
}
.brand-stat-orange .brand-stat-num { color: #fbbf24; }
.brand-stat-orange .brand-stat-label { color: #f59e0b; }

.brand-stat-green {
  background: rgba(16, 185, 129, 0.08);
  border: 1px solid rgba(16, 185, 129, 0.25);
  opacity: 0.6;
}
.brand-stat-green.has-ready {
  opacity: 1;
  border-color: rgba(16, 185, 129, 0.4);
  box-shadow: 0 0 8px rgba(16, 185, 129, 0.15);
}
.brand-stat-green .brand-stat-icon { color: #10b981; }
.brand-stat-green .brand-stat-num { color: #34d399; }
.brand-stat-green .brand-stat-label { color: #10b981; }

.brand-stat-purple {
  background: rgba(139, 92, 246, 0.08);
  border: 1px solid rgba(139, 92, 246, 0.25);
}
.brand-stat-purple .brand-stat-num { color: #c4b5fd; }
.brand-stat-purple .brand-stat-label { color: #a78bfa; }
.panel-body { flex: 1; padding: 14px; overflow-y: auto; }
.panel-empty {
  display: flex; align-items: center; justify-content: center;
  height: 100%; color: var(--text-faint); font-size: 12px;
  text-align: center; padding: 20px;
}

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--bg-deep); }
::-webkit-scrollbar-thumb { background: var(--bg-elev); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--border); }

/* WORKSPACE */
.workspace-grid {
  flex: 1;
  display: grid; grid-template-columns: 2.6fr 1fr;
  gap: 12px; padding: 12px 16px 0;
  overflow: hidden; min-height: 0;
}

.ws-header-actions {
  display: flex; gap: 6px;
}
.ws-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 11px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.8px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg-elev);
  color: var(--text-dim);
  transition: all 0.12s;
}
.ws-btn span { font-size: 13px; }
.ws-btn:hover { transform: translateY(-1px); }
.ws-btn-load { background: var(--accent-soft); color: var(--accent); border-color: var(--accent); }
.ws-btn-load:hover { background: var(--accent); color: #00141a; }
.ws-btn-save { background: rgba(16, 185, 129, 0.15); color: var(--green); border-color: var(--green); }
.ws-btn-save:hover { background: var(--green); color: #fff; }
.ws-btn-clear { background: var(--bg-elev); color: var(--text-dim); border-color: var(--border); }
.ws-btn-clear:hover { background: var(--red); color: #fff; border-color: var(--red); }
.workspace-foot-grid {
  display: grid; grid-template-columns: 1.85fr 1fr;
  gap: 12px; padding: 8px 16px 12px;
  flex-shrink: 0;
  height: 110px;
}
.workspace-foot-grid .console {
  margin: 0; height: 100%;
}
.ws-foot-info {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 14px;
  display: flex; flex-direction: column; justify-content: center;
  font-size: 11px;
  overflow: hidden;
}
.ws-foot-info-empty {
  text-align: center; color: var(--text-faint);
  font-style: italic; font-size: 12px;
}
.ws-foot-info.has-file {
  border-color: var(--green);
}
.ws-foot-info-row {
  display: flex; align-items: center; gap: 8px;
  padding: 2px 0;
}
.ws-foot-info-label {
  color: var(--text-faint);
  font-weight: 700; letter-spacing: 0.5px;
  min-width: 70px;
  text-transform: uppercase;
  font-size: 10px;
}
.ws-foot-info-value {
  color: var(--text);
  font-family: monospace;
  word-break: break-all;
  font-size: 11px;
}
.ws-foot-info-value strong { color: var(--green); font-weight: 700; }
#tab-workspace {
  position: relative;
}
#tab-workspace.drag-over::before {
  content: "📂 Lësho file-in këtu për të ngarkuar";
  position: absolute; inset: 12px 16px;
  display: flex; align-items: center; justify-content: center;
  background: var(--accent-soft);
  border: 2px dashed var(--accent);
  border-radius: var(--radius);
  color: var(--accent);
  font-size: 18px; font-weight: 700; letter-spacing: 1px;
  z-index: 10;
  pointer-events: none;
}

.method-filter-bar {
  display: flex; gap: 4px;
  padding: 6px 8px;
  background: var(--bg-panel-2);
  border-bottom: 1px solid var(--border-soft);
  flex-shrink: 0;
}
.method-filter-btn {
  flex: 1; padding: 4px 4px;
  border-radius: 5px; font-size: 10px; font-weight: 700;
  border: 1px solid var(--border);
  background: var(--bg-elev); color: var(--text-faint);
  transition: all 0.15s;
}
.method-filter-btn[data-mf="All"].active { background: rgba(8, 145, 178, 0.2); color: var(--accent); border-color: var(--accent); }
.method-filter-btn[data-mf="OBD"].active { background: rgba(37, 99, 235, 0.2); color: #60a5fa; border-color: #2563eb; }
.method-filter-btn[data-mf="Bench"].active { background: rgba(234, 88, 12, 0.2); color: #fb923c; border-color: #ea580c; }
.method-filter-btn[data-mf="Boot"].active { background: rgba(147, 51, 234, 0.2); color: #c084fc; border-color: #9333ea; }
.method-filter-btn[data-mf="BDM"].active { background: rgba(16, 185, 129, 0.2); color: #34d399; border-color: #10b981; }
.method-filter-btn[data-mf="JTAG"].active { background: rgba(234, 179, 8, 0.2); color: #fbbf24; border-color: #eab308; }

.solutions-list { padding: 8px; display: grid; grid-template-columns: 1fr 1fr; gap: 6px; align-content: start; }
.solutions-list-empty {
  grid-column: 1 / -1;
  display: flex; align-items: center; justify-content: center;
  min-height: 100px; color: var(--text-faint); font-size: 12px;
  padding: 30px;
}
.solution-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px;
  background: var(--bg-panel-2);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-sm);
  transition: all 0.15s;
}
.solution-item:hover { border-color: var(--border); }
.solution-info { flex: 1; min-width: 0; }
.solution-name-row {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.solution-name { font-size: 12px; color: var(--text); font-weight: 700; letter-spacing: 0.5px; }
.solution-meta { font-size: 10px; color: var(--text-dim); margin-top: 3px; display: flex; align-items: center; gap: 5px; flex-wrap: wrap; }
.solution-tag {
  display: inline-block; padding: 1px 5px;
  background: var(--accent-soft); color: var(--accent);
  font-size: 9px; font-weight: 700; border-radius: 3px;
}

/* === Tool pill (KESS/KTAG/FC200/etc) === */
.sol-tool {
  display: inline-block;
  padding: 1px 5px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  background: rgba(6, 182, 212, 0.10);
  color: #06b6d4;
  border: 1px solid rgba(6, 182, 212, 0.25);
  border-radius: 3px;
  font-family: monospace;
  text-transform: uppercase;
}

.sol-meta-sep { color: var(--text-faint); opacity: 0.5; }

/* === File size pill (dynamic — shows current workspace file size) === */
.sol-filesize {
  display: inline-block;
  padding: 1px 6px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.3px;
  background: rgba(245, 158, 11, 0.10);
  color: #fbbf24;
  border: 1px solid rgba(245, 158, 11, 0.25);
  border-radius: 3px;
  font-family: monospace;
}

/* === Stage badge — for performance solutions (defaultOff: true) === */
.sol-stage-badge {
  display: inline-flex;
  align-items: center;
  font-size: 8.5px;
  font-weight: 800;
  letter-spacing: 0.7px;
  padding: 2px 7px;
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.18) 0%, rgba(220, 38, 38, 0.18) 100%);
  color: #fbbf24;
  border: 1px solid rgba(245, 158, 11, 0.40);
  cursor: help;
  line-height: 1;
}
.solution-item.is-stage {
  border-left: 3px solid #f59e0b;
}

.sol-switch {
  flex-shrink: 0;
  position: relative;
  width: 60px; height: 24px;
  border-radius: 4px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; letter-spacing: 1px;
  transition: all 0.15s;
  border: 1px solid;
  user-select: none;
}
.sol-switch.on {
  background: linear-gradient(180deg, #22c55e 0%, #16a34a 100%);
  color: #052e16;
  border-color: #166534;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.3), 0 1px 2px rgba(0,0,0,0.4);
}
.sol-switch.off {
  background: linear-gradient(180deg, #475569 0%, #334155 100%);
  color: #94a3b8;
  border-color: #1e293b;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 1px 2px rgba(0,0,0,0.4);
}
.sol-switch:hover { transform: translateY(-1px); }

.brand-list { padding: 0; }
.brand-item {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 12px;
  border-bottom: 1px solid var(--border-soft);
  cursor: pointer; transition: background 0.1s;
}
.brand-item:hover { background: var(--bg-panel-2); }
.brand-item.selected { background: var(--accent-soft); }
.brand-logo {
  width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  background: #fff; border-radius: 4px; padding: 3px;
}
.brand-logo img {
  max-width: 100%; max-height: 100%;
  object-fit: contain;
}
.brand-logo-fallback {
  font-size: 18px;
}
.brand-name { flex: 1; font-size: 13.5px; font-weight: 700; letter-spacing: 0.4px; }
.brand-count {
  background: var(--bg-elev); color: var(--text-dim);
  padding: 2px 8px; border-radius: 9px; font-size: 10.5px; font-weight: 700;
  margin-right: 3px;
}
.brand-count-ready {
  background: var(--accent-soft);
  color: var(--accent);
}
.brand-play {
  width: 24px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  background: var(--accent); color: #00141a;
  border-radius: 4px; font-size: 11px;
}
.brand-play:hover { background: var(--accent-hover); }
.ecu-item {
  padding: 6px 12px 6px 28px;
  font-size: 11px; color: var(--text-dim);
  border-bottom: 1px solid var(--border-soft);
  cursor: pointer;
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
}
/* First child = ECU name span — takes priority, can shrink with ellipsis if needed */
.ecu-item > span:first-child {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  flex: 1 1 auto;
  min-width: 0;
}
.ecu-item:hover { background: var(--bg-panel-2); color: var(--text); }
.ecu-item.selected { background: var(--accent-soft); color: var(--accent); }
.ecu-item.ecu-empty { opacity: 0.5; }
.ecu-item.ecu-empty:hover { opacity: 1; }
.ecu-item.ecu-empty.selected { opacity: 1; }
.ecu-mfr { font-size: 9px; color: var(--text-faint); margin-left: 5px; font-weight: 600; }
.ecu-sols {
  display: flex; gap: 2px; flex-wrap: wrap; justify-content: flex-end; align-items: center;
  flex: 0 1 auto;
  max-width: 55%;
  min-width: 0;
}
.ecu-sol {
  font-size: 6px; padding: 1px 3px; border-radius: 2px;
  background: var(--bg-elev); color: var(--text-dim);
  letter-spacing: 0.1px;
  white-space: nowrap;
  line-height: 1.3;
  font-weight: 600;
}

.workspace-foot {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 16px 0;
  flex-shrink: 0;
}
.drop-zone {
  flex: 1; padding: 14px;
  background: var(--bg-panel);
  border: 1px dashed var(--border);
  border-radius: var(--radius);
  text-align: center;
  font-size: 12px; font-weight: 600; letter-spacing: 1px;
  color: var(--text-dim);
  transition: all 0.15s; cursor: pointer;
}
.drop-zone.drag-over, .drop-zone.has-file {
  border-color: var(--accent); background: var(--accent-soft); color: var(--accent);
}
.icon-btn {
  width: 38px; height: 38px;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-panel); border: 1px solid var(--border);
  border-radius: var(--radius); color: var(--text); font-size: 14px;
}
.icon-btn.danger { background: var(--red); border-color: var(--red); color: #fff; }
.icon-btn.success { background: var(--green); border-color: var(--green); color: #fff; }
.icon-btn:hover { transform: translateY(-1px); }

.console {
  margin: 8px 16px 12px;
  background: #060d18;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 10px 14px;
  font-family: "JetBrains Mono", "Courier New", monospace;
  font-size: 11px; line-height: 1.7;
  height: 100px;
  overflow-y: auto;
  flex-shrink: 0;
  position: relative;
}
.console-clear {
  position: absolute; top: 8px; right: 12px;
  font-size: 10px; color: var(--text-dim); letter-spacing: 1px; font-weight: 700;
}
.console-clear:hover { color: var(--text); }
.log-line { display: flex; gap: 8px; }
.log-time { color: var(--text-faint); }
.log-msg.success { color: var(--green); }
.log-msg.info { color: var(--accent); }
.log-msg.warn { color: var(--yellow); }
.log-msg.error { color: var(--red); }

/* DTC */
/* ===== DTC Manager — sub-tabs ===== */
.dtc-subtabs {
  display: flex; gap: 4px;
  padding: 12px 16px 0;
  flex-shrink: 0;
}
.dtc-subtab-btn {
  padding: 8px 16px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-bottom: none;
  border-radius: var(--radius) var(--radius) 0 0;
  color: var(--text-dim);
  font-size: 11px; font-weight: 700; letter-spacing: 1px;
  transition: all 0.12s;
}
.dtc-subtab-btn:hover { color: var(--text); }
.dtc-subtab-btn.active {
  background: var(--bg-panel);
  color: var(--accent);
  border-color: var(--border);
  border-bottom-color: var(--bg-panel);
  margin-bottom: -1px;
  position: relative; z-index: 2;
}
.dtc-subtab-content { display: none; flex: 1; flex-direction: column; overflow: hidden; min-height: 0; }
.dtc-subtab-content.active { display: flex; }

/* ===== Library Faza 1 ===== */
.dtc-library-toolbar {
  display: flex; gap: 8px; align-items: center;
  padding: 12px 16px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 0 var(--radius) var(--radius) var(--radius);
  margin: 0 16px;
  flex-wrap: wrap;
}
.dtc-search-input {
  flex: 1; min-width: 240px;
  padding: 8px 12px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 12px;
}
.dtc-search-input:focus { outline: none; border-color: var(--accent); }
.dtc-filter-select {
  padding: 8px 10px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 12px;
  cursor: pointer;
}
.dtc-library-stats {
  padding: 8px 16px;
  font-size: 11px; color: var(--text-faint);
  flex-shrink: 0;
}
.dtc-library-list {
  flex: 1;
  margin: 0 16px 12px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow-y: auto;
  min-height: 0;
}

/* ===== ECU SEARCH (TOOLS sub-tab) ===== */
.ecusearch-toolbar {
  padding: 12px 16px 8px;
  flex-shrink: 0;
}
.ecusearch-stats {
  margin-top: 8px;
  font-size: 11px; color: var(--text-faint);
}
.ecusearch-list {
  flex: 1;
  margin: 0 16px 12px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow-y: auto;
  min-height: 0;
  padding: 8px;
}
.ecusearch-card {
  padding: 12px 14px;
  margin-bottom: 8px;
  background: var(--bg-elev);
  border: 1px solid var(--border-soft);
  border-radius: 6px;
  transition: all 0.15s;
}
.ecusearch-card:hover {
  border-color: var(--accent);
  background: var(--bg-panel-2);
}
.ecusearch-card-name {
  font-size: 14px; font-weight: 700; color: var(--text);
  font-family: monospace;
  letter-spacing: 0.3px;
  margin-bottom: 6px;
}
.ecusearch-card-brand {
  display: inline-block;
  font-size: 10px; font-weight: 700;
  color: var(--accent);
  background: var(--accent-soft);
  padding: 2px 8px;
  border-radius: 3px;
  margin-bottom: 8px;
  letter-spacing: 0.5px;
}
.ecusearch-card-sols-label {
  font-size: 10px; color: var(--text-faint);
  text-transform: uppercase; letter-spacing: 0.5px;
  margin-bottom: 5px;
}
.ecusearch-card-sols {
  display: flex; flex-wrap: wrap; gap: 4px;
}
.ecusearch-sol {
  font-size: 11px; padding: 3px 8px; border-radius: 3px;
  background: var(--accent-soft); color: var(--accent);
  font-weight: 700; letter-spacing: 0.4px;
}
.ecusearch-sol.empty {
  background: rgba(239,68,68,0.1); color: #f87171;
  font-style: italic; font-weight: 500;
}
.ecusearch-empty {
  padding: 40px 20px;
  text-align: center;
  color: var(--text-faint);
  font-size: 13px;
}
.ecusearch-empty-hint {
  font-size: 11px; margin-top: 8px; color: var(--text-faint); opacity: 0.7;
}
.ecusearch-highlight {
  background: var(--accent);
  color: var(--bg);
  padding: 0 2px;
  border-radius: 2px;
  font-weight: 800;
}
.dtc-card {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border-soft);
  display: grid;
  grid-template-columns: 90px 90px 1fr auto;
  gap: 12px;
  align-items: start;
}
.dtc-card:last-child { border-bottom: none; }
.dtc-card:hover { background: var(--bg-panel-2); }
.dtc-card-code {
  font-family: monospace; font-size: 14px; font-weight: 800;
  color: var(--accent);
  letter-spacing: 0.5px;
  display: flex;
  align-items: center;
  gap: 4px;
}
.dtc-card-badge {
  font-size: 10px;
  flex-shrink: 0;
  cursor: help;
}
.dtc-badge-premium { filter: saturate(1.4); }
.dtc-badge-standard { opacity: 0.55; }
.dtc-badge-private {
  filter: saturate(1.2);
  margin-left: 2px;
}
.dtc-loadmore {
  padding: 14px;
  text-align: center;
  border-top: 1px solid var(--border-soft);
}
.dtc-loadmore button { width: 100%; max-width: 400px; }
.dtc-card-cat {
  display: inline-block;
  padding: 2px 8px;
  background: var(--bg-elev);
  color: var(--text-dim);
  border-radius: 3px;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.5px;
  text-align: center;
  align-self: start;
}
.dtc-card-cat.severity-high { background: var(--red-soft); color: var(--red); }
.dtc-card-cat.severity-medium { background: var(--orange-soft); color: var(--orange); }
.dtc-card-cat.severity-low { background: var(--accent-soft); color: var(--accent); }
.dtc-card-info { font-size: 12px; }
.dtc-card-desc { color: var(--text); margin-bottom: 4px; line-height: 1.5; }
.dtc-card-causes {
  color: var(--text-faint);
  font-size: 11px;
  font-style: italic;
}
.dtc-card-related {
  margin-top: 6px;
  display: flex; gap: 4px; flex-wrap: wrap;
}
.dtc-related-tag {
  font-size: 9px; padding: 2px 6px;
  background: var(--accent-soft); color: var(--accent);
  border-radius: 2px;
  font-weight: 700; letter-spacing: 0.5px;
}
.dtc-card-actions {
  display: flex; gap: 4px; align-items: start;
}
.dtc-card-edit, .dtc-card-del {
  padding: 4px 8px;
  font-size: 10px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 3px;
  color: var(--text-faint);
  cursor: pointer;
  font-weight: 700;
}
.dtc-card-edit:hover { background: var(--accent); color: #00141a; border-color: var(--accent); }
.dtc-card-del:hover { background: var(--red); color: #fff; border-color: var(--red); }
.dtc-empty {
  padding: 60px 20px; text-align: center;
  color: var(--text-faint); font-style: italic;
}

/* ===== Customer Log Faza 2 ===== */
.dtc-cust-grid {
  flex: 1;
  display: grid; grid-template-columns: 320px 1fr;
  gap: 12px; padding: 12px 16px;
  overflow: hidden; min-height: 0;
}
.cust-list { padding: 0; }
.cust-item {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-soft);
  cursor: pointer;
  transition: background 0.1s;
}
.cust-item:hover { background: var(--bg-panel-2); }
.cust-item.selected { background: var(--accent-soft); border-left: 3px solid var(--accent); }
.cust-item-name { font-size: 13px; font-weight: 700; color: var(--text); }
.cust-item-meta { font-size: 10px; color: var(--text-faint); margin-top: 2px; }
.cust-item-cars { font-size: 10px; color: var(--accent); margin-top: 2px; font-weight: 600; }
.cust-item-owner {
  font-size: 9px; color: var(--text-faint); margin-top: 4px;
  padding: 2px 6px; background: var(--bg-elev); border-radius: 3px;
  display: inline-block; letter-spacing: 0.3px;
}
.cust-owner-banner {
  background: var(--orange-soft);
  color: var(--orange);
  padding: 8px 14px;
  font-size: 11px;
  border-bottom: 1px solid var(--border);
  letter-spacing: 0.3px;
}

.cust-detail { padding: 0; }
.cust-detail-header {
  padding: 14px 16px;
  background: var(--bg-panel-2);
  border-bottom: 1px solid var(--border);
}
.cust-detail-name { font-size: 16px; font-weight: 800; color: var(--text); }
.cust-detail-info {
  display: grid; grid-template-columns: 1fr 1fr; gap: 4px 16px;
  margin-top: 8px;
  font-size: 11px;
}
.cust-detail-info-row { display: flex; gap: 6px; }
.cust-detail-info-label { color: var(--text-faint); font-weight: 700; }
.cust-detail-info-value { color: var(--text); }

.cust-section {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border-soft);
}
.cust-section-title {
  font-size: 11px; font-weight: 700; letter-spacing: 1px;
  color: var(--text-dim);
  margin-bottom: 10px;
  text-transform: uppercase;
}
.veh-card {
  padding: 10px 12px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
  font-size: 12px;
}
.veh-card-title { font-weight: 700; color: var(--accent); margin-bottom: 4px; }
.veh-card-meta { font-size: 10px; color: var(--text-faint); }
.veh-card-vin { font-family: monospace; font-size: 11px; color: var(--text-dim); }

.visit-row {
  display: grid;
  grid-template-columns: 90px 1fr auto;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border-soft);
  font-size: 11px;
  align-items: start;
}
.visit-row:last-child { border-bottom: none; }
.visit-date { color: var(--accent); font-weight: 700; font-family: monospace; }
.visit-veh-tag { font-size: 10px; color: var(--text-dim); margin-top: 2px; }
.visit-content { color: var(--text); line-height: 1.5; }
.visit-dtcs {
  margin-top: 4px;
  display: flex; gap: 3px; flex-wrap: wrap;
}
.visit-dtc-tag {
  font-family: monospace; font-size: 9px;
  padding: 1px 5px;
  background: var(--red-soft); color: var(--red);
  border-radius: 2px;
  font-weight: 700;
}
.visit-actions {
  display: flex; gap: 4px;
}
.visit-actions button {
  font-size: 10px; padding: 2px 6px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: 3px; color: var(--text-faint);
}
.visit-actions button:hover { background: var(--red); color: #fff; border-color: var(--red); }
.dtc-import-section { padding: 14px; }
.dtc-import-label {
  font-size: 11px; font-weight: 700; letter-spacing: 1.2px;
  color: var(--text-dim); margin-bottom: 8px; text-transform: uppercase;
}
.dtc-textarea {
  width: 100%; min-height: 120px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 10px;
  color: var(--text); font-size: 12px;
  font-family: "JetBrains Mono", monospace; resize: vertical;
}
.dtc-textarea:focus { border-color: var(--accent); }
.dtc-action-row { display: flex; gap: 8px; margin-top: 10px; }
.btn-primary {
  flex: 1; padding: 9px;
  background: var(--green); color: #fff;
  border-radius: var(--radius-sm);
  font-weight: 700; letter-spacing: 1px; font-size: 12px;
}
.btn-primary:hover { background: #059669; }
.btn-secondary {
  padding: 9px 16px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text);
  font-weight: 700; letter-spacing: 1px; font-size: 12px;
}
.btn-secondary:hover { background: var(--border); }
.dtc-hint { font-size: 11px; color: var(--text-faint); margin-top: 8px; line-height: 1.5; }
.dtc-divider { height: 1px; background: var(--border-soft); margin: 16px 0; }
.dtc-input-row { display: flex; gap: 8px; }
.dtc-input {
  flex: 1; padding: 8px 10px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 12px;
}
.dtc-input:focus { border-color: var(--accent); }
.btn-add {
  padding: 8px 18px;
  background: var(--accent); color: #00141a;
  border-radius: var(--radius-sm); font-weight: 700; letter-spacing: 1px;
}
.dtc-tools { margin-top: 16px; display: flex; flex-direction: column; gap: 6px; }
.dtc-tool-btn {
  padding: 9px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text);
  font-weight: 700; letter-spacing: 1px; font-size: 11px;
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.dtc-tool-btn:hover { background: var(--border); }
.dtc-tool-btn.accent { background: var(--accent); color: #00141a; border-color: var(--accent); }
.dtc-tool-btn.accent:hover { background: var(--accent-hover); }
.dtc-codes-panel { display: flex; flex-direction: column; }
.dtc-search {
  padding: 6px 10px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 12px;
  width: 280px;
}
.dtc-search:focus { border-color: var(--accent); }
.dtc-table-wrap { flex: 1; overflow-y: auto; padding: 0; }
.dtc-table { width: 100%; border-collapse: collapse; }
.dtc-table thead th {
  position: sticky; top: 0; z-index: 1;
  background: var(--bg-panel-2);
  padding: 10px 14px; text-align: left;
  font-size: 11px; font-weight: 700; letter-spacing: 1px;
  color: var(--text-dim);
  border-bottom: 1px solid var(--border);
}
.dtc-table tbody td {
  padding: 10px 14px;
  font-size: 12px;
  border-bottom: 1px solid var(--border-soft);
}
.dtc-table tbody tr:hover { background: var(--bg-panel-2); }
.dtc-code { color: var(--accent); font-family: "JetBrains Mono", monospace; font-weight: 700; }
.dtc-value { color: var(--text-dim); font-family: "JetBrains Mono", monospace; }
.dtc-desc { color: var(--text); }
.toggle-pill {
  display: inline-flex; align-items: center;
  padding: 3px 12px;
  border-radius: 12px; font-size: 10px; font-weight: 800;
  letter-spacing: 1px; cursor: pointer; transition: all 0.15s;
  min-width: 44px; justify-content: center;
}
.toggle-pill.on { background: var(--accent); color: #00141a; }
.toggle-pill.off { background: var(--bg-elev); color: var(--text-faint); border: 1px solid var(--border); }

/* LIBRARY */
.lib-grid {
  flex: 1;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 12px; padding: 12px 16px;
  overflow: hidden; min-height: 0;
}
.lib-builder-body { padding: 14px; }
.builder-desc { font-size: 12px; color: var(--text-dim); margin-bottom: 14px; line-height: 1.6; }
.file-drop-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 10px; margin-bottom: 12px;
}
.file-drop {
  padding: 18px 12px;
  background: var(--bg-deep); border: 1px dashed var(--border);
  border-radius: var(--radius); text-align: center;
  cursor: pointer; transition: all 0.15s;
}
.file-drop:hover { border-color: var(--accent); }
.file-drop.has-file { border-color: var(--green); border-style: solid; background: var(--green-soft); }
.file-drop-title {
  font-size: 11px; font-weight: 700; letter-spacing: 1.5px;
  color: var(--accent); margin-bottom: 4px;
}
.file-drop.has-file .file-drop-title { color: var(--green); }
.file-drop-text { font-size: 11px; color: var(--text-faint); }
.compare-btn {
  padding: 8px 14px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-dim);
  font-weight: 700; letter-spacing: 1px; font-size: 11px;
  margin-bottom: 14px; width: 100%;
}
.compare-btn.ready { background: var(--accent); color: #00141a; border-color: var(--accent); cursor: pointer; }
.compare-btn.ready:hover { background: var(--accent-hover); }
.compare-btn:disabled { cursor: not-allowed; }
.builder-divider { height: 1px; background: var(--border-soft); margin: 14px 0; }
.field-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 10px 12px; margin-bottom: 10px;
}
.field { display: flex; flex-direction: column; }
.field-label {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 11px; font-weight: 700; letter-spacing: 1px;
  color: var(--text-dim); margin-bottom: 5px; text-transform: uppercase;
}
.field-add { font-size: 10px; color: var(--accent); font-weight: 700; cursor: pointer; }
.field-add:hover { text-decoration: underline; }
.field-input, .field-select {
  padding: 8px 10px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 12px;
}
.field-input:focus, .field-select:focus { border-color: var(--accent); }
.field-textarea {
  padding: 8px 10px; min-height: 60px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 12px;
  font-family: inherit; resize: vertical;
}
.field-full { grid-column: 1 / -1; }
.method-group { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 6px; }
.method-btn {
  padding: 8px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-dim);
  font-size: 11px; font-weight: 700; letter-spacing: 0.5px;
  display: flex; align-items: center; justify-content: center; gap: 4px;
}
.method-btn[data-method="OBD"].active { background: rgba(37, 99, 235, 0.2); color: #60a5fa; border-color: #2563eb; }
.method-btn[data-method="Bench"].active { background: rgba(234, 88, 12, 0.2); color: #fb923c; border-color: #ea580c; }
.method-btn[data-method="Boot"].active { background: rgba(147, 51, 234, 0.2); color: #c084fc; border-color: #9333ea; }
.method-btn[data-method="BDM"].active { background: rgba(16, 185, 129, 0.2); color: #34d399; border-color: #10b981; }
.method-btn[data-method="JTAG"].active { background: rgba(234, 179, 8, 0.2); color: #fbbf24; border-color: #eab308; }

.btn-save {
  width: 100%; padding: 11px; margin-top: 14px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-dim);
  font-weight: 700; letter-spacing: 1.5px; font-size: 12px;
  cursor: not-allowed;
}
.btn-save.ready { background: var(--accent); color: #00141a; border-color: var(--accent); cursor: pointer; }
.btn-save.ready:hover { background: var(--accent-hover); }

.lib-filter-row {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  gap: 8px; padding: 12px 14px; background: var(--bg-panel-2);
  border-bottom: 1px solid var(--border);
}
.lib-list { flex: 1; overflow-y: auto; padding: 6px 0; }
.lib-empty { text-align: center; padding: 40px 20px; color: var(--text-faint); font-size: 12px; }
.lib-row {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-soft);
  display: flex; align-items: center; gap: 10px;
}
.lib-row:hover { background: var(--bg-panel-2); }
.lib-row-check { width: 16px; height: 16px; accent-color: var(--accent); }
.lib-row-info { flex: 1; min-width: 0; }
.lib-row-name { font-size: 12px; font-weight: 700; color: var(--text); }
.lib-row-meta { font-size: 11px; color: var(--text-dim); margin-top: 2px; display: flex; gap: 4px; flex-wrap: wrap; align-items: center; }
.lib-row-tag {
  display: inline-block; padding: 1px 6px;
  font-size: 10px; font-weight: 700; border-radius: 3px;
}
.lib-row-tag.cat { background: var(--accent-soft); color: var(--accent); }
.lib-row-tag.brand { background: var(--orange-soft); color: var(--orange); }
.lib-row-del { font-size: 14px; color: var(--text-faint); padding: 4px 8px; }
.lib-row-del:hover { color: var(--red); }

.lib-bottom { padding: 12px 14px; border-top: 1px solid var(--border); flex-shrink: 0; }
.btn-load-target {
  width: 100%; padding: 11px; margin-bottom: 6px;
  background: var(--accent-soft); color: var(--accent);
  border: 1px solid var(--accent);
  border-radius: var(--radius-sm); font-weight: 700; letter-spacing: 1px; font-size: 12px;
}
.btn-load-target:hover { background: var(--accent); color: #00141a; }
.btn-apply {
  width: 100%; padding: 11px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-dim);
  font-weight: 700; letter-spacing: 1px; font-size: 12px;
  cursor: not-allowed;
}
.btn-apply.ready { background: var(--accent); color: #00141a; border-color: var(--accent); cursor: pointer; }
.lib-bottom-hint { font-size: 11px; color: var(--text-faint); margin-top: 8px; line-height: 1.5; }
.export-link { font-size: 11px; color: var(--accent); font-weight: 700; cursor: pointer; }
.export-link:hover { text-decoration: underline; }

/* INFO */
.info-wrap {
  flex: 1; overflow-y: auto;
  padding: 16px;
  display: flex; flex-direction: column; gap: 14px;
}
.info-card {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px;
}
.info-desc {
  font-size: 13px; color: var(--text); line-height: 1.7;
  margin-bottom: 22px;
  padding-bottom: 18px; border-bottom: 1px solid var(--border-soft);
}
.info-desc strong { color: var(--accent); font-weight: 700; }

/* === SECTION HEADER === */
.info-section-header {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 0 4px;
  margin-bottom: 14px;
}
.info-section-title {
  font-size: 13px; font-weight: 800;
  color: var(--text);
  letter-spacing: 1.5px;
}
.info-section-subtitle {
  font-size: 11px; color: var(--text-faint);
  font-style: italic;
}

/* === SOLUTIONS GRID === */
.info-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.info-tile {
  position: relative;
  padding: 14px 16px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: default;
  transition: transform 0.18s, border-color 0.18s, box-shadow 0.18s;
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.info-tile::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--tile-color, var(--accent));
  transition: width 0.18s;
}
.info-tile:hover {
  transform: translateY(-2px);
  border-color: var(--tile-color, var(--accent));
  box-shadow: 0 4px 14px -4px rgba(0,0,0,0.4);
}
.info-tile:hover::before {
  width: 5px;
}
.info-tile-icon {
  font-size: 24px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px; height: 38px;
  background: var(--tile-color-bg, rgba(6,182,212,0.12));
  border-radius: 10px;
  line-height: 1;
}
.info-tile-body {
  flex: 1;
  min-width: 0;
}
.info-tile-name {
  font-size: 13px; font-weight: 800;
  letter-spacing: 0.8px;
  color: var(--tile-color, var(--accent));
  margin-bottom: 3px;
}
.info-tile-desc {
  font-size: 11px;
  color: var(--text-dim);
  line-height: 1.45;
}
.info-version {
  text-align: center; margin: 18px 0 22px;
  font-size: 11px; color: var(--text-faint); font-style: italic;
}

/* NEWS TICKER & NEWS CARDS */
.news-ticker {
  position: relative;
  overflow: hidden;
  background: linear-gradient(90deg, rgba(245,158,11,0.12) 0%, rgba(6,182,212,0.12) 50%, rgba(245,158,11,0.12) 100%);
  border: 1px solid var(--orange);
  border-radius: var(--radius);
  padding: 0;
  height: 38px;
  display: flex; align-items: center;
  margin-bottom: 14px;
}
.news-ticker-label {
  flex-shrink: 0;
  background: var(--orange);
  color: #000;
  font-weight: 800;
  font-size: 11px;
  letter-spacing: 1.5px;
  padding: 0 12px;
  height: 100%;
  display: flex; align-items: center;
}
.news-ticker-track {
  flex: 1;
  overflow: hidden;
  white-space: nowrap;
  position: relative;
}
.news-ticker-content {
  display: inline-block;
  padding-left: 100%;
  animation: ticker-scroll 50s linear infinite;
  font-size: 13px;
  color: var(--text);
  font-weight: 500;
}
.news-ticker-content:hover { animation-play-state: paused; }
.news-ticker-item {
  display: inline-block;
  padding: 0 30px;
}
.news-ticker-item strong { color: var(--orange); margin-right: 6px; }
.news-ticker-item .nt-date { color: var(--text-faint); font-size: 11px; margin-left: 8px; }
.news-ticker-sep { color: var(--accent); font-weight: 700; }
@keyframes ticker-scroll {
  0% { transform: translate3d(0,0,0); }
  100% { transform: translate3d(-100%,0,0); }
}
.news-ticker-empty {
  flex: 1;
  text-align: center;
  font-size: 12px;
  font-style: italic;
  color: var(--text-faint);
  padding: 0 16px;
}

.news-list { display: flex; flex-direction: column; gap: 10px; margin-top: 14px; }
.news-card {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-left: 3px solid var(--orange);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
}
.news-card.inactive { opacity: 0.5; border-left-color: var(--text-faint); }
.news-card-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; margin-bottom: 6px;
}
.news-card-title { font-size: 13px; font-weight: 700; color: var(--text); flex: 1; min-width: 0; }
.news-card-date { font-size: 11px; color: var(--text-faint); flex-shrink: 0; font-family: monospace; }
.news-card-body { font-size: 12px; color: var(--text-dim); line-height: 1.6; white-space: pre-wrap; word-wrap: break-word; }
.news-card-foot {
  display: flex; align-items: center; gap: 8px; margin-top: 8px;
  padding-top: 8px; border-top: 1px solid var(--border-soft);
}
.news-card-author { font-size: 10px; color: var(--text-faint); flex: 1; }
.news-card-action {
  font-size: 10px; padding: 3px 8px;
  border: 1px solid var(--border);
  border-radius: 3px; color: var(--text-dim);
  background: var(--bg-elev); font-weight: 700; letter-spacing: 0.5px;
  cursor: pointer;
}
.news-card-action.toggle.on { background: var(--green); color: #fff; border-color: var(--green); }
.news-card-action.toggle.off { background: var(--bg-elev); color: var(--text-faint); }
.news-card-action.delete { color: var(--red); border-color: rgba(239,68,68,0.3); }
.news-card-action.delete:hover { background: var(--red); color: #fff; }

.news-form { padding: 14px; }
.news-form-input {
  width: 100%; padding: 9px 10px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 13px;
  margin-bottom: 10px;
}
.news-form-input:focus { border-color: var(--accent); }
.news-form-textarea {
  width: 100%; padding: 9px 10px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 12px;
  min-height: 90px; resize: vertical;
  font-family: inherit;
  margin-bottom: 10px;
}
.news-form-textarea:focus { border-color: var(--accent); }
.news-form-btn {
  width: 100%; padding: 11px;
  background: var(--orange); color: #000;
  border-radius: var(--radius-sm); font-weight: 800; letter-spacing: 1.5px; font-size: 12px;
}
.news-form-btn:hover { background: #fbbf24; }
.news-empty {
  text-align: center; padding: 30px;
  color: var(--text-faint); font-size: 12px; font-style: italic;
}

/* ADMIN */
.admin-tabs {
  display: flex; gap: 4px;
  padding: 10px 16px 0;
  flex-shrink: 0;
}
.admin-tab-btn {
  padding: 8px 18px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm) var(--radius-sm) 0 0;
  font-size: 11px; font-weight: 700; letter-spacing: 1px;
  color: var(--text-dim);
}
.admin-tab-btn:hover { color: var(--text); }
.admin-tab-btn.active { background: var(--accent); color: #00141a; border-color: var(--accent); }
.admin-grid {
  flex: 1;
  display: grid; grid-template-columns: 360px 1fr;
  gap: 12px; padding: 12px 16px;
  overflow: hidden; min-height: 0;
}
.admin-form { padding: 14px; overflow-y: auto; }
.admin-section-label {
  font-size: 11px; font-weight: 700; letter-spacing: 1.2px;
  color: var(--text-dim); margin-bottom: 8px; text-transform: uppercase;
}
.admin-divider { height: 1px; background: var(--border-soft); margin: 14px 0; }
.checkbox-list { display: flex; flex-direction: column; gap: 6px; }
.checkbox-row {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer; transition: all 0.15s;
}
.checkbox-row:hover { border-color: var(--accent); }
.checkbox-row.checked { background: var(--accent-soft); border-color: var(--accent); }
.checkbox-row input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--accent); }
.checkbox-row span { font-size: 12px; font-weight: 600; }
.subscription-card {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 12px;
}
.sub-title {
  font-size: 11px; font-weight: 700; letter-spacing: 1px;
  color: var(--orange); margin-bottom: 10px;
  display: flex; align-items: center; gap: 6px;
}
.sub-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 8px; }
.sub-field-label { font-size: 11px; color: var(--text-dim); margin-bottom: 4px; }
.sub-input {
  width: 100%; padding: 7px 9px;
  background: var(--bg-panel); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 12px;
}
.sub-aboname-label { font-size: 11px; color: var(--text-dim); margin: 4px 0; }
.sub-aboname-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; }
.sub-pill {
  padding: 7px;
  background: var(--bg-panel); border: 1px solid var(--border);
  border-radius: var(--radius-sm); font-size: 11px; font-weight: 700;
  text-align: center; letter-spacing: 0.5px;
}
.sub-pill.active { background: var(--green); color: #fff; border-color: var(--green); }
.sub-date {
  width: 100%; margin-top: 8px; padding: 7px 9px;
  background: var(--bg-panel); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 12px;
}
.btn-create-user {
  width: 100%; padding: 13px; margin-top: 14px;
  background: var(--accent); color: #00141a;
  border-radius: var(--radius-sm); font-weight: 800; letter-spacing: 2px; font-size: 12px;
}
.btn-create-user:hover { background: var(--accent-hover); }
.user-list-row {
  display: grid;
  grid-template-columns: minmax(140px, 1.2fr) 90px 110px 70px 60px 95px 110px minmax(220px, auto);
  gap: 8px; align-items: center;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-soft);
  font-size: 12px;
}
.status-cell { display: flex; align-items: center; gap: 6px; }
.last-login-cell { font-size: 11px; color: var(--text-dim); }
.online-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--text-faint);
  flex-shrink: 0;
}
.online-dot.online {
  background: var(--green);
  box-shadow: 0 0 6px var(--green);
  animation: pulse-online 2s ease-in-out infinite;
}
@keyframes pulse-online {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.6; }
}
.online-label {
  font-size: 10px; font-weight: 700; letter-spacing: 0.5px;
  color: var(--text-faint);
}
.online-label.online { color: var(--green); }
.user-list-row.disabled { opacity: 0.55; }
.user-list-row.head {
  background: var(--bg-panel-2);
  font-size: 11px; font-weight: 700; letter-spacing: 1px;
  color: var(--text-dim); text-transform: uppercase;
}
.role-badge {
  display: inline-block; padding: 2px 8px;
  background: var(--orange-soft); color: var(--orange);
  border-radius: 3px; font-size: 10px; font-weight: 700;
}
.role-badge.staff { background: var(--accent-soft); color: var(--accent); }
.role-badge.disabled { background: var(--red-soft); color: var(--red); }
.user-tokens-cell { font-family: monospace; font-size: 11px; color: var(--text-dim); }
.user-tokens-cell strong { color: var(--green); }
.user-tokens-cell strong.danger { color: var(--red); }
.user-actions {
  display: flex; gap: 4px; flex-wrap: wrap;
  justify-content: flex-end;
}
.user-action-btn {
  font-size: 10px; padding: 4px 8px;
  border: 1px solid var(--border);
  background: var(--bg-elev); color: var(--text-dim);
  border-radius: 3px; font-weight: 700; letter-spacing: 0.5px;
  cursor: pointer;
  transition: all 0.1s;
}
.user-action-btn:hover { background: var(--border); color: var(--text); }
.user-action-btn.history:hover { background: var(--blue); color: #fff; border-color: var(--blue); }
.user-action-btn.hwid { background: rgba(245, 158, 11, 0.15); color: var(--orange); border-color: var(--orange); }
.user-action-btn.hwid:hover { background: var(--orange); color: #000; }
.user-action-btn.disabled-btn { opacity: 0.4; cursor: not-allowed; pointer-events: none; }

/* History modal */
.history-stat-tile {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 10px;
  text-align: center;
}
.history-stat-value { font-size: 18px; font-weight: 800; color: var(--accent); }
.history-stat-label { font-size: 9px; font-weight: 700; letter-spacing: 1px; color: var(--text-faint); margin-top: 4px; text-transform: uppercase; }
.history-row {
  display: grid;
  grid-template-columns: 100px 60px 70px 1fr;
  gap: 8px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-soft);
  font-size: 11px;
  align-items: center;
}
.history-row:last-child { border-bottom: none; }
.history-row.head {
  background: var(--bg-panel-2);
  font-weight: 700; letter-spacing: 0.5px;
  color: var(--text-dim);
  position: sticky; top: 0;
}
.history-date { font-family: monospace; color: var(--text); }
.history-time { font-family: monospace; color: var(--accent); font-weight: 700; }
.history-day { color: var(--text-dim); font-size: 10px; }
.history-ago { color: var(--text-faint); font-size: 10px; font-style: italic; text-align: right; }
.history-empty { padding: 30px; text-align: center; color: var(--text-faint); font-style: italic; font-size: 12px; }
.user-action-btn.edit:hover { background: var(--accent); color: #00141a; border-color: var(--accent); }
.user-action-btn.reset:hover { background: var(--orange); color: #000; border-color: var(--orange); }
.user-action-btn.disable:hover { background: var(--yellow); color: #000; border-color: var(--yellow); }
.user-action-btn.enable { background: rgba(16, 185, 129, 0.2); color: var(--green); border-color: var(--green); }
.user-action-btn.enable:hover { background: var(--green); color: #fff; }
.user-action-btn.delete:hover { background: var(--red); color: #fff; border-color: var(--red); }
.user-del-btn { color: var(--text-faint); font-size: 14px; padding: 4px 8px; }
.user-del-btn:hover { color: var(--red); }
.activity-row {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border-soft);
  font-size: 12px;
}
.activity-time { color: var(--text-faint); font-family: monospace; font-size: 11px; min-width: 130px; padding-top: 1px; }
.activity-user { color: var(--accent); font-weight: 700; min-width: 90px; padding-top: 1px; }
.activity-msg { color: var(--text); flex: 1; min-width: 0; }
.activity-meta {
  margin-top: 4px;
  font-size: 10px;
  color: var(--text-faint);
  font-family: monospace;
  letter-spacing: 0.3px;
  word-break: break-word;
}

.remote-mgmt { padding: 30px; text-align: center; }
.remote-mgmt-icon { font-size: 40px; margin-bottom: 12px; }
.remote-mgmt-title {
  font-size: 16px; font-weight: 700; color: var(--accent);
  margin-bottom: 8px; letter-spacing: 1px;
}
.remote-mgmt-text {
  font-size: 12px; color: var(--text-dim); line-height: 1.7;
  max-width: 500px; margin: 0 auto;
}
.remote-mgmt-tag {
  display: inline-block; margin-top: 14px;
  padding: 4px 10px;
  background: var(--orange-soft); color: var(--orange);
  border-radius: 3px; font-size: 10px; font-weight: 700; letter-spacing: 1px;
}

/* === BACKUP & RESTORE === */
.backup-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.backup-card {
  padding: 22px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
}
.backup-card-icon {
  font-size: 36px;
  margin-bottom: 10px;
}
.backup-card-title {
  font-size: 14px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: 1px;
  margin-bottom: 8px;
}
.backup-card-desc {
  font-size: 12px;
  color: var(--text-dim);
  line-height: 1.6;
  flex: 1;
  margin-bottom: 4px;
}
.backup-card-meta {
  font-size: 11px;
  color: var(--text-faint);
  font-style: italic;
  margin-top: 8px;
  padding-top: 10px;
  border-top: 1px solid var(--border-soft);
}
.backup-export-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.backup-export-row .modal-btn {
  flex: 1 1 auto;
  min-width: 200px;
}
@media (max-width: 768px) {
  .backup-grid {
    grid-template-columns: 1fr;
  }
}

/* === STATISTIKA === */
.stats-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
}
.stats-kpi-card {
  padding: 16px;
  background: linear-gradient(135deg, rgba(6,182,212,0.10) 0%, rgba(168,85,247,0.06) 100%);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.stats-kpi-icon {
  font-size: 22px;
  margin-bottom: 6px;
  opacity: 0.8;
}
.stats-kpi-value {
  font-size: 26px;
  font-weight: 800;
  color: var(--accent);
  line-height: 1;
  margin-bottom: 4px;
  font-variant-numeric: tabular-nums;
}
.stats-kpi-label {
  font-size: 10.5px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
  font-weight: 600;
}
.stats-grid-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 768px) {
  .stats-grid-2col { grid-template-columns: 1fr; }
}
.stats-block {
  padding: 14px 16px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.stats-block-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.5px;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border-soft);
}
.stats-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 4px;
  font-size: 12px;
}
.stats-row + .stats-row {
  border-top: 1px dashed var(--border-soft);
}
.stats-row-rank {
  font-weight: 800;
  color: var(--text-faint);
  width: 24px;
  flex-shrink: 0;
  text-align: right;
}
.stats-row-rank.gold { color: #fbbf24; }
.stats-row-rank.silver { color: #cbd5e1; }
.stats-row-rank.bronze { color: #d97706; }
.stats-row-name {
  flex: 1;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.stats-row-bar {
  flex: 2;
  height: 6px;
  background: var(--bg-elev);
  border-radius: 3px;
  overflow: hidden;
}
.stats-row-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent) 0%, var(--purple) 100%);
  border-radius: 3px;
}
.stats-row-count {
  font-weight: 700;
  color: var(--accent);
  font-variant-numeric: tabular-nums;
  min-width: 36px;
  text-align: right;
  flex-shrink: 0;
}
.stats-empty {
  text-align: center;
  padding: 16px;
  font-size: 11px;
  color: var(--text-faint);
  font-style: italic;
}

/* Monthly chart bars */
.stats-monthly {
  display: flex;
  align-items: flex-end;
  gap: 4px;
  height: 140px;
  padding: 8px 0;
}
.stats-month-bar {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
  min-width: 0;
}
.stats-month-bar-fill {
  width: 100%;
  background: linear-gradient(180deg, var(--accent) 0%, rgba(6,182,212,0.3) 100%);
  border-radius: 2px 2px 0 0;
  min-height: 2px;
  position: relative;
  cursor: help;
}
.stats-month-bar:hover .stats-month-bar-fill {
  background: linear-gradient(180deg, var(--orange) 0%, rgba(245,158,11,0.4) 100%);
}
.stats-month-label {
  font-size: 9px;
  color: var(--text-faint);
  letter-spacing: 0.3px;
  font-variant-numeric: tabular-nums;
}
.stats-month-count {
  font-size: 9.5px;
  color: var(--accent);
  font-weight: 700;
}

.footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 16px;
  background: var(--bg-panel);
  border-top: 1px solid var(--border);
  font-size: 11px;
  flex-shrink: 0; height: 32px;
}
.footer-left { color: var(--orange); font-weight: 700; letter-spacing: 1px; }
.footer-right { color: var(--text-dim); }

/* MODAL */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.75);
  backdrop-filter: blur(4px);
  display: none; align-items: center; justify-content: center;
  z-index: 2000;
}
.modal-backdrop.show { display: flex; }
.modal {
  width: 100%; max-width: 400px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 24px;
  box-shadow: var(--shadow);
}
.modal-icon { font-size: 28px; text-align: center; margin-bottom: 8px; }
.modal-title {
  font-size: 14px; font-weight: 700; color: #fff;
  text-align: center; margin-bottom: 4px;
}
.modal-subtitle {
  font-size: 11px; color: var(--text-dim);
  text-align: center; margin-bottom: 20px;
}
.modal-label {
  font-size: 10px; text-transform: uppercase; letter-spacing: 1px;
  color: var(--text-dim); font-weight: 600;
  margin-bottom: 8px;
}
.modal-input {
  width: 100%; padding: 8px 10px;
  background: var(--bg-deep); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text); font-size: 12px;
  margin-bottom: 16px;
}

/* === Add modal extra checkbox row (used for "Default OFF" stage flag) === */
.add-modal-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 7px;
  cursor: pointer;
  transition: all 0.15s ease;
}
.add-modal-checkbox:hover {
  border-color: rgba(245, 158, 11, 0.35);
  background: rgba(245, 158, 11, 0.04);
}
.add-modal-checkbox input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
  cursor: pointer;
  accent-color: #f59e0b;
}
.add-modal-checkbox-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}
.add-modal-checkbox-label {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--text);
}
.add-modal-checkbox-desc {
  font-size: 9.5px;
  color: var(--text-faint);
  line-height: 1.3;
}
.modal-method-row {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 6px;
  margin-bottom: 16px;
}
.modal-method-btn {
  padding: 10px 4px;
  border-radius: 6px; font-size: 11px; font-weight: 700;
  border: 1px solid var(--border);
  background: var(--bg-elev); color: var(--text-dim);
  transition: all 0.15s;
}
.modal-method-btn[data-method="OBD"].active { background: var(--blue); color: #fff; border-color: var(--blue); box-shadow: 0 4px 12px rgba(37, 99, 235, 0.3); }
.modal-method-btn[data-method="Bench"].active { background: #ea580c; color: #fff; border-color: #ea580c; box-shadow: 0 4px 12px rgba(234, 88, 12, 0.3); }
.modal-method-btn[data-method="Boot"].active { background: var(--purple); color: #fff; border-color: var(--purple); box-shadow: 0 4px 12px rgba(147, 51, 234, 0.3); }
.modal-method-btn[data-method="BDM"].active { background: var(--green); color: #fff; border-color: var(--green); box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3); }
.modal-method-btn[data-method="JTAG"].active { background: var(--yellow); color: #1a1a1a; border-color: var(--yellow); box-shadow: 0 4px 12px rgba(234, 179, 8, 0.3); }
.modal-actions { display: flex; gap: 8px; }
.modal-btn {
  flex: 1; padding: 9px;
  background: var(--bg-elev); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-dim);
  font-size: 12px; font-weight: 700; letter-spacing: 0.5px;
}
.modal-btn:hover { background: var(--border); color: var(--text); }
.modal-btn.primary {
  flex: 2;
  background: var(--accent); color: #00141a; border-color: var(--accent);
}
.modal-btn.primary:hover { background: var(--accent-hover); }
.modal-btn.danger {
  flex: 2;
  background: var(--red); color: #fff; border-color: var(--red);
}
.modal-btn.danger:hover { background: #dc2626; }

/* === RICH FORM MODALS === */
.modal-form {
  padding: 0;
  overflow: hidden;
  animation: modal-pop 0.18s ease-out;
}
@keyframes modal-pop {
  from { opacity: 0; transform: scale(0.95) translateY(-8px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}
.modal-form-header {
  display: flex; align-items: center; gap: 14px;
  padding: 18px 22px;
  background: linear-gradient(135deg, rgba(6,182,212,0.10) 0%, rgba(168,85,247,0.06) 100%);
  border-bottom: 1px solid var(--border);
}
.modal-form-icon {
  font-size: 28px;
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 10px;
  flex-shrink: 0;
}
.modal-title-lg {
  font-size: 16px; font-weight: 800;
  color: var(--text);
  letter-spacing: 0.3px;
}
.modal-subtitle-sm {
  font-size: 11px; color: var(--text-faint);
  margin-top: 2px;
}
.form-grid {
  padding: 18px 22px;
  display: flex; flex-direction: column; gap: 14px;
  max-height: 65vh;
  overflow-y: auto;
}
.form-row { display: flex; flex-direction: column; gap: 6px; }
.form-row-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.form-label {
  font-size: 11px; font-weight: 700;
  color: var(--text-dim);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  display: flex; align-items: center; gap: 4px;
}
.form-required { color: var(--red); font-size: 13px; }
.form-hint {
  font-size: 9px; color: var(--text-faint);
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  font-style: italic;
}
.form-input {
  width: 100%;
  padding: 9px 12px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 13px;
  font-family: inherit;
  transition: border-color 0.15s, background 0.15s;
}
.form-input:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--bg-panel);
}
.form-input.invalid {
  border-color: var(--red);
  background: rgba(239,68,68,0.05);
}
.form-input-uppercase { text-transform: uppercase; letter-spacing: 0.5px; }
.form-input-mono { font-family: monospace; font-size: 12px; letter-spacing: 0.5px; }
.form-textarea {
  width: 100%;
  padding: 9px 12px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 13px;
  font-family: inherit;
  resize: vertical;
  min-height: 60px;
}
.form-textarea:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--bg-panel);
}
.modal-form .modal-actions {
  padding: 14px 22px;
  background: var(--bg-deep);
  border-top: 1px solid var(--border);
  margin: 0;
}

/* DTC privacy banner */
.dtc-privacy-banner {
  margin: 0 22px;
  padding: 10px 14px;
  background: linear-gradient(90deg, rgba(168,85,247,0.12) 0%, rgba(6,182,212,0.10) 100%);
  border: 1px solid rgba(168,85,247,0.4);
  border-radius: var(--radius-sm);
  font-size: 11.5px;
  color: var(--text);
  margin-top: 14px;
  margin-bottom: -4px;
  letter-spacing: 0.2px;
}
.dtc-privacy-banner b { color: #c084fc; font-weight: 700; }

/* === DTC TAG INPUT (multi-select with autocomplete) === */
.dtc-tag-input-wrap {
  position: relative;
}
.dtc-tag-list {
  display: flex; flex-wrap: wrap; gap: 4px;
  margin-bottom: 6px;
  min-height: 0;
}
.dtc-tag-list:empty { display: none; }
.dtc-tag {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: monospace;
  font-size: 11px; font-weight: 700;
  padding: 3px 4px 3px 8px;
  background: var(--accent-soft);
  color: var(--accent);
  border-radius: 4px;
  letter-spacing: 0.3px;
}
.dtc-tag-x {
  cursor: pointer;
  width: 16px; height: 16px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 3px;
  font-size: 14px; line-height: 1;
  color: var(--accent);
  opacity: 0.6;
}
.dtc-tag-x:hover { background: var(--red); color: #fff; opacity: 1; }
.dtc-autocomplete {
  position: absolute;
  top: 100%; left: 0; right: 0;
  margin-top: 4px;
  max-height: 240px;
  overflow-y: auto;
  background: var(--bg-panel);
  border: 1px solid var(--accent);
  border-radius: var(--radius-sm);
  box-shadow: 0 8px 24px -8px rgba(0,0,0,0.5);
  z-index: 10;
  display: none;
}
.dtc-autocomplete.show { display: block; }
.dtc-suggest-item {
  padding: 8px 12px;
  border-bottom: 1px solid var(--border-soft);
  cursor: pointer;
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 8px;
  align-items: center;
}
.dtc-suggest-item:last-child { border-bottom: none; }
.dtc-suggest-item:hover, .dtc-suggest-item.active {
  background: var(--accent-soft);
}
.dtc-suggest-code {
  font-family: monospace; font-size: 12px; font-weight: 800;
  color: var(--accent);
}
.dtc-suggest-desc {
  font-size: 11px; color: var(--text-dim);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.dtc-suggest-empty {
  padding: 12px; text-align: center;
  color: var(--text-faint); font-size: 11px; font-style: italic;
}

#toast {
  position: fixed; bottom: 50px; left: 50%;
  transform: translateX(-50%) translateY(20px);
  padding: 10px 18px;
  background: var(--bg-panel); border: 1px solid var(--accent);
  border-radius: var(--radius);
  color: var(--text); font-size: 12px;
  box-shadow: var(--shadow);
  opacity: 0; pointer-events: none;
  transition: all 0.25s;
  z-index: 3000;
}
#toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
#toast.error { border-color: var(--red); }
#toast.success { border-color: var(--green); }
#toast.warn { border-color: var(--orange); background: linear-gradient(180deg, var(--bg-panel) 0%, rgba(245, 158, 11, 0.08) 100%); color: #fcd34d; font-weight: 600; }

.hidden-file { display: none; }

@media (max-width: 1100px) {
  .topbar-brand { gap: 9px; }
  .brand-logo { width: 38px; height: 38px; }
  .brand-title { font-size: 16px; letter-spacing: 3px; }
  .brand-subtitle { font-size: 7.5px; letter-spacing: 4px; margin-top: 4px; }
  .tab-btn {
    padding: 6px 11px 6px 10px;
    height: 34px;
    font-size: 10.5px;
    letter-spacing: 1px;
    gap: 6px;
  }
  .tab-icon { font-size: 14px; }
  /* User card slightly smaller */
  .user-card { padding: 3px 12px 3px 3px; gap: 8px; }
  .user-avatar { width: 28px; height: 28px; font-size: 11px; }
  .user-name { font-size: 11.5px; }
  .user-role-text { font-size: 8.5px; letter-spacing: 1.2px; }
  .logout-btn { padding: 6px 11px; font-size: 10.5px; letter-spacing: 1.2px; }
  /* Brand stats pills compact */
  .brand-stat-pill { padding: 3px 8px 3px 7px; gap: 5px; }
  .brand-stat-num { font-size: 11px; }
  .brand-stat-label { font-size: 7px; }
}

/* ============================================================
   RESPONSIVE — TABLET (≤1024px)
   ============================================================ */
@media (max-width: 1024px) {
  /* Topbar */
  .topbar {
    padding: 0 12px;
    gap: 8px;
    height: 44px;
  }
  .topbar-brand {
    gap: 8px;
  }
  .brand-logo { width: 32px; height: 32px; }
  .brand-title { font-size: 14px; letter-spacing: 2.5px; }
  .brand-subtitle { display: none; }
  /* User card minimal — hide name, keep avatar + role */
  .user-card { padding: 2px 10px 2px 2px; gap: 6px; }
  .user-avatar { width: 26px; height: 26px; font-size: 10.5px; }
  .user-name { display: none; }
  .user-role-text { font-size: 9px; letter-spacing: 1px; }
  .logout-btn span { display: none; }
  .logout-btn { padding: 7px 9px; }
  /* Brand stats — only icons + numbers (hide labels) */
  .brand-stats-pills { gap: 4px; }
  .brand-stat-pill { padding: 3px 7px 3px 6px; gap: 4px; }
  .brand-stat-label { display: none; }
  .brand-stat-num { font-size: 11px; }
  .topbar-user {
    font-size: 10.5px;
  }
  /* Tabs scrollable */
  .tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    height: 38px;
  }
  .tabs::-webkit-scrollbar { display: none; }
  .tab-btn {
    flex-shrink: 0;
    padding: 6px 10px;
    height: 32px;
    font-size: 10px;
    letter-spacing: 0.8px;
    gap: 5px;
  }
  .tab-icon { font-size: 13px; }

  /* Workspace stacks: solutions on top (limited height), brand list below */
  .workspace-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(280px, 50vh) auto;
    overflow-y: auto;
  }
  .workspace-foot-grid {
    grid-template-columns: 1fr;
  }
  .workspace-foot-grid .ws-foot-info {
    margin-top: 8px;
  }

  /* DTC customer detail: stack columns */
  .dtc-cust-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(220px, 35vh) auto;
  }

  /* Admin grid: stack */
  .admin-grid {
    grid-template-columns: 1fr !important;
  }
  .admin-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    scrollbar-width: none;
  }
  .admin-tabs::-webkit-scrollbar { display: none; }
  .admin-tab-btn { flex-shrink: 0; }

  /* Library grid: stack */
  .library-grid {
    grid-template-columns: 1fr !important;
  }

  /* Modal sizes */
  .modal {
    max-width: 92vw !important;
  }
  .form-row-2col {
    grid-template-columns: 1fr 1fr;
  }

  /* INFO grid */
  .info-grid {
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  }

  /* Hero stats wrap */
  .info-hero-stats {
    grid-template-columns: repeat(2, 1fr);
  }

  /* DTC library list */
  .dtc-library-list {
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  }
}

/* ============================================================
   RESPONSIVE — MOBILE (≤640px)
   ============================================================ */
@media (max-width: 640px) {
  /* Topbar — slim and compact */
  .topbar {
    height: 40px;
    padding: 0 10px;
    gap: 6px;
  }
  .topbar-brand {
    gap: 6px;
  }
  .brand-logo { width: 26px; height: 26px; }
  .brand-title { font-size: 11px; letter-spacing: 1.5px; }
  .brand-subtitle { display: none; }
  .topbar-user {
    font-size: 9.5px;
    margin-left: auto;
    white-space: nowrap;
  }
  .topbar-logout {
    padding: 3px 7px;
    font-size: 9.5px;
  }
  .topbar-fp-badge {
    display: none; /* hide HWID badge on mobile to save space */
  }

  /* Tabs — compact */
  .tabs {
    padding: 0 6px;
    height: 34px;
  }
  .tab-btn {
    padding: 6px 9px 6px 8px;
    height: 30px;
    font-size: 9.5px;
    letter-spacing: 0.4px;
    gap: 4px;
  }
  .tab-icon { font-size: 12px; }
  /* Hide pulse dot on small mobile to save space */
  .tab-btn.active::before { display: none; }

  /* Workspace */
  .workspace-grid {
    padding: 8px;
    gap: 8px;
    grid-template-rows: minmax(260px, 45vh) auto;
  }
  .panel-header {
    padding: 8px 10px;
    flex-wrap: wrap;
    gap: 6px;
  }
  .panel-title {
    font-size: 11px;
    letter-spacing: 1px;
  }
  .ws-header-actions {
    flex-wrap: wrap;
    gap: 4px;
  }
  .ws-btn {
    padding: 5px 8px;
    font-size: 10px;
    letter-spacing: 0.4px;
  }
  .ws-btn span { font-size: 12px; }

  /* Brand items more compact */
  .brand-item {
    padding: 7px 10px;
    gap: 9px;
  }
  .brand-logo {
    width: 28px;
    height: 28px;
  }
  .brand-name {
    font-size: 12px;
  }
  .brand-count {
    font-size: 9.5px;
    padding: 1px 6px;
  }

  /* ECU items */
  .ecu-item {
    padding: 6px 10px 6px 22px;
    font-size: 10.5px;
    gap: 6px;
  }
  .ecu-sols {
    max-width: 50%;
  }
  .ecu-sol {
    font-size: 6px;
    padding: 1px 2px;
    line-height: 1.3;
  }

  /* Solutions list (left panel) */
  .solutions-list {
    padding: 6px;
  }
  .method-filter-bar {
    padding: 6px 8px;
    gap: 4px;
    overflow-x: auto;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .method-filter-bar::-webkit-scrollbar { display: none; }
  .method-filter-btn {
    flex-shrink: 0;
    font-size: 10px;
    padding: 5px 8px;
  }

  /* Workspace foot console */
  .workspace-foot-grid {
    padding: 8px;
    grid-template-rows: 100px auto;
    grid-template-columns: 1fr;
  }
  .console {
    height: 100px !important;
    font-size: 10.5px;
  }

  /* Modals — full screen on mobile */
  .modal-backdrop {
    padding: 0;
    align-items: stretch;
    justify-content: stretch;
  }
  .modal {
    width: 100% !important;
    max-width: 100% !important;
    max-height: 100vh !important;
    min-height: 100vh;
    border-radius: 0;
    border: none;
    overflow-y: auto;
  }
  .modal-form {
    display: flex;
    flex-direction: column;
  }
  .modal-form-header {
    padding: 14px 16px;
    position: sticky;
    top: 0;
    z-index: 10;
    background: var(--bg-panel);
  }
  .modal-form-icon {
    width: 40px;
    height: 40px;
    font-size: 22px;
  }
  .modal-title-lg {
    font-size: 14px;
  }
  .modal-subtitle-sm {
    font-size: 10px;
  }
  .form-grid {
    padding: 14px 16px;
    flex: 1;
    overflow-y: auto;
    max-height: none;
  }
  .form-row-2col {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .form-input, .form-textarea {
    font-size: 14px; /* prevent iOS zoom on focus */
  }
  .modal-form .modal-actions {
    padding: 12px 16px;
    position: sticky;
    bottom: 0;
    z-index: 10;
    background: var(--bg-deep);
  }
  .modal-btn {
    padding: 11px;
    font-size: 12px;
  }
  /* Confirm modal stays small but centered */
  .modal-backdrop:has(.modal:not(.modal-form)) {
    padding: 16px;
    align-items: center;
    justify-content: center;
  }
  .modal:not(.modal-form) {
    min-height: 0;
    border-radius: 12px !important;
    border: 1px solid var(--border) !important;
  }

  /* DTC library */
  .dtc-library-list {
    grid-template-columns: 1fr !important;
    padding: 8px !important;
    gap: 8px !important;
  }
  .dtc-library-search {
    flex-wrap: wrap;
    gap: 6px;
    padding: 8px;
  }
  .dtc-library-search input,
  .dtc-library-search select {
    width: 100% !important;
    flex: 1 1 100%;
  }
  .dtc-card {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 10px;
  }
  .dtc-card-info {
    grid-column: 1 / -1;
  }
  .dtc-card-actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
    margin-top: 4px;
  }

  /* DTC customer log: stack */
  .dtc-cust-grid {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(180px, 30vh) auto;
    padding: 8px;
    gap: 8px;
  }
  .dtc-subtab-bar {
    padding: 8px;
  }

  /* INFO tab */
  .info-wrap {
    padding: 10px;
    gap: 12px;
  }
  .info-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .info-tile {
    padding: 10px 12px;
    gap: 10px;
  }
  .info-tile-icon {
    width: 32px;
    height: 32px;
    font-size: 20px;
  }
  .info-tile-name {
    font-size: 11.5px;
  }
  .info-tile-desc {
    font-size: 10px;
  }
  .info-section-title {
    font-size: 12px;
  }
  .info-section-subtitle {
    font-size: 10px;
  }
  .news-ticker {
    height: 32px;
  }
  .news-ticker-label {
    font-size: 10px;
    padding: 0 8px;
  }

  /* Admin */
  .admin-grid {
    padding: 8px;
    gap: 8px;
  }
  .admin-tabs {
    padding: 0 8px;
  }
  .admin-tab-btn {
    padding: 7px 10px;
    font-size: 10px;
  }
  .admin-form {
    padding: 12px;
  }
  .field-input, .field-select {
    font-size: 14px; /* prevent iOS zoom */
  }

  /* Library tab */
  .library-grid {
    padding: 8px;
    gap: 8px;
  }
  .lib-drop {
    padding: 14px;
  }
  .lib-drop-text {
    font-size: 12px;
  }

  /* Login screen */
  .login-screen {
    padding: 16px;
  }
  .login-box {
    width: 100%;
    max-width: 400px;
    padding: 24px 20px;
  }
  .login-title {
    font-size: 18px;
  }
  .login-input {
    font-size: 14px; /* prevent iOS zoom */
  }

  /* Customer list & detail */
  .cust-list {
    font-size: 12px;
  }
  .cust-detail-name {
    font-size: 16px;
  }
  .cust-vehicle-card,
  .cust-visit-card {
    padding: 10px;
  }

  /* Mobile hint banner for workspace */
  .mobile-workspace-hint {
    display: block !important;
  }

  /* Toast adjustment */
  #toast {
    bottom: 16px;
    left: 16px;
    right: 16px;
    transform: translateY(20px);
    max-width: none;
    font-size: 12px;
  }
  #toast.show {
    transform: translateY(0);
  }

  /* Add news modal width on small */
  .news-form {
    padding: 12px;
  }
  .news-form-row {
    flex-direction: column;
    gap: 8px;
  }
}

/* Hide hint on desktop */
.mobile-workspace-hint { display: none; }

/* Very small phones (≤375px) */
@media (max-width: 375px) {
  .topbar {
    height: 36px;
    padding: 0 8px;
  }
  .topbar-brand {
    gap: 5px;
  }
  .brand-logo { width: 22px; height: 22px; }
  .brand-title { font-size: 10px; letter-spacing: 1px; }
  .brand-subtitle { display: none; }
  .topbar-user {
    font-size: 9px;
  }
  .topbar-logout {
    padding: 2px 6px;
    font-size: 9px;
  }
  .tabs {
    height: 30px;
    padding: 0 4px;
  }
  .tab-btn {
    padding: 5px 7px 5px 6px;
    height: 28px;
    font-size: 9px;
    letter-spacing: 0.3px;
    gap: 3px;
  }
  .tab-icon { font-size: 11px; }
  .info-grid {
    grid-template-columns: 1fr;
  }
  .info-hero-stats {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .form-row-2col {
    grid-template-columns: 1fr !important;
  }
}

/* ============================================================
   SOLUTION FORGE — Creative redesign
   ============================================================ */
#admin-library-view {
  overflow-y: auto !important;
  overflow-x: hidden;
  padding: 0 !important;
}
.forge-wrap {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  width: 100%;
  min-height: 0;
}

/* Hero header with animated gradient */
.forge-hero {
  position: relative;
  border-radius: 14px;
  padding: 28px 32px;
  overflow: hidden;
  border: 1px solid rgba(6, 182, 212, 0.25);
  background: linear-gradient(135deg, rgba(6, 182, 212, 0.10) 0%, rgba(99, 102, 241, 0.08) 50%, rgba(245, 158, 11, 0.08) 100%);
  flex-shrink: 0;
}
.forge-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 50%, rgba(6, 182, 212, 0.15), transparent 50%),
    radial-gradient(circle at 80% 50%, rgba(245, 158, 11, 0.12), transparent 50%);
  animation: forge-pulse 8s ease-in-out infinite;
  pointer-events: none;
}
@keyframes forge-pulse {
  0%, 100% { opacity: 0.6; }
  50% { opacity: 1; }
}
.forge-hero-content {
  position: relative;
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.forge-hero-icon {
  font-size: 56px;
  filter: drop-shadow(0 4px 12px rgba(6, 182, 212, 0.4));
}
.forge-hero-text { flex: 1; min-width: 200px; }
.forge-hero-title {
  font-size: 26px;
  font-weight: 800;
  letter-spacing: 2px;
  background: linear-gradient(135deg, #06b6d4 0%, #f59e0b 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 4px;
}
.forge-hero-subtitle {
  font-size: 12px;
  color: var(--text-dim);
  letter-spacing: 0.3px;
}
.forge-hero-stats {
  display: flex;
  gap: 16px;
}
.forge-stat {
  text-align: center;
  padding: 10px 18px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(6, 182, 212, 0.2);
  border-radius: 10px;
  min-width: 76px;
  backdrop-filter: blur(10px);
}
.forge-stat-num {
  font-size: 22px;
  font-weight: 800;
  color: var(--accent);
  font-family: monospace;
  letter-spacing: 0.5px;
}
.forge-stat-label {
  font-size: 9px;
  color: var(--text-faint);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-top: 2px;
}

/* Mode toggle (Library/Builder) */
.forge-mode-toggle {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.forge-mode-btn {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 14px;
  text-align: left;
  transition: all 0.2s;
  color: var(--text-dim);
}
.forge-mode-btn:hover {
  border-color: var(--accent);
  background: var(--bg-panel-2);
  transform: translateY(-1px);
}
.forge-mode-btn.active {
  background: linear-gradient(135deg, rgba(6, 182, 212, 0.12) 0%, rgba(6, 182, 212, 0.04) 100%);
  border-color: var(--accent);
  color: var(--text);
  box-shadow: 0 4px 16px rgba(6, 182, 212, 0.15);
}
.forge-mode-icon {
  font-size: 28px;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.3));
}
.forge-mode-text {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 1px;
  display: block;
}
.forge-mode-desc {
  font-size: 10px;
  color: var(--text-faint);
  font-weight: 400;
  display: block;
  margin-top: 2px;
}
.forge-mode-btn.active .forge-mode-text { color: var(--accent); }

/* Mode content */
.forge-mode-content { display: none; }
.forge-mode-content.active { display: block; animation: forge-fade-in 0.3s ease; }
@keyframes forge-fade-in {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* LIBRARY MODE */
.forge-toolbar {
  display: grid;
  grid-template-columns: 1fr 200px 200px auto;
  gap: 10px;
  margin-bottom: 14px;
}
.forge-search-wrap {
  position: relative;
}
.forge-search-icon {
  position: absolute;
  left: 12px; top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
  font-size: 13px;
}
.forge-search {
  width: 100%;
  padding: 10px 12px 10px 34px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font-size: 12px;
  font-family: inherit;
  transition: all 0.15s;
}
.forge-search:focus {
  outline: none;
  border-color: var(--accent);
  background: var(--bg-panel-2);
  box-shadow: 0 0 0 3px rgba(6, 182, 212, 0.15);
}
.forge-filter {
  padding: 10px 12px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--text);
  font-size: 12px;
  font-family: inherit;
  cursor: pointer;
}
.forge-action-btn {
  padding: 10px 16px;
  background: linear-gradient(135deg, var(--accent) 0%, #0891b2 100%);
  border: none;
  border-radius: 8px;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all 0.15s;
  white-space: nowrap;
}
.forge-action-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(6, 182, 212, 0.3); }
.forge-action-secondary {
  background: var(--bg-elev);
  color: var(--text-dim);
  border: 1px solid var(--border);
}
.forge-action-secondary:hover { color: var(--accent); border-color: var(--accent); }

.forge-counter {
  font-size: 11px;
  color: var(--text-faint);
  margin-bottom: 10px;
  letter-spacing: 0.3px;
}

.forge-list {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  min-height: 180px;
  max-height: 50vh;
  overflow-y: auto;
  padding: 8px;
}

.forge-empty {
  text-align: center;
  padding: 50px 20px;
  color: var(--text-faint);
}
.forge-empty-icon { font-size: 48px; margin-bottom: 12px; opacity: 0.6; }
.forge-empty-title {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-dim);
  margin-bottom: 4px;
}
.forge-empty-desc { font-size: 11px; color: var(--text-faint); }

.forge-apply-bar {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  margin-top: 14px;
}
.forge-apply-load,
.forge-apply-btn {
  padding: 12px 18px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.6px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: all 0.15s;
  border: none;
  font-family: inherit;
}
.forge-apply-load {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  color: var(--text);
}
.forge-apply-load:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.forge-apply-btn {
  background: linear-gradient(135deg, #10b981 0%, #059669 100%);
  color: #fff;
  font-size: 12px;
}
.forge-apply-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(16, 185, 129, 0.35);
}
.forge-apply-btn:disabled {
  background: var(--bg-elev);
  color: var(--text-faint);
  cursor: not-allowed;
}
.forge-apply-hint {
  font-size: 10px;
  color: var(--text-faint);
  text-align: center;
  margin-top: 8px;
  font-style: italic;
}

/* BUILDER MODE */
.forge-builder-intro {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 16px;
  background: linear-gradient(90deg, rgba(245, 158, 11, 0.08) 0%, transparent 100%);
  border-left: 3px solid var(--orange);
  border-radius: 6px;
  margin-bottom: 14px;
}
.forge-builder-step {
  width: 30px; height: 30px;
  background: var(--orange);
  color: #1a1a1a;
  font-weight: 800;
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(245, 158, 11, 0.3);
}
.forge-builder-step-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 2px;
}
.forge-builder-step-desc {
  font-size: 11px;
  color: var(--text-faint);
}

.forge-drops {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 10px;
  align-items: center;
  margin-bottom: 10px;
}
.forge-drop {
  position: relative;
  padding: 14px 14px 12px;
  background: var(--bg-panel);
  border: 2px dashed var(--border);
  border-radius: 10px;
  cursor: pointer;
  text-align: center;
  transition: all 0.2s;
}
.forge-drop:hover {
  border-color: var(--accent);
  background: var(--bg-panel-2);
}
.forge-drop.has-file {
  border-color: var(--green);
  border-style: solid;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.08) 0%, transparent 100%);
}
.forge-drop-tuned:hover { border-color: var(--orange); }
.forge-drop-tuned.has-file { border-color: var(--orange); background: linear-gradient(135deg, rgba(245, 158, 11, 0.10) 0%, transparent 100%); }
.forge-drop-badge {
  position: absolute;
  top: -8px; left: 50%;
  transform: translateX(-50%);
  background: var(--bg-elev);
  border: 1px solid var(--border);
  padding: 1px 10px;
  border-radius: 10px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1.2px;
  color: var(--text-dim);
}
.forge-drop:hover .forge-drop-badge { color: var(--accent); border-color: var(--accent); }
.forge-drop-tuned:hover .forge-drop-badge { color: var(--orange); border-color: var(--orange); }
.forge-drop.has-file .forge-drop-badge { color: var(--green); border-color: var(--green); }
.forge-drop-tuned.has-file .forge-drop-badge { color: var(--orange); border-color: var(--orange); }
.forge-drop-icon {
  font-size: 22px;
  margin-bottom: 4px;
  opacity: 0.7;
}
.forge-drop .file-drop-text {
  font-size: 10.5px;
  line-height: 1.3;
}
.forge-vs {
  font-size: 12px;
  font-weight: 800;
  color: var(--text-faint);
  letter-spacing: 1.5px;
  background: var(--bg-elev);
  padding: 4px 8px;
  border-radius: 5px;
  border: 1px solid var(--border);
}

.forge-compare-btn {
  width: 100%;
  padding: 9px;
  background: linear-gradient(135deg, var(--accent) 0%, #0891b2 100%);
  border: none;
  border-radius: 8px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: inherit;
  transition: all 0.15s;
  margin-bottom: 10px;
}
.forge-compare-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(6, 182, 212, 0.35);
}
.forge-compare-btn:disabled {
  background: var(--bg-elev);
  color: var(--text-faint);
  cursor: not-allowed;
}

.forge-fields {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px 10px;
  margin-bottom: 10px;
}
.forge-fields .field-full { grid-column: 1 / -1; }
/* Tighter spacing inside builder fields */
.forge-fields .field-label {
  font-size: 9.5px;
  letter-spacing: 0.8px;
  margin-bottom: 3px;
}
.forge-fields .field-input,
.forge-fields .field-select {
  padding: 6px 9px;
  font-size: 11.5px;
}
.forge-fields .field-textarea {
  min-height: 38px;
  padding: 6px 9px;
  font-size: 11.5px;
}
.forge-fields .method-group {
  grid-template-columns: repeat(5, 1fr);
  gap: 5px;
}
.forge-fields .method-btn {
  padding: 6px 4px;
  font-size: 10px;
  letter-spacing: 0.3px;
}

.forge-save-btn {
  width: 100%;
  padding: 11px;
  background: linear-gradient(135deg, #10b981 0%, #059669 100%);
  border: none;
  border-radius: 8px;
  color: #fff;
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 1.5px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-family: inherit;
  transition: all 0.15s;
}
.forge-save-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(16, 185, 129, 0.35);
}
.forge-save-btn:disabled {
  background: var(--bg-elev);
  color: var(--text-faint);
  cursor: not-allowed;
}

/* Mobile responsive */
@media (max-width: 800px) {
  .forge-wrap { padding: 12px; }
  .forge-hero { padding: 18px; }
  .forge-hero-icon { font-size: 36px; }
  .forge-hero-title { font-size: 18px; letter-spacing: 1px; }
  .forge-hero-stats { width: 100%; justify-content: space-around; }
  .forge-mode-toggle { grid-template-columns: 1fr; }
  .forge-toolbar { grid-template-columns: 1fr; }
  .forge-drops { grid-template-columns: 1fr; }
  .forge-vs { justify-self: center; }
  .forge-apply-bar { grid-template-columns: 1fr; }
  .forge-fields { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 1100px) {
  .forge-fields { grid-template-columns: repeat(2, 1fr); }
}


/* ============================================================
   EMPTY STATES
   ============================================================ */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 50px 24px;
  min-height: 200px;
  color: var(--text-faint, #7a8499);
}
.empty-state-icon {
  font-size: 56px;
  margin-bottom: 18px;
  opacity: 0.85;
  animation: empty-pulse 2.4s ease-in-out infinite;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,0.3));
}
.empty-state-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-strong, #d4dbeb);
  margin-bottom: 8px;
  letter-spacing: 0.3px;
}
.empty-state-message {
  font-size: 13px;
  line-height: 1.5;
  max-width: 380px;
  margin-bottom: 20px;
  color: var(--text-faint, #7a8499);
}
.empty-state-cta {
  background: linear-gradient(135deg, #00b8d4, #008c9e);
  color: #fff;
  border: none;
  padding: 10px 22px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.5px;
  transition: transform 0.15s, box-shadow 0.15s;
  box-shadow: 0 4px 12px rgba(0, 184, 212, 0.25);
}
.empty-state-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(0, 184, 212, 0.35);
}
.empty-state-cta:active {
  transform: translateY(0);
}
.empty-state.compact {
  padding: 24px 16px;
  min-height: 120px;
}
.empty-state.compact .empty-state-icon {
  font-size: 36px;
  margin-bottom: 10px;
}
.empty-state.compact .empty-state-title {
  font-size: 13px;
}
.empty-state.compact .empty-state-message {
  font-size: 12px;
  margin-bottom: 12px;
}
@keyframes empty-pulse {
  0%, 100% { opacity: 0.85; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.05); }
}


/* ============================================================
   ECU MANAGEMENT
   ============================================================ */
.ecu-mgmt-grid {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 16px;
  padding: 20px;
}
@media (max-width: 900px) {
  .ecu-mgmt-grid { grid-template-columns: 1fr; }
}
.ecu-mgmt-section-title {
  font-size: 13px;
  font-weight: 600;
  color: #d4dbeb;
  margin-bottom: 12px;
  letter-spacing: 0.5px;
  padding-bottom: 8px;
  border-bottom: 1px solid #2a3344;
}
.ecu-mgmt-brands {
  background: rgba(20, 25, 38, 0.6);
  border: 1px solid #2a3344;
  border-radius: 10px;
  padding: 14px;
  align-self: start;
  max-height: 500px;
  overflow-y: auto;
}
.ecu-mgmt-brand-item {
  padding: 10px 12px;
  border-radius: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
  transition: background 0.15s;
  border: 1px solid transparent;
}
.ecu-mgmt-brand-item:hover {
  background: rgba(0, 184, 212, 0.08);
}
.ecu-mgmt-brand-item.active {
  background: rgba(0, 184, 212, 0.15);
  border-color: rgba(0, 184, 212, 0.4);
}
.ecu-mgmt-brand-logo {
  font-size: 18px;
  width: 28px;
  text-align: center;
  flex-shrink: 0;
}
.ecu-mgmt-brand-name {
  font-size: 13px;
  font-weight: 500;
  color: #d4dbeb;
  flex: 1;
}
.ecu-mgmt-brand-count {
  font-size: 11px;
  color: #7a8499;
  background: rgba(0, 0, 0, 0.3);
  padding: 2px 8px;
  border-radius: 10px;
}
.ecu-mgmt-ecus {
  background: rgba(20, 25, 38, 0.6);
  border: 1px solid #2a3344;
  border-radius: 10px;
  padding: 14px;
}
.ecu-mgmt-toolbar {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid #2a3344;
}
.ecu-mgmt-hint {
  font-size: 11px;
  color: #7a8499;
  font-style: italic;
}
.ecu-item {
  background: #1a1f2e;
  border: 1px solid #2a3344;
  border-radius: 8px;
  padding: 10px 14px;
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: grab;
  transition: all 0.15s;
}
.ecu-item:hover {
  border-color: rgba(0, 184, 212, 0.4);
  background: rgba(0, 184, 212, 0.05);
}
.ecu-item.dragging {
  opacity: 0.4;
  cursor: grabbing;
}
.ecu-item.drag-over {
  border-top: 2px solid #00b8d4;
}
.ecu-drag-handle {
  color: #5a6478;
  font-size: 16px;
  cursor: grab;
  user-select: none;
  padding: 0 4px;
}
.ecu-drag-handle:hover { color: #00b8d4; }
.ecu-item-info {
  flex: 1;
  min-width: 0;
}
.ecu-item-name {
  font-size: 13px;
  font-weight: 600;
  color: #d4dbeb;
}
.ecu-item-mfr {
  font-size: 11px;
  color: #7a8499;
  margin-top: 2px;
}
.ecu-item-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}
.ecu-item-btn {
  background: rgba(0, 0, 0, 0.3);
  border: 1px solid #2a3344;
  color: #b8c2d4;
  padding: 5px 10px;
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  transition: all 0.15s;
}
.ecu-item-btn:hover { background: rgba(0, 184, 212, 0.2); border-color: #00b8d4; }
.ecu-item-btn.danger { color: #ff6b6b; }
.ecu-item-btn.danger:hover { background: rgba(255, 107, 107, 0.15); border-color: #ff6b6b; }


/* TAB CONTENT SCROLL FIX */
.tab-content.active {
  overflow: hidden !important;
}


/* ============================================================
   DASHBOARD
   ============================================================ */
.dashboard-wrap {
  padding: 20px;
  width: 100%;
}
.dashboard-hero {
  display: flex;
  align-items: center;
  gap: 16px;
  background: linear-gradient(135deg, rgba(0, 184, 212, 0.1), rgba(0, 140, 158, 0.05));
  border: 1px solid rgba(0, 184, 212, 0.25);
  border-radius: 14px;
  padding: 20px 24px;
  margin-bottom: 22px;
  position: relative;
  overflow: hidden;
}
.dashboard-hero-icon {
  font-size: 48px;
  filter: drop-shadow(0 4px 12px rgba(0, 184, 212, 0.4));
}
.dashboard-hero-text { flex: 1; }
.dashboard-hero-title {
  font-size: 24px;
  font-weight: 700;
  color: #00d4ff;
  letter-spacing: 1.5px;
}
.dashboard-hero-subtitle {
  font-size: 12px;
  color: #7a8499;
  margin-top: 4px;
}
.dashboard-refresh-btn {
  background: rgba(0, 184, 212, 0.15);
  border: 1px solid rgba(0, 184, 212, 0.3);
  color: #00d4ff;
  width: 40px;
  height: 40px;
  border-radius: 8px;
  font-size: 18px;
  cursor: pointer;
  transition: all 0.2s;
}
.dashboard-refresh-btn:hover { background: rgba(0, 184, 212, 0.3); transform: rotate(180deg); }

.dashboard-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 22px;
}
.dashboard-kpi-card {
  background: linear-gradient(180deg, rgba(20, 25, 38, 0.8), rgba(15, 20, 32, 0.9));
  border: 1px solid #2a3344;
  border-radius: 12px;
  padding: 18px;
  text-align: center;
  transition: transform 0.15s, border-color 0.15s;
}
.dashboard-kpi-card:hover {
  transform: translateY(-2px);
  border-color: rgba(0, 184, 212, 0.4);
}
.dashboard-kpi-icon { font-size: 28px; margin-bottom: 8px; }
.dashboard-kpi-value {
  font-size: 28px;
  font-weight: 700;
  color: #00d4ff;
  letter-spacing: 0.5px;
}
.dashboard-kpi-label {
  font-size: 11px;
  color: #7a8499;
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.dashboard-section {
  background: rgba(20, 25, 38, 0.6);
  border: 1px solid #2a3344;
  border-radius: 12px;
  padding: 18px;
  margin-bottom: 16px;
}
.dashboard-section-title {
  font-size: 14px;
  font-weight: 600;
  color: #d4dbeb;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid #2a3344;
}
.dashboard-chart-wrap {
  height: 260px;
  position: relative;
}

.dashboard-grid-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 900px) {
  .dashboard-grid-2col { grid-template-columns: 1fr; }
}

.dashboard-alerts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}
.dashboard-alert-card {
  background: rgba(255, 165, 0, 0.08);
  border: 1px solid rgba(255, 165, 0, 0.3);
  border-radius: 10px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.dashboard-alert-icon { font-size: 22px; }
.dashboard-alert-info { flex: 1; }
.dashboard-alert-count {
  font-size: 18px;
  font-weight: 700;
  color: #ffb547;
}
.dashboard-alert-label { font-size: 11px; color: #c4a87f; }

.dashboard-recent-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid rgba(42, 51, 68, 0.5);
}
.dashboard-recent-row:last-child { border-bottom: none; }
.dashboard-recent-main {
  font-size: 13px;
  color: #d4dbeb;
  font-weight: 500;
}
.dashboard-recent-meta {
  font-size: 11px;
  color: #7a8499;
  margin-top: 2px;
}
.dashboard-recent-right {
  font-size: 11px;
  color: #7a8499;
  text-align: right;
  flex-shrink: 0;
}
.dashboard-recent-paid {
  background: rgba(76, 175, 80, 0.15);
  color: #4caf50;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 600;
  margin-left: 6px;
}
.dashboard-recent-unpaid {
  background: rgba(244, 67, 54, 0.15);
  color: #ef5350;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 600;
  margin-left: 6px;
}


/* DASHBOARD SCROLL FIX */
#tab-dashboard.active {
  overflow-y: auto !important;
  overflow-x: hidden;
}


/* ============================================================
   NOTIFICATIONS BELL
   ============================================================ */
.notif-wrap {
  position: relative;
  display: inline-block;
  margin-right: 8px;
}
.notif-bell {
  background: rgba(20, 25, 38, 0.6);
  border: 1px solid #2a3344;
  color: #d4dbeb;
  width: 40px;
  height: 40px;
  border-radius: 8px;
  cursor: pointer;
  position: relative;
  transition: all 0.15s;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.notif-bell:hover {
  background: rgba(0, 184, 212, 0.15);
  border-color: rgba(0, 184, 212, 0.4);
}
.notif-bell-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background: #ff4444;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  padding: 0 5px;
  line-height: 18px;
  text-align: center;
  border: 2px solid #0a0e17;
  animation: notif-pulse 2s infinite;
}
@keyframes notif-pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.15); }
}
.notif-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 360px;
  max-width: 92vw;
  background: #131825;
  border: 1px solid #2a3344;
  border-radius: 12px;
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.6);
  z-index: 9999;
  display: none;
  flex-direction: column;
  max-height: 480px;
  overflow: hidden;
}
.notif-dropdown.open { display: flex; }
.notif-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid #2a3344;
  flex-shrink: 0;
}
.notif-header-title {
  font-size: 14px;
  font-weight: 600;
  color: #d4dbeb;
}
.notif-action {
  background: transparent;
  border: none;
  color: #00b8d4;
  font-size: 12px;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 4px;
  transition: background 0.15s;
}
.notif-action:hover { background: rgba(0, 184, 212, 0.1); }
.notif-action.danger { color: #ff7676; }
.notif-action.danger:hover { background: rgba(255, 118, 118, 0.1); }
.notif-list {
  flex: 1;
  overflow-y: auto;
  max-height: 360px;
}
.notif-item {
  padding: 12px 16px;
  border-bottom: 1px solid rgba(42, 51, 68, 0.4);
  display: flex;
  gap: 12px;
  cursor: pointer;
  transition: background 0.15s;
  position: relative;
}
.notif-item:hover { background: rgba(0, 184, 212, 0.06); }
.notif-item.unread { background: rgba(0, 184, 212, 0.05); }
.notif-item.unread::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #00d4ff;
}
.notif-item-icon {
  font-size: 22px;
  flex-shrink: 0;
  width: 32px;
  text-align: center;
}
.notif-item-content { flex: 1; min-width: 0; }
.notif-item-title {
  font-size: 13px;
  font-weight: 600;
  color: #d4dbeb;
  margin-bottom: 2px;
}
.notif-item-body {
  font-size: 12px;
  color: #b0b8cc;
  line-height: 1.4;
  margin-bottom: 4px;
  word-wrap: break-word;
}
.notif-item-time {
  font-size: 11px;
  color: #6a7488;
}
.notif-item-delete {
  background: transparent;
  border: none;
  color: #6a7488;
  font-size: 14px;
  cursor: pointer;
  padding: 0 4px;
  opacity: 0;
  transition: opacity 0.15s;
}
.notif-item:hover .notif-item-delete { opacity: 1; }
.notif-item-delete:hover { color: #ff7676; }
.notif-footer {
  padding: 8px 16px;
  border-top: 1px solid #2a3344;
  text-align: center;
  flex-shrink: 0;
}
.notif-empty {
  padding: 40px 20px;
  text-align: center;
  color: #6a7488;
  font-size: 13px;
}


/* STATS — Users Status */
.stats-users-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin-top: 8px;
}
.stats-user-card {
  background: rgba(20, 25, 38, 0.6);
  border: 1px solid #2a3344;
  border-radius: 10px;
  padding: 14px;
  text-align: center;
  transition: all 0.15s;
}
.stats-user-card.online { border-color: rgba(76, 175, 80, 0.4); }
.stats-user-card.online .stats-user-value { color: #4caf50; }
.stats-user-card.offline { border-color: rgba(122, 132, 153, 0.4); }
.stats-user-card.disabled { border-color: rgba(244, 67, 54, 0.4); }
.stats-user-card.disabled .stats-user-value { color: #ef5350; }
.stats-user-icon { font-size: 24px; margin-bottom: 6px; }
.stats-user-value {
  font-size: 26px;
  font-weight: 700;
  color: #00d4ff;
}
.stats-user-label {
  font-size: 11px;
  color: #7a8499;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 4px;
}


/* USERS LIST (last seen) */
#stats-users-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}
.user-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  background: rgba(20, 25, 38, 0.5);
  border: 1px solid #2a3344;
  border-radius: 8px;
  transition: background 0.15s;
}
.user-row:hover { background: rgba(0, 184, 212, 0.06); }
.user-row.disabled { opacity: 0.55; }
.user-row-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, #06b6d4, #f59e0b);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 13px;
  color: #fff;
  flex-shrink: 0;
}
.user-row-info { flex: 1; min-width: 0; }
.user-row-name {
  font-weight: 600;
  color: #d4dbeb;
  font-size: 14px;
}
.user-row-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 3px;
  font-size: 11px;
  color: #7a8499;
}
.user-row-role {
  background: rgba(0, 184, 212, 0.15);
  padding: 2px 6px;
  border-radius: 4px;
  font-weight: 600;
  color: #00d4ff;
  font-size: 10px;
}
.user-row-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}
.user-row-dot.online { background: #4caf50; box-shadow: 0 0 6px #4caf50; }
.user-row-dot.offline { background: #6a7488; }
.user-row-dot.disabled { background: #ef5350; }

/* SPLASH SCREEN */
#app-splash {
  position: fixed;
  inset: 0;
  background: linear-gradient(135deg, #0a0e17, #131825);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  transition: opacity 0.4s ease;
}
#app-splash.fade-out { opacity: 0; pointer-events: none; }
.app-splash-logo {
  font-size: 32px;
  font-weight: 700;
  color: #f59e0b;
  letter-spacing: 2px;
  margin-bottom: 12px;
  text-shadow: 0 0 20px rgba(245, 158, 11, 0.4);
}
.app-splash-sub {
  font-size: 12px;
  color: #7a8499;
  letter-spacing: 1px;
  margin-bottom: 32px;
}
.app-splash-bar {
  width: 200px;
  height: 3px;
  background: rgba(255,255,255,0.05);
  border-radius: 2px;
  overflow: hidden;
}
.app-splash-bar-fill {
  height: 100%;
  width: 30%;
  background: linear-gradient(90deg, #06b6d4, #f59e0b);
  animation: splash-loading 1.2s infinite;
}
@keyframes splash-loading {
  0%   { transform: translateX(-100%); width: 30%; }
  50%  { width: 60%; }
  100% { transform: translateX(400%); width: 30%; }
}


/* AVATAR GRID (Edit Profile) */
.avatar-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 6px;
  margin-top: 8px;
  max-height: 200px;
  overflow-y: auto;
  padding: 8px;
  background: rgba(20, 25, 38, 0.4);
  border-radius: 8px;
  border: 1px solid #2a3344;
}
.avatar-option {
  width: 38px;
  height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  background: rgba(255,255,255,0.03);
  border: 2px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s;
  user-select: none;
}
.avatar-option:hover {
  background: rgba(0, 184, 212, 0.12);
  transform: scale(1.1);
}
.avatar-option.selected {
  background: rgba(0, 184, 212, 0.2);
  border-color: #00d4ff;
  box-shadow: 0 0 12px rgba(0, 184, 212, 0.4);
}
.avatar-option.none-option {
  font-size: 14px;
  color: #6a7488;
  font-weight: 600;
}

/* User card avatar with emoji */
.user-avatar.emoji-avatar {
  font-size: 22px;
  background: rgba(255,255,255,0.05);
}


.profile-menu-username {
  font-size: 11px;
  color: #00d4ff;
  font-family: 'Courier New', monospace;
  margin-top: 2px;
  opacity: 0.85;
}


/* ECU IDENTIFICATION SECTION (te Save Solution) */
.ecu-id-section {
  background: rgba(20, 25, 38, 0.6);
  border: 1px solid #2a3344;
  border-radius: 10px;
  padding: 14px;
  margin-bottom: 8px;
}
.ecu-id-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 10px;
  flex-wrap: wrap;
  gap: 6px;
}
.ecu-id-title {
  font-size: 12px;
  font-weight: 700;
  color: #00d4ff;
  letter-spacing: 0.5px;
}
.ecu-id-hint {
  font-size: 10px;
  color: #6a7488;
  font-style: italic;
}
.ecu-id-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.ecu-id-full {
  grid-column: 1 / -1;
}
.field-label-sm {
  display: block;
  font-size: 10px;
  color: #7a8499;
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  font-weight: 600;
}
.ecu-id-input {
  font-family: 'Courier New', monospace;
  font-size: 12px;
  padding: 8px 10px;
}
.ecu-id-input:focus {
  border-color: #00d4ff;
  box-shadow: 0 0 0 2px rgba(0,184,212,0.15);
}
.ecu-id-note {
  margin-top: 10px;
  font-size: 11px;
  color: #f59e0b;
  padding: 6px 10px;
  background: rgba(245, 158, 11, 0.08);
  border-radius: 6px;
  border-left: 3px solid #f59e0b;
}


/* AUTO-SUGGEST MODAL */
.autosuggest-grid {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 6px;
  background: rgba(20, 25, 38, 0.5);
  border: 1px solid #2a3344;
  border-radius: 8px;
  padding: 10px;
  max-height: 200px;
  overflow-y: auto;
}
.autosuggest-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  background: rgba(255,255,255,0.02);
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
}
.autosuggest-row:hover { background: rgba(0, 184, 212, 0.08); }
.autosuggest-row input[type=checkbox] {
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: #00d4ff;
}
.autosuggest-label {
  font-size: 11px;
  color: #6a7488;
  text-transform: uppercase;
  font-weight: 600;
  width: 70px;
  letter-spacing: 0.4px;
}
.autosuggest-value {
  flex: 1;
  font-family: 'Courier New', monospace;
  font-size: 13px;
  color: #d4dbeb;
  word-break: break-all;
}


/* THEME TOGGLE BUTTON */
.theme-toggle-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--bg-panel);
  color: var(--text);
  cursor: pointer;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  margin-right: 8px;
}
.theme-toggle-btn:hover {
  background: var(--accent-soft);
  border-color: var(--accent);
  transform: rotate(180deg);
}
[data-theme="cyber"] .theme-toggle-btn {
  box-shadow: 0 0 8px rgba(255, 0, 255, 0.3);
}

/* Light theme - console (logs panel) */
[data-theme="light"] .console {
  background: #ffffff !important;
  color: #1e293b !important;
  border: 1px solid #cbd5e1 !important;
}
[data-theme="light"] .console * {
  color: inherit !important;
}
[data-theme="light"] .console-clear {
  color: #64748b !important;
  background: #f1f5f9 !important;
  border: 1px solid #cbd5e1 !important;
}
[data-theme="light"] .console-clear:hover {
  background: #e2e8f0 !important;
}
/* Logs ngjyrat ne light theme */
[data-theme="light"] .console .log-info,
[data-theme="light"] .console [class*="info"] { color: #0369a1 !important; }
[data-theme="light"] .console .log-success,
[data-theme="light"] .console [class*="success"] { color: #047857 !important; }
[data-theme="light"] .console .log-warn,
[data-theme="light"] .console .log-warning,
[data-theme="light"] .console [class*="warn"] { color: #b45309 !important; }
[data-theme="light"] .console .log-error,
[data-theme="light"] .console [class*="error"] { color: #b91c1c !important; }
✅ CSS u shtuacat


/* HWID Toggle */
.hwid-toggle-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  background: rgba(0, 184, 212, 0.06);
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
}
.hwid-toggle-row:hover { background: rgba(0, 184, 212, 0.1); }
.hwid-toggle-row input[type=checkbox] {
  width: 18px;
  height: 18px;
  accent-color: var(--accent);
  cursor: pointer;
}
.hwid-toggle-text {
  font-size: 12px;
  color: var(--text-dim);
}

/* TuneX Logo */
.brand-logo-img {
  display: block;
  max-width: 100%;
  height: auto;
}
.app-splash-logo .brand-logo-img {
  width: 320px;
  max-width: 80vw;
}
.login-title .brand-logo-img {
  width: 220px;
  margin: 0 auto 8px;
}
.brand-title .brand-logo-img,
.topbar-brand > .brand-logo-img {
  height: 40px;
  width: auto;
}
/* Light theme - prej kuq i logos është e dukshme natyrshëm */
[data-theme="light"] .brand-logo-img {
  filter: none;
}
/* Dark theme - logo bëhet më e ndritshme */
[data-theme="dark"] .brand-logo-img {
  filter: brightness(1.4);
}
