/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   BotPanel v2.0 â€” Premium AI Hosting Panel UI
   Dark glassmorphism theme with fluid animations
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ Design Tokens â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
:root {
  --bg-primary:   #080b16;
  --bg-secondary: #0d1025;
  --bg-tertiary:  #111430;
  --bg-card:      rgba(17, 20, 48, 0.7);
  --bg-card-solid:#111430;
  --bg-hover:     rgba(99, 102, 241, 0.06);
  --bg-input:     rgba(13, 16, 37, 0.8);
  --bg-glass:     rgba(17, 20, 48, 0.45);
  --border:       rgba(99, 102, 241, 0.1);
  --border-light: rgba(99, 102, 241, 0.18);
  --border-glass: rgba(255, 255, 255, 0.05);
  --text-primary:   #eef0ff;
  --text-secondary: #a0a8c8;
  --text-muted:     #5c6380;
  --text-heading:   #f4f5ff;
  --accent:       #6366f1;
  --accent-hover: #818cf8;
  --accent-glow:  rgba(99, 102, 241, 0.12);
  --accent-bright:rgba(99, 102, 241, 0.35);
  --success:    #10b981;
  --success-bg: rgba(16, 185, 129, 0.1);
  --success-border: rgba(16, 185, 129, 0.25);
  --warning:    #f59e0b;
  --warning-bg: rgba(245, 158, 11, 0.1);
  --warning-border: rgba(245, 158, 11, 0.25);
  --danger:     #ef4444;
  --danger-bg:  rgba(239, 68, 68, 0.1);
  --danger-border: rgba(239, 68, 68, 0.25);
  --info:       #3b82f6;
  --info-bg:    rgba(59, 130, 246, 0.1);
  --info-border: rgba(59, 130, 246, 0.25);
  --purple:     #a855f7;
  --pink:       #ec4899;
  --cyan:       #06b6d4;
  --sidebar-width: 264px;
  --sidebar-collapsed: 70px;
  --topbar-height: 62px;
  --radius:    14px;
  --radius-sm: 10px;
  --radius-xs: 6px;
  --shadow:     0 8px 40px rgba(0,0,0,0.4), 0 0 0 1px rgba(99,102,241,0.06);
  --shadow-sm:  0 2px 12px rgba(0,0,0,0.25);
  --shadow-glow:0 0 30px rgba(99,102,241,0.15);
  --ease:       cubic-bezier(0.4, 0, 0.2, 1);
  --ease-spring:cubic-bezier(0.34, 1.56, 0.64, 1);
  --transition: 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  --duration:   0.25s;
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* â”€â”€ Reset & Global â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 14px; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }
body { font-family: var(--font); background: var(--bg-primary); color: var(--text-primary); line-height: 1.65; overflow-x: hidden; min-height: 100vh; }
a { color: var(--accent-hover); text-decoration: none; transition: color var(--duration) var(--ease); }
a:hover { color: #c4b5fd; }
img { max-width: 100%; }
.hidden { display: none !important; }
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.25); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: rgba(99,102,241,0.4); }
::selection { background: var(--accent); color: white; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   LOGIN SCREEN â€” Cinematic immersive experience
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.login-screen {
  min-height: 100vh; display: flex; align-items: center; justify-content: center;
  background: #050816;
  position: relative; overflow: hidden;
}

/* â”€â”€ Animated Background â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.login-bg { position: absolute; inset: 0; z-index: 0; }

/* Grid overlay */
.login-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(99,102,241,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(99,102,241,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, black 20%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 70% 60% at 50% 50%, black 20%, transparent 70%);
  animation: gridPulse 8s ease-in-out infinite;
}
@keyframes gridPulse {
  0%, 100% { opacity: 0.6; }
  50% { opacity: 1; }
}

/* Floating gradient orbs */
.login-orb {
  position: absolute; border-radius: 50%;
  filter: blur(80px);
  animation: floatOrb var(--dur, 12s) var(--delay, 0s) ease-in-out infinite alternate;
}
.login-orb-1 {
  width: 600px; height: 600px; top: -20%; right: -10%;
  background: radial-gradient(circle, rgba(99,102,241,0.2) 0%, transparent 70%);
  --dur: 14s; --delay: 0s;
}
.login-orb-2 {
  width: 450px; height: 450px; bottom: -15%; left: -10%;
  background: radial-gradient(circle, rgba(168,85,247,0.18) 0%, transparent 70%);
  --dur: 16s; --delay: -3s;
}
.login-orb-3 {
  width: 350px; height: 350px; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: radial-gradient(circle, rgba(236,72,153,0.1) 0%, transparent 70%);
  --dur: 18s; --delay: -7s;
}
.login-orb-4 {
  width: 250px; height: 250px; top: 10%; left: 20%;
  background: radial-gradient(circle, rgba(6,182,212,0.1) 0%, transparent 70%);
  --dur: 20s; --delay: -5s;
}

@keyframes floatOrb {
  0%   { transform: translate(0, 0) scale(1); }
  33%  { transform: translate(40px, -30px) scale(1.1); }
  66%  { transform: translate(-25px, 20px) scale(0.95); }
  100% { transform: translate(15px, -15px) scale(1.05); }
}

/* Floating particles */
.login-particles { position: absolute; inset: 0; }
.login-particles span {
  position: absolute; display: block; width: 3px; height: 3px;
  background: rgba(99,102,241,0.4); border-radius: 50%;
  animation: particleFloat var(--p-dur, 10s) var(--p-delay, 0s) linear infinite;
}
.login-particles span:nth-child(1)  { left: 10%; --p-dur: 12s; --p-delay: 0s; }
.login-particles span:nth-child(2)  { left: 20%; --p-dur: 15s; --p-delay: -2s; width: 2px; height: 2px; }
.login-particles span:nth-child(3)  { left: 30%; --p-dur: 11s; --p-delay: -4s; background: rgba(168,85,247,0.4); }
.login-particles span:nth-child(4)  { left: 40%; --p-dur: 14s; --p-delay: -6s; width: 4px; height: 4px; }
.login-particles span:nth-child(5)  { left: 50%; --p-dur: 13s; --p-delay: -1s; }
.login-particles span:nth-child(6)  { left: 60%; --p-dur: 16s; --p-delay: -3s; background: rgba(236,72,153,0.3); width: 2px; height: 2px; }
.login-particles span:nth-child(7)  { left: 70%; --p-dur: 12s; --p-delay: -5s; }
.login-particles span:nth-child(8)  { left: 80%; --p-dur: 18s; --p-delay: -7s; width: 4px; height: 4px; background: rgba(6,182,212,0.3); }
.login-particles span:nth-child(9)  { left: 15%; --p-dur: 14s; --p-delay: -8s; }
.login-particles span:nth-child(10) { left: 25%; --p-dur: 11s; --p-delay: -2s; background: rgba(168,85,247,0.3); }
.login-particles span:nth-child(11) { left: 45%; --p-dur: 17s; --p-delay: -4s; width: 2px; height: 2px; }
.login-particles span:nth-child(12) { left: 55%; --p-dur: 13s; --p-delay: -6s; }
.login-particles span:nth-child(13) { left: 65%; --p-dur: 15s; --p-delay: -1s; background: rgba(99,102,241,0.5); width: 4px; height: 4px; }
.login-particles span:nth-child(14) { left: 75%; --p-dur: 19s; --p-delay: -3s; }
.login-particles span:nth-child(15) { left: 90%; --p-dur: 12s; --p-delay: -5s; width: 2px; height: 2px; }

@keyframes particleFloat {
  0%   { bottom: -5%; opacity: 0; transform: translateX(0); }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { bottom: 105%; opacity: 0; transform: translateX(calc(var(--p-delay, 0) * 8px)); }
}

/* â”€â”€ Login Card â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.login-wrapper {
  position: relative; z-index: 2; width: 100%; max-width: 460px; padding: 1.5rem;
}

.login-card {
  position: relative;
  background: rgba(10, 13, 30, 0.75);
  backdrop-filter: blur(40px) saturate(1.6);
  -webkit-backdrop-filter: blur(40px) saturate(1.6);
  border: 1px solid rgba(99,102,241,0.12);
  border-radius: 28px;
  padding: 3rem 2.5rem 2.2rem;
  box-shadow:
    0 25px 60px rgba(0,0,0,0.5),
    0 0 0 1px rgba(99,102,241,0.08),
    0 0 80px rgba(99,102,241,0.06);
  animation: cardEnter 0.7s var(--ease-spring) both;
  width: auto; max-width: none;
  overflow: hidden;
}

/* Animated border glow that rotates around the card */
.login-card-glow {
  position: absolute; inset: -1px; border-radius: 28px; z-index: -1;
  background: conic-gradient(
    from var(--glow-angle, 0deg),
    transparent 0%,
    rgba(99,102,241,0.4) 10%,
    rgba(168,85,247,0.3) 20%,
    transparent 40%,
    transparent 60%,
    rgba(99,102,241,0.3) 80%,
    transparent 100%
  );
  animation: glowRotate 6s linear infinite;
  opacity: 0.7;
}
@keyframes glowRotate {
  0%   { --glow-angle: 0deg; filter: hue-rotate(0deg); }
  100% { --glow-angle: 360deg; filter: hue-rotate(30deg); }
}
@property --glow-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

@keyframes cardEnter {
  from { opacity: 0; transform: translateY(40px) scale(0.94); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* â”€â”€ Login Header â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.login-header { text-align: center; margin-bottom: 1.8rem; }

.login-logo {
  display: flex; justify-content: center; margin-bottom: 1.2rem;
  position: relative; width: 90px; height: 90px; margin-left: auto; margin-right: auto;
}
.login-logo svg {
  position: relative; z-index: 2;
  filter: drop-shadow(0 6px 20px rgba(99,102,241,0.4));
  animation: logoFloat 4s ease-in-out infinite;
}
@keyframes logoFloat {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}

/* Pulsing ring behind logo */
.logo-ring {
  position: absolute; inset: -10px; border-radius: 50%; z-index: 1;
  border: 2px solid rgba(99,102,241,0.2);
  animation: ringPulse 3s ease-in-out infinite;
}
.logo-ring::before {
  content: ''; position: absolute; inset: -8px; border-radius: 50%;
  border: 1px solid rgba(168,85,247,0.1);
  animation: ringPulse 3s ease-in-out infinite 0.5s;
}
.logo-ring::after {
  content: ''; position: absolute; inset: -16px; border-radius: 50%;
  border: 1px solid rgba(99,102,241,0.05);
  animation: ringPulse 3s ease-in-out infinite 1s;
}
@keyframes ringPulse {
  0%, 100% { transform: scale(1); opacity: 0.6; }
  50%      { transform: scale(1.08); opacity: 1; }
}

.login-header h1 {
  font-size: 2.2rem; font-weight: 800; letter-spacing: -0.03em;
  background: linear-gradient(135deg, #818cf8 0%, #c084fc 40%, #f0abfc 60%, #818cf8 100%);
  background-size: 300% auto;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  animation: shimmer 5s linear infinite;
  margin-bottom: 0.25rem;
}
@keyframes shimmer {
  0%   { background-position: 0% center; }
  100% { background-position: 300% center; }
}

.login-subtitle {
  color: var(--text-muted); font-size: 0.9rem; letter-spacing: 0.02em;
  animation: fadeInUp 0.7s 0.3s var(--ease) both;
}

.login-version {
  display: inline-block; margin-top: 0.6rem;
  padding: 0.15rem 0.6rem; border-radius: 20px;
  font-size: 0.65rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--accent-hover);
  background: rgba(99,102,241,0.1); border: 1px solid rgba(99,102,241,0.15);
  animation: fadeInUp 0.7s 0.5s var(--ease) both;
}

/* â”€â”€ Login Divider â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.login-divider {
  display: flex; align-items: center; gap: 1rem;
  margin-bottom: 1.6rem;
  animation: fadeInUp 0.7s 0.4s var(--ease) both;
}
.login-divider::before, .login-divider::after {
  content: ''; flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(99,102,241,0.15), transparent);
}
.login-divider span {
  font-size: 0.72rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.1em; color: var(--text-muted); white-space: nowrap;
}

/* â”€â”€ Login Form Animations â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.login-card .form-group:nth-child(1) { animation: fadeInUp 0.5s 0.4s var(--ease) both; }
.login-card .form-group:nth-child(2) { animation: fadeInUp 0.5s 0.5s var(--ease) both; }
.login-card .login-submit { animation: fadeInUp 0.5s 0.6s var(--ease) both; }

/* Login-specific input styling */
.login-card input[type="text"],
.login-card input[type="password"] {
  background: rgba(8, 11, 22, 0.6);
  border: 1.5px solid rgba(99,102,241,0.1);
  padding: 0.82rem 1rem 0.82rem 44px;
  font-size: 0.95rem;
  border-radius: 12px;
  transition: all 0.3s var(--ease);
}
.login-card input:focus {
  border-color: rgba(99,102,241,0.5);
  box-shadow: 0 0 0 4px rgba(99,102,241,0.1), 0 0 30px rgba(99,102,241,0.08);
  background: rgba(8, 11, 22, 0.9);
}
.login-card .input-icon .icon {
  width: 18px; height: 18px; left: 15px;
}

/* Login submit button â€” extra styling */
.login-submit {
  margin-top: 0.5rem;
  padding: 0.9rem 1.5rem !important;
  font-size: 1rem !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, #6366f1, #8b5cf6, #a855f7) !important;
  background-size: 200% auto !important;
  box-shadow: 0 4px 20px rgba(99,102,241,0.3), 0 0 40px rgba(99,102,241,0.1) !important;
  transition: all 0.3s var(--ease) !important;
  letter-spacing: 0.02em;
}
.login-submit:hover {
  background-position: right center !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 30px rgba(99,102,241,0.4), 0 0 60px rgba(99,102,241,0.15) !important;
}
.login-submit:active {
  transform: translateY(0) !important;
}

/* â”€â”€ Feature Badges â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.login-features {
  display: flex; justify-content: center; gap: 0.6rem;
  margin-top: 1.8rem; flex-wrap: wrap;
  animation: fadeInUp 0.5s 0.8s var(--ease) both;
}
.login-feature {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 0.28rem 0.7rem; border-radius: 20px;
  font-size: 0.68rem; font-weight: 600; color: var(--text-muted);
  background: rgba(99,102,241,0.05);
  border: 1px solid rgba(99,102,241,0.08);
  transition: all 0.3s var(--ease);
}
.login-feature:hover {
  color: var(--accent-hover); border-color: rgba(99,102,241,0.2);
  background: rgba(99,102,241,0.08);
}
.login-feature svg { width: 12px; height: 12px; opacity: 0.7; }

/* â”€â”€ Footer Text â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.login-footer-text {
  text-align: center; margin-top: 1.5rem;
  font-size: 0.72rem; color: rgba(92, 99, 128, 0.5);
  letter-spacing: 0.02em;
  animation: fadeInUp 0.5s 1s var(--ease) both;
}

/* â”€â”€ Login Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 480px) {
  .login-card { padding: 2.2rem 1.5rem 1.8rem; border-radius: 22px; }
  .login-header h1 { font-size: 1.8rem; }
  .login-logo { width: 76px; height: 76px; }
  .login-logo svg { width: 52px; height: 52px; }
  .login-features { gap: 0.4rem; }
  .login-feature { font-size: 0.62rem; padding: 0.22rem 0.55rem; }
}

/* â”€â”€ Forms â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.form-group { margin-bottom: 1.3rem; }
.form-group label {
  display: block; font-size: 0.8rem; font-weight: 600; color: var(--text-secondary);
  margin-bottom: 0.45rem; text-transform: uppercase; letter-spacing: 0.04em;
}
.input-icon { position: relative; }
.input-icon .icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); width: 17px; height: 17px; color: var(--text-muted); transition: color var(--duration) var(--ease); pointer-events: none; }
.input-icon input { padding-left: 42px; }
.input-icon:focus-within .icon { color: var(--accent); }
input[type="text"], input[type="password"], input[type="email"], input[type="number"], input[type="url"],
select, textarea {
  width: 100%; padding: 0.72rem 1rem;
  background: var(--bg-input);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text-primary); font-family: var(--font); font-size: 0.92rem;
  transition: all var(--duration) var(--ease); outline: none;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow), 0 0 20px rgba(99,102,241,0.08);
  background: rgba(13, 16, 37, 1);
}
input::placeholder { color: var(--text-muted); }
textarea { min-height: 100px; resize: vertical; }
select {
  cursor: pointer; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235c6380' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 14px center; padding-right: 38px;
}

/* â”€â”€ Buttons â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 0.62rem 1.3rem; border: none; border-radius: var(--radius-sm);
  font-family: var(--font); font-size: 0.88rem; font-weight: 600;
  cursor: pointer; transition: all var(--duration) var(--ease); white-space: nowrap;
  position: relative; overflow: hidden;
}
.btn .icon { width: 16px; height: 16px; }
.btn-primary {
  background: linear-gradient(135deg, #6366f1, #7c3aed);
  color: white; box-shadow: 0 2px 10px rgba(99,102,241,0.25);
}
.btn-primary:hover {
  background: linear-gradient(135deg, #818cf8, #8b5cf6);
  transform: translateY(-1px); box-shadow: 0 6px 24px rgba(99,102,241,0.35);
}
.btn-primary:active { transform: translateY(0); }
.btn-secondary { background: var(--bg-tertiary); color: var(--text-primary); border: 1.5px solid var(--border); }
.btn-secondary:hover { border-color: var(--border-light); background: var(--bg-hover); }
.btn-success { background: var(--success); color: white; }
.btn-success:hover { background: #059669; box-shadow: 0 4px 16px rgba(16,185,129,0.3); }
.btn-danger { background: var(--danger); color: white; }
.btn-danger:hover { background: #dc2626; box-shadow: 0 4px 16px rgba(239,68,68,0.3); }
.btn-warning { background: var(--warning); color: #000; }
.btn-warning:hover { background: #d97706; }
.btn-sm { padding: 0.38rem 0.85rem; font-size: 0.8rem; border-radius: var(--radius-xs); }
.btn-block { width: 100%; justify-content: center; padding: 0.85rem; font-size: 0.95rem; }
.btn:disabled { opacity: 0.45; cursor: not-allowed; transform: none !important; box-shadow: none !important; }
.btn-icon { background: none; border: none; color: var(--text-muted); cursor: pointer; padding: 8px; border-radius: var(--radius-xs); transition: all var(--duration) var(--ease); }
.btn-icon:hover { color: var(--text-primary); background: var(--bg-hover); }
.btn-group { display: flex; gap: 6px; flex-wrap: wrap; }
.btn::after {
  content: ''; position: absolute; inset: 0; border-radius: inherit;
  background: radial-gradient(circle at var(--x, 50%) var(--y, 50%), rgba(255,255,255,0.2) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.4s;
}
.btn:active::after { opacity: 1; transition: opacity 0s; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PANEL LAYOUT
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.panel { display: flex; min-height: 100vh; }

/* â”€â”€ Sidebar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.sidebar {
  width: var(--sidebar-width);
  background: var(--bg-secondary);
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  position: fixed; top: 0; left: 0; bottom: 0; z-index: 100;
  transition: transform var(--duration) var(--ease), width var(--duration) var(--ease);
}
.sidebar-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 1.2rem; border-bottom: 1px solid var(--border);
  height: var(--topbar-height); flex-shrink: 0;
}
.brand { display: flex; align-items: center; gap: 11px; }
.brand svg { width: 34px; height: 34px; filter: drop-shadow(0 2px 8px rgba(99,102,241,0.3)); }
.brand-text {
  font-size: 1.22rem; font-weight: 800; letter-spacing: -0.02em;
  background: linear-gradient(135deg, #818cf8, #c084fc);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.sidebar-toggle { display: none; background: none; border: none; color: var(--text-muted); cursor: pointer; padding: 4px; }
.sidebar-toggle svg { width: 20px; height: 20px; }
.sidebar-nav { flex: 1; overflow-y: auto; padding: 0.6rem 0.7rem; }
.nav-item {
  display: flex; align-items: center; gap: 12px;
  padding: 0.58rem 0.85rem; border-radius: var(--radius-sm);
  color: var(--text-muted); font-weight: 500; font-size: 0.88rem;
  transition: all var(--duration) var(--ease); margin-bottom: 1px;
  position: relative;
}
.nav-item svg { width: 19px; height: 19px; flex-shrink: 0; transition: stroke var(--duration) var(--ease); }
.nav-item:hover { color: var(--text-primary); background: var(--bg-hover); }
.nav-item:hover svg { stroke: var(--text-secondary); }
.nav-item.active {
  color: white; font-weight: 600;
  background: linear-gradient(135deg, rgba(99,102,241,0.18), rgba(124,58,237,0.1));
}
.nav-item.active::before {
  content: ''; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 3px; height: 22px; border-radius: 0 3px 3px 0;
  background: linear-gradient(180deg, var(--accent), var(--purple));
}
.nav-item.active svg { stroke: var(--accent-hover); }
.nav-ai { color: var(--purple); }
.nav-ai:hover { color: #c084fc; }
.nav-ai.active { color: white; background: linear-gradient(135deg, rgba(168,85,247,0.15), rgba(99,102,241,0.08)); }
.nav-ai.active::before { background: linear-gradient(180deg, var(--purple), var(--pink)); }
.nav-divider { height: 1px; background: var(--border); margin: 0.6rem 0.85rem; }
.badge { font-size: 0.6rem; padding: 2px 7px; border-radius: 5px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.badge-ai { background: linear-gradient(135deg, var(--accent), var(--purple)); color: white; }
.sidebar-footer {
  padding: 0.85rem 1rem; border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.user-info { display: flex; align-items: center; gap: 10px; }
.user-avatar {
  width: 36px; height: 36px; border-radius: 10px;
  background: linear-gradient(135deg, var(--accent), var(--purple));
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; color: white; font-size: 0.88rem;
  box-shadow: 0 2px 10px rgba(99,102,241,0.3);
}
.user-details { display: flex; flex-direction: column; }
.user-name { font-size: 0.84rem; font-weight: 600; color: var(--text-primary); }
.user-role { font-size: 0.68rem; color: var(--text-muted); text-transform: capitalize; }

/* â”€â”€ Main Content â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.main-content {
  flex: 1; margin-left: var(--sidebar-width);
  display: flex; flex-direction: column; min-height: 100vh;
  min-width: 0; max-width: 100%;
  background:
    radial-gradient(ellipse 80% 50% at 50% -20%, rgba(99,102,241,0.06), transparent),
    radial-gradient(ellipse 60% 40% at 80% 100%, rgba(168,85,247,0.04), transparent),
    var(--bg-primary);
}

/* â”€â”€ Top Bar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.topbar {
  height: var(--topbar-height); display: flex; align-items: center; gap: 16px;
  padding: 0 1.5rem;
  background: rgba(13, 16, 37, 0.6);
  backdrop-filter: blur(16px) saturate(1.2);
  -webkit-backdrop-filter: blur(16px) saturate(1.2);
  border-bottom: 1px solid var(--border);
  position: sticky; top: 0; z-index: 50;
}
.mobile-toggle { display: none; background: none; border: none; color: var(--text-primary); cursor: pointer; }
.mobile-toggle svg { width: 22px; height: 22px; }
.topbar-title { flex: 1; }
.topbar-title h2 { font-size: 1.15rem; font-weight: 700; color: var(--text-heading); }
.topbar-breadcrumb { font-size: 0.76rem; color: var(--text-muted); letter-spacing: 0.01em; }
.topbar-actions { display: flex; align-items: center; gap: 12px; }
.server-status {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.78rem; color: var(--text-secondary); font-weight: 500;
  padding: 0.35rem 0.9rem; border-radius: 20px;
  background: rgba(16,185,129,0.06); border: 1px solid rgba(16,185,129,0.12);
}
.status-dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; }
.status-online { background: var(--success); box-shadow: 0 0 10px rgba(16,185,129,0.5); animation: pulse-dot 2s ease-in-out infinite; }
.status-offline { background: var(--danger); box-shadow: 0 0 10px rgba(239,68,68,0.5); }
@keyframes pulse-dot { 0%,100% { opacity: 1; } 50% { opacity: 0.5; } }
.topbar-search { position: relative; }
.topbar-search svg {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  width: 15px; height: 15px; color: var(--text-muted);
}
.topbar-search input {
  padding: 0.42rem 1rem 0.42rem 36px; width: 200px;
  background: var(--bg-input); border: 1.5px solid var(--border);
  border-radius: 20px; font-size: 0.82rem;
  transition: all var(--duration) var(--ease);
}
.topbar-search input:focus { width: 260px; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }

/* â”€â”€ Content Area â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.content {
  flex: 1; padding: 1.5rem; overflow-y: auto; overflow-x: hidden;
  min-width: 0; max-width: 100%;
  animation: fadeInUp 0.3s var(--ease) both;
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   CARDS â€” Glassmorphic
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.card {
  background: var(--bg-card);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
  transition: all var(--duration) var(--ease);
  animation: slideUp 0.35s var(--ease) both;
}
.card:hover { border-color: var(--border-light); box-shadow: 0 4px 20px rgba(0,0,0,0.15); }
.card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; flex-wrap: wrap; gap: 0.5rem; }
.card-title { font-size: 1rem; font-weight: 700; color: var(--text-heading); }
.card-subtitle { font-size: 0.8rem; color: var(--text-muted); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   STAT CARDS â€” Elevated dashboard metrics
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 1rem; margin-bottom: 1.5rem; }
.stat-card {
  background: var(--bg-card);
  backdrop-filter: blur(12px);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.3rem 1.4rem;
  position: relative; overflow: hidden;
  transition: all var(--duration) var(--ease);
  animation: slideUp 0.35s var(--ease) both;
}
.stat-card:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.2); }
.stat-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; border-radius: 3px 3px 0 0; }
.stat-card.accent::before  { background: linear-gradient(90deg, #6366f1, #a855f7); }
.stat-card.success::before { background: linear-gradient(90deg, #10b981, #06b6d4); }
.stat-card.warning::before { background: linear-gradient(90deg, #f59e0b, #f97316); }
.stat-card.danger::before  { background: linear-gradient(90deg, #ef4444, #f97316); }
.stat-card.info::before    { background: linear-gradient(90deg, #3b82f6, #6366f1); }
.stat-card.cyan::before    { background: linear-gradient(90deg, #06b6d4, #10b981); }
.stat-card::after {
  content: ''; position: absolute; top: -40px; right: -40px; width: 100px; height: 100px;
  border-radius: 50%; opacity: 0.07;
  transition: opacity var(--duration) var(--ease);
}
.stat-card.accent::after  { background: var(--accent); }
.stat-card.success::after { background: var(--success); }
.stat-card.warning::after { background: var(--warning); }
.stat-card.danger::after  { background: var(--danger); }
.stat-card.info::after    { background: var(--info); }
.stat-card:hover::after   { opacity: 0.12; }
.stat-icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 0.8rem;
}
.stat-icon svg { width: 22px; height: 22px; }
.stat-icon.accent  { background: var(--accent-glow); color: var(--accent); }
.stat-icon.success { background: var(--success-bg); color: var(--success); }
.stat-icon.warning { background: var(--warning-bg); color: var(--warning); }
.stat-icon.danger  { background: var(--danger-bg); color: var(--danger); }
.stat-icon.info    { background: var(--info-bg); color: var(--info); }
.stat-value { font-size: 1.9rem; font-weight: 800; line-height: 1.15; letter-spacing: -0.03em; }
.stat-label { font-size: 0.78rem; color: var(--text-muted); font-weight: 500; margin-top: 2px; }
.stat-change { font-size: 0.75rem; display: flex; align-items: center; gap: 4px; margin-top: 4px; }
.stat-change.up { color: var(--success); }
.stat-change.down { color: var(--danger); }
.stat-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem; }

/* â”€â”€ Grids â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1rem; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   TABLES â€” Modern data tables
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.table-wrapper { overflow-x: auto; border-radius: var(--radius); border: 1px solid var(--border); background: var(--bg-card); }
table { width: 100%; border-collapse: collapse; }
thead { background: rgba(99,102,241,0.04); }
th {
  padding: 0.7rem 1rem; text-align: left;
  font-size: 0.72rem; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap;
  border-bottom: 1px solid var(--border);
}
td { padding: 0.72rem 1rem; font-size: 0.88rem; border-bottom: 1px solid rgba(99,102,241,0.05); }
tr:last-child td { border-bottom: none; }
tbody tr { transition: background var(--duration) var(--ease); }
tbody tr:hover { background: var(--bg-hover); }

/* â”€â”€ Progress Bars â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.progress { height: 7px; background: rgba(99,102,241,0.06); border-radius: 10px; overflow: hidden; }
.progress-bar { height: 100%; border-radius: 10px; transition: width 0.6s var(--ease); position: relative; }
.progress-bar.accent  { background: linear-gradient(90deg, #6366f1, #a855f7); }
.progress-bar.success { background: linear-gradient(90deg, #10b981, #06b6d4); }
.progress-bar.warning { background: linear-gradient(90deg, #f59e0b, #f97316); }
.progress-bar.danger  { background: linear-gradient(90deg, #ef4444, #f97316); }

/* â”€â”€ Tags / Badges â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.tag {
  display: inline-flex; align-items: center;
  padding: 0.22rem 0.65rem; border-radius: 6px;
  font-size: 0.73rem; font-weight: 600; letter-spacing: 0.01em;
}
.tag-success { background: var(--success-bg); color: var(--success); border: 1px solid var(--success-border); }
.tag-warning { background: var(--warning-bg); color: var(--warning); border: 1px solid var(--warning-border); }
.tag-danger  { background: var(--danger-bg);  color: var(--danger);  border: 1px solid var(--danger-border); }
.tag-info    { background: var(--info-bg);    color: var(--info);    border: 1px solid var(--info-border); }
.tag-accent  { background: var(--accent-glow); color: var(--accent-hover); border: 1px solid rgba(99,102,241,0.2); }

/* â”€â”€ AI Score Ring â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.ai-score {
  width: 100px; height: 100px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 2rem; font-weight: 800; position: relative;
}
.ai-score::before {
  content: ''; position: absolute; inset: 0; border-radius: 50%;
  border: 4px solid var(--border);
}
.ai-score.grade-a { color: var(--success); }
.ai-score.grade-a::before { border-color: var(--success); box-shadow: 0 0 25px rgba(16,185,129,0.2), inset 0 0 25px rgba(16,185,129,0.06); }
.ai-score.grade-b { color: var(--info); }
.ai-score.grade-b::before { border-color: var(--info); box-shadow: 0 0 25px rgba(59,130,246,0.2); }
.ai-score.grade-c { color: var(--warning); }
.ai-score.grade-c::before { border-color: var(--warning); box-shadow: 0 0 25px rgba(245,158,11,0.2); }
.ai-score.grade-d { color: var(--danger); }
.ai-score.grade-d::before { border-color: var(--danger); box-shadow: 0 0 25px rgba(239,68,68,0.2); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   TOASTS â€” Slide-in notifications
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.toast-container {
  position: fixed; top: 20px; right: 20px; z-index: 10000;
  display: flex; flex-direction: column; gap: 10px; pointer-events: none;
}
.toast {
  display: flex; align-items: center; gap: 12px;
  padding: 0.85rem 1.2rem; border-radius: var(--radius-sm);
  background: rgba(17,20,48,0.92);
  backdrop-filter: blur(20px);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  min-width: 300px; max-width: 420px;
  animation: toastIn 0.35s var(--ease-spring);
  pointer-events: all;
}
.toast.success { border-left: 3px solid var(--success); }
.toast.error   { border-left: 3px solid var(--danger); }
.toast.warning { border-left: 3px solid var(--warning); }
.toast.info    { border-left: 3px solid var(--info); }
.toast-icon { font-size: 1.1rem; flex-shrink: 0; }
.toast-message { flex: 1; font-size: 0.88rem; color: var(--text-primary); }
.toast-close {
  background: none; border: none; color: var(--text-muted); cursor: pointer;
  font-size: 1.1rem; padding: 4px; border-radius: 4px; transition: color var(--duration) var(--ease);
}
.toast-close:hover { color: var(--text-primary); }
@keyframes toastIn { from { opacity: 0; transform: translateX(30px) scale(0.95); } to { opacity: 1; transform: translateX(0) scale(1); } }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   MODAL â€” Elevated dialog
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.modal { position: fixed; inset: 0; z-index: 9999; display: flex; align-items: center; justify-content: center; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.55); backdrop-filter: blur(8px); }
.modal-dialog {
  position: relative;
  background: var(--bg-card-solid);
  border: 1px solid var(--border);
  border-radius: 18px;
  width: 540px; max-width: 95vw; max-height: 90vh; overflow-y: auto;
  box-shadow: var(--shadow), var(--shadow-glow);
  animation: modalIn 0.3s var(--ease-spring);
}
.modal-dialog.modal-wide {
  width: 900px;
}
@keyframes modalIn { from { opacity: 0; transform: scale(0.92) translateY(10px); } to { opacity: 1; transform: scale(1) translateY(0); } }
.modal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.2rem 1.5rem; border-bottom: 1px solid var(--border);
}
.modal-header h3 { font-size: 1.08rem; font-weight: 700; color: var(--text-heading); }
.modal-close {
  background: none; border: none; color: var(--text-muted);
  font-size: 1.4rem; cursor: pointer; padding: 4px 8px; line-height: 1;
  border-radius: var(--radius-xs); transition: all var(--duration) var(--ease);
}
.modal-close:hover { color: var(--text-primary); background: var(--bg-hover); }
.modal-body { padding: 1.5rem; }
.modal-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 1rem 1.5rem; border-top: 1px solid var(--border); }

/* â”€â”€ Alerts â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.alert {
  padding: 0.8rem 1rem; border-radius: var(--radius-sm);
  font-size: 0.88rem; margin-bottom: 1rem;
  display: flex; align-items: center; gap: 10px;
}
.alert-danger  { background: var(--danger-bg);  color: var(--danger);  border: 1px solid var(--danger-border); }
.alert-success { background: var(--success-bg); color: var(--success); border: 1px solid var(--success-border); }
.alert-warning { background: var(--warning-bg); color: var(--warning); border: 1px solid var(--warning-border); }
.alert-info    { background: var(--info-bg);    color: var(--info);    border: 1px solid var(--info-border); }

/* â”€â”€ Empty States â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.empty-state { text-align: center; padding: 4rem 2rem; color: var(--text-muted); }
.empty-state svg { width: 64px; height: 64px; margin-bottom: 1rem; opacity: 0.25; }
.empty-state h3 { font-size: 1.15rem; color: var(--text-secondary); margin-bottom: 0.5rem; font-weight: 600; }
.empty-state p { font-size: 0.88rem; max-width: 380px; margin: 0 auto; line-height: 1.6; }

/* â”€â”€ Loading â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.spinner {
  width: 28px; height: 28px;
  border: 3px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.loading-overlay { display: flex; align-items: center; justify-content: center; padding: 5rem; flex-direction: column; gap: 1rem; }
.loading-overlay::after { content: 'Loading...'; font-size: 0.82rem; color: var(--text-muted); animation: pulse 1.5s ease-in-out infinite; }
@keyframes pulse { 0%,100% { opacity: 0.4; } 50% { opacity: 1; } }

/* â”€â”€ File Manager â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.fm-container { display: flex; flex-direction: column; gap: 0; position: relative; min-height: 400px; }
.fm-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 10px 16px; background: var(--bg-secondary); border: 1px solid var(--border); border-radius: var(--radius-sm) var(--radius-sm) 0 0; flex-wrap: wrap; }
.fm-toolbar-left { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; }
.fm-toolbar-right { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.fm-toolbar-divider { width: 1px; height: 20px; background: var(--border); }
.fm-breadcrumbs { display: flex; align-items: center; gap: 2px; flex-wrap: wrap; font-size: 0.82rem; }
.fm-crumb { padding: 3px 8px; border-radius: 5px; cursor: pointer; color: var(--accent); font-weight: 500; transition: all var(--duration) var(--ease); }
.fm-crumb:hover { background: var(--accent-glow); }
.fm-crumb:last-child { color: var(--text-primary); cursor: default; background: none; }
.fm-crumb-sep { color: var(--text-muted); font-size: 0.7rem; margin: 0 1px; }

/* View Toggle */
.fm-view-toggle { display: flex; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; }
.fm-view-btn { padding: 5px 8px; background: transparent; border: none; color: var(--text-muted); cursor: pointer; transition: all var(--duration) var(--ease); display: flex; align-items: center; }
.fm-view-btn:hover { color: var(--text-primary); }
.fm-view-btn.active { background: var(--accent); color: #fff; }

/* Bulk Bar */
.fm-bulk-bar { display: flex; align-items: center; justify-content: space-between; padding: 8px 16px; background: var(--accent-glow); border-left: 1px solid var(--accent); border-right: 1px solid var(--accent); animation: fmSlideDown 0.2s ease; }
.fm-bulk-left { display: flex; align-items: center; gap: 10px; font-size: 0.82rem; font-weight: 600; color: var(--accent); }
.fm-bulk-right { display: flex; align-items: center; gap: 6px; }
@keyframes fmSlideDown { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }

/* Paste Bar */
.fm-paste-bar { display: flex; align-items: center; justify-content: space-between; padding: 8px 16px; background: rgba(16,185,129,0.06); border-left: 1px solid var(--success); border-right: 1px solid var(--success); }
.fm-paste-actions { display: flex; gap: 6px; }

/* Drop Zone */
.fm-drop-zone { position: absolute; inset: 0; z-index: 100; background: rgba(99,102,241,0.08); border: 2px dashed var(--accent); border-radius: var(--radius-sm); display: flex; align-items: center; justify-content: center; backdrop-filter: blur(4px); }
.fm-drop-content { text-align: center; color: var(--accent); font-weight: 600; }
.fm-drop-content p { margin-top: 8px; font-size: 0.92rem; }

/* Upload Progress */
.fm-upload-progress { padding: 10px 16px; background: var(--bg-secondary); border-left: 1px solid var(--border); border-right: 1px solid var(--border); }
.fm-upload-info { display: flex; justify-content: space-between; font-size: 0.78rem; color: var(--text-muted); margin-bottom: 6px; }
.fm-progress-track { height: 4px; background: var(--border); border-radius: 2px; overflow: hidden; }
.fm-progress-fill { height: 100%; width: 0; background: var(--accent); border-radius: 2px; transition: width 0.15s ease; }

/* List View Table */
.fm-list-wrapper { overflow-x: auto; max-height: calc(100vh - 280px); overflow-y: auto; }
.fm-table { width: 100%; border-collapse: collapse; font-size: 0.82rem; border-left: 1px solid var(--border); border-right: 1px solid var(--border); }
.fm-table thead { position: sticky; top: 0; z-index: 2; }
.fm-table thead th { padding: 10px 12px; text-align: left; font-weight: 600; color: var(--text-muted); font-size: 0.74rem; text-transform: uppercase; letter-spacing: 0.04em; background: var(--bg-secondary); border-bottom: 1px solid var(--border); cursor: default; user-select: none; white-space: nowrap; }
.fm-table th.fm-sortable { cursor: pointer; }
.fm-table th.fm-sortable:hover { color: var(--text-primary); }
.fm-th-check { width: 36px; text-align: center !important; }
.fm-th-actions { width: 150px; text-align: right !important; }
.fm-th-size { width: 90px; }
.fm-th-mod { width: 110px; }
.fm-th-perm { width: 80px; }
.fm-table tbody tr { border-bottom: 1px solid var(--border); transition: background var(--duration) var(--ease); }
.fm-table tbody tr:hover { background: var(--bg-hover); }
.fm-table tbody tr.selected { background: var(--accent-glow); }
.fm-table td { padding: 8px 12px; color: var(--text-secondary); white-space: nowrap; }
.fm-td-check { text-align: center; }
.fm-td-size, .fm-td-mod { font-size: 0.78rem; color: var(--text-muted); }
.fm-td-perm code { font-size: 0.72rem; padding: 2px 6px; background: var(--bg-secondary); border-radius: 4px; color: var(--text-muted); }
.fm-td-actions { text-align: right; }
.fm-name-cell { display: flex; align-items: center; gap: 10px; }
.fm-name-info { display: flex; flex-direction: column; gap: 1px; }
.fm-file-name { cursor: pointer; color: var(--text-primary); font-weight: 500; transition: color var(--duration) var(--ease); }
.fm-file-name:hover { color: var(--accent); }
.fm-item-count { font-size: 0.7rem; color: var(--text-muted); }
.fm-go-up-label { color: var(--text-muted); cursor: pointer; }
.fm-go-up-label:hover { color: var(--text-primary); }
.fm-go-up { cursor: pointer; }

/* Actions */
.fm-actions-row { display: flex; align-items: center; justify-content: flex-end; gap: 2px; }
.fm-act-btn { padding: 5px; border-radius: 5px; background: none; border: none; color: var(--text-muted); cursor: pointer; transition: all var(--duration) var(--ease); display: flex; align-items: center; }
.fm-act-btn:hover { background: var(--bg-hover); color: var(--text-primary); }
.fm-more-btn:hover { color: var(--accent); }

/* Grid View */
.fm-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(125px, 1fr)); gap: 4px; padding: 12px; border: 1px solid var(--border); border-top: none; background: var(--bg-primary); }
.fm-grid-item { position: relative; display: flex; flex-direction: column; align-items: center; gap: 8px; padding: 16px 10px; border-radius: var(--radius-sm); cursor: pointer; transition: all var(--duration) var(--ease); border: 1px solid transparent; text-align: center; }
.fm-grid-item:hover { background: var(--bg-hover); border-color: var(--border); }
.fm-grid-item.selected { background: var(--accent-glow); border-color: var(--accent); }
.fm-grid-check { position: absolute; top: 6px; left: 6px; opacity: 0; transition: opacity 0.15s; }
.fm-grid-item:hover .fm-grid-check, .fm-grid-item.selected .fm-grid-check { opacity: 1; }
.fm-grid-icon svg { width: 36px; height: 36px; }
.fm-grid-name { font-size: 0.76rem; word-break: break-all; max-width: 100%; color: var(--text-secondary); line-height: 1.3; }
.fm-grid-size { font-size: 0.68rem; color: var(--text-muted); }
.fm-grid-empty { grid-column: 1 / -1; text-align: center; padding: 60px 20px; color: var(--text-muted); }
.fm-grid-empty p { margin-top: 10px; }

/* Status Bar */
.fm-status-bar { display: flex; align-items: center; gap: 20px; padding: 8px 16px; font-size: 0.74rem; color: var(--text-muted); background: var(--bg-secondary); border: 1px solid var(--border); border-top: none; border-radius: 0 0 var(--radius-sm) var(--radius-sm); }
.fm-path-display { margin-left: auto; font-family: 'JetBrains Mono', monospace; font-size: 0.7rem; opacity: 0.6; }

/* Context Menu */
.fm-context-menu { position: fixed; z-index: 9999; background: var(--bg-secondary); border: 1px solid var(--border); border-radius: var(--radius-sm); min-width: 180px; padding: 6px 0; box-shadow: 0 8px 30px rgba(0,0,0,0.25); }
.fm-ctx-item { display: flex; align-items: center; gap: 10px; padding: 8px 16px; cursor: pointer; font-size: 0.82rem; color: var(--text-secondary); transition: all var(--duration) var(--ease); }
.fm-ctx-item:hover { background: var(--bg-hover); color: var(--text-primary); }
.fm-ctx-icon { width: 20px; text-align: center; font-size: 0.9rem; }
.fm-ctx-sep { height: 1px; background: var(--border); margin: 4px 8px; }
.fm-ctx-danger { color: var(--danger); }
.fm-ctx-danger:hover { background: rgba(239,68,68,0.08); }

/* Empty State */
.fm-empty { text-align: center; padding: 60px 20px; }
.fm-empty-td { border: 1px solid var(--border) !important; }
.fm-empty-title { font-size: 1rem; font-weight: 600; color: var(--text-secondary); margin-top: 12px; }
.fm-empty-sub { font-size: 0.82rem; color: var(--text-muted); margin-top: 4px; }

/* Error State */
.fm-error { text-align: center; padding: 60px 20px; display: flex; flex-direction: column; align-items: center; gap: 10px; color: var(--text-muted); }

/* Editor */
.fm-editor-header { display: flex; align-items: center; justify-content: space-between; padding: 10px 16px; background: var(--bg-secondary); border-bottom: 1px solid var(--border); }
.fm-editor-title { display: flex; align-items: center; gap: 8px; font-weight: 600; font-size: 0.88rem; }
.fm-editor-lang { font-size: 0.68rem; padding: 2px 8px; background: var(--accent-glow); color: var(--accent); border-radius: 4px; font-weight: 500; text-transform: uppercase; }
.fm-editor-meta { display: flex; align-items: center; gap: 12px; }
.fm-editor-unsaved, #fm-unsaved { color: var(--warning); font-size: 0.78rem; font-weight: 600; animation: fmPulse 1.5s infinite; }
@keyframes fmPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
.fm-editor-wrap { display: flex; position: relative; }
.fm-editor-lines { width: 50px; padding: 14px 8px; text-align: right; font-family: 'JetBrains Mono', 'Fira Code', monospace; font-size: 0.8rem; line-height: 1.7; color: var(--text-muted); background: var(--bg-secondary); border-right: 1px solid var(--border); user-select: none; overflow: hidden; white-space: pre; opacity: 0.5; }
.fm-editor-textarea { flex: 1; width: 100%; min-height: 450px; padding: 14px 16px; background: var(--bg-primary); border: none; color: var(--text-primary); font-family: 'JetBrains Mono', 'Fira Code', monospace; font-size: 0.8rem; resize: vertical; outline: none; tab-size: 2; line-height: 1.7; }

/* Preview */
.fm-preview-container { display: flex; align-items: center; justify-content: center; padding: 20px; min-height: 300px; background: repeating-conic-gradient(var(--bg-secondary) 0% 25%, transparent 0% 50%) 50% / 20px 20px; border-radius: var(--radius-sm); }
.fm-preview-img { max-width: 100%; max-height: 70vh; border-radius: 6px; opacity: 0; transition: opacity 0.3s ease; box-shadow: 0 4px 20px rgba(0,0,0,0.15); }

/* Info Panel */
.fm-info-panel { display: flex; flex-direction: column; gap: 1px; }
.fm-info-row { display: flex; padding: 10px 4px; border-bottom: 1px solid var(--border); }
.fm-info-row:last-child { border-bottom: none; }
.fm-info-label { width: 110px; font-size: 0.78rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.03em; flex-shrink: 0; }
.fm-info-value { font-size: 0.84rem; color: var(--text-primary); word-break: break-all; }
.fm-info-path { font-family: 'JetBrains Mono', monospace; font-size: 0.76rem; }

/* Search */
.fm-search-input-wrap { position: relative; display: flex; align-items: center; }
.fm-search-input-wrap svg { position: absolute; left: 12px; pointer-events: none; }
.fm-search-input-wrap input { padding-left: 38px !important; }
.fm-search-loading { display: flex; justify-content: center; padding: 30px; }
.fm-search-empty { text-align: center; padding: 30px; color: var(--text-muted); display: flex; flex-direction: column; align-items: center; gap: 8px; }
.fm-search-item { display: flex; align-items: center; gap: 10px; padding: 8px 12px; cursor: pointer; border-radius: 6px; transition: background var(--duration) var(--ease); }
.fm-search-item:hover { background: var(--bg-hover); }
.fm-search-info { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.fm-search-name { font-size: 0.84rem; font-weight: 500; color: var(--text-primary); }
.fm-search-path { font-size: 0.72rem; color: var(--text-muted); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* Loading */
.fm-loading { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 12px; padding: 80px 20px; color: var(--text-muted); font-size: 0.85rem; }

/* Navigation buttons */
.fm-nav-btn { padding: 4px 6px !important; min-width: auto; }
.fm-nav-btn:disabled { opacity: 0.3; cursor: not-allowed; }

/* Quick filter */
.fm-filter-wrap { position: relative; display: flex; align-items: center; }
.fm-filter-wrap svg { position: absolute; left: 8px; pointer-events: none; opacity: 0.5; }
.fm-filter-input { padding: 5px 10px 5px 28px !important; font-size: 0.78rem !important; width: 140px; border: 1px solid var(--border) !important; border-radius: 6px !important; background: var(--bg-primary) !important; color: var(--text-primary) !important; transition: all var(--duration) var(--ease); height: 30px !important; }
.fm-filter-input:focus { width: 200px; border-color: var(--accent) !important; box-shadow: 0 0 0 2px var(--accent-glow); }
.fm-filter-input::placeholder { color: var(--text-muted); font-size: 0.75rem; }
.fm-filter-badge { font-size: 0.7rem; padding: 2px 8px; background: var(--accent-glow); color: var(--accent); border-radius: 4px; font-weight: 500; }

/* Disk usage */
.fm-disk-usage { font-size: 0.72rem; color: var(--text-muted); }

/* Chmod dialog */
.fm-chmod-info { margin-bottom: 12px; font-size: 0.88rem; }
.fm-chmod-presets { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.fm-chmod-preset { font-family: 'JetBrains Mono', monospace !important; font-size: 0.75rem !important; }

/* Legacy compat */
.file-browser { display: flex; flex-direction: column; gap: 1rem; }
.file-path { display: flex; align-items: center; gap: 4px; padding: 0.5rem 0; flex-wrap: wrap; }
.file-path-segment { padding: 0.25rem 0.55rem; border-radius: 6px; cursor: pointer; font-size: 0.82rem; color: var(--text-secondary); transition: all var(--duration) var(--ease); }
.file-path-segment:hover { background: var(--bg-hover); color: var(--text-primary); }
.file-path-separator { color: var(--text-muted); font-size: 0.7rem; }

/* â”€â”€ Code Editor (legacy) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.code-editor {
  font-family: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.code-editor textarea {
  width: 100%; min-height: 400px; padding: 1.2rem;
  background: transparent; border: none; color: var(--text-primary);
  font-family: inherit; font-size: 0.82rem; resize: vertical;
  outline: none; tab-size: 2; line-height: 1.7;
}

/* â”€â”€ Insight Cards â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.insight-card {
  display: flex; gap: 14px; padding: 1.1rem;
  border-radius: var(--radius-sm);
  background: rgba(99,102,241,0.03);
  border: 1px solid var(--border);
  margin-bottom: 0.75rem;
  transition: all var(--duration) var(--ease);
}
.insight-card:hover { background: var(--bg-hover); border-color: var(--border-light); }
.insight-icon {
  width: 38px; height: 38px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 1.1rem;
}
.insight-icon.critical { background: var(--danger-bg); color: var(--danger); }
.insight-icon.warning { background: var(--warning-bg); color: var(--warning); }
.insight-icon.info { background: var(--info-bg); color: var(--info); }
.insight-icon.optimization { background: var(--accent-glow); color: var(--accent); }
.insight-content h4 { font-size: 0.9rem; font-weight: 600; margin-bottom: 3px; color: var(--text-heading); }
.insight-content p { font-size: 0.8rem; color: var(--text-secondary); line-height: 1.5; }
.insight-actions { display: flex; gap: 6px; margin-top: 8px; }

/* â”€â”€ Chart Bars â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.chart-container {
  position: relative; height: 200px;
  display: flex; align-items: flex-end; gap: 3px; padding-top: 20px;
}
.chart-bar {
  flex: 1; border-radius: 4px 4px 0 0; min-width: 5px; position: relative;
  background: linear-gradient(to top, rgba(99,102,241,0.7), rgba(168,85,247,0.7));
  transition: height 0.5s var(--ease);
}
.chart-bar:hover { background: linear-gradient(to top, var(--accent), var(--purple)); }
.chart-bar::after {
  content: attr(data-value); position: absolute; top: -18px; left: 50%; transform: translateX(-50%);
  font-size: 0.6rem; color: var(--text-muted); white-space: nowrap; display: none;
}
.chart-bar:hover::after { display: block; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   RESPONSIVE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
@media (max-width: 1100px) {
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .sidebar { transform: translateX(-100%); width: var(--sidebar-width); }
  .sidebar.open, .sidebar.mobile-open { transform: translateX(0); box-shadow: 10px 0 40px rgba(0,0,0,0.5); }
  .main-content { margin-left: 0; }
  .mobile-toggle { display: block; }
  .topbar-search { display: none; }
  .stats-grid { grid-template-columns: 1fr; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .content { padding: 1rem; }
  .server-status span:not(.status-dot) { display: none; }
}
@media (max-width: 480px) {
  html { font-size: 13px; }
  .login-card { padding: 2rem 1.5rem; }
  .content { padding: 0.8rem; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   UTILITIES
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.justify-center { justify-content: center; }
.gap-1 { gap: 0.25rem; }
.gap-2 { gap: 0.5rem; }
.gap-3 { gap: 0.75rem; }
.gap-4 { gap: 1rem; }
.mt-1 { margin-top: 0.5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mb-1 { margin-bottom: 0.5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }
.mr-2 { margin-right: 0.5rem; }
.ml-auto { margin-left: auto; }
.text-sm { font-size: 0.84rem; }
.text-xs { font-size: 0.73rem; }
.text-muted { color: var(--text-muted); }
.text-success { color: var(--success); }
.text-danger { color: var(--danger); }
.text-warning { color: var(--warning); }
.text-center { text-align: center; }
.w-full { width: 100%; }
.truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.font-bold { font-weight: 700; }
.opacity-50 { opacity: 0.5; }

/* â”€â”€ Micro-animations â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
.stats-grid .stat-card:nth-child(1) { animation-delay: 0.04s; }
.stats-grid .stat-card:nth-child(2) { animation-delay: 0.08s; }
.stats-grid .stat-card:nth-child(3) { animation-delay: 0.12s; }
.stats-grid .stat-card:nth-child(4) { animation-delay: 0.16s; }
.stats-grid .stat-card:nth-child(5) { animation-delay: 0.20s; }
.stats-grid .stat-card:nth-child(6) { animation-delay: 0.24s; }

/* â”€â”€ Code/Kbd â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
code, kbd {
  font-family: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;
  padding: 0.15em 0.45em; border-radius: 4px; font-size: 0.85em;
  background: rgba(99,102,241,0.08); color: var(--accent-hover);
  border: 1px solid rgba(99,102,241,0.12);
}

/* â”€â”€ Confirm Dialog â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#confirm-yes { background: var(--danger); color: white; }
#confirm-yes:hover { background: #dc2626; box-shadow: 0 4px 16px rgba(239,68,68,0.3); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   WEBSITES SECTION â€” Next-Gen Premium UI
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.ws-page { display: flex; flex-direction: column; gap: 22px; }

/* â”€â”€ Stats Row â”€â”€ */
.ws-stats-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 14px; }
.ws-stat-card {
  position: relative; display: flex; align-items: center; gap: 16px;
  background: linear-gradient(135deg, rgba(17,20,48,0.85), rgba(13,16,37,0.65));
  border: 1px solid rgba(255,255,255,0.06); border-radius: 16px; padding: 18px 20px;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  transition: all 0.3s var(--ease); overflow: hidden;
}
.ws-stat-card::before {
  content: ''; position: absolute; inset: 0; border-radius: 16px;
  background: radial-gradient(ellipse at 30% 30%, var(--_stat-glow, rgba(99,102,241,0.08)), transparent 70%);
  opacity: 0; transition: opacity 0.4s; pointer-events: none;
}
.ws-stat-card:hover { transform: translateY(-2px); border-color: rgba(255,255,255,0.12); box-shadow: 0 8px 32px rgba(0,0,0,0.3); }
.ws-stat-card:hover::before { opacity: 1; }
.ws-stat-icon {
  width: 46px; height: 46px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
  position: relative; z-index: 1;
  background: var(--_stat-bg, rgba(99,102,241,0.1));
  box-shadow: 0 0 20px var(--_stat-glow, rgba(99,102,241,0.08));
  transition: transform 0.3s var(--ease-spring), box-shadow 0.3s;
}
.ws-stat-card:hover .ws-stat-icon { transform: scale(1.08); }
.ws-stat-info { display: flex; flex-direction: column; position: relative; z-index: 1; }
.ws-stat-value { font-size: 1.75rem; font-weight: 800; line-height: 1.15; color: var(--text-primary); letter-spacing: -0.02em; }
.ws-stat-label { font-size: 0.7rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 2px; }
.ws-stat-card[data-color="accent"] { --_stat-bg: rgba(99,102,241,0.12); --_stat-glow: rgba(99,102,241,0.1); }
.ws-stat-card[data-color="success"] { --_stat-bg: rgba(16,185,129,0.12); --_stat-glow: rgba(16,185,129,0.1); }
.ws-stat-card[data-color="warning"] { --_stat-bg: rgba(251,191,36,0.12); --_stat-glow: rgba(251,191,36,0.1); }
.ws-stat-card[data-color="danger"] { --_stat-bg: rgba(239,68,68,0.1); --_stat-glow: rgba(239,68,68,0.08); }
/* Legacy compat */
.ws-stat-icon[style*="--accent"] { background: rgba(99,102,241,0.12); }
.ws-stat-icon[style*="--success"] { background: rgba(16,185,129,0.1); }
.ws-stat-icon[style*="--warning"] { background: rgba(251,191,36,0.1); }
.ws-stat-icon[style*="--danger"]  { background: rgba(239,68,68,0.08); }

/* â”€â”€ Toolbar â”€â”€ */
.ws-toolbar {
  display: flex; flex-direction: column; gap: 10px;
  background: linear-gradient(135deg, rgba(17,20,48,0.55), rgba(13,16,37,0.35));
  border: 1px solid rgba(255,255,255,0.06); border-radius: 16px; padding: 14px 16px;
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
}

/* Toolbar rows */
.ws-toolbar-row { display: flex; align-items: center; gap: 10px; }

/* Top row: search + actions */
.ws-toolbar-top { gap: 12px; }
.ws-search-wrap {
  flex: 1; display: flex; align-items: center; gap: 8px;
  background: rgba(0,0,0,0.28); border: 1px solid rgba(255,255,255,0.07);
  border-radius: 10px; padding: 8px 14px;
  transition: all 0.25s var(--ease); position: relative;
}
.ws-search-wrap:focus-within { border-color: var(--accent); box-shadow: 0 0 20px rgba(99,102,241,0.12); background: rgba(0,0,0,0.38); }
.ws-search-icon { color: var(--text-muted); flex-shrink: 0; opacity: 0.55; transition: opacity 0.2s; }
.ws-search-wrap:focus-within .ws-search-icon { opacity: 1; color: var(--accent); }
.ws-search-input {
  flex: 1; background: transparent; border: none; outline: none;
  color: var(--text-primary); font-size: 0.85rem; min-width: 0;
}
.ws-search-input::placeholder { color: var(--text-muted); opacity: 0.5; }
.ws-search-kbd {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 6px; flex-shrink: 0;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  color: var(--text-muted); font-size: 0.7rem; font-family: inherit;
  opacity: 0.7; transition: opacity 0.2s;
}
.ws-search-wrap:focus-within .ws-search-kbd { opacity: 0; pointer-events: none; }

/* Action buttons */
.ws-toolbar-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.ws-icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 36px; height: 36px; border-radius: 10px; border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04); color: var(--text-secondary);
  cursor: pointer; transition: all 0.2s var(--ease); flex-shrink: 0;
}
.ws-icon-btn:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.15); color: var(--text-primary); transform: rotate(45deg); }
.ws-icon-btn:active { transform: rotate(90deg) scale(0.92); }
.ws-add-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 18px; border-radius: 10px; border: none;
  background: linear-gradient(135deg, var(--accent), #818cf8);
  color: #fff; font-size: 0.82rem; font-weight: 600;
  cursor: pointer; transition: all 0.25s var(--ease); white-space: nowrap;
  box-shadow: 0 2px 12px rgba(99,102,241,0.25);
}
.ws-add-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 20px rgba(99,102,241,0.35); filter: brightness(1.08); }
.ws-add-btn:active { transform: translateY(0) scale(0.97); }
.ws-add-btn-sub {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 18px; border-radius: 10px;
  border: 1.5px solid rgba(99,102,241,0.45);
  background: transparent; color: var(--accent);
  font-size: 0.82rem; font-weight: 600; cursor: pointer;
  transition: all 0.25s var(--ease); white-space: nowrap;
}
.ws-add-btn-sub:hover { background: rgba(99,102,241,0.1); border-color: var(--accent); transform: translateY(-1px); }
.ws-add-btn-sub:active { transform: translateY(0) scale(0.97); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SP â€” Subdomain Picker  (sp-*)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.sp-overlay {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: min(16vh, 140px);
  animation: spIn .18s ease;
}
.sp-overlay--hide { animation: spOut .18s ease forwards; }
@keyframes spIn  { from { opacity:0 } to { opacity:1 } }
@keyframes spOut { from { opacity:1 } to { opacity:0 } }

.sp-bg {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(8px);
}

.sp-box {
  position: relative; z-index: 1;
  width: 92%; max-width: 460px;
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px; overflow: hidden;
  box-shadow: 0 20px 70px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04);
  animation: spSlide .22s cubic-bezier(.22,1,.36,1);
}
@keyframes spSlide { from { opacity:0; transform: translateY(14px) scale(.97) } to { opacity:1; transform: none } }

/* Head */
.sp-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid rgba(255,255,255,.06);
}
.sp-head-left { display: flex; align-items: center; gap: 10px; }
.sp-head-ico {
  width: 36px; height: 36px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; flex-shrink: 0;
  background: rgba(99,102,241,.1); border: 1px solid rgba(99,102,241,.14);
}
.sp-head-title { font-size: .94rem; font-weight: 700; color: var(--text-primary); }
.sp-head-sub { font-size: .72rem; color: var(--text-muted); margin-top: 1px; }
.sp-x {
  width: 30px; height: 30px; border-radius: 8px; border: none;
  background: rgba(255,255,255,.04); color: var(--text-muted);
  font-size: 1.2rem; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.sp-x:hover { background: rgba(239,68,68,.12); color: var(--danger); }

/* Search */
.sp-search-row { padding: 0 16px 10px; }
.sp-search {
  width: 100%; padding: 9px 12px; border-radius: 8px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.2); color: var(--text-primary);
  font-size: .82rem; outline: none; box-sizing: border-box;
  transition: border-color .2s;
}
.sp-search:focus { border-color: var(--accent); }
.sp-search::placeholder { color: var(--text-muted); opacity: .4; }

/* Body */
.sp-body { padding: 6px 12px 12px; }
.sp-label {
  font-size: .63rem; font-weight: 700; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: .06em;
  padding: 4px 6px 3px;
}
.sp-list {
  display: flex; flex-direction: column; gap: 3px;
  max-height: 300px; overflow-y: auto;
}
.sp-list::-webkit-scrollbar { width: 4px; }
.sp-list::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 4px; }

/* Items */
.sp-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; border-radius: 9px;
  border: 1px solid transparent; background: transparent;
  cursor: pointer; transition: all .15s; text-align: left; width: 100%;
}
.sp-item:hover { background: rgba(99,102,241,.06); border-color: rgba(99,102,241,.16); }
.sp-item--ext {
  border-style: dashed; border-color: rgba(255,255,255,.07);
  margin-top: 2px;
}
.sp-item--ext:hover { border-color: rgba(139,92,246,.3); background: rgba(139,92,246,.04); }

.sp-avatar {
  width: 32px; height: 32px; border-radius: 8px;
  background: rgba(99,102,241,.14);
  display: flex; align-items: center; justify-content: center;
  font-size: .8rem; font-weight: 700; color: var(--accent); flex-shrink: 0;
}
.sp-avatar--ext { background: rgba(139,92,246,.14); font-size: 1rem; }

.sp-info { flex: 1; min-width: 0; }
.sp-info b {
  display: block; font-size: .82rem; font-weight: 600;
  color: var(--text-primary); white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
}
.sp-info small { display: block; font-size: .7rem; color: var(--text-muted); margin-top: 1px; }

.sp-arrow {
  color: var(--text-muted); font-size: 1.1rem; font-weight: 300;
  opacity: 0; transition: opacity .15s, transform .15s; flex-shrink: 0;
}
.sp-item:hover .sp-arrow { opacity: 1; transform: translateX(2px); }

/* Divider */
.sp-divider {
  height: 1px; margin: 8px 6px;
  background: rgba(255,255,255,.05);
}

/* Footer */
.sp-foot {
  padding: 8px 16px;
  border-top: 1px solid rgba(255,255,255,.05);
  font-size: .68rem; color: var(--text-muted); text-align: center;
}
.sp-foot kbd {
  display: inline-block; padding: 1px 6px; border-radius: 4px;
  border: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.04);
  font-family: inherit; font-size: .66rem;
}

/* Responsive */
@media (max-width: 768px) {
  .sp-box { max-width: 96vw; }
}

/* Bottom row: filters + selects */
.ws-toolbar-bottom { gap: 12px; flex-wrap: wrap; }
.ws-filter-group { display: flex; align-items: center; gap: 8px; flex: 1; min-width: 0; }
.ws-filter-label {
  display: inline-flex; align-items: center; gap: 5px;
  color: var(--text-muted); font-size: 0.72rem; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.5px; flex-shrink: 0;
  opacity: 0.7;
}

/* Filter pills */
.ws-filter-pills {
  display: flex; align-items: center; gap: 5px;
  overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none;
  padding: 2px 0;
}
.ws-filter-pills::-webkit-scrollbar { display: none; }
.ws-pill {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 8px; border: 1px solid rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.03); color: var(--text-muted);
  font-size: 0.76rem; font-weight: 500; white-space: nowrap;
  cursor: pointer; transition: all 0.2s var(--ease);
}
.ws-pill:hover { background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.12); color: var(--text-secondary); }
.ws-pill.active {
  background: rgba(99,102,241,0.12); border-color: rgba(99,102,241,0.3);
  color: var(--accent); font-weight: 600;
  box-shadow: 0 0 10px rgba(99,102,241,0.08);
}
.ws-pill-dot {
  width: 7px; height: 7px; border-radius: 50%;
  flex-shrink: 0; opacity: 0.8;
}
.ws-pill.active .ws-pill-dot { opacity: 1; }

/* Select wrappers */
.ws-toolbar-selects { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.ws-select-wrap {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(0,0,0,0.22); border: 1px solid rgba(255,255,255,0.07);
  border-radius: 8px; padding: 5px 8px 5px 10px;
  transition: all 0.2s var(--ease);
}
.ws-select-wrap svg { color: var(--text-muted); flex-shrink: 0; opacity: 0.6; }
.ws-select-wrap:hover { border-color: rgba(255,255,255,0.14); }
.ws-select-wrap:focus-within { border-color: var(--accent); box-shadow: 0 0 12px rgba(99,102,241,0.1); }
.ws-select-wrap:focus-within svg { color: var(--accent); opacity: 1; }
.ws-filter-select {
  background: transparent; border: none; outline: none;
  color: var(--text-secondary); font-size: 0.78rem;
  cursor: pointer; appearance: none; padding-right: 4px;
}
.ws-filter-select option { background: var(--bg-primary); color: var(--text-primary); }

/* Result count */
.ws-result-count {
  display: inline-flex; align-items: center;
  padding: 4px 10px; border-radius: 7px;
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.06);
  color: var(--text-muted); font-size: 0.72rem; font-weight: 500;
  white-space: nowrap; flex-shrink: 0;
}

/* â”€â”€ Cards Grid â”€â”€ */
.ws-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px; }

/* â”€â”€ Website Card â”€â”€ */
.ws-card {
  position: relative;
  background: linear-gradient(160deg, rgba(17,20,48,0.8), rgba(13,16,37,0.6));
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 16px; display: flex; flex-direction: column;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  transition: all 0.3s var(--ease); overflow: hidden;
}
.ws-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--purple), var(--accent));
  opacity: 0; transition: opacity 0.3s; border-radius: 16px 16px 0 0;
}
.ws-card:hover {
  border-color: rgba(99,102,241,0.25);
  box-shadow: 0 8px 40px rgba(99,102,241,0.08), 0 0 1px rgba(99,102,241,0.3);
  transform: translateY(-3px);
}
.ws-card:hover::before { opacity: 1; }
.ws-card-inactive { opacity: 0.55; filter: saturate(0.6); }
.ws-card-inactive:hover { opacity: 1; filter: saturate(1); }

.ws-card-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 18px 0; }
.ws-card-status { display: flex; align-items: center; gap: 10px; }
.ws-status-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; transition: all 0.3s; }
.ws-dot-active { background: var(--success); box-shadow: 0 0 8px var(--success); }
.ws-dot-inactive { background: var(--danger); box-shadow: 0 0 8px rgba(239,68,68,0.4); }
.ws-card-type-badge { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; }
.ws-card-actions-top { display: flex; gap: 4px; }
.ws-card-action-btn {
  background: transparent; border: none; cursor: pointer; padding: 6px;
  color: var(--text-muted); border-radius: 8px; transition: all 0.2s var(--ease);
}
.ws-card-action-btn:hover { background: rgba(99,102,241,0.1); color: var(--accent); transform: scale(1.1); }

.ws-card-body { padding: 12px 18px 16px; cursor: pointer; flex: 1; }
.ws-card-domain {
  font-size: 1.08rem; font-weight: 700; color: var(--text-primary);
  margin-bottom: 5px; word-break: break-all; letter-spacing: -0.01em;
}
.ws-card-path {
  font-size: 0.7rem; color: var(--text-muted); margin: 0; word-break: break-all;
  font-family: 'JetBrains Mono', monospace; opacity: 0.8;
}
.ws-card-aliases { margin-top: 10px; display: flex; flex-wrap: wrap; gap: 5px; }
.ws-alias-tag {
  font-size: 0.66rem; background: rgba(99,102,241,0.1); color: var(--accent);
  padding: 3px 10px; border-radius: 20px; font-weight: 500;
  border: 1px solid rgba(99,102,241,0.12); transition: all 0.2s;
}
.ws-alias-tag:hover { background: rgba(99,102,241,0.18); }

.ws-card-meta {
  display: flex; align-items: center; gap: 16px; padding: 11px 18px;
  font-size: 0.7rem; color: var(--text-muted);
  border-top: 1px solid rgba(255,255,255,0.04);
  background: rgba(0,0,0,0.1);
}
.ws-card-meta-item { display: flex; align-items: center; gap: 5px; transition: color 0.2s; }
.ws-card-meta-item:hover { color: var(--text-secondary); }

.ws-card-footer {
  display: flex; align-items: center; padding: 8px 12px; gap: 2px;
  border-top: 1px solid rgba(255,255,255,0.04);
  background: rgba(0,0,0,0.06);
}
.ws-footer-btn {
  background: transparent; border: none; cursor: pointer;
  padding: 7px 9px; color: var(--text-muted); border-radius: 8px;
  transition: all 0.2s var(--ease); display: flex; align-items: center;
}
.ws-footer-btn:hover { background: rgba(99,102,241,0.12); color: var(--accent); transform: scale(1.08); }
.ws-btn-ssl:hover { color: var(--warning); background: rgba(251,191,36,0.1); }
.ws-btn-danger:hover { color: var(--danger); background: rgba(239,68,68,0.1); }

/* â”€â”€ Empty State â”€â”€ */
.ws-empty-state {
  grid-column: 1 / -1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; padding: 80px 20px; text-align: center;
}
.ws-empty-icon { opacity: 0.2; margin-bottom: 4px; }
.ws-empty-title { font-size: 1.3rem; color: var(--text-primary); margin: 16px 0 8px; font-weight: 700; }
.ws-empty-sub { color: var(--text-muted); font-size: 0.88rem; max-width: 360px; line-height: 1.6; }
.ws-error-state { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 80px 20px; gap: 16px; text-align: center; }

/* â”€â”€ Create Modal Type Grid â”€â”€ */
.ws-type-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); gap: 8px; margin-top: 6px; }
.ws-type-option { display: flex; flex-direction: column; align-items: center; gap: 4px; padding: 12px 8px; border-radius: 12px; border: 2px solid var(--border); cursor: pointer; transition: all 0.2s var(--ease); }
.ws-type-option:hover { border-color: var(--accent); background: rgba(99,102,241,0.04); transform: translateY(-1px); }
.ws-type-selected { border-color: var(--accent); background: rgba(99,102,241,0.08); box-shadow: 0 0 16px rgba(99,102,241,0.15); }
.ws-type-icon { font-size: 1.5rem; }
.ws-type-label { font-size: 0.72rem; color: var(--text-secondary); }
.ws-form-hint { font-size: 0.7rem; color: var(--text-muted); margin-top: 4px; display: block; }
.ws-input-disabled { opacity: 0.5; cursor: not-allowed; }

/* â”€â”€ Detail Modal â”€â”€ */
/* Full-Page Detail View */
.ws-detail-page { animation: wsCardFadeIn 0.35s cubic-bezier(0.22, 1, 0.36, 1) both; }
.ws-detail-topbar {
  display: flex; align-items: center; gap: 14px; margin-bottom: 20px;
}
.ws-back-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px; padding: 8px 18px; color: var(--text-secondary);
  font-size: 0.82rem; font-weight: 600; cursor: pointer;
  transition: all 0.2s var(--ease);
}
.ws-back-btn:hover {
  background: rgba(99,102,241,0.08); border-color: rgba(99,102,241,0.2);
  color: var(--accent); transform: translateX(-2px);
}
.ws-back-btn svg { transition: transform 0.2s; }
.ws-back-btn:hover svg { transform: translateX(-3px); }
.ws-detail {
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.005));
  border: 1px solid rgba(255,255,255,0.06); border-radius: 18px;
  overflow: hidden;
}
.ws-detail-header {
  padding: 24px 28px 0;
  background: linear-gradient(180deg, rgba(99,102,241,0.04), transparent);
}
.ws-detail-title-row { display: flex; justify-content: space-between; align-items: flex-start; }
.ws-detail-domain { font-size: 1.35rem; font-weight: 800; color: var(--text-primary); margin: 0 0 10px; letter-spacing: -0.02em; }
.ws-detail-badges { display: flex; gap: 7px; flex-wrap: wrap; }
.ws-badge {
  font-size: 0.65rem; padding: 4px 12px; border-radius: 20px;
  font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em;
  backdrop-filter: blur(4px); transition: all 0.2s;
}
.ws-badge-success { background: rgba(16,185,129,0.12); color: var(--success); border: 1px solid rgba(16,185,129,0.15); }
.ws-badge-danger { background: rgba(239,68,68,0.1); color: var(--danger); border: 1px solid rgba(239,68,68,0.12); }
.ws-badge-warning { background: rgba(251,191,36,0.1); color: var(--warning); border: 1px solid rgba(251,191,36,0.12); }
.ws-badge-accent { background: rgba(99,102,241,0.1); color: var(--accent); border: 1px solid rgba(99,102,241,0.12); }
.ws-badge-info { background: rgba(59,130,246,0.1); color: var(--info); border: 1px solid rgba(59,130,246,0.12); }
.ws-badge-neutral { background: rgba(255,255,255,0.05); color: var(--text-secondary); border: 1px solid rgba(255,255,255,0.08); }

/* â”€â”€ Tabs â”€â”€ */
.ws-detail-tabs {
  display: flex; gap: 2px; padding: 18px 28px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: rgba(0,0,0,0.1);
  position: sticky; top: 0; z-index: 10;
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
}
.ws-tab {
  background: transparent; border: none; cursor: pointer;
  padding: 10px 20px; font-size: 0.8rem; font-weight: 500;
  color: var(--text-muted); border-bottom: 2px solid transparent;
  transition: all 0.2s var(--ease); border-radius: 8px 8px 0 0;
  display: flex; align-items: center; gap: 6px;
}
.ws-tab:hover { color: var(--text-primary); background: rgba(255,255,255,0.03); }
.ws-tab.active {
  color: var(--accent); border-bottom-color: var(--accent); font-weight: 600;
  background: rgba(99,102,241,0.04);
}
.ws-tab svg { opacity: 0.5; flex-shrink: 0; transition: opacity 0.2s; }
.ws-tab:hover svg { opacity: 0.8; }
.ws-tab.active svg { opacity: 1; }
.ws-tab-content { padding: 24px 28px; }

/* â”€â”€ Info Cards Grid â”€â”€ */
.ws-detail-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 12px; }
.ws-info-card {
  background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px; padding: 16px 18px;
  transition: all 0.25s var(--ease);
}
.ws-info-card:hover { border-color: rgba(255,255,255,0.1); background: rgba(255,255,255,0.04); }
.ws-info-card.ws-info-wide { grid-column: 1 / -1; }
.ws-info-label { font-size: 0.66rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.07em; margin-bottom: 7px; font-weight: 500; }
.ws-info-value { font-size: 0.88rem; color: var(--text-primary); word-break: break-all; }
.ws-info-value code { font-size: 0.8rem; }

/* â”€â”€ DNS Table â”€â”€ */
.ws-dns-table { width: 100%; border-collapse: collapse; font-size: 0.82rem; }
.ws-dns-table th {
  text-align: left; padding: 10px 14px; color: var(--text-muted);
  font-weight: 600; font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.05em;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  background: rgba(0,0,0,0.1);
}
.ws-dns-table th:first-child { border-radius: 8px 0 0 0; }
.ws-dns-table th:last-child { border-radius: 0 8px 0 0; }
.ws-dns-table td { padding: 11px 14px; border-bottom: 1px solid rgba(255,255,255,0.03); transition: background 0.15s; }
.ws-dns-table tr:hover td { background: rgba(255,255,255,0.02); }
.ws-dns-table tr:last-child td { border-bottom: none; }
.ws-dns-type { font-size: 0.7rem; font-weight: 700; background: rgba(99,102,241,0.12); color: var(--accent); padding: 3px 10px; border-radius: 6px; }
.ws-dns-value { font-family: 'JetBrains Mono', monospace; font-size: 0.76rem; color: var(--text-secondary); word-break: break-all; }

/* â”€â”€ WP Manager Sections â”€â”€ */
.ws-dns-section {
  background: rgba(255,255,255,0.015); border: 1px solid rgba(255,255,255,0.05);
  border-radius: 14px; overflow: hidden; transition: border-color 0.25s;
}
.ws-dns-section:hover { border-color: rgba(255,255,255,0.08); }
.ws-dns-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid rgba(255,255,255,0.04);
  background: rgba(0,0,0,0.1);
}
.ws-dns-header h4 { margin: 0; font-size: 0.9rem; font-weight: 700; color: var(--text-primary); }
.ws-dns-section .ws-dns-table th { background: transparent; }

/* â”€â”€ Domain Connect Panel â”€â”€ */
.ws-connect-panel { overflow-y: auto; }
.ws-connect-server-info {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px;
  background: linear-gradient(135deg, rgba(99,102,241,0.06), rgba(99,102,241,0.02));
  border: 1px solid rgba(99,102,241,0.15); border-radius: 14px;
  margin-bottom: 18px; flex-wrap: wrap; gap: 14px;
}
.ws-server-ip-card { display: flex; flex-direction: column; gap: 5px; }
.ws-server-ip-label { font-size: 0.68rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.07em; font-weight: 500; }
.ws-server-ip-row { display: flex; align-items: center; gap: 10px; }
.ws-server-ip { font-size: 1.25rem; font-weight: 800; color: var(--accent); letter-spacing: -0.01em; }

/* Required Records */
.ws-connect-section-title { font-size: 0.9rem; font-weight: 700; color: var(--text-primary); margin: 22px 0 12px; }
.ws-required-records { display: flex; flex-direction: column; gap: 8px; }
.ws-req-record {
  display: flex; align-items: center; gap: 10px; padding: 12px 16px;
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px; flex-wrap: wrap; transition: border-color 0.2s;
}
.ws-req-record:hover { border-color: rgba(255,255,255,0.1); }
.ws-req-type { font-size: 0.68rem; font-weight: 700; background: rgba(99,102,241,0.14); color: var(--accent); padding: 4px 10px; border-radius: 6px; min-width: 42px; text-align: center; }
.ws-req-name { font-family: monospace; font-size: 0.82rem; color: var(--text-secondary); }
.ws-req-arrow { color: var(--text-muted); }
.ws-req-value { font-family: monospace; font-size: 0.82rem; font-weight: 600; }
.ws-req-desc { font-size: 0.7rem; color: var(--text-muted); width: 100%; margin-top: 2px; }

/* Method Cards */
.ws-method-cards { display: flex; flex-direction: column; gap: 12px; }
.ws-method-card { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06); border-radius: 14px; padding: 20px; transition: border-color 0.2s; }
.ws-method-card:hover { border-color: rgba(255,255,255,0.1); }
.ws-method-recommended { border-color: rgba(99,102,241,0.3); background: rgba(99,102,241,0.04); }
.ws-method-header h5 { margin: 0 0 4px; font-size: 0.92rem; color: var(--text-primary); }
.ws-method-header p { margin: 0; font-size: 0.78rem; color: var(--text-muted); }
.ws-method-badge { font-size: 0.6rem; background: var(--accent); color: white; padding: 3px 10px; border-radius: 20px; text-transform: uppercase; font-weight: 700; letter-spacing: 0.05em; margin-bottom: 4px; display: inline-block; }
.ws-method-steps { margin: 12px 0 0; padding-left: 20px; font-size: 0.8rem; color: var(--text-secondary); }
.ws-method-steps li { margin-bottom: 6px; line-height: 1.5; }
.ws-method-steps code { font-size: 0.78rem; }

/* Provider Grid */
.ws-provider-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); gap: 8px; }
.ws-provider-card { display: flex; align-items: center; gap: 8px; padding: 10px 14px; background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06); border-radius: 10px; cursor: default; }
.ws-provider-icon { font-size: 1.2rem; }
.ws-provider-name { font-size: 0.78rem; color: var(--text-secondary); font-weight: 500; }

/* DNS Verify */
.ws-dns-checking { display: flex; align-items: center; gap: 10px; padding: 16px; color: var(--text-muted); font-size: 0.82rem; }
.ws-dns-result { padding: 16px; border-radius: 14px; margin-bottom: 16px; }
.ws-dns-connected { background: rgba(16,185,129,0.06); border: 1px solid rgba(16,185,129,0.2); }
.ws-dns-not-connected { background: rgba(251,191,36,0.04); border: 1px solid rgba(251,191,36,0.2); }
.ws-dns-result-header { display: flex; align-items: center; gap: 8px; font-weight: 600; font-size: 0.88rem; color: var(--text-primary); margin-bottom: 12px; }
.ws-dns-checks { display: flex; flex-direction: column; gap: 6px; }
.ws-dns-check-row { display: flex; align-items: center; gap: 8px; font-size: 0.78rem; padding: 4px 0; }
.ws-dns-check-type { font-weight: 600; min-width: 30px; color: var(--accent); }
.ws-dns-check-name { color: var(--text-secondary); min-width: 60px; }
.ws-dns-check-actual { font-family: monospace; color: var(--text-muted); font-size: 0.74rem; }
.ws-dns-note { font-size: 0.74rem; color: var(--text-muted); margin-top: 10px; font-style: italic; }

/* Nginx Viewer */
.ws-nginx-viewer { overflow: auto; }
.ws-nginx-code {
  background: rgba(0,0,0,0.35); border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px; padding: 20px; font-size: 0.76rem; line-height: 1.6;
  overflow-x: auto; white-space: pre;
}
.ws-nginx-code code { background: transparent; border: none; padding: 0; font-size: inherit; color: var(--text-secondary); }

/* Detail Action Bar */
.ws-detail-actions { display: flex; align-items: center; gap: 7px; margin-top: 16px; flex-wrap: wrap; }
.ws-detail-actions .btn { font-size: 0.72rem; gap: 5px; border-radius: 8px; }

/* Toggle Switch Buttons */
.ws-toggle-btn { border: none; background: transparent; cursor: pointer; padding: 5px; border-radius: 8px; transition: all 0.2s var(--ease); }
.ws-toggle-btn:hover { background: rgba(255,255,255,0.06); transform: scale(1.1); }
.ws-toggle-on svg rect { fill: rgba(16,185,129,0.15); }
.ws-toggle-off svg rect { fill: rgba(255,255,255,0.04); }

/* DNS Tab Toolbar + Add Form */
.ws-dns-toolbar { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.ws-dns-count { font-size: 0.78rem; color: var(--text-muted); font-weight: 600; }
.ws-dns-add-form {
  display: flex; align-items: center; gap: 8px; padding: 14px 16px;
  background: rgba(99,102,241,0.04); border: 1px solid rgba(99,102,241,0.12);
  border-radius: 12px; margin-bottom: 14px; flex-wrap: wrap;
}
.ws-dns-add-form select, .ws-dns-add-form input {
  background: rgba(0,0,0,0.25); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px; padding: 7px 12px; color: var(--text-primary); font-size: 0.8rem; outline: none;
  transition: border-color 0.2s;
}
.ws-dns-add-form select:focus, .ws-dns-add-form input:focus { border-color: var(--accent); }
.ws-dns-add-form select { width: 80px; }
.ws-dns-add-form input { flex: 1; min-width: 100px; }
.ws-dns-loading { display: flex; align-items: center; justify-content: center; padding: 40px; }

/* â”€â”€ SSL Tab â”€â”€ */
.ws-ssl-status {
  display: flex; align-items: center; gap: 18px; padding: 20px 22px; border-radius: 14px;
}
.ws-ssl-active { background: rgba(16,185,129,0.06); border: 1px solid rgba(16,185,129,0.15); }
.ws-ssl-inactive { background: rgba(251,191,36,0.04); border: 1px solid rgba(251,191,36,0.12); }
.ws-ssl-icon { font-size: 2rem; }
.ws-ssl-info h4 { margin: 0 0 4px; font-size: 1rem; color: var(--text-primary); font-weight: 700; }
.ws-ssl-info p { margin: 0; font-size: 0.82rem; color: var(--text-muted); }

/* â”€â”€ Log Viewer â”€â”€ */
.ws-logs-toolbar { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; flex-wrap: wrap; }
.ws-logs-toolbar select {
  background: rgba(0,0,0,0.25); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px; padding: 7px 12px; color: var(--text-secondary); font-size: 0.82rem; outline: none;
  transition: border-color 0.2s;
}
.ws-logs-toolbar select:hover { border-color: rgba(255,255,255,0.15); }
.ws-logs-toolbar select option { background: var(--bg-primary); color: var(--text-primary); }
.ws-log-viewer {
  background: rgba(0,0,0,0.4); border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px; padding: 18px; font-size: 0.72rem; line-height: 1.7;
  font-family: 'JetBrains Mono', monospace; color: var(--text-muted);
  white-space: pre-wrap; word-break: break-all; max-height: 600px; overflow-y: auto;
}

/* â”€â”€ Expandable Provider Guides â”€â”€ */
.ws-provider-guides { display: flex; flex-direction: column; gap: 6px; }
.ws-provider-guide { border: 1px solid rgba(255,255,255,0.06); border-radius: 12px; overflow: hidden; transition: border-color 0.2s; }
.ws-provider-guide:hover { border-color: rgba(255,255,255,0.1); }
.ws-provider-toggle {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 13px 18px; background: rgba(255,255,255,0.02);
  border: none; cursor: pointer; color: var(--text-primary); font-size: 0.85rem;
  transition: background 0.15s;
}
.ws-provider-toggle:hover { background: rgba(255,255,255,0.04); }
.ws-provider-toggle-left { display: flex; align-items: center; gap: 8px; }
.ws-provider-chevron { transition: transform 0.25s var(--ease); color: var(--text-muted); flex-shrink: 0; }
.ws-provider-expanded .ws-provider-chevron { transform: rotate(180deg); }
.ws-provider-steps { max-height: 0; overflow: hidden; transition: max-height 0.3s var(--ease), padding 0.3s; padding: 0 16px; }
.ws-provider-expanded .ws-provider-steps { max-height: 500px; padding: 4px 18px 18px; }
.ws-provider-steps ol { margin: 0; padding-left: 20px; }
.ws-provider-steps a { color: var(--accent); text-decoration: none; }
.ws-provider-steps a:hover { text-decoration: underline; }

/* Connect loading state */
.ws-connect-loading { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 40px; color: var(--text-muted); font-size: 0.82rem; }

/* Wide modal helper */
.modal-wide { max-width: 780px; }

/* â”€â”€ Responsive â”€â”€ */
@media (max-width: 768px) {
  .ws-grid { grid-template-columns: 1fr; }
  .ws-stats-row { grid-template-columns: repeat(2, 1fr); }
  .ws-toolbar { padding: 10px 12px; gap: 8px; }
  .ws-toolbar-top { flex-wrap: wrap; }
  .ws-search-wrap { min-width: 100%; order: -1; }
  .ws-toolbar-bottom { flex-direction: column; align-items: stretch; gap: 8px; }
  .ws-filter-pills { max-width: 100%; }
  .ws-toolbar-selects { flex-wrap: wrap; }
  .ws-add-btn span { display: none; }
  .ws-add-btn { padding: 8px 10px; }
  .ws-add-btn-sub span { display: none; }
  .ws-add-btn-sub { padding: 8px 10px; }
  .ws-detail-grid { grid-template-columns: 1fr; }
  .ws-connect-server-info { flex-direction: column; }
  .ws-provider-grid { grid-template-columns: repeat(2, 1fr); }
  .ws-detail-tabs { overflow-x: auto; flex-wrap: nowrap; padding: 14px 16px 0; }
  .ws-detail-actions { gap: 4px; }
  .ws-detail-actions .btn { font-size: 0.65rem; padding: 5px 8px; }
  .ws-dns-add-form { flex-direction: column; }
  .ws-dns-add-form select, .ws-dns-add-form input { width: 100%; }
  .ws-bulk-bar { flex-direction: column; gap: 8px; }
  .ws-bulk-actions { flex-wrap: wrap; }
  .ws-detail-header { padding: 16px 16px 0; }
  .ws-tab-content { padding: 16px; }
  .ws-detail { border-radius: 12px; }
  .ws-back-btn { padding: 6px 12px; font-size: 0.78rem; }
}

/* â”€â”€ Active Dot Pulse â”€â”€ */
@keyframes wsPulse {
  0%, 100% { box-shadow: 0 0 6px var(--success); }
  50% { box-shadow: 0 0 16px var(--success), 0 0 28px rgba(16,185,129,0.25); }
}
.ws-dot-active { animation: wsPulse 2.5s ease-in-out infinite; }

/* â”€â”€ Bulk Operations Bar â”€â”€ */
.ws-bulk-bar {
  display: flex; align-items: center; gap: 14px; padding: 12px 18px;
  background: linear-gradient(135deg, rgba(99,102,241,0.08), rgba(99,102,241,0.03));
  border: 1px solid rgba(99,102,241,0.18); border-radius: 12px;
  transition: all 0.25s var(--ease);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.ws-bulk-bar.hidden { display: none; }
.ws-bulk-select-all { display: flex; align-items: center; gap: 6px; font-size: 0.8rem; color: var(--text-secondary); cursor: pointer; }
.ws-bulk-select-all input { accent-color: var(--accent); }
.ws-bulk-count { font-size: 0.78rem; font-weight: 700; color: var(--accent); }
.ws-bulk-actions { display: flex; align-items: center; gap: 6px; margin-left: auto; }

/* â”€â”€ Card Checkbox â”€â”€ */
.ws-card-checkbox { display: flex; align-items: center; }
.ws-card-checkbox input { width: 15px; height: 15px; accent-color: var(--accent); cursor: pointer; border-radius: 4px; }
.ws-card-selected { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent), 0 0 20px rgba(99,102,241,0.1); }

/* â”€â”€ App Detail Badge â”€â”€ */
.ws-app-detail { font-size: 0.62rem; opacity: 0.7; font-weight: 400; }

/* â”€â”€ Small spinner for inline loading â”€â”€ */
.spinner-sm { width: 14px; height: 14px; border: 2px solid rgba(255,255,255,0.1); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.6s linear infinite; display: inline-block; }
.ws-ov-loading { display: flex; align-items: center; gap: 8px; }

/* â”€â”€ SSL Actions Bar â”€â”€ */
.ws-ssl-actions-bar { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 18px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.05); }

/* â”€â”€ Logs Search + Highlight + Download â”€â”€ */
.ws-logs-search-wrap {
  display: flex; align-items: center; gap: 6px;
  background: rgba(0,0,0,0.25); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px; padding: 5px 10px;
}
.ws-logs-search { background: transparent; border: none; outline: none; color: var(--text-primary); font-size: 0.78rem; width: 140px; }
.ws-log-highlight { background: rgba(251,191,36,0.4); color: var(--text-primary); padding: 0 3px; border-radius: 3px; }

/* â”€â”€ DNS Actions cell â”€â”€ */
.ws-dns-actions { display: flex; gap: 4px; }

/* â”€â”€ Analytics Tab â”€â”€ */
.ws-analytics-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 22px; padding-bottom: 16px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.ws-analytics-header-info { display: flex; flex-direction: column; gap: 3px; }
.ws-analytics-header-title {
  font-size: 1.15rem; font-weight: 800; color: var(--text-primary);
  letter-spacing: -0.01em;
  background: linear-gradient(135deg, var(--text-primary), var(--accent));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.ws-analytics-header-meta { font-size: 0.72rem; color: var(--text-muted); letter-spacing: 0.01em; }
.ws-analytics-header-actions { display: flex; align-items: center; gap: 8px; }
.ws-analytics-refresh { display: flex; align-items: center; gap: 5px; font-size: 0.74rem; }
.ws-analytics-refresh.ws-spin svg { animation: wsSpin 0.8s linear infinite; }
@keyframes wsSpin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

.ws-analytics-stats { display: grid; grid-template-columns: repeat(auto-fill, minmax(135px, 1fr)); gap: 12px; margin-bottom: 22px; }
.ws-analytics-stat {
  background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px; padding: 16px 18px; text-align: center;
  transition: all 0.3s var(--ease); position: relative; overflow: hidden;
}
.ws-analytics-stat::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0; transition: opacity 0.3s;
}
.ws-analytics-stat:hover { border-color: rgba(255,255,255,0.12); transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.15); }
.ws-analytics-stat:hover::before { opacity: 1; }
.ws-analytics-stat-value { font-size: 1.4rem; font-weight: 800; color: var(--text-primary); line-height: 1.2; letter-spacing: -0.02em; animation: wsCountPop 0.4s var(--ease) backwards; }
@keyframes wsCountPop { from { opacity: 0; transform: scale(0.85); } to { opacity: 1; transform: scale(1); } }
.ws-analytics-stat-label { font-size: 0.67rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; margin-top: 6px; font-weight: 500; }
.ws-analytics-stat-success { border-color: rgba(16,185,129,0.15); }
.ws-analytics-stat-success::before { background: linear-gradient(90deg, transparent, var(--success), transparent); }
.ws-analytics-stat-success .ws-analytics-stat-value { color: var(--success); }
.ws-analytics-stat-error { border-color: rgba(251,191,36,0.15); }
.ws-analytics-stat-error::before { background: linear-gradient(90deg, transparent, var(--warning), transparent); }
.ws-analytics-stat-error .ws-analytics-stat-value { color: var(--warning); }
.ws-analytics-stat-server-error { border-color: rgba(239,68,68,0.15); }
.ws-analytics-stat-server-error::before { background: linear-gradient(90deg, transparent, var(--danger), transparent); }
.ws-analytics-stat-server-error .ws-analytics-stat-value { color: var(--danger); }

/* Mini-cards row (bot traffic, peak hour, redirects) */
.ws-analytics-mini-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 12px; margin-bottom: 24px; }
.ws-analytics-mini-card {
  display: flex; align-items: center; gap: 12px; padding: 14px 18px;
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05);
  border-radius: 14px; transition: all 0.25s var(--ease);
}
.ws-analytics-mini-card:hover { border-color: rgba(255,255,255,0.12); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(0,0,0,0.1); }
.ws-analytics-mini-card svg { opacity: 0.7; flex-shrink: 0; }
.ws-analytics-mini-info { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.ws-analytics-mini-val { font-size: 0.85rem; font-weight: 700; color: var(--text-primary); }
.ws-analytics-mini-sub { font-size: 0.69rem; color: var(--text-muted); line-height: 1.3; }
.ws-analytics-mini-bar { height: 5px; background: rgba(255,255,255,0.05); border-radius: 3px; overflow: hidden; width: 56px; flex-shrink: 0; }
.ws-analytics-mini-bar-fill { height: 100%; border-radius: 3px; transition: width 0.5s var(--ease); animation: wsBarGrow 0.6s var(--ease) backwards; }
.ws-analytics-mini-bar-bot { background: var(--warning); }

.ws-analytics-section { margin-bottom: 26px; }
.ws-analytics-section + .ws-analytics-section::before {
  content: ''; display: block; height: 1px; margin-bottom: 26px;
  background: linear-gradient(90deg, transparent, rgba(99,102,241,0.12) 30%, rgba(99,102,241,0.12) 70%, transparent);
}
.ws-analytics-section-title {
  font-size: 0.9rem; font-weight: 700; color: var(--text-primary); margin: 0 0 14px;
  display: flex; align-items: center; gap: 8px;
  padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,0.04);
  letter-spacing: 0.01em;
}

.ws-analytics-chart {
  background: rgba(0,0,0,0.15); border: 1px solid rgba(255,255,255,0.05);
  border-radius: 14px; padding: 20px 16px 12px;
}
.ws-chart-bars { display: flex; align-items: flex-end; gap: 3px; height: 160px; position: relative; }
.ws-chart-bars::before {
  content: ''; position: absolute; inset: 0;
  background: repeating-linear-gradient(to bottom, transparent, transparent calc(25% - 1px), rgba(255,255,255,0.03) calc(25% - 1px), rgba(255,255,255,0.03) 25%);
  pointer-events: none; z-index: 0;
}
.ws-chart-col { display: flex; flex-direction: column; align-items: center; flex: 1; height: 100%; justify-content: flex-end; position: relative; z-index: 1; cursor: crosshair; }
.ws-chart-col::after {
  content: attr(title); position: absolute; bottom: 100%; left: 50%; transform: translateX(-50%) translateY(-4px);
  background: rgba(0,0,0,0.85); color: #fff; font-size: 0.62rem; padding: 4px 8px;
  border-radius: 6px; white-space: nowrap; pointer-events: none;
  opacity: 0; transition: opacity 0.15s; z-index: 10;
  backdrop-filter: blur(8px); border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3); font-family: 'JetBrains Mono', monospace;
}
.ws-chart-col:hover::after { opacity: 1; }
.ws-chart-bar-wrap { display: flex; gap: 1px; align-items: flex-end; width: 100%; height: 100%; }
.ws-chart-bar {
  flex: 1; border-radius: 4px 4px 0 0; min-height: 2px;
  background: linear-gradient(to top, var(--accent), rgba(99,102,241,0.35));
  transition: all 0.4s var(--ease);
  animation: wsChartBarGrow 0.5s var(--ease) backwards;
}
@keyframes wsChartBarGrow { from { height: 0 !important; transform: scaleY(0); transform-origin: bottom; } to { transform: scaleY(1); } }
.ws-chart-bar-bw {
  flex: 1; border-radius: 4px 4px 0 0; min-height: 1px;
  background: linear-gradient(to top, rgba(251,191,36,0.7), rgba(251,191,36,0.2));
  transition: all 0.4s var(--ease);
}
.ws-chart-col:hover .ws-chart-bar {
  background: linear-gradient(to top, var(--accent), rgba(99,102,241,0.7));
  box-shadow: 0 0 12px rgba(99,102,241,0.3);
}
.ws-chart-col:hover .ws-chart-bar-bw {
  background: linear-gradient(to top, rgba(251,191,36,0.9), rgba(251,191,36,0.4));
  box-shadow: 0 0 8px rgba(251,191,36,0.25);
}
.ws-chart-bar-peak {
  background: linear-gradient(to top, var(--success), rgba(16,185,129,0.5)) !important;
  box-shadow: 0 0 8px rgba(16,185,129,0.25);
}
.ws-chart-col-peak:hover .ws-chart-bar-peak {
  background: linear-gradient(to top, var(--success), rgba(16,185,129,0.8)) !important;
  box-shadow: 0 0 16px rgba(16,185,129,0.4);
}
.ws-chart-label { font-size: 0.62rem; color: var(--text-muted); margin-top: 6px; font-weight: 500; transition: color 0.2s; }
.ws-chart-col:hover .ws-chart-label { color: var(--text-primary); }

/* Donut charts row */
.ws-analytics-donuts-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 14px; margin-bottom: 26px; }
.ws-analytics-donut-card {
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05);
  border-radius: 14px; padding: 18px; transition: all 0.25s var(--ease);
}
.ws-analytics-donut-card:hover { border-color: rgba(255,255,255,0.12); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(0,0,0,0.1); }
.ws-donut-wrap { display: flex; align-items: center; gap: 18px; }
.ws-donut { border-radius: 50%; position: relative; flex-shrink: 0; box-shadow: 0 0 20px rgba(0,0,0,0.2); }
.ws-donut::after {
  content: ''; position: absolute; top: 50%; left: 50%;
  width: 52%; height: 52%; border-radius: 50%;
  background: var(--bg-primary, #080b16);
  transform: translate(-50%, -50%);
}
.ws-donut-center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  z-index: 2; text-align: center; pointer-events: none;
}
.ws-donut-center-pct {
  font-size: 0.82rem; font-weight: 800; color: var(--text-primary);
  line-height: 1; letter-spacing: -0.02em;
}
.ws-donut-center-label {
  font-size: 0.5rem; color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.04em; margin-top: 1px; display: block;
}
.ws-donut-legend { display: flex; flex-direction: column; gap: 5px; flex: 1; min-width: 0; }
.ws-donut-legend-item { display: flex; align-items: center; gap: 7px; font-size: 0.75rem; transition: opacity 0.2s; }
.ws-donut-legend-item:hover { opacity: 0.75; }
.ws-donut-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; box-shadow: 0 0 4px rgba(0,0,0,0.2); }
.ws-donut-label { color: var(--text-secondary); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ws-donut-val { color: var(--text-muted); font-weight: 600; font-size: 0.72rem; font-family: 'JetBrains Mono', monospace; white-space: nowrap; }

.ws-analytics-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-bottom: 26px; align-items: start; }
.ws-analytics-columns > .ws-analytics-section { margin-bottom: 0; }
.ws-analytics-columns > .ws-analytics-section + .ws-analytics-section::before { display: none; }
@media (max-width: 900px) { .ws-analytics-columns { grid-template-columns: 1fr; } }
@media (max-width: 768px) { .ws-analytics-donuts-row { grid-template-columns: 1fr; } .ws-analytics-stats { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); } }
@media (max-width: 500px) { .ws-donut-wrap { flex-direction: column; align-items: center; text-align: center; } .ws-donut-legend { align-items: center; } }

.ws-analytics-list { display: flex; flex-direction: column; gap: 4px; }
.ws-analytics-list-item {
  display: grid; grid-template-columns: 28px 1fr 65px 80px; align-items: center;
  gap: 10px; padding: 9px 14px; background: rgba(255,255,255,0.02); border-radius: 10px;
  font-size: 0.8rem; transition: all 0.2s var(--ease);
}
.ws-analytics-list-item:nth-child(odd) { background: rgba(255,255,255,0.025); }
.ws-analytics-list-item:hover { background: rgba(255,255,255,0.055); transform: translateX(2px); }
.ws-analytics-rank {
  color: var(--text-muted); font-weight: 700; font-size: 0.72rem; text-align: center;
  width: 24px; height: 24px; line-height: 24px;
  border-radius: 6px; background: rgba(255,255,255,0.04);
}
.ws-analytics-list-item:first-child .ws-analytics-rank { background: rgba(99,102,241,0.15); color: var(--accent); }
.ws-analytics-list-item:nth-child(2) .ws-analytics-rank { background: rgba(99,102,241,0.1); color: var(--accent); opacity: 0.8; }
.ws-analytics-list-item:nth-child(3) .ws-analytics-rank { background: rgba(99,102,241,0.07); color: var(--accent); opacity: 0.65; }
.ws-analytics-path { color: var(--text-secondary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; font-family: 'JetBrains Mono', monospace; font-size: 0.76rem; }
.ws-analytics-path-error { color: var(--danger); opacity: 0.85; }
.ws-analytics-count { color: var(--accent); font-weight: 600; font-size: 0.78rem; text-align: right; font-family: 'JetBrains Mono', monospace; }
.ws-analytics-bar { height: 5px; background: rgba(255,255,255,0.05); border-radius: 3px; overflow: hidden; }
.ws-analytics-bar-fill { height: 100%; background: var(--accent); border-radius: 3px; transition: width 0.5s var(--ease); animation: wsBarGrow 0.6s var(--ease) backwards; }
@keyframes wsBarGrow { from { width: 0 !important; } }
.ws-analytics-bar-referrer { background: var(--success); }

.ws-analytics-status-grid { display: flex; flex-wrap: wrap; gap: 10px; }
.ws-analytics-status-item {
  display: flex; align-items: center; gap: 10px; padding: 10px 16px;
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05);
  border-radius: 12px; transition: all 0.25s var(--ease); min-width: 100px;
}
.ws-analytics-status-item:hover { border-color: rgba(255,255,255,0.12); transform: translateY(-1px); box-shadow: 0 4px 12px rgba(0,0,0,0.1); }
.ws-analytics-status-code { font-family: 'JetBrains Mono', monospace; font-weight: 700; font-size: 0.85rem; }
.ws-analytics-status-count { font-size: 0.8rem; color: var(--text-secondary); font-weight: 500; }
.ws-analytics-status-pct { font-size: 0.68rem; color: var(--text-muted); opacity: 0.7; background: rgba(255,255,255,0.04); padding: 2px 6px; border-radius: 4px; }

/* Traffic trend arrow indicator */
.ws-trend { font-size: 0.68rem; font-weight: 700; margin-left: 5px; padding: 2px 7px; border-radius: 6px; vertical-align: middle; letter-spacing: 0.02em; }
.ws-trend-up { color: var(--success); background: rgba(16,185,129,0.14); border: 1px solid rgba(16,185,129,0.2); }
.ws-trend-down { color: var(--danger); background: rgba(239,68,68,0.12); border: 1px solid rgba(239,68,68,0.2); }
.ws-trend-stable { color: var(--text-muted); background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.06); }

/* Day-of-week chart */
.ws-dow-chart .ws-chart-bars { height: 120px; }
.ws-dow-bars { gap: 10px !important; }
.ws-dow-bars .ws-chart-col { max-width: 70px; }
.ws-dow-bars .ws-chart-label { font-size: 0.72rem; font-weight: 600; }

/* Bandwidth by content type */
.ws-analytics-bw-type-list { display: flex; flex-direction: column; gap: 5px; }
.ws-analytics-bw-type-item {
  display: flex; align-items: center; gap: 12px; padding: 9px 14px;
  background: rgba(255,255,255,0.02); border-radius: 10px;
  font-size: 0.8rem; transition: all 0.2s var(--ease);
}
.ws-analytics-bw-type-item:nth-child(odd) { background: rgba(255,255,255,0.025); }
.ws-analytics-bw-type-item:hover { background: rgba(255,255,255,0.055); transform: translateX(2px); }
.ws-analytics-bw-type-name { display: flex; align-items: center; gap: 7px; min-width: 95px; color: var(--text-secondary); font-weight: 600; }
.ws-analytics-bw-type-val { color: var(--accent); font-weight: 600; font-family: 'JetBrains Mono', monospace; font-size: 0.76rem; min-width: 75px; text-align: right; }

/* Threat breakdown grid */
.ws-analytics-threat-grid { display: flex; flex-wrap: wrap; gap: 10px; }
.ws-analytics-threat-item {
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  padding: 12px 18px; border-radius: 12px; min-width: 160px;
  transition: all 0.25s var(--ease);
}
.ws-threat-critical { background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.2); }
.ws-threat-critical:hover { border-color: rgba(239,68,68,0.4); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(239,68,68,0.1); }
.ws-threat-high { background: rgba(251,191,36,0.08); border: 1px solid rgba(251,191,36,0.2); }
.ws-threat-high:hover { border-color: rgba(251,191,36,0.4); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(251,191,36,0.1); }
.ws-threat-medium { background: rgba(99,102,241,0.08); border: 1px solid rgba(99,102,241,0.15); }
.ws-threat-medium:hover { border-color: rgba(99,102,241,0.3); transform: translateY(-1px); box-shadow: 0 4px 16px rgba(99,102,241,0.1); }
.ws-threat-label { font-size: 0.78rem; font-weight: 600; color: var(--text-secondary); }
.ws-threat-count { font-family: 'JetBrains Mono', monospace; font-weight: 800; font-size: 0.95rem; }
.ws-threat-critical .ws-threat-count { color: var(--danger); }
.ws-threat-high .ws-threat-count { color: var(--warning); }
.ws-threat-medium .ws-threat-count { color: var(--accent); }
.ws-threat-total { font-size: 0.68rem; font-weight: 600; color: var(--danger); margin-left: 8px; opacity: 0.85; background: rgba(239,68,68,0.1); padding: 2px 8px; border-radius: 6px; }

/* UA list items â€” wider path column */
.ws-analytics-ua-item { grid-template-columns: 28px 1fr 65px !important; }
.ws-analytics-ua-str { font-size: 0.7rem !important; }
/* Danger mini-card (scan attempts) */
.ws-analytics-mini-card-danger { border-color: rgba(239,68,68,0.2); background: rgba(239,68,68,0.04); }
.ws-analytics-mini-card-danger:hover { border-color: rgba(239,68,68,0.35); box-shadow: 0 4px 16px rgba(239,68,68,0.08); }

/* Chart legend */
.ws-chart-legend { display: flex; justify-content: center; gap: 20px; margin-top: 12px; padding-top: 8px; border-top: 1px solid rgba(255,255,255,0.04); }
.ws-chart-legend-item { display: flex; align-items: center; gap: 6px; font-size: 0.7rem; color: var(--text-muted); font-weight: 500; }
.ws-chart-legend-dot { width: 10px; height: 10px; border-radius: 3px; flex-shrink: 0; }
.ws-chart-legend-req { background: var(--accent); }
.ws-chart-legend-bw { background: rgba(251,191,36,0.7); }
.ws-chart-legend-err { background: var(--danger); }
/* Error rate chart bar */
.ws-chart-bar-error { background: linear-gradient(0deg, var(--danger), rgba(239,68,68,0.5)); border-radius: 3px 3px 0 0; }
.ws-chart-col-danger .ws-chart-bar-error { background: var(--danger); box-shadow: 0 0 8px rgba(239,68,68,0.5); }
.ws-error-rate-chart .ws-chart-bars { height: 100px; }
.ws-error-rate-chart .ws-chart-col:hover .ws-chart-bar-error {
  background: linear-gradient(0deg, var(--danger), rgba(239,68,68,0.85));
  box-shadow: 0 0 10px rgba(239,68,68,0.35);
}
/* Suspicious items */
.ws-analytics-suspicious-item { grid-template-columns: 28px 1fr 65px 80px !important; }
.ws-analytics-bar-error { background: linear-gradient(90deg, var(--danger), rgba(239,68,68,0.3)); }
/* Trending paths */
.ws-trending-badge { font-size: 0.64rem; color: var(--success); background: rgba(16,185,129,0.14); padding: 3px 10px; border-radius: 8px; margin-left: 8px; font-weight: 600; border: 1px solid rgba(16,185,129,0.2); }
.ws-trending-growth { color: var(--success) !important; font-weight: 600; }
.ws-analytics-trend-detail { font-size: 0.66rem; color: var(--text-muted); margin-left: 6px; white-space: nowrap; font-family: 'JetBrains Mono', monospace; }
/* Donut percentage label */
.ws-donut-pct { color: var(--text-muted); opacity: 0.65; font-size: 0.64rem; margin-left: 3px; }
/* Heavy pages item â€” no bar column */
.ws-analytics-heavy-item { grid-template-columns: 28px 1fr 65px !important; }
.ws-analytics-heavy-size { color: var(--warning); font-weight: 600; font-family: 'JetBrains Mono', monospace; font-size: 0.78rem; }

/* Analytics section entrance animation */
@keyframes wsAnalyticsFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
@keyframes wsShimmer {
  0% { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.ws-analytics-skeleton {
  display: flex; flex-direction: column; gap: 16px; padding: 24px;
}
.ws-analytics-skeleton-row {
  display: flex; gap: 12px;
}
.ws-analytics-skeleton-block {
  border-radius: 14px; flex: 1;
  background: linear-gradient(90deg, rgba(255,255,255,0.03) 25%, rgba(255,255,255,0.06) 50%, rgba(255,255,255,0.03) 75%);
  background-size: 200% 100%;
  animation: wsShimmer 1.5s ease-in-out infinite;
}
.ws-analytics-skeleton-lg { height: 80px; }
.ws-analytics-skeleton-md { height: 160px; }
.ws-analytics-skeleton-sm { height: 48px; }
.ws-analytics-section,
.ws-analytics-donuts-row,
.ws-analytics-columns { animation: wsAnalyticsFadeIn 0.35s ease-out backwards; }
.ws-analytics-section:nth-child(n+3) { animation-delay: 0.05s; }
.ws-analytics-section:nth-child(n+5) { animation-delay: 0.1s; }
.ws-analytics-donuts-row:nth-child(n+4) { animation-delay: 0.08s; }

/* Analytics empty state */
.ws-analytics-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 48px 24px; text-align: center;
}
.ws-analytics-empty-icon {
  width: 56px; height: 56px; border-radius: 50%;
  background: rgba(99,102,241,0.08); border: 1px solid rgba(99,102,241,0.15);
  display: flex; align-items: center; justify-content: center; margin-bottom: 16px;
}
.ws-analytics-empty-icon svg { opacity: 0.5; }
.ws-analytics-empty-title {
  font-size: 0.92rem; font-weight: 700; color: var(--text-primary); margin-bottom: 6px;
}
.ws-analytics-empty-sub {
  font-size: 0.76rem; color: var(--text-muted); max-width: 280px; line-height: 1.5;
}

/* â”€â”€ Nginx Syntax Highlighting â”€â”€ */
.ws-nx-comment { color: #6a9955; font-style: italic; }
.ws-nx-block { color: #c586c0; font-weight: 700; }
.ws-nx-directive { color: #569cd6; }
.ws-nx-string { color: #ce9178; }
.ws-nx-number { color: #b5cea8; }
.ws-nx-var { color: #9cdcfe; }

/* â”€â”€ Auto-refresh Button â”€â”€ */
.ws-auto-refresh-btn { transition: all 0.2s; border-radius: 8px; }
.ws-auto-refresh-active { background: rgba(16,185,129,0.15) !important; color: var(--success) !important; border: 1px solid rgba(16,185,129,0.3); box-shadow: 0 0 8px rgba(16,185,129,0.15); }
.ws-auto-refresh-active svg { animation: wsPulse 2s ease-in-out infinite; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SD â€” Subdomain Wizard  (sd-*)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Overlay + Backdrop */
.sd-overlay {
  position: fixed; inset: 0; z-index: 9998;
  display: flex; align-items: center; justify-content: center;
  animation: sdIn .2s ease;
}
.sd-overlay--hide { animation: sdOut .2s ease forwards; }
@keyframes sdIn  { from { opacity:0 } to { opacity:1 } }
@keyframes sdOut { from { opacity:1 } to { opacity:0 } }

.sd-drop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.58);
  backdrop-filter: blur(12px);
}

/* Modal card */
.sd-modal {
  position: relative; z-index: 1;
  width: 94%; max-width: 640px; max-height: 88vh;
  display: flex; flex-direction: column;
  background: var(--bg-card);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 16px; overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.04);
  animation: sdCard .25s cubic-bezier(.16,1,.3,1);
}
.sd-modal--sm { max-width: 540px; }
@keyframes sdCard { from { opacity:0; transform: translateY(16px) scale(.97) } to { opacity:1; transform: none } }

/* Header bar */
.sd-top {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 22px; border-bottom: 1px solid rgba(255,255,255,.06);
}
.sd-top-left { display: flex; align-items: center; gap: 12px; }
.sd-top-icon {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; flex-shrink: 0;
  background: rgba(99,102,241,.1); border: 1px solid rgba(99,102,241,.15);
}
.sd-top-icon--warn { background: rgba(251,191,36,.1); border-color: rgba(251,191,36,.15); }
.sd-top-title { font-size: 1rem; font-weight: 700; color: var(--text-primary); }
.sd-top-sub {
  font-size: .76rem; color: var(--text-muted);
  font-family: 'JetBrains Mono', monospace; margin-top: 1px;
}
.sd-close-x {
  width: 32px; height: 32px; border-radius: 8px; border: none;
  background: rgba(255,255,255,.04); color: var(--text-muted);
  font-size: 1.3rem; line-height: 1; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.sd-close-x:hover { background: rgba(239,68,68,.12); color: var(--danger); }

/* Stepper */
.sd-steps { padding: 12px 22px; border-bottom: 1px solid rgba(255,255,255,.04); }
.sd-steps-bar {
  width: 100%; height: 3px; border-radius: 3px;
  background: rgba(255,255,255,.06); overflow: hidden;
}
.sd-steps-fill {
  height: 100%; border-radius: 3px;
  background: linear-gradient(90deg, var(--accent), #a78bfa);
  transition: width .35s ease;
}
.sd-steps-row { display: flex; justify-content: space-between; margin-top: 7px; }
.sd-step {
  font-size: .72rem; font-weight: 600; color: var(--text-muted);
  display: flex; align-items: center; gap: 5px;
}
.sd-step b {
  display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px; border-radius: 50%;
  font-size: .6rem; font-weight: 700;
  background: rgba(255,255,255,.05); border: 1.5px solid rgba(255,255,255,.08);
}
.sd-step--on { color: var(--accent); }
.sd-step--on b { background: rgba(99,102,241,.15); border-color: var(--accent); color: var(--accent); }
.sd-step--ok { color: var(--success); }
.sd-step--ok b { background: rgba(16,185,129,.12); border-color: var(--success); color: var(--success); }

/* Body */
.sd-body { flex: 1; overflow-y: auto; padding: 20px 24px; }

/* Footer */
.sd-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 22px;
  border-top: 1px solid rgba(255,255,255,.06);
  background: rgba(0,0,0,.06);
}

/* Buttons */
.sd-btn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 18px; border-radius: 8px; border: none;
  font-size: .8rem; font-weight: 600; white-space: nowrap;
  cursor: pointer; transition: all .15s; outline: none;
}
.sd-btn:disabled { opacity: .35; pointer-events: none; }
.sd-btn--ghost { background: transparent; color: var(--text-muted); }
.sd-btn--ghost:hover { color: var(--text-primary); background: rgba(255,255,255,.05); }
.sd-btn--go {
  background: linear-gradient(135deg, var(--accent), #818cf8);
  color: #fff; box-shadow: 0 2px 10px rgba(99,102,241,.22);
}
.sd-btn--go:hover { filter: brightness(1.08); transform: translateY(-1px); }
.sd-btn--go:disabled { filter: none; transform: none; }
.sd-btn--out {
  background: transparent; color: var(--accent);
  border: 1px solid rgba(99,102,241,.2);
}
.sd-btn--out:hover { background: rgba(99,102,241,.08); }
.sd-btn--auto-on { color: var(--success); border-color: rgba(16,185,129,.3); background: rgba(16,185,129,.05); }

/* Segmented toggle */
.sd-seg {
  display: flex; gap: 4px; margin-bottom: 16px;
  background: rgba(0,0,0,.2); border-radius: 10px; padding: 3px;
  border: 1px solid rgba(255,255,255,.04);
}
.sd-seg-btn {
  flex: 1; padding: 9px 12px; border: none; border-radius: 8px;
  font-size: .8rem; font-weight: 600; cursor: pointer;
  background: transparent; color: var(--text-muted);
  transition: background .15s, color .15s;
}
.sd-seg-btn:hover { color: var(--text-primary); }
.sd-seg-btn--on {
  background: rgba(99,102,241,.14); color: var(--accent);
  border: 1px solid rgba(99,102,241,.18);
}

/* Labels */
.sd-lbl {
  display: block; font-size: .76rem; font-weight: 600;
  color: var(--text-secondary); margin-bottom: 7px;
}
.sd-lbl--s { font-size: .72rem; margin-bottom: 4px; }

/* Domain combo input */
.sd-combo {
  display: flex; align-items: center;
  border: 2px solid rgba(255,255,255,.08); border-radius: 10px;
  background: rgba(0,0,0,.18); overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.sd-combo:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(99,102,241,.07);
}
.sd-combo--ok { border-color: rgba(16,185,129,.35); }
.sd-combo--err { border-color: rgba(239,68,68,.35); }
.sd-combo--full { /* external â€” no suffix */ }
.sd-combo-in {
  flex: 1; background: transparent; border: none;
  color: var(--text-primary); font-size: .92rem;
  padding: 11px 14px; outline: none;
  font-family: 'JetBrains Mono', monospace;
}
.sd-combo-in::placeholder { color: var(--text-muted); opacity: .3; }
.sd-combo-sfx {
  padding: 11px 14px; font-size: .8rem; color: var(--text-muted);
  background: rgba(255,255,255,.02); border-left: 1px solid rgba(255,255,255,.06);
  font-family: 'JetBrains Mono', monospace; white-space: nowrap; font-weight: 500;
}

/* Domain preview */
.sd-preview {
  margin-top: 6px; font-size: .76rem;
  font-family: 'JetBrains Mono', monospace; color: var(--accent); font-weight: 500;
}
.sd-preview--ph { color: var(--text-muted); opacity: .4; font-weight: 400; }

/* DNS section */
#sd-dns { margin-top: 14px; }
.sd-dns-idle { font-size: .78rem; color: var(--text-muted); opacity: .5; padding: 10px 0; }
.sd-dns-load {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 0; font-size: .82rem; color: var(--text-muted);
}
.sd-spin {
  display: inline-block; width: 20px; height: 20px; border-radius: 50%;
  border: 2.5px solid rgba(99,102,241,.15); border-top-color: var(--accent);
  animation: sdSpin .7s linear infinite;
}
@keyframes sdSpin { to { transform: rotate(360deg) } }

/* Alert banners */
.sd-alert {
  padding: 14px 16px; border-radius: 10px; margin-bottom: 12px;
  border: 1px solid;
}
.sd-alert b { display: block; font-size: .86rem; color: var(--text-primary); margin-bottom: 4px; }
.sd-alert p { margin: 0; font-size: .78rem; color: var(--text-secondary); line-height: 1.5; }
.sd-alert code {
  background: rgba(255,255,255,.06); padding: 1px 6px; border-radius: 4px;
  font-size: .84em; font-family: 'JetBrains Mono', monospace;
}
.sd-alert--ok  { background: rgba(16,185,129,.05); border-color: rgba(16,185,129,.18); }
.sd-alert--warn { background: rgba(251,191,36,.04); border-color: rgba(251,191,36,.18); }
.sd-alert--err  { background: rgba(239,68,68,.05); border-color: rgba(239,68,68,.18); }

/* IP row */
.sd-ip-row {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; margin-bottom: 10px; border-radius: 8px;
  background: rgba(99,102,241,.05); border: 1px solid rgba(99,102,241,.12);
}
.sd-ip-lbl { font-size: .76rem; font-weight: 600; color: var(--text-muted); }
.sd-ip-val {
  font-family: 'JetBrains Mono', monospace; font-size: .88rem;
  font-weight: 600; color: var(--accent); flex: 1;
}
.sd-copy {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: 6px;
  background: rgba(99,102,241,.1); border: 1px solid rgba(99,102,241,.15);
  color: var(--accent); font-size: .7rem; font-weight: 600;
  cursor: pointer; transition: background .15s;
}
.sd-copy:hover { background: rgba(99,102,241,.18); }
.sd-copy-sm {
  background: none; border: none; cursor: pointer;
  color: var(--text-muted); padding: 0; transition: color .15s;
}
.sd-copy-sm:hover { color: var(--accent); }

/* DNS table */
.sd-tbl {
  width: 100%; border-collapse: collapse; font-size: .8rem;
  border: 1px solid rgba(255,255,255,.06); border-radius: 10px;
  overflow: hidden; margin-bottom: 10px;
}
.sd-tbl th {
  padding: 7px 14px; text-align: left; font-size: .66rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em; color: var(--text-muted);
  background: rgba(0,0,0,.08); border-bottom: 1px solid rgba(255,255,255,.03);
}
.sd-tbl td { padding: 9px 14px; color: var(--text-secondary); }
.sd-tbl code {
  font-family: 'JetBrains Mono', monospace; font-size: .84em;
  background: rgba(255,255,255,.04); padding: 1px 5px; border-radius: 4px;
}
.sd-tbl-a {
  display: inline-block; padding: 1px 8px; border-radius: 4px;
  font-size: .68rem; color: var(--accent); background: rgba(99,102,241,.1);
}
.sd-tbl-note {
  font-size: .74rem; color: var(--text-muted); margin: 0 0 12px;
}

/* Provider guides */
.sd-guides {
  border: 1px solid rgba(255,255,255,.06); border-radius: 10px;
  overflow: hidden; margin-bottom: 10px;
}
.sd-guides-sum {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 16px; font-size: .78rem; font-weight: 600;
  color: var(--text-muted); cursor: pointer; list-style: none;
}
.sd-guides-sum::-webkit-details-marker { display: none; }
.sd-guides-sum::marker { display: none; content: ''; }
.sd-guides[open] > .sd-guides-sum {
  background: rgba(255,255,255,.02); border-bottom: 1px solid rgba(255,255,255,.04);
}
.sd-guides-body { padding: 4px; }
.sd-prov {
  border: 1px solid rgba(255,255,255,.04); border-radius: 8px;
  overflow: hidden; margin-bottom: 3px;
}
.sd-prov > summary {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 12px; font-size: .8rem; font-weight: 500;
  color: var(--text-primary); cursor: pointer; list-style: none;
}
.sd-prov > summary::-webkit-details-marker { display: none; }
.sd-prov > summary::marker { display: none; content: ''; }
.sd-prov-ol {
  padding: 2px 12px 12px 28px; margin: 0; font-size: .78rem;
  color: var(--text-secondary); line-height: 1.9;
}
.sd-prov-ol code { background: rgba(255,255,255,.06); padding: 1px 6px; border-radius: 4px; font-size: .88em; }
.sd-prov-ol a { color: var(--accent); text-decoration: none; }
.sd-prov-ol a:hover { text-decoration: underline; }

/* DNS actions row */
.sd-dns-acts { display: flex; align-items: center; gap: 8px; margin: 12px 0; }
.sd-poll-lbl { font-size: .72rem; color: var(--success); font-weight: 600; }

/* DNS hint */
.sd-hint {
  font-size: .76rem; color: var(--text-muted); line-height: 1.5;
  padding: 10px 14px; border-radius: 8px;
  background: rgba(255,255,255,.015); border: 1px solid rgba(255,255,255,.04);
  margin: 0;
}

/* Domain pill (step 1) */
.sd-domain-pill {
  display: inline-flex; align-items: center; gap: 8px;
  margin-bottom: 16px;
}
.sd-domain-pill-d {
  font-family: 'JetBrains Mono', monospace; font-size: .84rem;
  font-weight: 600; color: var(--text-primary);
}
.sd-pill {
  font-size: .62rem; font-weight: 700; padding: 2px 9px; border-radius: 16px;
}
.sd-pill--ok { background: rgba(16,185,129,.1); color: var(--success); }
.sd-pill--warn { background: rgba(251,191,36,.1); color: var(--warning); }

/* App type grid */
.sd-apps {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 7px; margin-bottom: 14px;
}
.sd-app-card {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: 10px;
  border: 2px solid rgba(255,255,255,.06);
  background: rgba(255,255,255,.01);
  cursor: pointer; transition: all .15s; text-align: left;
}
.sd-app-card:hover { border-color: rgba(99,102,241,.2); background: rgba(99,102,241,.03); }
.sd-app-card--on {
  border-color: var(--accent); background: rgba(99,102,241,.06);
  box-shadow: 0 0 0 2px rgba(99,102,241,.06);
}
.sd-app-ico {
  font-size: 1.2rem; width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 8px; background: rgba(255,255,255,.03); flex-shrink: 0;
}
.sd-app-card--on .sd-app-ico { background: rgba(99,102,241,.1); }
.sd-app-info { flex: 1; min-width: 0; }
.sd-app-name { display: block; font-size: .8rem; font-weight: 700; color: var(--text-primary); }
.sd-app-desc { display: block; font-size: .68rem; color: var(--text-muted); margin-top: 1px; }
.sd-app-tag {
  font-size: .56rem; font-weight: 700; padding: 2px 7px;
  border-radius: 5px; text-transform: uppercase; letter-spacing: .03em;
  background: rgba(99,102,241,.08); color: var(--accent); flex-shrink: 0;
}

/* Config section */
.sd-cfg {
  margin-top: 12px; padding: 14px 16px; border-radius: 10px;
  background: rgba(255,255,255,.02); border: 1px solid rgba(255,255,255,.06);
}
.sd-cfg-title {
  font-size: .82rem; font-weight: 600; color: var(--text-primary);
  margin: 0 0 10px;
}
.sd-cfg-row { display: flex; gap: 12px; }
.sd-cfg-col { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.sd-cfg-in {
  width: 100%; padding: 9px 12px; border-radius: 8px; font-size: .84rem;
  border: 1.5px solid rgba(255,255,255,.08); background: rgba(0,0,0,.18);
  color: var(--text-primary); outline: none;
  font-family: 'JetBrains Mono', monospace;
  transition: border-color .2s; box-sizing: border-box;
}
.sd-cfg-in:focus { border-color: var(--accent); }
.sd-cfg-in::placeholder { color: var(--text-muted); opacity: .3; }
.sd-cfg-sel {
  width: 100%; padding: 9px 12px; border-radius: 8px;
  border: 1.5px solid rgba(255,255,255,.08); background: rgba(0,0,0,.22);
  color: var(--text-primary); font-size: .84rem; outline: none;
  cursor: pointer; transition: border-color .2s;
}
.sd-cfg-sel:focus { border-color: var(--accent); }

/* DB toggle */
.sd-db-row {
  display: flex; align-items: center; gap: 12px;
  margin-top: 14px; cursor: pointer; padding: 12px 14px;
  border-radius: 10px; border: 1px solid rgba(255,255,255,.04);
  background: rgba(255,255,255,.01); transition: background .15s;
}
.sd-db-row:hover { background: rgba(255,255,255,.03); }
.sd-db-row input[type="checkbox"] { display: none; }
.sd-db-sw {
  width: 40px; height: 22px; border-radius: 22px; flex-shrink: 0;
  background: rgba(255,255,255,.1); position: relative;
  transition: background .25s;
}
.sd-db-knob {
  position: absolute; top: 2px; left: 2px;
  width: 18px; height: 18px; border-radius: 50%;
  background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.3);
  transition: transform .25s cubic-bezier(.16,1,.3,1);
}
.sd-db-row input:checked ~ .sd-db-sw { background: var(--accent); }
.sd-db-row input:checked ~ .sd-db-sw .sd-db-knob { transform: translateX(18px); }
.sd-db-txt b { display: block; font-size: .82rem; color: var(--text-primary); font-weight: 600; }
.sd-db-txt small { display: block; font-size: .72rem; color: var(--text-muted); margin-top: 1px; }

/* Responsive */
@media (max-width: 560px) {
  .sd-apps { grid-template-columns: 1fr; }
  .sd-cfg-row { flex-direction: column; }
  .sd-modal { border-radius: 12px; }
}

/* Badge info variant */
.ws-badge-info {
  background: rgba(56,189,248,0.12); color: #38bdf8;
  border: 1px solid rgba(56,189,248,0.2);
}

@media (max-width: 768px) {
  .nxs-header { flex-direction: column; gap: 12px; }
  .nxs-header-actions { width: 100%; flex-wrap: wrap; }
  .nxs-grid { grid-template-columns: 1fr; }
  .nxw-app-grid { grid-template-columns: repeat(3, 1fr); }
  .nxw-glow { max-width: 96vw; }
  .nxw-config-row { flex-direction: column; gap: 8px; }
  .sp-box { max-width: 96vw; }
}

/* â”€â”€ Copy Domain â”€â”€ */
.ws-copy-domain { cursor: pointer; transition: color 0.2s; }
.ws-copy-domain:hover { color: var(--accent); }
.ws-copy-domain-detail:hover { color: var(--accent); }

/* â”€â”€ Card Stagger Fade-in â”€â”€ */
@keyframes wsCardFadeIn {
  from { opacity: 0; transform: translateY(16px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.ws-card { animation: wsCardFadeIn 0.4s cubic-bezier(0.22, 1, 0.36, 1) backwards; }
.ws-card:nth-child(1) { animation-delay: 0s; }
.ws-card:nth-child(2) { animation-delay: 0.05s; }
.ws-card:nth-child(3) { animation-delay: 0.1s; }
.ws-card:nth-child(4) { animation-delay: 0.15s; }
.ws-card:nth-child(5) { animation-delay: 0.2s; }
.ws-card:nth-child(6) { animation-delay: 0.25s; }
.ws-card:nth-child(7) { animation-delay: 0.3s; }
.ws-card:nth-child(8) { animation-delay: 0.35s; }
.ws-card:nth-child(9) { animation-delay: 0.4s; }
.ws-card:nth-child(n+10) { animation-delay: 0.45s; }

/* â”€â”€ WP Quick Actions â”€â”€ */
.wp-quick-actions {
  display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 1.2rem;
  padding: 14px 18px; border-radius: 14px;
  background: rgba(0,0,0,0.1); border: 1px solid rgba(255,255,255,0.04);
}
.wp-qa-group {
  display: flex; align-items: center; gap: 5px;
  padding: 4px 10px 4px 0; border-right: 1px solid rgba(255,255,255,0.06);
}
.wp-qa-group:last-child { border-right: none; padding-right: 0; }
.wp-qa-label {
  font-size: .65rem; text-transform: uppercase; letter-spacing: .06em;
  color: var(--text-muted); font-weight: 600; margin-right: 2px;
}

/* â”€â”€ WP Info Grid (WordPress Tab) â”€â”€ */
.wp-info-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 8px; margin-bottom: 1.2rem;
}
.wp-info-item {
  background: rgba(255,255,255,0.025); border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px; padding: 12px 14px; transition: all 0.25s var(--ease);
}
.wp-info-item:hover { border-color: rgba(255,255,255,0.1); background: rgba(255,255,255,0.04); }
.wp-info-item .ws-info-label { margin-bottom: 4px; font-size: .68rem; }
.wp-info-item .ws-info-value { font-size: 0.82rem; font-weight: 600; }

/* â”€â”€ WP Suggestions Bar â”€â”€ */
.wp-suggestions {
  display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: .75rem;
}
.wp-suggestion {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 10px; border-radius: 8px;
  background: rgba(245,158,11,.06); border: 1px solid rgba(245,158,11,.12);
  font-size: .75rem; color: var(--warning); transition: all .2s var(--ease);
}
.wp-suggestion:hover { background: rgba(245,158,11,.1); }
.wp-suggestion-icon { font-size: .85rem; }

/* â”€â”€ Table Enhancements â”€â”€ */
.ws-dns-table.wp-table { border: 1px solid rgba(255,255,255,0.05); border-radius: 12px; overflow: hidden; }
.ws-dns-table.wp-table th { background: rgba(0,0,0,0.15); }
.ws-dns-table.wp-table td { font-size: 0.8rem; }
.ws-dns-table.wp-table tr:hover td { background: rgba(255,255,255,0.02); }

/* â”€â”€ WP Section Spacing â”€â”€ */
.wp-manager .ws-dns-section + .ws-dns-section { margin-top: 14px; }

/* â”€â”€ Smooth content transitions â”€â”€ */
.ws-tab-content { animation: wsTabFadeIn 0.25s ease-out; }
@keyframes wsTabFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}

/* â”€â”€ Scrollbar for modal content â”€â”€ */
.ws-detail .ws-tab-content { max-height: 65vh; overflow-y: auto; }
.ws-detail .ws-tab-content::-webkit-scrollbar { width: 4px; }
.ws-detail .ws-tab-content::-webkit-scrollbar-track { background: transparent; }
.ws-detail .ws-tab-content::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.2); border-radius: 4px; }

/* â”€â”€ Form controls inside WP manager â”€â”€ */
.wp-manager .form-input {
  background: rgba(0,0,0,0.25); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 8px; color: var(--text-primary); transition: all 0.2s var(--ease);
}
.wp-manager .form-input:focus { border-color: var(--accent); box-shadow: 0 0 12px rgba(99,102,241,0.1); outline: none; }

/* â”€â”€ WP Backup List â”€â”€ */
.wp-backup-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px; border-radius: 8px;
  background: rgba(255,255,255,0.015); border: 1px solid rgba(255,255,255,0.04);
  transition: border-color 0.2s;
}
.wp-backup-item:hover { border-color: rgba(255,255,255,0.08); }
.wp-backup-item + .wp-backup-item { margin-top: 6px; }

/* â”€â”€ WP Collapsible Sections â”€â”€ */
.wp-collapsible .wp-section-toggle { cursor: pointer; user-select: none; }
.wp-collapsible .wp-section-toggle:hover { background: rgba(255,255,255,0.02); }
.wp-toggle-icon {
  display: inline-block; width: 14px; font-size: .7rem; color: var(--text-muted);
  transition: transform 0.2s var(--ease);
}
.wp-section-body {
  animation: wpSectionExpand 0.2s ease-out;
  overflow: hidden;
}
@keyframes wpSectionExpand {
  from { opacity: 0; max-height: 0; }
  to { opacity: 1; max-height: 2000px; }
}

/* â”€â”€ WP Table Search Filter â”€â”€ */
.wp-table-filter {
  background: rgba(0,0,0,0.2) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: 6px !important;
  transition: all .2s var(--ease) !important;
}
.wp-table-filter:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 8px rgba(99,102,241,.1) !important;
  width: 180px !important;
}

/* â”€â”€ WP Bulk Actions Bar â”€â”€ */
.wp-bulk-actions {
  background: rgba(99,102,241,.04);
  border-top: 1px solid rgba(99,102,241,.1);
  border-radius: 0 0 12px 12px;
}

/* â”€â”€ WP Cleanup Cards â”€â”€ */
.wp-cleanup-card {
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px; padding: .75rem 1rem;
  transition: all .2s var(--ease);
}
.wp-cleanup-card:hover {
  border-color: rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
}

/* â”€â”€ WP Suggestion Fix Buttons â”€â”€ */
.wp-suggestion .btn { opacity: 0; transition: opacity .2s; }
.wp-suggestion:hover .btn { opacity: 1; }

/* â”€â”€ WP Health Score Badge â”€â”€ */
.wp-health-badge {
  display: flex; align-items: center; gap: 4px;
  padding: 3px 10px 3px 3px; border-radius: 20px;
  background: rgba(255,255,255,0.03); border: 1px solid rgba(255,255,255,0.06);
  font-size: .72rem; font-weight: 600;
}
.wp-health-ring { width: 28px; height: 28px; transform: rotate(-90deg); }
.wp-health-ring-bg { fill: none; stroke: rgba(255,255,255,0.06); stroke-width: 3; }
.wp-health-ring-fg { fill: none; stroke-width: 3; stroke-linecap: round; transition: stroke-dasharray .5s ease; }
.wp-health-good .wp-health-ring-fg { stroke: var(--success); }
.wp-health-fair .wp-health-ring-fg { stroke: var(--warning); }
.wp-health-poor .wp-health-ring-fg { stroke: var(--danger); }
.wp-health-val { font-size: .8rem; font-weight: 700; }
.wp-health-good .wp-health-val { color: var(--success); }
.wp-health-fair .wp-health-val { color: var(--warning); }
.wp-health-poor .wp-health-val { color: var(--danger); }
.wp-health-grade {
  font-size: .6rem; padding: 1px 5px; border-radius: 4px;
  text-transform: uppercase; letter-spacing: .04em;
}
.wp-health-good .wp-health-grade { background: rgba(34,197,94,.12); color: var(--success); }
.wp-health-fair .wp-health-grade { background: rgba(245,158,11,.12); color: var(--warning); }
.wp-health-poor .wp-health-grade { background: rgba(239,68,68,.12); color: var(--danger); }

/* â”€â”€ WP Search Modal â”€â”€ */
.wp-search-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  animation: wpModalFadeIn .2s ease;
}
@keyframes wpModalFadeIn { from { opacity: 0; } to { opacity: 1; } }
.wp-search-dialog {
  width: 90%; max-width: 600px; max-height: 80vh;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 16px; overflow: hidden; display: flex; flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
}
.wp-search-dialog-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--border);
}
.wp-search-dialog-header h3 { margin: 0; font-size: .95rem; }
.wp-search-results-area {
  flex: 1; overflow-y: auto; max-height: 50vh;
}
.wp-search-item {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 18px; border-bottom: 1px solid rgba(255,255,255,0.03);
  transition: background .15s;
}
.wp-search-item:hover { background: rgba(255,255,255,0.02); }
.wp-search-item-info { flex: 1; min-width: 0; }
.wp-search-item-name { font-size: .85rem; font-weight: 600; color: var(--text-primary); }
.wp-search-item-meta { font-size: .7rem; color: var(--text-muted); margin-top: 2px; }
.wp-search-item-meta { color: #f59e0b; }
.wp-search-item-desc {
  font-size: .75rem; color: var(--text-secondary); margin-top: 3px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.wp-search-dialog-footer {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 18px; border-top: 1px solid var(--border);
  background: rgba(0,0,0,0.1);
}

/* â”€â”€ WP Debug Log Syntax Highlighting â”€â”€ */
.wp-log-error { color: var(--danger); font-weight: 600; }
.wp-log-warning { color: var(--warning); font-weight: 600; }
.wp-log-notice { color: #60a5fa; }
.wp-log-deprecated { color: #a78bfa; font-style: italic; }
.wp-log-timestamp { color: var(--text-muted); font-size: .9em; }

/* â”€â”€ Enhanced WP Info Grid responsiveness â”€â”€ */
@media (max-width: 600px) {
  .wp-info-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .wp-quick-actions { flex-direction: column; }
  .wp-qa-group { border-right: none !important; border-bottom: 1px solid rgba(255,255,255,0.06); padding-bottom: 8px; }
  .wp-qa-group:last-child { border-bottom: none; }
  .wp-table-filter:focus { width: 140px !important; }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   SMART SETUP WIZARD
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.wz-wizard { display: flex; flex-direction: column; min-height: 480px; }

/* Progress Bar */
.wz-progress { display: flex; align-items: center; justify-content: center; gap: 0; padding: 20px 24px 16px; border-bottom: 1px solid var(--border); background: rgba(0,0,0,0.2); }
.wz-step { display: flex; flex-direction: column; align-items: center; gap: 6px; position: relative; z-index: 1; }
.wz-step-circle { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; border: 2px solid var(--border); background: var(--bg-card); color: var(--text-muted); transition: all 0.3s ease; font-size: 0.8rem; }
.wz-step-active .wz-step-circle { border-color: var(--accent); background: var(--accent); color: #fff; box-shadow: 0 0 16px rgba(99,102,241,0.4); transform: scale(1.08); }
.wz-step-done .wz-step-circle { border-color: var(--success); background: rgba(16,185,129,0.15); color: var(--success); }
.wz-step-label { font-size: 0.65rem; color: var(--text-muted); font-weight: 500; text-transform: uppercase; letter-spacing: 0.06em; transition: color 0.3s; white-space: nowrap; }
.wz-step-active .wz-step-label { color: var(--accent); font-weight: 700; }
.wz-step-done .wz-step-label { color: var(--success); }
.wz-step-line { width: 40px; height: 2px; background: var(--border); margin: 0 4px; margin-bottom: 22px; transition: background 0.3s; }
.wz-line-done { background: var(--success); }

/* Body */
.wz-body { flex: 1; overflow-y: auto; padding: 0; }
.wz-step-content { padding: 24px 28px; animation: wzFadeIn 0.3s ease; }
@keyframes wzFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.wz-step-header { margin-bottom: 20px; }
.wz-step-title { margin: 0 0 6px; font-size: 1.15rem; font-weight: 700; color: var(--text-primary); }
.wz-step-desc { margin: 0; font-size: 0.82rem; color: var(--text-secondary); line-height: 1.5; }

/* Footer */
.wz-footer { display: flex; justify-content: space-between; align-items: center; padding: 14px 24px; border-top: 1px solid var(--border); background: rgba(0,0,0,0.15); }
.wz-footer-right { display: flex; gap: 8px; }
.btn-success { background: var(--success); color: #fff; border: none; }
.btn-success:hover { background: #059669; }
.btn-ghost { background: transparent; border: 1px solid var(--border); color: var(--text-secondary); }
.btn-ghost:hover { border-color: var(--text-muted); color: var(--text-primary); }

/* â”€â”€ Domain Step â”€â”€ */
.wz-domain-input-wrap { display: flex; align-items: center; gap: 0; border: 2px solid var(--border); border-radius: 10px; padding: 0; background: rgba(0,0,0,0.2); transition: border-color 0.2s; overflow: hidden; }
.wz-domain-input-wrap:focus-within { border-color: var(--accent); box-shadow: 0 0 12px rgba(99,102,241,0.15); }
.wz-domain-prefix { padding: 10px 12px; background: rgba(255,255,255,0.03); color: var(--text-muted); font-size: 0.82rem; font-family: 'JetBrains Mono', monospace; border-right: 1px solid var(--border); white-space: nowrap; }
.wz-domain-input { flex: 1; background: transparent; border: none; color: var(--text-primary); font-size: 1rem; padding: 10px 14px; outline: none; font-family: 'JetBrains Mono', monospace; }
.wz-domain-input::placeholder { color: var(--text-muted); opacity: 0.5; }
.wz-domain-result { margin-top: 14px; }

/* Result Cards */
.wz-result-card { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; border-radius: 10px; border: 1px solid; font-size: 0.85rem; line-height: 1.5; }
.wz-result-card p { margin: 4px 0 0; font-size: 0.78rem; color: var(--text-secondary); }
.wz-result-success { background: rgba(16,185,129,0.06); border-color: rgba(16,185,129,0.2); color: var(--text-primary); }
.wz-result-error { background: rgba(239,68,68,0.06); border-color: rgba(239,68,68,0.2); color: var(--text-primary); }
.wz-result-warn { background: rgba(251,191,36,0.06); border-color: rgba(251,191,36,0.2); color: var(--text-primary); }
.wz-result-icon { font-size: 1.2rem; flex-shrink: 0; margin-top: 2px; }

/* DNS Preview */
.wz-dns-preview { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; padding: 12px 16px; border-radius: 10px; background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.05); }
.wz-dns-preview-item { display: flex; justify-content: space-between; align-items: center; font-size: 0.8rem; }
.wz-dns-preview-label { color: var(--text-muted); font-weight: 500; }
.wz-dns-preview code { font-size: 0.78rem; background: rgba(99,102,241,0.1); padding: 2px 8px; border-radius: 4px; }

/* Badges */
.wz-badge-ok { font-size: 0.75rem; padding: 3px 10px; border-radius: 20px; background: rgba(16,185,129,0.12); color: var(--success); font-weight: 600; }
.wz-badge-warn { font-size: 0.75rem; padding: 3px 10px; border-radius: 20px; background: rgba(251,191,36,0.12); color: var(--warning); font-weight: 600; }
.wz-badge-info { font-size: 0.75rem; padding: 3px 10px; border-radius: 20px; background: rgba(99,102,241,0.12); color: var(--accent); font-weight: 600; }

/* Smart Tips */
.wz-smart-tips { margin-top: 18px; display: flex; flex-direction: column; gap: 6px; }
.wz-tip { font-size: 0.75rem; color: var(--text-muted); padding: 6px 10px; background: rgba(255,255,255,0.015); border-radius: 6px; }
.wz-hint { font-size: 0.78rem; color: var(--text-muted); margin: 0; }

/* Checking Spinner */
.wz-checking { display: flex; align-items: center; gap: 10px; font-size: 0.85rem; color: var(--accent); padding: 12px 0; }
.spinner-sm { width: 16px; height: 16px; border: 2px solid rgba(99,102,241,0.2); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.6s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* â”€â”€ App Type Step â”€â”€ */
.wz-type-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; }
.wz-type-card { display: flex; flex-direction: column; align-items: center; gap: 6px; padding: 16px 10px 12px; border-radius: 12px; border: 2px solid var(--border); cursor: pointer; transition: all 0.2s ease; background: rgba(255,255,255,0.01); position: relative; }
.wz-type-card:hover { border-color: var(--accent); background: rgba(99,102,241,0.04); transform: translateY(-2px); }
.wz-type-selected { border-color: var(--accent); background: rgba(99,102,241,0.08); box-shadow: 0 0 20px rgba(99,102,241,0.15); }
.wz-type-card-icon { font-size: 1.6rem; margin-bottom: 2px; }
.wz-type-card-name { font-size: 0.82rem; font-weight: 700; color: var(--text-primary); }
.wz-type-card-desc { font-size: 0.65rem; color: var(--text-muted); text-align: center; line-height: 1.4; }
.wz-type-badge { position: absolute; top: 6px; right: 6px; font-size: 0.55rem; padding: 1px 6px; border-radius: 8px; background: rgba(99,102,241,0.15); color: var(--accent); font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; }
.wz-type-badge-php { background: rgba(136,146,191,0.15); color: #8892BF; }
.wz-type-badge-static { background: rgba(16,185,129,0.12); color: var(--success); }
.wz-type-detail { display: flex; align-items: flex-start; gap: 14px; margin-top: 16px; padding: 14px 16px; border-radius: 10px; background: rgba(99,102,241,0.04); border: 1px solid rgba(99,102,241,0.12); }
.wz-type-detail-icon { font-size: 1.4rem; flex-shrink: 0; }
.wz-type-detail-text { font-size: 0.82rem; line-height: 1.6; color: var(--text-secondary); }
.wz-type-detail-text strong { display: block; color: var(--text-primary); margin-bottom: 4px; }
.wz-smart-tag { display: inline-block; margin-top: 6px; font-size: 0.72rem; padding: 3px 10px; border-radius: 20px; background: rgba(99,102,241,0.1); color: var(--accent); font-weight: 600; margin-right: 6px; }
.wz-smart-tag-sm { font-size: 0.65rem; padding: 2px 8px; margin-top: 0; }

/* â”€â”€ Config Step â”€â”€ */
.wz-config-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.wz-config-wide { grid-column: 1 / -1; }
.wz-config-card { background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06); border-radius: 12px; padding: 16px; }
.wz-config-card-header { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; font-size: 0.85rem; font-weight: 600; color: var(--text-primary); flex-wrap: wrap; }
.wz-config-input { width: 100%; padding: 8px 12px; background: rgba(0,0,0,0.3); border: 1px solid var(--border); border-radius: 8px; color: var(--text-primary); font-size: 0.85rem; outline: none; transition: border-color 0.2s; box-sizing: border-box; }
.wz-config-input:focus { border-color: var(--accent); box-shadow: 0 0 8px rgba(99,102,241,0.15); }
select.wz-config-input { appearance: auto; cursor: pointer; }
.wz-form-hint { font-size: 0.7rem; color: var(--text-muted); margin-top: 6px; display: block; }
.wz-optional-badge { font-size: 0.6rem; padding: 1px 8px; border-radius: 10px; background: rgba(255,255,255,0.05); color: var(--text-muted); font-weight: 500; }
.wz-config-ready { display: flex; align-items: center; gap: 14px; padding: 20px; margin-top: 4px; border-radius: 12px; background: rgba(16,185,129,0.04); border: 1px solid rgba(16,185,129,0.15); }
.wz-config-ready p { margin: 4px 0 0; font-size: 0.78rem; color: var(--text-muted); }
.wz-config-preview { margin-top: 18px; padding: 14px 16px; border-radius: 10px; background: rgba(0,0,0,0.15); border: 1px solid rgba(255,255,255,0.04); }
.wz-config-preview-heading { font-size: 0.75rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 10px; }
.wz-config-preview-list { display: flex; flex-direction: column; gap: 6px; }
.wz-preview-item { font-size: 0.78rem; color: var(--text-secondary); }
.wz-preview-item code { font-size: 0.74rem; background: rgba(99,102,241,0.08); padding: 1px 6px; border-radius: 4px; }

/* â”€â”€ DNS Step â”€â”€ */
.wz-dns-connected-banner { display: flex; align-items: center; gap: 14px; padding: 20px; border-radius: 12px; background: rgba(16,185,129,0.06); border: 1px solid rgba(16,185,129,0.2); }
.wz-dns-connected-banner p { margin: 4px 0 0; font-size: 0.78rem; color: var(--text-muted); }
.wz-dns-setup-box { padding: 18px; border-radius: 12px; background: rgba(99,102,241,0.03); border: 1px solid rgba(99,102,241,0.1); }
.wz-dns-setup-heading { font-size: 0.88rem; font-weight: 600; color: var(--text-primary); margin-bottom: 6px; }
.wz-dns-records-table { display: grid; grid-template-columns: 55px 110px 1fr 55px 40px; gap: 0; font-size: 0.8rem; border-radius: 8px; overflow: hidden; border: 1px solid rgba(255,255,255,0.06); }
.wz-dns-rec-header { font-weight: 700; text-transform: uppercase; font-size: 0.68rem; color: var(--text-muted); letter-spacing: 0.04em; background: rgba(0,0,0,0.3); }
.wz-dns-rec-row { display: contents; }
.wz-dns-rec-row > * { padding: 10px 12px; border-bottom: 1px solid rgba(255,255,255,0.03); display: flex; align-items: center; }
.wz-dns-rec-row:last-child > * { border-bottom: none; }
.wz-dns-rec-type { font-weight: 700; font-size: 0.75rem; color: var(--accent); }
.wz-dns-skip { margin-top: 20px; padding: 14px 16px; border-radius: 10px; background: rgba(255,255,255,0.015); border: 1px solid rgba(255,255,255,0.04); }
.wz-dns-skip-label { display: flex; align-items: center; gap: 8px; font-size: 0.82rem; color: var(--text-secondary); cursor: pointer; }
.wz-dns-skip-label input { accent-color: var(--accent); width: 16px; height: 16px; }

/* â”€â”€ Wizard Provider Guides â”€â”€ */
.wz-provider-guides { display: flex; flex-direction: column; gap: 6px; }
.wz-provider-guide { border: 1px solid rgba(255,255,255,0.06); border-radius: 10px; overflow: hidden; transition: border-color 0.15s; }
.wz-provider-guide:hover { border-color: rgba(255,255,255,0.1); }
.wz-provider-toggle { display: flex; align-items: center; justify-content: space-between; width: 100%; padding: 12px 16px; background: rgba(255,255,255,0.02); border: none; cursor: pointer; color: var(--text-primary); font-size: 0.85rem; transition: background 0.15s; }
.wz-provider-toggle:hover { background: rgba(255,255,255,0.04); }
.wz-provider-toggle-left { display: flex; align-items: center; gap: 8px; }
.wz-provider-icon { font-size: 1.15rem; line-height: 1; }
.wz-provider-name { font-weight: 500; font-size: 0.85rem; }
.wz-provider-chevron { transition: transform 0.2s; color: var(--text-muted); flex-shrink: 0; }
.wz-provider-expanded .wz-provider-chevron { transform: rotate(180deg); }
.wz-provider-steps { max-height: 0; overflow: hidden; transition: max-height 0.25s ease, padding 0.25s; padding: 0 16px; }
.wz-provider-expanded .wz-provider-steps { max-height: 500px; padding: 4px 16px 16px; }
.wz-provider-steps-list { margin: 0; padding-left: 20px; font-size: 0.82rem; color: var(--text-secondary); line-height: 1.8; }
.wz-provider-steps-list li { padding: 2px 0; }
.wz-provider-steps-list a { color: var(--accent); text-decoration: none; }
.wz-provider-steps-list a:hover { text-decoration: underline; }
.wz-provider-steps-list code { background: var(--glass-bg); padding: 1px 6px; border-radius: 4px; font-size: 0.9em; }

/* â”€â”€ Review Step â”€â”€ */
.wz-review-card { border-radius: 12px; border: 1px solid rgba(99,102,241,0.15); overflow: hidden; background: rgba(99,102,241,0.02); }
.wz-review-row { display: flex; justify-content: space-between; align-items: center; padding: 12px 18px; border-bottom: 1px solid rgba(255,255,255,0.03); font-size: 0.85rem; }
.wz-review-row:last-child { border-bottom: none; }
.wz-review-highlight { background: rgba(99,102,241,0.04); }
.wz-review-label { color: var(--text-muted); display: flex; align-items: center; gap: 6px; font-size: 0.78rem; }
.wz-launch-checklist { margin-top: 18px; padding: 14px 16px; border-radius: 10px; background: rgba(16,185,129,0.03); border: 1px solid rgba(16,185,129,0.1); }
.wz-checklist-title { font-size: 0.78rem; font-weight: 700; color: var(--text-primary); margin-bottom: 10px; }
.wz-checklist-item { font-size: 0.78rem; color: var(--text-secondary); padding: 3px 0; }

/* Launch Progress */
.wz-launch-progress { margin-top: 16px; padding: 14px 16px; border-radius: 10px; background: rgba(0,0,0,0.15); border: 1px solid rgba(255,255,255,0.04); display: flex; flex-direction: column; gap: 8px; }
.wz-launch-step { font-size: 0.82rem; color: var(--text-secondary); padding: 4px 0; }
.wz-launch-done { color: var(--success); }
.wz-launch-active { color: var(--accent); animation: wzPulse 1.2s ease-in-out infinite; }
@keyframes wzPulse { 0%,100% { opacity: 1; } 50% { opacity: 0.5; } }
.wz-launch-success { text-align: center; padding: 24px 16px; margin-top: 16px; border-radius: 12px; background: linear-gradient(135deg, rgba(99,102,241,0.06), rgba(16,185,129,0.06)); border: 1px solid rgba(99,102,241,0.15); }
.wz-launch-success-icon { font-size: 2.5rem; margin-bottom: 8px; }
.wz-launch-success h3 { margin: 0 0 6px; color: var(--text-primary); font-size: 1.1rem; }
.wz-launch-success p { margin: 0; font-size: 0.85rem; color: var(--text-secondary); }
.wz-launch-success a { color: var(--accent); text-decoration: none; }
.wz-launch-success a:hover { text-decoration: underline; }

/* â”€â”€ Install Step â”€â”€ */
.wz-install-step { display: flex; flex-direction: column; gap: 20px; }
.wz-install-config { border-radius: 12px; border: 1px solid rgba(99,102,241,0.15); padding: 16px; background: rgba(99,102,241,0.02); }
.wz-install-config-header { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid rgba(255,255,255,0.04); }
.wz-install-config-icon { font-size: 1.6rem; line-height: 1; }
.wz-install-config-header strong { font-size: 0.92rem; color: var(--text-primary); }

.wz-install-preview { border-radius: 12px; border: 1px solid rgba(16,185,129,0.15); padding: 16px; background: rgba(16,185,129,0.02); }
.wz-install-preview-header { display: flex; align-items: center; gap: 8px; font-size: 0.85rem; color: var(--text-primary); margin-bottom: 12px; }
.wz-install-preview-steps { display: flex; flex-direction: column; gap: 6px; }
.wz-preview-step { display: flex; align-items: center; gap: 10px; font-size: 0.82rem; color: var(--text-secondary); padding: 4px 0; }
.wz-preview-step-num { width: 22px; height: 22px; border-radius: 50%; background: rgba(99,102,241,0.15); color: var(--accent); font-size: 0.7rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

.wz-install-cta { margin-top: 16px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,0.04); text-align: center; }
.wz-install-btn { padding: 12px 32px !important; font-size: 0.95rem !important; display: inline-flex; align-items: center; gap: 8px; border-radius: 10px !important; }
.wz-install-note { font-size: 0.78rem; color: var(--text-muted); margin: 10px 0 0; }

/* â”€â”€ Installing Progress â”€â”€ */
.wz-installing-view { text-align: center; }
.wz-installing-spinner { width: 56px; height: 56px; border: 3px solid rgba(99,102,241,0.15); border-top-color: var(--accent); border-radius: 50%; animation: wzSpin 0.8s linear infinite; margin: 0 auto 16px; }
@keyframes wzSpin { to { transform: rotate(360deg); } }

.wz-install-progress { max-width: 420px; margin: 20px auto 0; text-align: left; display: flex; flex-direction: column; gap: 4px; }
.wz-install-progress-step { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border-radius: 8px; font-size: 0.84rem; color: var(--text-secondary); transition: all 0.3s ease; }
.wz-install-progress-step.active { background: rgba(99,102,241,0.06); color: var(--accent); font-weight: 600; }
.wz-install-progress-step.done { color: var(--success); }
.wz-install-progress-step.error { color: var(--danger); background: rgba(239,68,68,0.06); }
.wz-install-progress-step.pending { opacity: 0.4; }
.wz-install-progress-icon { width: 22px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.wz-install-pending-dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.15); }
.wz-install-status { margin-top: 16px; font-size: 0.82rem; color: var(--text-muted); text-align: center; }

/* â”€â”€ Installed Success â”€â”€ */
.wz-install-success-hero { text-align: center; padding: 24px 16px 8px; }
.wz-install-success-icon { font-size: 3rem; margin-bottom: 8px; }
.wz-install-success-hero h3 { font-size: 1.15rem; color: var(--text-primary); margin: 0 0 4px; }
.wz-install-success-hero p { font-size: 0.88rem; color: var(--text-secondary); margin: 0; }
.wz-install-next-hint { display: flex; align-items: center; gap: 8px; justify-content: center; padding: 14px; margin-top: 16px; border-radius: 10px; background: rgba(16,185,129,0.04); border: 1px solid rgba(16,185,129,0.12); font-size: 0.84rem; color: var(--text-secondary); }
.wz-install-setup-url { display: flex; flex-direction: column; gap: 6px; padding: 14px 16px; margin-top: 16px; border-radius: 10px; background: rgba(99,102,241,0.04); border: 1px solid rgba(99,102,241,0.12); font-size: 0.84rem; }
.wz-install-setup-url a { color: var(--accent); text-decoration: none; }
.wz-install-setup-url a:hover { text-decoration: underline; }
.wz-wp-credentials-box { margin-top: 10px; padding: 12px 14px; border-radius: 8px; background: rgba(0,0,0,0.2); border: 1px solid rgba(255,255,255,0.06); }
.wz-wp-cred-row { display: flex; align-items: center; gap: 8px; padding: 4px 0; font-size: 0.82rem; color: var(--text-secondary); }
.wz-wp-cred-label { font-weight: 600; color: var(--text-muted); min-width: 70px; }
.wz-wp-cred-row code { font-family: var(--font-mono, 'JetBrains Mono', monospace); font-size: 0.82rem; padding: 2px 8px; border-radius: 4px; background: rgba(99,102,241,0.08); color: var(--accent); user-select: all; }
.wz-wp-cred-copy { font-size: 0.68rem; padding: 2px 8px; border-radius: 4px; border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.04); color: var(--text-muted); cursor: pointer; transition: all 0.15s; }
.wz-wp-cred-copy:hover { border-color: var(--accent); color: var(--accent); }
.wz-wp-admin-config { border-color: rgba(99,102,241,0.2); background: linear-gradient(135deg, rgba(99,102,241,0.02), rgba(139,92,246,0.02)); }
.wz-node-config { border-color: rgba(104,160,99,0.25); background: linear-gradient(135deg, rgba(104,160,99,0.03), rgba(68,160,63,0.02)); }
.wz-node-dropzone { border: 2px dashed rgba(104,160,99,0.3); border-radius: 12px; padding: 24px 16px; text-align: center; cursor: pointer; transition: all 0.2s ease; background: rgba(104,160,99,0.02); user-select: none; }
.wz-node-dropzone:hover, .wz-node-dropzone-active { border-color: rgba(104,160,99,0.6); background: rgba(104,160,99,0.06); }
.wz-node-dropzone-content p { line-height: 1.4; }
.wz-install-error-msg { display: flex; align-items: flex-start; gap: 10px; padding: 16px; border-radius: 10px; background: rgba(239,68,68,0.06); border: 1px solid rgba(239,68,68,0.15); }
.wz-install-error-msg span { font-size: 1.3rem; line-height: 1; }
.wz-install-error-msg strong { color: var(--danger); font-size: 0.92rem; }
.wz-install-error-msg p { font-size: 0.82rem; color: var(--text-secondary); margin: 4px 0 12px; }

/* â”€â”€ Done Step â”€â”€ */
.wz-done-hero { text-align: center; padding: 28px 16px 16px; }
.wz-done-icon { font-size: 3rem; margin-bottom: 8px; }
.wz-done-hero h3 { font-size: 1.2rem; color: var(--text-primary); margin: 0 0 8px; }
.wz-done-link { color: var(--accent); text-decoration: none; font-size: 1rem; font-weight: 600; }
.wz-done-link:hover { text-decoration: underline; }
.wz-done-setup-url { display: flex; align-items: center; gap: 10px; padding: 14px 16px; margin-top: 16px; border-radius: 10px; background: rgba(99,102,241,0.04); border: 1px solid rgba(99,102,241,0.12); font-size: 0.84rem; }
.wz-done-setup-url a { color: var(--accent); text-decoration: none; }
.wz-done-setup-url a:hover { text-decoration: underline; }
.wz-done-actions { display: flex; justify-content: center; gap: 10px; margin-top: 20px; }

/* Responsive */

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   Security Dashboard â€” Unified Security Center
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Hero summary */
.sec-dash-hero {
  display:flex;align-items:center;gap:1.5rem;padding:1.5rem 1.8rem;margin-bottom:1.2rem;
  background:linear-gradient(135deg,rgba(99,102,241,0.08) 0%,rgba(139,92,246,0.06) 50%,rgba(168,85,247,0.04) 100%);
  border:1px solid rgba(99,102,241,0.15);border-radius:var(--radius);
  backdrop-filter:blur(12px);animation:slideUp .35s var(--ease) both;
}
.sec-dash-ring-wrap { position:relative;width:100px;height:100px;flex-shrink:0 }
.sec-dash-ring-svg { width:100px;height:100px;transform:rotate(-90deg) }
.sec-dash-ring-inner { position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center }
.sec-dash-grade { font-size:1.8rem;font-weight:800;line-height:1 }
.sec-dash-pct { font-size:.7rem;color:var(--text-secondary) }
.sec-dash-hero-stats { flex:1;min-width:0 }
.sec-dash-hero-title { font-size:1.2rem;font-weight:700;color:var(--text-heading);margin-bottom:.2rem }
.sec-dash-hero-sub { font-size:.82rem;color:var(--text-secondary);margin-bottom:.7rem }
.sec-dash-chips { display:flex;gap:.5rem;flex-wrap:wrap }
.sec-chip { display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .7rem;border-radius:20px;font-size:.72rem;font-weight:600 }
.sec-chip-success { background:rgba(34,197,94,.08);color:#22c55e;border:1px solid rgba(34,197,94,.18) }
.sec-chip-danger { background:rgba(239,68,68,.08);color:#ef4444;border:1px solid rgba(239,68,68,.18) }
.sec-chip-warning { background:rgba(245,158,11,.08);color:#f59e0b;border:1px solid rgba(245,158,11,.18) }
.sec-chip-info { background:rgba(59,130,246,.08);color:#3b82f6;border:1px solid rgba(59,130,246,.18) }

/* Domain grid */
.sec-domains-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1rem }
.sec-domain-card {
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.2rem;
  transition:all .25s var(--ease);animation:slideUp .35s var(--ease) both;position:relative;overflow:hidden;
}
.sec-domain-card:hover { border-color:var(--border-light);box-shadow:0 6px 24px rgba(0,0,0,.2);transform:translateY(-2px) }
.sec-domain-card::before {
  content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:3px 3px 0 0;
  background:linear-gradient(90deg,#6366f1,#a855f7);opacity:.6;
}
.sec-domain-header { display:flex;align-items:center;gap:.8rem;margin-bottom:.7rem }
.sec-domain-ring-wrap { position:relative;width:52px;height:52px;flex-shrink:0 }
.sec-domain-ring-svg { width:52px;height:52px;transform:rotate(-90deg) }
.sec-domain-ring-inner { position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center }
.sec-domain-info { flex:1;min-width:0 }
.sec-domain-name { font-size:.9rem;font-weight:700;color:var(--text-heading);white-space:nowrap;overflow:hidden;text-overflow:ellipsis }
.sec-domain-meta { display:flex;gap:.4rem;margin-top:.2rem;flex-wrap:wrap }
.sec-meta-badge { font-size:.62rem;font-weight:600;padding:.1rem .35rem;background:rgba(255,255,255,.04);border-radius:4px;letter-spacing:.3px;text-transform:uppercase }
.sec-domain-stats {
  display:grid;grid-template-columns:repeat(5,1fr);gap:.3rem;padding:.5rem 0;
  border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04);margin-bottom:.5rem;
}
.sec-mini-stat { display:flex;flex-direction:column;align-items:center;gap:.05rem }
.sec-mini-val { font-size:.9rem;font-weight:700;line-height:1.2 }
.sec-mini-lbl { font-size:.55rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px }
.sec-domain-hardening { display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:.6rem }
.sec-harden-badge { font-size:.62rem;font-weight:600;padding:.15rem .4rem;border-radius:4px;letter-spacing:.2px }
.sec-harden-badge.on { background:rgba(34,197,94,.1);color:#22c55e;border:1px solid rgba(34,197,94,.15) }
.sec-harden-badge.off { background:rgba(239,68,68,.06);color:#ef4444;border:1px solid rgba(239,68,68,.12) }
.sec-domain-actions { display:flex;gap:.4rem }
.sec-manage-btn { flex:1;text-align:center }

/* Ring animation */
.sec-ring-animate { animation:secRingDraw 1.2s var(--ease) both }
@keyframes secRingDraw { from { stroke-dasharray:0 252 } }

/* Loading spinner */
.sec-loading-spinner { width:28px;height:28px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 1rem }
.sec-loading-spinner-sm { width:18px;height:18px;border:2px solid rgba(255,255,255,.1);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;display:inline-block;vertical-align:middle;margin-right:.4rem }
@keyframes spin { to { transform:rotate(360deg) } }

/* Tab bar */
.sec-tabs-bar {
  display:flex;gap:0;margin-bottom:1.2rem;border-bottom:1px solid var(--border);overflow-x:auto;
  scrollbar-width:none;-ms-overflow-style:none;
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   DATABASE MANAGEMENT v3 â€” Complete redesign
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ Loading State â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-loading {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  padding: 4rem 2rem; color: var(--text-muted); font-size: 0.9rem;
}
.db-spinner {
  width: 24px; height: 24px; border: 3px solid rgba(99,102,241,0.15);
  border-top-color: var(--accent); border-radius: 50%;
  animation: dbSpin 0.7s linear infinite;
}
@keyframes dbSpin { to { transform: rotate(360deg); } }

/* â”€â”€ Error State â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-error {
  padding: 1.5rem; border-radius: var(--radius); color: var(--danger);
  background: var(--danger-bg); border: 1px solid var(--danger-border);
  display: flex; align-items: center; gap: 10px; font-size: 0.9rem;
}

/* â”€â”€ Server Status Bar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-server-bar {
  display: flex; align-items: center; gap: 1rem;
  padding: 0.85rem 1.2rem; margin-bottom: 1.25rem;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); flex-wrap: wrap;
  animation: slideUp 0.3s var(--ease) both;
}
.db-server-indicator {
  display: flex; align-items: center; gap: 8px;
  font-weight: 700; font-size: 0.88rem; white-space: nowrap;
}
.db-server-indicator.online { color: var(--success); }
.db-server-indicator.offline { color: var(--danger); }
.db-server-ver {
  font-size: 0.72rem; font-weight: 500; color: var(--text-muted);
  background: rgba(99,102,241,0.08); padding: 2px 8px; border-radius: 4px;
}
.db-server-metrics {
  display: flex; align-items: center; gap: 0.75rem; flex: 1;
  justify-content: center; flex-wrap: wrap;
}
.db-metric {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.78rem; color: var(--text-secondary); white-space: nowrap;
}
.db-metric i { color: var(--text-muted); font-size: 0.7rem; }
.db-metric span { color: var(--text-muted); }
.db-metric strong { color: var(--text-primary); font-weight: 600; }
.db-server-actions { margin-left: auto; }

/* â”€â”€ List Header â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-list-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1.2rem; flex-wrap: wrap; gap: 0.75rem;
}
.db-list-header-left h2 {
  margin: 0; font-size: 1.3rem; font-weight: 700; color: var(--text-heading);
  display: flex; align-items: center; gap: 10px;
}
.db-list-header-left h2 i { color: var(--accent); font-size: 1.1rem; }
.db-count {
  font-size: 0.72rem; font-weight: 600; padding: 2px 8px;
  background: var(--accent-glow); color: var(--accent-hover);
  border-radius: 20px; border: 1px solid rgba(99,102,241,0.2);
}
.db-list-header-right { display: flex; align-items: center; gap: 8px; }

/* â”€â”€ Database Card Grid â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-card-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 1rem;
}
.db-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.3rem;
  cursor: pointer; transition: all var(--duration) var(--ease);
  position: relative; overflow: hidden;
  animation: slideUp 0.35s var(--ease) both;
}
.db-card:hover {
  border-color: var(--accent); transform: translateY(-2px);
  box-shadow: 0 8px 30px rgba(0,0,0,0.2), 0 0 0 1px rgba(99,102,241,0.1);
}
.db-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--purple));
  border-radius: 3px 3px 0 0; opacity: 0;
  transition: opacity var(--duration) var(--ease);
}
.db-card:hover::before { opacity: 1; }
.db-card-offline { opacity: 0.6; }
.db-card-top {
  display: flex; align-items: center; gap: 12px; margin-bottom: 1rem;
}
.db-card-icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  background: var(--accent-glow); color: var(--accent); font-size: 1.1rem; flex-shrink: 0;
}
.db-card-info { flex: 1; min-width: 0; }
.db-card-name {
  margin: 0; font-size: 1rem; font-weight: 700; color: var(--text-heading);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.db-card-type {
  font-size: 0.72rem; color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.04em; font-weight: 600;
}
.db-card-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.5rem;
  margin-bottom: 0.75rem;
}
.db-card-stat { text-align: center; }
.db-card-stat-val {
  display: block; font-size: 0.88rem; font-weight: 700; color: var(--text-primary);
  line-height: 1.3; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.db-card-stat-label {
  display: block; font-size: 0.65rem; color: var(--text-muted);
  text-transform: uppercase; letter-spacing: 0.04em;
}
.db-card-actions {
  display: flex; gap: 6px; margin-top: 0.75rem; padding-top: 0.75rem;
  border-top: 1px solid var(--border); justify-content: flex-end;
}
.db-card-sub {
  display: flex; align-items: center; gap: 6px; margin-top: 3px;
}
.db-card-auto { color: var(--accent); font-size: 0.72rem; }
.db-card-link {
  font-size: 0.75rem; color: var(--accent); padding: 0.4rem 0; margin-bottom: 0.3rem;
  display: flex; align-items: center; gap: 6px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.db-card-desc {
  font-size: 0.75rem; color: var(--text-muted); margin-bottom: 0.5rem;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.db-card-footer {
  padding-top: 0.5rem; border-top: 1px solid var(--border); margin-bottom: 0;
}
.db-card-footer-meta {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  font-size: 0.68rem; color: var(--text-muted);
}
.db-card-footer-meta span {
  display: flex; align-items: center; gap: 4px;
}

/* ── Detail Info Bar ─────────────────────────────────────── */
.db-detail-infobar {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  padding: 0.8rem 1.3rem; margin-bottom: 1.2rem;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); font-size: 0.78rem; color: var(--text-muted);
}
.db-infobar-item {
  display: flex; align-items: center; gap: 5px;
}
.db-infobar-item strong { color: var(--text-primary); font-weight: 600; }
.db-detail-dbname {
  font-size: 0.8rem; font-weight: 400; color: var(--text-muted);
}
.db-detail-desc {
  font-size: 0.82rem; color: var(--text-muted); margin: 4px 0 0; line-height: 1.3;
}

/* ── Edit Metadata Modal ─────────────────────────────────── */
.db-meta-readonly {
  margin-top: 1rem; padding-top: 1rem; border-top: 1px solid var(--border);
}
.db-meta-ro-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0.4rem 0; font-size: 0.82rem;
}
.db-meta-ro-item label { color: var(--text-muted); font-weight: 500; }
.db-meta-ro-item span { color: var(--text-primary); }

/* ── Orphan List ─────────────────────────────────────────── */
.db-orphan-list { list-style: none; padding: 0; margin: 0.5rem 0; }
.db-orphan-list li {
  padding: 0.5rem 0.75rem; font-size: 0.82rem;
  border-bottom: 1px solid var(--border);
}

/* â”€â”€ Empty State â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-empty {
  grid-column: 1 / -1; text-align: center; padding: 4rem 2rem;
  background: var(--bg-card); border: 1px dashed var(--border);
  border-radius: var(--radius);
}
.db-empty-icon { font-size: 3rem; color: var(--text-muted); margin-bottom: 1rem; opacity: 0.4; }
.db-empty h3 { margin: 0 0 0.3rem; color: var(--text-heading); }
.db-empty p { color: var(--text-muted); margin: 0 0 1.5rem; font-size: 0.9rem; }
.db-empty-section { padding: 2rem; text-align: center; color: var(--text-muted); font-size: 0.9rem; }

/* â”€â”€ Breadcrumb â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-breadcrumb {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 1rem; font-size: 0.85rem;
}
.db-breadcrumb a {
  color: var(--text-muted); display: flex; align-items: center; gap: 6px;
  transition: color var(--duration) var(--ease);
}
.db-breadcrumb a:hover { color: var(--accent-hover); }
.db-breadcrumb-sep { color: var(--text-muted); font-size: 0.65rem; }
.db-breadcrumb > span:last-child { color: var(--text-primary); font-weight: 600; }

/* â”€â”€ Detail Header â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-detail-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: 1.2rem; flex-wrap: wrap; gap: 1rem;
  padding: 1.3rem; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); animation: slideUp 0.3s var(--ease) both;
}
.db-detail-title { display: flex; align-items: center; gap: 14px; }
.db-detail-icon {
  width: 52px; height: 52px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, rgba(99,102,241,0.15), rgba(168,85,247,0.1));
  color: var(--accent-hover); font-size: 1.4rem; flex-shrink: 0;
}
.db-detail-title h2 { margin: 0; font-size: 1.25rem; font-weight: 700; color: var(--text-heading); }
.db-detail-meta { display: flex; align-items: center; gap: 8px; margin-top: 6px; flex-wrap: wrap; }
.db-detail-meta-item {
  font-size: 0.78rem; color: var(--text-muted);
  display: flex; align-items: center; gap: 5px;
}
.db-detail-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

/* â”€â”€ Tabs â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-tabs {
  display: flex; gap: 2px; margin-bottom: 1.25rem;
  padding: 4px; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); overflow-x: auto;
}
.db-tabs::-webkit-scrollbar { display: none; }
.db-tab {
  padding: 0.6rem 1.1rem; font-size: 0.82rem; font-weight: 500;
  color: var(--text-muted); background: none; border: none;
  border-radius: var(--radius-xs); cursor: pointer;
  transition: all var(--duration) var(--ease);
  white-space: nowrap; display: flex; align-items: center; gap: 7px;
}
.db-tab:hover { color: var(--text-primary); background: rgba(99,102,241,0.06); }
.db-tab.active {
  color: #c4b5fd; font-weight: 600;
  background: linear-gradient(135deg, rgba(99,102,241,0.18), rgba(124,58,237,0.12));
  box-shadow: 0 2px 8px rgba(99,102,241,0.1);
}
.db-tab i { font-size: 0.78rem; }

/* â”€â”€ Section Layout â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-section { animation: slideUp 0.3s var(--ease) both; }
.db-section-bar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1rem; flex-wrap: wrap; gap: 0.75rem;
}
.db-section-bar-left, .db-section-bar-right {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.db-section-bar h4 {
  margin: 0; font-size: 1rem; font-weight: 600; color: var(--text-heading);
  display: flex; align-items: center; gap: 8px;
}
.db-section-count {
  font-size: 0.72rem; font-weight: 600; color: var(--text-muted);
  background: rgba(99,102,241,0.08); padding: 2px 8px; border-radius: 4px;
}
.db-sub-heading {
  font-size: 0.92rem; font-weight: 600; color: var(--text-heading);
  margin: 0 0 0.75rem; display: flex; align-items: center; gap: 8px;
}

/* â”€â”€ Search Box â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-search-box {
  position: relative; display: flex; align-items: center;
}
.db-search-box i {
  position: absolute; left: 12px; color: var(--text-muted); font-size: 0.78rem;
  pointer-events: none;
}
.db-search-box input {
  padding: 0.5rem 0.8rem 0.5rem 2.2rem; font-size: 0.82rem;
  width: 220px; border-radius: var(--radius-xs);
}

/* â”€â”€ Table Link â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-table-link {
  color: var(--accent-hover); font-weight: 600;
  display: flex; align-items: center; gap: 7px;
  transition: color var(--duration) var(--ease);
}
.db-table-link:hover { color: #c4b5fd; }
.db-table-link i { font-size: 0.78rem; color: var(--text-muted); }

/* â”€â”€ Row Actions â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-row-actions { display: flex; gap: 4px; justify-content: flex-end; }
.db-bulk-actions { display: flex; gap: 4px; flex-wrap: wrap; }

/* â”€â”€ Action Dropdown Menu â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-action-menu { position: relative; display: inline-block; }
.db-action-dropdown {
  display: none; position: absolute; right: 0; top: calc(100% + 4px);
  z-index: 200; min-width: 190px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: var(--radius-sm); box-shadow: 0 8px 24px rgba(0,0,0,0.45);
  padding: 4px 0; backdrop-filter: blur(12px);
}
.db-action-dropdown.show { display: block; }
.db-action-dropdown > div {
  padding: 7px 14px; cursor: pointer; font-size: 0.82rem;
  color: var(--text-secondary); display: flex; align-items: center; gap: 8px;
  transition: background 0.15s, color 0.15s;
}
.db-action-dropdown > div:hover {
  background: rgba(99, 102, 241, 0.12); color: var(--text-primary);
}
.db-action-dropdown > div.db-action-danger { color: var(--danger); }
.db-action-dropdown > div.db-action-danger:hover { background: rgba(239, 68, 68, 0.12); }
.db-action-dropdown > div i { width: 16px; text-align: center; font-size: 0.78rem; }
.db-action-dropdown > hr {
  border: none; border-top: 1px solid var(--border); margin: 3px 0;
}

/* â”€â”€ Sortable Columns â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-sortable { cursor: pointer; user-select: none; white-space: nowrap; }
.db-sortable:hover { color: var(--accent); }
.db-sortable i { margin-left: 4px; font-size: 0.7rem; opacity: 0.6; }
.db-sort-idle { opacity: 0.25; }

/* â”€â”€ Monospace text â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-mono { font-family: 'JetBrains Mono', 'Fira Code', monospace; font-size: 0.82rem; }
.db-null { color: var(--text-muted); font-style: italic; opacity: 0.6; }

/* â”€â”€ Browser Header â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-browser-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1rem; flex-wrap: wrap; gap: 0.75rem;
}
.db-browser-title {
  display: flex; align-items: center; gap: 10px;
}
.db-browser-title h3 {
  margin: 0; font-size: 1.05rem; font-weight: 600; color: var(--text-heading);
  display: flex; align-items: center; gap: 8px;
}
.db-browser-actions { display: flex; gap: 6px; flex-wrap: wrap; }

/* â”€â”€ Data Grid â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-data-grid { margin-bottom: 1rem; max-width: 100%; min-width: 0; }
.db-data-grid .table-wrapper, #db-query-result .table-wrapper { max-height: 600px; overflow-x: auto; overflow-y: auto; max-width: 100%; width: 100%; display: block; }
.db-data-grid table, #db-query-result table { width: max-content !important; min-width: 100%; }
.db-data-grid td, #db-query-result td { max-width: 400px; min-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.db-data-grid th, #db-query-result th { min-width: 120px; white-space: nowrap; }

/* â”€â”€ Pagination â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-pagination {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 1rem; color: var(--text-muted); font-size: 0.85rem; flex-wrap: wrap;
}
.db-pagination-left { display: flex; align-items: center; gap: 6px; }
.db-pagination-right {
  display: flex; align-items: center; gap: 8px; font-size: 0.82rem;
}
.db-pagination-right select {
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 4px 8px; color: var(--text-primary);
  font-size: 0.82rem;
}
.db-pagination-info { font-weight: 500; }

/* â”€â”€ Code Block â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-code-block {
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 1rem 1.2rem;
  font-family: 'JetBrains Mono', 'Fira Code', monospace; font-size: 0.82rem;
  color: var(--text-secondary); overflow-x: auto; line-height: 1.7;
  white-space: pre-wrap; word-break: break-all;
}

/* â”€â”€ Query Panel â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-query-panel {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 1.2rem; margin-bottom: 1rem;
}
.db-query-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 0.8rem; flex-wrap: wrap; gap: 0.5rem;
}
.db-query-header h4 {
  margin: 0; font-size: 0.95rem; font-weight: 600; color: var(--text-heading);
  display: flex; align-items: center; gap: 8px;
}
.db-query-btns { display: flex; align-items: center; gap: 8px; }
.db-query-select {
  padding: 0.38rem 2rem 0.38rem 0.8rem; font-size: 0.8rem;
  border-radius: var(--radius-xs); width: auto;
}
.db-query-textarea {
  width: 100%; min-height: 140px; font-family: 'JetBrains Mono', 'Fira Code', monospace;
  font-size: 0.85rem; line-height: 1.7; resize: vertical;
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 1rem;
  color: var(--text-primary);
}
.db-query-textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.db-query-hint {
  font-size: 0.72rem; color: var(--text-muted); margin-top: 6px; text-align: right;
}
.db-query-success {
  padding: 1rem 1.2rem; border-radius: var(--radius-sm);
  background: var(--success-bg); border: 1px solid var(--success-border);
  color: var(--success); font-size: 0.9rem;
  display: flex; align-items: center; gap: 8px;
}
.db-query-error {
  padding: 1rem 1.2rem; border-radius: var(--radius-sm);
  background: var(--danger-bg); border: 1px solid var(--danger-border);
  color: var(--danger); font-size: 0.9rem;
  display: flex; align-items: center; gap: 8px;
}
.db-query-result-header {
  padding: 0.6rem 0; font-size: 0.82rem; color: var(--text-muted);
  font-weight: 500; margin-bottom: 0.5rem;
}
.db-query-history { margin-top: 1.5rem; }
.db-query-history h4 {
  font-size: 0.9rem; font-weight: 600; color: var(--text-secondary);
  margin-bottom: 0.5rem; display: flex; align-items: center; gap: 8px;
}
.db-query-history-list { display: flex; flex-direction: column; gap: 4px; }
.db-query-history-item {
  padding: 0.5rem 0.8rem; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: var(--radius-xs);
  font-size: 0.78rem; cursor: pointer;
  transition: all var(--duration) var(--ease);
}
.db-query-history-item:hover { border-color: var(--accent); background: var(--bg-hover); }
.db-query-history-item code {
  font-family: 'JetBrains Mono', 'Fira Code', monospace; color: var(--text-secondary);
}

/* â”€â”€ User Cards â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-user-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 0.75rem;
}
.db-user-card {
  display: flex; align-items: center; gap: 14px;
  padding: 1rem 1.2rem; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: var(--radius);
  transition: all var(--duration) var(--ease);
  animation: slideUp 0.35s var(--ease) both;
}
.db-user-card:hover { border-color: var(--border-light); }
.db-user-avatar {
  width: 42px; height: 42px; border-radius: 12px;
  background: rgba(99,102,241,0.08); color: var(--accent);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; flex-shrink: 0;
}
.db-user-info { flex: 1; min-width: 0; }
.db-user-info h4 {
  margin: 0; font-size: 0.92rem; font-weight: 600; color: var(--text-heading);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.db-user-host {
  font-size: 0.75rem; color: var(--text-muted);
  display: flex; align-items: center; gap: 5px; margin-top: 2px;
}
.db-user-actions { display: flex; gap: 4px; }

/* â”€â”€ Credentials Display â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-credentials { margin-bottom: 1rem; }
.db-cred-row {
  display: flex; align-items: center; padding: 0.6rem 0;
  border-bottom: 1px solid var(--border);
}
.db-cred-row:last-child { border-bottom: none; }
.db-cred-row label {
  width: 100px; font-size: 0.78rem; font-weight: 600;
  color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.03em;
  margin: 0;
}
.db-cred-row span { font-size: 0.92rem; color: var(--text-primary); word-break: break-all; }
.db-cred-warn {
  display: flex; align-items: center; gap: 8px;
  margin-top: 1rem; padding: 0.8rem; border-radius: var(--radius-xs);
  background: var(--warning-bg); border: 1px solid var(--warning-border);
  color: var(--warning); font-size: 0.82rem;
}

/* â”€â”€ Connection Strings â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-conn-strings { display: flex; flex-direction: column; gap: 1rem; }
.db-conn-item label {
  display: block; font-size: 0.78rem; font-weight: 700; color: var(--accent-hover);
  text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 0.4rem;
}

/* â”€â”€ Settings Grid â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-settings-grid { display: flex; flex-direction: column; gap: 1.5rem; }
.db-settings-section h4 {
  font-size: 0.92rem; font-weight: 600; color: var(--text-heading);
  margin: 0 0 0.75rem; display: flex; align-items: center; gap: 8px;
}

/* â”€â”€ Performance Grid â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-perf-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.75rem; margin-bottom: 1.5rem;
}
.db-perf-card {
  display: flex; align-items: center; gap: 14px;
  padding: 1.1rem 1.2rem; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: var(--radius);
  transition: all var(--duration) var(--ease);
  animation: slideUp 0.35s var(--ease) both;
}
.db-perf-card:hover { border-color: var(--border-light); transform: translateY(-1px); }
.db-perf-icon {
  width: 44px; height: 44px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; flex-shrink: 0;
}
.db-perf-icon.accent { background: var(--accent-glow); color: var(--accent); }
.db-perf-icon.success { background: var(--success-bg); color: var(--success); }
.db-perf-icon.warning { background: var(--warning-bg); color: var(--warning); }
.db-perf-icon.info { background: var(--info-bg); color: var(--info); }
.db-perf-content { min-width: 0; }
.db-perf-val { display: block; font-size: 1.15rem; font-weight: 700; color: var(--text-heading); }
.db-perf-label { display: block; font-size: 0.72rem; color: var(--text-muted); margin-top: 2px; }

/* â”€â”€ Advanced section spacing â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-adv-section { margin-bottom: 1.5rem; }
.db-adv-section:last-child { margin-bottom: 0; }
.db-muted-msg { color: var(--text-muted); font-size: 0.85rem; padding: 1rem 0; margin: 0; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   CLEANUP PAGE
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

.clp-page { max-width: 1100px; margin: 0 auto; }

/* Loading */
.clp-loading { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 16px; padding: 80px 0; color: var(--text-muted); font-size: 0.95rem; }

/* â”€â”€ Hero â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-hero { display: flex; flex-wrap: wrap; align-items: center; gap: 32px; padding: 28px 32px; margin-bottom: 24px; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); }
.clp-hero-ring { position: relative; width: 130px; height: 130px; flex-shrink: 0; }
.clp-ring-svg { width: 100%; height: 100%; }
.clp-ring-progress { transition: stroke-dashoffset 1s var(--ease); }
.clp-ring-label { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.clp-ring-pct { font-size: 1.5rem; font-weight: 800; color: var(--text-heading); line-height: 1; }
.clp-ring-sub { font-size: 0.65rem; color: var(--text-muted); margin-top: 4px; text-transform: uppercase; letter-spacing: 0.5px; }

.clp-hero-stats { display: flex; gap: 28px; flex: 1; }
.clp-stat { display: flex; flex-direction: column; gap: 2px; }
.clp-stat-value { font-size: 1.25rem; font-weight: 700; color: var(--text-heading); }
.clp-stat-label { font-size: 0.72rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; }

.clp-hero-actions { display: flex; gap: 10px; flex-wrap: wrap; width: 100%; margin-top: 4px; }
.clp-hero-actions .btn { display: inline-flex; align-items: center; gap: 6px; font-size: 0.82rem; padding: 8px 18px; }

/* â”€â”€ Category Cards â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-categories { display: flex; flex-direction: column; gap: 12px; margin-bottom: 24px; }

.clp-cat { border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; background: var(--bg-card); transition: border-color 0.2s; }
.clp-cat:hover { border-color: var(--border-light); }

.clp-cat-header { display: flex; align-items: center; gap: 14px; padding: 16px 20px; cursor: pointer; user-select: none; transition: background 0.15s; }
.clp-cat-header:hover { background: var(--bg-hover); }

.clp-cat-icon { width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; border-radius: var(--radius-xs); background: rgba(99,102,241,0.06); flex-shrink: 0; }

.clp-cat-info { flex: 1; min-width: 0; }
.clp-cat-name { font-size: 0.95rem; font-weight: 600; color: var(--text-heading); margin: 0; }
.clp-cat-meta { font-size: 0.78rem; color: var(--text-muted); }

.clp-cat-actions { display: flex; align-items: center; gap: 8px; }
.clp-cat-chevron { transition: transform 0.25s var(--ease); color: var(--text-muted); flex-shrink: 0; }
.clp-cat-expanded .clp-cat-chevron { transform: rotate(180deg); }

.clp-cat-body { display: none; border-top: 1px solid var(--border); }
.clp-cat-expanded .clp-cat-body { display: block; }

/* â”€â”€ Items â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-item { display: flex; align-items: center; gap: 12px; padding: 12px 20px 12px 24px; border-bottom: 1px solid rgba(99,102,241,0.04); transition: background 0.12s; }
.clp-item:last-child { border-bottom: none; }
.clp-item:hover { background: var(--bg-hover); }

.clp-item-check { position: relative; width: 20px; height: 20px; flex-shrink: 0; cursor: pointer; }
.clp-item-check input { position: absolute; opacity: 0; width: 20px; height: 20px; cursor: pointer; margin: 0; }
.clp-checkmark { position: absolute; inset: 0; border: 2px solid var(--border-light); border-radius: 4px; transition: all 0.15s; }
.clp-item-check input:checked + .clp-checkmark { background: var(--accent); border-color: var(--accent); }
.clp-item-check input:checked + .clp-checkmark::after { content: ''; position: absolute; left: 5px; top: 1px; width: 5px; height: 10px; border: solid #fff; border-width: 0 2px 2px 0; transform: rotate(45deg); }

.clp-item-info { flex: 1; min-width: 0; }
.clp-item-name { font-size: 0.88rem; font-weight: 500; color: var(--text-primary); display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.clp-item-desc { font-size: 0.76rem; color: var(--text-muted); margin-top: 2px; line-height: 1.4; }
.clp-item-path { margin-top: 3px; }
.clp-item-path code { font-size: 0.7rem; color: var(--text-muted); background: rgba(99,102,241,0.06); padding: 1px 6px; border-radius: 3px; font-family: 'JetBrains Mono', monospace; }

.clp-item-size { font-size: 0.9rem; font-weight: 600; color: var(--accent); white-space: nowrap; min-width: 70px; text-align: right; }

.clp-item-clean { flex-shrink: 0; }

/* Tags */
.clp-tag { font-size: 0.65rem; padding: 1px 7px; border-radius: 20px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px; }
.clp-tag-safe { background: var(--success-bg); color: var(--success); }
.clp-tag-caution { background: var(--warning-bg); color: var(--warning); }

/* â”€â”€ Schedule Card â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-schedule { padding: 0; margin-bottom: 20px; border: 1px solid var(--border); border-radius: var(--radius); background: var(--bg-card); }
.clp-schedule-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid var(--border); }
.clp-schedule-title { display: flex; align-items: center; gap: 14px; }
.clp-schedule-title h3 { margin: 0; font-size: 1rem; font-weight: 600; color: var(--text-heading); }
.clp-schedule-sub { font-size: 0.76rem; color: var(--text-muted); display: block; }

/* Toggle switch */
.clp-toggle { position: relative; display: inline-block; width: 48px; height: 26px; }
.clp-toggle input { opacity: 0; width: 0; height: 0; }
.clp-toggle-slider { position: absolute; cursor: pointer; inset: 0; background: rgba(99,102,241,0.15); border-radius: 26px; transition: 0.3s; }
.clp-toggle-slider::before { content: ''; position: absolute; width: 20px; height: 20px; left: 3px; bottom: 3px; background: #fff; border-radius: 50%; transition: 0.3s; }
.clp-toggle input:checked + .clp-toggle-slider { background: var(--accent); }
.clp-toggle input:checked + .clp-toggle-slider::before { transform: translateX(22px); }

.clp-schedule-body { padding: 20px 24px; }

.clp-sched-row { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 16px; }
.clp-sched-row:last-child { margin-bottom: 0; }
.clp-sched-row > label { font-size: 0.82rem; font-weight: 600; color: var(--text-secondary); min-width: 80px; padding-top: 6px; }
.clp-sched-row select { background: var(--bg-input); border: 1px solid var(--border); border-radius: var(--radius-xs); color: var(--text-primary); padding: 7px 12px; font-size: 0.85rem; outline: none; cursor: pointer; }
.clp-sched-row select:focus { border-color: var(--accent); }

.clp-sched-targets { display: flex; flex-wrap: wrap; gap: 8px 16px; }
.clp-sched-target-item { display: flex; align-items: center; gap: 6px; font-size: 0.82rem; color: var(--text-secondary); cursor: pointer; }
.clp-sched-target-item input { accent-color: var(--accent); cursor: pointer; }

.clp-sched-last-info { font-size: 0.85rem; color: var(--text-muted); padding-top: 6px; display: flex; align-items: center; }

/* â”€â”€ Empty / Error states â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-empty, .clp-error-state { text-align: center; padding: 60px 20px; color: var(--text-muted); }
.clp-empty svg { margin-bottom: 16px; color: var(--success); }
.clp-empty h3, .clp-error-state h3 { color: var(--text-heading); font-size: 1.2rem; margin: 0 0 8px; }
.clp-empty p, .clp-error-state p { font-size: 0.88rem; margin: 0 0 16px; }
.clp-error-state svg { margin-bottom: 16px; color: var(--danger); }

/* â”€â”€ Footer â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-footer { text-align: center; font-size: 0.75rem; color: var(--text-muted); padding: 8px 0 20px; }

/* â”€â”€ Buttons â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn-xs { font-size: 0.72rem; padding: 3px 10px; border-radius: 6px; }
.btn-outline-danger { border: 1px solid var(--danger); color: var(--danger); background: transparent; cursor: pointer; transition: all 0.15s; }
.btn-outline-danger:hover { background: var(--danger-bg); }
.btn-sm.btn-outline { border: 1px solid var(--border-light); color: var(--text-secondary); background: transparent; }
.btn-sm.btn-outline:hover { background: var(--bg-hover); border-color: var(--accent); color: var(--accent); }

.spinner-xs { width: 14px; height: 14px; border: 2px solid rgba(255,255,255,0.2); border-top-color: #fff; border-radius: 50%; animation: spin 0.6s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }

/* â”€â”€ Hero layout upgrade â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-hero-left { display: flex; align-items: center; gap: 28px; flex: 1; min-width: 0; }
.clp-hero-trend { min-width: 220px; flex-shrink: 0; }
.clp-trend-title { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); font-weight: 600; margin-bottom: 8px; }
.clp-sparkline { height: 50px; }
.clp-sparkline-svg { width: 100%; height: 100%; }
.clp-sparkline-empty { font-size: 0.78rem; color: var(--text-muted); padding: 12px 0; }
.clp-trend-range { display: flex; justify-content: space-between; font-size: 0.7rem; color: var(--text-muted); margin-top: 4px; }

/* Item size highlighting */
.clp-size-medium { color: #f59e0b !important; }
.clp-size-large { color: #ef4444 !important; font-weight: 700 !important; }

/* â”€â”€ Bottom grid (Schedule + History) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-bottom-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 24px; }

/* â”€â”€ Cleanup History â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-history { border: 1px solid var(--border); border-radius: var(--radius); background: var(--bg-card); overflow: hidden; }
.clp-history-header { padding: 18px 24px; border-bottom: 1px solid var(--border); }
.clp-history-header h3 { margin: 0; font-size: 1rem; font-weight: 600; color: var(--text-heading); display: flex; align-items: center; gap: 10px; }
.clp-history-body { padding: 0; max-height: 320px; overflow-y: auto; }
.clp-history-empty { padding: 40px 24px; text-align: center; font-size: 0.85rem; color: var(--text-muted); }
.clp-history-list { display: flex; flex-direction: column; }
.clp-history-item { display: flex; align-items: center; gap: 12px; padding: 10px 24px; border-bottom: 1px solid rgba(99,102,241,0.04); font-size: 0.82rem; }
.clp-history-item:last-child { border-bottom: none; }
.clp-hist-badge { font-size: 0.65rem; padding: 2px 8px; border-radius: 20px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px; flex-shrink: 0; }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   BOOTSTRAP-COMPAT UTILITIES (used by email + shared pages)
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ Layout utilities â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.d-flex { display: flex; }
.d-block { display: block; }
.d-none { display: none; }
.align-items-center { align-items: center; }
.justify-content-between { justify-content: space-between; }
.ms-auto { margin-left: auto; }
.ms-2 { margin-left: 0.5rem; }
.me-2 { margin-right: 0.5rem; }
.p-2 { padding: 0.5rem; }
.table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.row { display: flex; flex-wrap: wrap; margin-left: -6px; margin-right: -6px; }
.col-6 { flex: 0 0 50%; max-width: 50%; padding-left: 6px; padding-right: 6px; box-sizing: border-box; }

/* â”€â”€ Form controls â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.form-control {
  width: 100%; padding: 9px 14px;
  background: var(--bg-input); border: 1px solid var(--border);
  border-radius: var(--radius-xs); color: var(--text-primary);
  font-family: var(--font); font-size: 0.88rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.form-control:focus {
  border-color: var(--accent); outline: none;
  box-shadow: 0 0 0 3px var(--accent-glow);
}
.form-control::placeholder { color: var(--text-muted); }
.form-control-sm { padding: 6px 10px; font-size: 0.82rem; }

/* â”€â”€ Input group â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.input-group {
  display: flex; align-items: stretch; width: 100%;
}
.input-group .form-control {
  flex: 1; border-radius: 0;
}
.input-group .form-control:first-child { border-radius: var(--radius-xs) 0 0 var(--radius-xs); }
.input-group .form-control:last-child { border-radius: 0 var(--radius-xs) var(--radius-xs) 0; }
.input-group .input-group-text {
  display: flex; align-items: center; padding: 6px 12px;
  background: rgba(99,102,241,0.08); border: 1px solid var(--border);
  color: var(--text-secondary); font-size: 0.82rem; white-space: nowrap;
}
.input-group .input-group-text:first-child { border-radius: var(--radius-xs) 0 0 var(--radius-xs); border-right: none; }
.input-group .input-group-text:last-child { border-radius: 0 var(--radius-xs) var(--radius-xs) 0; border-left: none; }
.input-group-sm .form-control { padding: 5px 10px; font-size: 0.8rem; }
.input-group-sm .input-group-text { padding: 5px 10px; font-size: 0.78rem; }

/* â”€â”€ Outline button variants â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn-outline-primary {
  border: 1px solid var(--accent); color: var(--accent);
  background: transparent; cursor: pointer; transition: all 0.15s;
}
.btn-outline-primary:hover { background: rgba(99,102,241,0.1); }
.btn-outline-secondary {
  border: 1px solid var(--border-light); color: var(--text-secondary);
  background: transparent; cursor: pointer; transition: all 0.15s;
}
.btn-outline-secondary:hover { background: var(--bg-hover); }
.btn-outline-success {
  border: 1px solid var(--success); color: var(--success);
  background: transparent; cursor: pointer; transition: all 0.15s;
}
.btn-outline-success:hover { background: var(--success-bg); }
.btn-outline-warning {
  border: 1px solid var(--warning); color: var(--warning);
  background: transparent; cursor: pointer; transition: all 0.15s;
}
.btn-outline-warning:hover { background: var(--warning-bg); }
.btn-outline-info {
  border: 1px solid var(--info); color: var(--info);
  background: transparent; cursor: pointer; transition: all 0.15s;
}
.btn-outline-info:hover { background: var(--info-bg); }

/* â”€â”€ Spinner border â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.spinner-border {
  display: inline-block; width: 1.2rem; height: 1.2rem;
  border: 2px solid currentColor; border-right-color: transparent;
  border-radius: 50%; animation: emSpin 0.65s linear infinite;
  vertical-align: -0.125em;
}
.spinner-border-sm { width: 0.85rem; height: 0.85rem; border-width: 2px; }

/* â”€â”€ Badge color variants â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge.bg-success, .badge.success { background: var(--success-bg); color: var(--success); }
.badge.bg-danger, .badge.danger { background: var(--danger-bg); color: var(--danger); }
.badge.bg-warning, .badge.warning { background: var(--warning-bg); color: var(--warning); }
.badge.bg-info, .badge.info { background: var(--info-bg); color: var(--info); }

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   EMAIL HOSTING SYSTEM â€” Premium UI
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ Email Page Container â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-page { animation: emailFadeIn 0.35s ease both; }
@keyframes emailFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

/* â”€â”€ Header â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-header {
  margin-bottom: 20px;
}
.email-header h2 {
  font-size: 1.35rem; font-weight: 800; margin: 0 0 16px;
  color: var(--text-heading); display: flex; align-items: center; gap: 10px;
  letter-spacing: -0.02em;
}
.email-header h2 i { color: var(--accent); font-size: 1.1em; }

/* â”€â”€ Stats Grid â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-stats-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; margin-bottom: 16px;
}
.em-stat {
  background: var(--bg-card); backdrop-filter: blur(12px);
  border: 1px solid var(--border); border-radius: var(--radius);
  padding: 16px 18px; position: relative; overflow: hidden;
  transition: all 0.25s ease;
}
.em-stat:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.2); border-color: var(--border-light); }
.em-stat::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
  border-radius: 3px 3px 0 0;
}
.em-stat:nth-child(1)::before { background: linear-gradient(90deg, #6366f1, #a855f7); }
.em-stat:nth-child(2)::before { background: linear-gradient(90deg, #3b82f6, #6366f1); }
.em-stat:nth-child(3)::before { background: linear-gradient(90deg, #10b981, #06b6d4); }
.em-stat:nth-child(4)::before { background: linear-gradient(90deg, #f59e0b, #f97316); }
.em-stat:nth-child(5)::before { background: linear-gradient(90deg, #ef4444, #f97316); }
.em-stat-val {
  font-size: 1.7rem; font-weight: 800; line-height: 1.1; letter-spacing: -0.03em;
  color: var(--text-heading);
}
.em-stat-lbl {
  font-size: 0.72rem; color: var(--text-muted); font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.5px; margin-top: 4px;
}

/* â”€â”€ Services Bar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-services-bar {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  padding: 10px 16px; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); margin-bottom: 16px;
}
.em-svc-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 20px; font-size: 0.72rem;
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px;
  cursor: pointer; transition: all 0.2s; border: 1px solid transparent;
}
.em-svc-badge:hover { filter: brightness(1.15); }
.em-svc-badge .em-svc-dot {
  width: 7px; height: 7px; border-radius: 50%;
}
.em-svc-badge.active { background: var(--success-bg); color: var(--success); border-color: var(--success-border); }
.em-svc-badge.active .em-svc-dot { background: var(--success); box-shadow: 0 0 6px rgba(16,185,129,0.5); }
.em-svc-badge.inactive { background: var(--danger-bg); color: var(--danger); border-color: var(--danger-border); }
.em-svc-badge.inactive .em-svc-dot { background: var(--danger); box-shadow: 0 0 6px rgba(239,68,68,0.5); }
.em-svc-badge.none { background: rgba(92,99,128,0.12); color: var(--text-muted); border-color: rgba(92,99,128,0.2); }
.em-svc-badge.none .em-svc-dot { background: var(--text-muted); }
.em-hostname {
  margin-left: auto; color: var(--text-muted); font-size: 0.75rem;
  font-family: 'JetBrains Mono', 'SF Mono', 'Consolas', monospace;
  display: flex; align-items: center; gap: 6px;
}
.em-hostname i { font-size: 0.85em; }

/* â”€â”€ Domain Selector â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-domain-selector {
  display: flex; align-items: center; gap: 10px; margin-bottom: 16px;
}
.email-domain-selector label {
  font-size: 0.78rem; font-weight: 600; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.4px;
}
.email-domain-selector select {
  padding: 7px 14px; border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--bg-card); color: var(--text-primary); font-size: 0.85rem;
  font-weight: 500; cursor: pointer; transition: all 0.2s;
  appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236366f1' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 10px center; padding-right: 30px;
}
.email-domain-selector select:focus { border-color: var(--accent); outline: none; box-shadow: 0 0 0 3px var(--accent-glow); }

/* â”€â”€ Tab Navigation â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-tabs {
  display: flex; gap: 2px; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 4px; overflow-x: auto; margin-bottom: 20px;
}
.email-tabs::-webkit-scrollbar { height: 0; }
.email-tab {
  display: flex; align-items: center; gap: 7px; padding: 9px 18px; border: none;
  background: transparent; color: var(--text-muted); font-size: 0.8rem;
  font-weight: 600; border-radius: calc(var(--radius) - 2px); cursor: pointer;
  transition: all 0.2s ease; white-space: nowrap; position: relative;
}
.email-tab i { font-size: 1rem; }
.email-tab:hover { background: var(--bg-hover); color: var(--text-primary); }
.email-tab.active {
  background: linear-gradient(135deg, var(--accent), #818cf8);
  color: #fff; box-shadow: 0 2px 12px rgba(99,102,241,0.3);
}

/* â”€â”€ Tab Content Panel â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#emailTabContent { min-height: 200px; }

/* â”€â”€ Section Cards â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-section {
  margin-bottom: 16px; padding: 20px;
  background: var(--bg-card); backdrop-filter: blur(12px);
  border: 1px solid var(--border); border-radius: var(--radius);
  transition: border-color 0.2s;
}
.email-section:hover { border-color: var(--border-light); }
.email-section h5 {
  font-size: 0.88rem; font-weight: 700; margin: 0 0 14px;
  color: var(--text-heading); display: flex; align-items: center; gap: 8px;
}
.email-section h5 i { color: var(--accent); font-size: 1.05em; }

/* â”€â”€ Toolbar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-tab-toolbar {
  display: flex; align-items: center; gap: 10px; margin-bottom: 14px; flex-wrap: wrap;
}
.email-tab-toolbar h5 { margin: 0 !important; }

/* â”€â”€ Overview Actions â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-overview-actions {
  display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap;
}

/* â”€â”€ Empty State â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-empty-state {
  text-align: center; padding: 60px 20px; color: var(--text-secondary);
}
.email-empty-state i {
  font-size: 3.5rem; color: var(--accent); opacity: 0.6;
  margin-bottom: 16px; display: block;
}
.email-empty-state h4 {
  font-size: 1.1rem; font-weight: 700; color: var(--text-heading);
  margin: 0 0 8px;
}
.email-empty-state p {
  font-size: 0.85rem; color: var(--text-muted); margin: 0 0 20px;
}

/* â”€â”€ Tables â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-section .table {
  width: 100%; border-collapse: separate; border-spacing: 0;
  font-size: 0.82rem;
}
.email-section .table thead th {
  font-size: 0.7rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text-muted);
  padding: 10px 14px; border-bottom: 1px solid var(--border);
  background: rgba(99,102,241,0.03); white-space: nowrap;
}
.email-section .table thead th:first-child { border-radius: var(--radius-xs) 0 0 0; }
.email-section .table thead th:last-child { border-radius: 0 var(--radius-xs) 0 0; }
.email-section .table tbody td {
  padding: 10px 14px; border-bottom: 1px solid rgba(99,102,241,0.04);
  vertical-align: middle; color: var(--text-primary);
}
.email-section .table tbody tr {
  transition: background 0.15s;
}
.email-section .table tbody tr:hover {
  background: var(--bg-hover);
}
.email-section .table tbody tr:last-child td { border-bottom: none; }

/* â”€â”€ Quota Progress â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-quota-bar {
  width: 100%; height: 6px; background: rgba(99,102,241,0.08);
  border-radius: 3px; overflow: hidden; margin-bottom: 3px;
}
.em-quota-fill {
  height: 100%; border-radius: 3px; transition: width 0.4s ease;
}
.em-quota-fill.ok { background: linear-gradient(90deg, #10b981, #06b6d4); }
.em-quota-fill.warn { background: linear-gradient(90deg, #f59e0b, #f97316); }
.em-quota-fill.danger { background: linear-gradient(90deg, #ef4444, #f97316); }
.em-quota-text {
  font-size: 0.68rem; color: var(--text-muted); white-space: nowrap;
}

/* â”€â”€ Action Buttons â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-actions { display: flex; gap: 4px; flex-wrap: wrap; }
.em-act {
  width: 30px; height: 30px; border-radius: var(--radius-xs); border: 1px solid var(--border);
  background: transparent; color: var(--text-secondary); cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all 0.2s; font-size: 0.82rem;
}
.em-act:hover { background: var(--bg-hover); color: var(--text-primary); border-color: var(--border-light); }
.em-act.edit:hover { color: var(--accent); border-color: rgba(99,102,241,0.3); }
.em-act.reply:hover { color: var(--info); border-color: rgba(59,130,246,0.3); }
.em-act.history:hover { color: var(--purple); border-color: rgba(168,85,247,0.3); }
.em-act.delete:hover { color: var(--danger); border-color: var(--danger-border); background: var(--danger-bg); }

/* â”€â”€ Bulk Operations Bar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-bulk-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 14px; margin: 8px 0;
  background: rgba(99,102,241,0.06); border: 1px solid rgba(99,102,241,0.2);
  border-radius: var(--radius-sm);
}
.em-bulk-count {
  font-weight: 600; font-size: 0.82rem; color: var(--accent);
  margin-right: 8px;
}
.em-bulk-bar .btn { font-size: 0.72rem; padding: 3px 10px; }
.em-mb-select { cursor: pointer; accent-color: var(--accent); }

/* â”€â”€ Badges â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 20px; font-size: 0.68rem;
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px;
}
.em-badge.active { background: var(--success-bg); color: var(--success); border: 1px solid var(--success-border); }
.em-badge.disabled { background: rgba(92,99,128,0.12); color: var(--text-muted); border: 1px solid rgba(92,99,128,0.2); }
.em-badge.on { background: var(--success-bg); color: var(--success); border: 1px solid var(--success-border); }
.em-badge.off { background: rgba(92,99,128,0.12); color: var(--text-muted); border: 1px solid rgba(92,99,128,0.2); }

/* â”€â”€ Pagination â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-pagination {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 14px; padding-top: 14px; border-top: 1px solid var(--border);
}
.em-pagination .text-muted { font-size: 0.78rem; }

/* â”€â”€ Catch-All â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-catchall {
  display: flex; align-items: center; gap: 0; max-width: 480px;
}
.em-catchall .input-group-text {
  background: rgba(99,102,241,0.08); border: 1px solid var(--border);
  color: var(--text-secondary); font-size: 0.8rem; border-right: none;
  padding: 7px 12px; border-radius: var(--radius-xs) 0 0 var(--radius-xs);
}
.em-catchall input {
  flex: 1; padding: 7px 12px; border: 1px solid var(--border);
  background: var(--bg-input); color: var(--text-primary); font-size: 0.85rem;
  border-radius: 0; border-left: none; border-right: none;
}
.em-catchall input:focus { outline: none; border-color: var(--accent); }
.em-catchall .btn { border-radius: 0; }
.em-catchall .btn:last-child { border-radius: 0 var(--radius-xs) var(--radius-xs) 0; }

/* â”€â”€ DKIM & DNS â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-dkim-info {
  padding: 4px 0;
}
.email-dkim-info p {
  margin: 0 0 8px; font-size: 0.85rem; color: var(--text-secondary);
  display: flex; align-items: center; gap: 6px;
}
.em-dns-table { width: 100%; border-collapse: separate; border-spacing: 0; }
.em-dns-table th {
  font-size: 0.68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text-muted); padding: 10px 14px;
  border-bottom: 1px solid var(--border); background: rgba(99,102,241,0.03);
}
.em-dns-table td {
  padding: 12px 14px; border-bottom: 1px solid rgba(99,102,241,0.04);
  font-size: 0.82rem; vertical-align: top;
}
.em-dns-table tr:last-child td { border-bottom: none; }
.em-dns-type {
  display: inline-block; padding: 2px 8px; border-radius: 4px;
  font-size: 0.68rem; font-weight: 700; font-family: 'JetBrains Mono', monospace;
  background: var(--info-bg); color: var(--info); border: 1px solid var(--info-border);
}
.email-dns-name, .email-dns-value {
  font-family: 'JetBrains Mono', 'SF Mono', 'Consolas', monospace; font-size: 0.75rem;
  background: var(--bg-input); border: 1px solid var(--border); border-radius: 4px;
  padding: 4px 8px; cursor: pointer; transition: all 0.2s;
  word-break: break-all; line-height: 1.5;
}
.email-dns-name:hover, .email-dns-value:hover {
  border-color: var(--accent); background: rgba(99,102,241,0.06);
}

/* â”€â”€ DNS Verify â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-dns-verify {
  padding: 14px 16px; background: var(--bg-input); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.email-dns-verify strong { font-size: 0.88rem; }
.dns-check-item {
  display: flex; align-items: center; gap: 8px; padding: 6px 0;
  font-size: 0.82rem; border-bottom: 1px solid rgba(99,102,241,0.04);
}
.dns-check-item:last-child { border-bottom: none; }

/* â”€â”€ Connect Cards â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-connect-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.email-connect-card {
  padding: 18px; border: 1px solid var(--border); border-radius: var(--radius);
  background: var(--bg-input); transition: border-color 0.2s;
}
.email-connect-card:hover { border-color: var(--border-light); }
.email-connect-card h6 {
  font-size: 0.85rem; font-weight: 700; margin: 0 0 12px;
  color: var(--accent); display: flex; align-items: center; gap: 7px;
}
.email-connect-card h6 i { font-size: 1.1em; }
.email-connect-card .table { margin: 0; }
.email-connect-card .table td {
  padding: 6px 10px; font-size: 0.8rem; border-bottom: 1px solid rgba(99,102,241,0.04);
}
.email-connect-card .table td:first-child {
  color: var(--text-muted); font-size: 0.72rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.3px; width: 90px;
}
.email-connect-card .table tr:last-child td { border-bottom: none; }
.email-connect-card .table code {
  font-family: 'JetBrains Mono', monospace; font-size: 0.78rem;
  color: var(--text-heading);
}

/* â”€â”€ Guide Cards (Accordion) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-app-guides { display: flex; flex-direction: column; gap: 8px; }
.email-guide-card {
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--bg-input); overflow: hidden; transition: border-color 0.2s;
}
.email-guide-card:hover { border-color: var(--border-light); }
.email-guide-toggle {
  padding: 12px 16px; margin: 0; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.85rem; font-weight: 600; color: var(--text-heading);
  background: transparent; transition: background 0.15s;
}
.email-guide-toggle:hover { background: var(--bg-hover); }
.email-guide-toggle i { transition: transform 0.25s; color: var(--text-muted); font-size: 0.8em; }
.email-guide-steps {
  display: none; padding: 4px 18px 16px 34px; font-size: 0.8rem;
  line-height: 1.8; color: var(--text-secondary);
}
.email-guide-card.open .email-guide-steps { display: block; }
.email-guide-card.open .email-guide-toggle i { transform: rotate(180deg); }
.email-guide-card.open { border-color: var(--border-light); }

/* â”€â”€ Health Checks â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-health-list { display: flex; flex-direction: column; gap: 4px; }
.email-health-item {
  display: flex; align-items: center; gap: 12px; padding: 8px 12px;
  font-size: 0.82rem; border-radius: var(--radius-xs);
  transition: background 0.15s;
}
.email-health-item:hover { background: var(--bg-hover); }
.health-icon { font-size: 1.05rem; width: 22px; text-align: center; flex-shrink: 0; }
.health-ok .health-icon { color: var(--success); }
.health-warn .health-icon { color: #f59e0b; }
.email-health-item strong { min-width: 140px; color: var(--text-heading); font-weight: 600; }
.email-health-item span { color: var(--text-secondary); }

/* â”€â”€ Queue Output â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-queue-output {
  background: var(--bg-input); border: 1px solid var(--border); border-radius: var(--radius-sm);
  padding: 14px 18px; font-family: 'JetBrains Mono', 'SF Mono', 'Consolas', monospace;
  font-size: 0.73rem; max-height: 220px; overflow: auto; white-space: pre-wrap;
  word-break: break-all; margin: 0; color: var(--text-secondary); line-height: 1.6;
}
.email-queue-output::-webkit-scrollbar { width: 4px; }
.email-queue-output::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* â”€â”€ Loading â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-loading {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 12px; padding: 60px 20px; color: var(--text-muted); font-size: 0.85rem;
}
.email-loading .spinner {
  width: 28px; height: 28px; border: 3px solid var(--border);
  border-top-color: var(--accent); border-radius: 50%;
  animation: emSpin 0.7s linear infinite;
}
@keyframes emSpin { to { transform: rotate(360deg); } }

/* â”€â”€ Copy Toast â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.email-copy-toast {
  position: fixed; bottom: 24px; right: 24px; z-index: 10000;
  background: var(--success); color: #fff; padding: 10px 20px;
  border-radius: var(--radius-sm); font-size: 0.8rem; font-weight: 600;
  box-shadow: 0 8px 30px rgba(16,185,129,0.3);
  animation: emToastIn 0.25s ease;
}
@keyframes emToastIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }

/* â”€â”€ Modals (email-specific) â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-modal-overlay {
  position: fixed; inset: 0; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(8px);
  animation: emModalBgIn 0.2s ease;
}
@keyframes emModalBgIn { from { opacity: 0; } to { opacity: 1; } }
.em-modal {
  background: var(--bg-card-solid); border: 1px solid var(--border);
  border-radius: 18px; width: 500px; max-width: 95vw; max-height: 90vh;
  overflow-y: auto; box-shadow: var(--shadow), var(--shadow-glow);
  animation: emModalIn 0.3s cubic-bezier(0.34,1.56,0.64,1);
  padding: 0;
}
@keyframes emModalIn { from { opacity: 0; transform: scale(0.92) translateY(10px); } to { opacity: 1; transform: scale(1) translateY(0); } }
.em-modal-head {
  padding: 18px 22px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.em-modal-head h5 {
  margin: 0; font-size: 1rem; font-weight: 700; color: var(--text-heading);
  display: flex; align-items: center; gap: 8px;
}
.em-modal-head h5 i { color: var(--accent); }
.em-modal-body { padding: 20px 22px; }
.em-modal-body label {
  display: block; font-size: 0.75rem; font-weight: 600; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.3px; margin-bottom: 5px;
}
.em-modal-body .form-control {
  background: var(--bg-input); border: 1px solid var(--border); color: var(--text-primary);
  border-radius: var(--radius-xs); padding: 8px 12px; font-size: 0.85rem;
  transition: border-color 0.2s, box-shadow 0.2s; width: 100%;
}
.em-modal-body .form-control:focus {
  border-color: var(--accent); outline: none; box-shadow: 0 0 0 3px var(--accent-glow);
}
.em-modal-body .mb-2 { margin-bottom: 14px; }
.em-modal-foot {
  padding: 14px 22px; border-top: 1px solid var(--border);
  display: flex; gap: 8px; justify-content: flex-end;
}

/* â”€â”€ Add Domain Wizard â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.wiz-modal { max-width: 680px; width: 680px; }
.wiz-modal.wiz-modal-wide { max-width: 780px; width: 780px; }
.wiz-modal .em-modal-head { display: flex; align-items: center; justify-content: space-between; }
.wiz-close-btn {
  background: none; border: none; color: var(--text-muted); font-size: 1.1rem;
  cursor: pointer; padding: 4px 8px; border-radius: var(--radius-xs);
  transition: all 0.2s; display: flex; align-items: center;
}
.wiz-close-btn:hover { background: var(--danger-bg); color: var(--danger); }

/* Stepper */
.wiz-stepper {
  display: flex; align-items: center; gap: 0; padding: 16px 22px;
  border-bottom: 1px solid var(--border); background: rgba(99,102,241,0.03);
}
.wiz-step {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  flex: 0 0 auto; position: relative; z-index: 1;
}
.wiz-step span { font-size: 0.65rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.5px; }
.wiz-step.active span { color: var(--accent); }
.wiz-step.done span { color: var(--success); }
.wiz-step-icon {
  width: 34px; height: 34px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
  background: var(--bg-tertiary); border: 2px solid var(--border); color: var(--text-muted);
  font-size: 0.85rem; transition: all 0.3s;
}
.wiz-step.active .wiz-step-icon { border-color: var(--accent); background: var(--accent); color: #fff; box-shadow: 0 0 16px var(--accent-bright); }
.wiz-step.done .wiz-step-icon { border-color: var(--success); background: var(--success); color: #fff; }
.wiz-step-line { flex: 1; height: 2px; background: var(--border); margin: 0 6px; align-self: center; transition: background 0.3s; }
.wiz-step-line.done { background: var(--success); }

/* Body */
.wiz-body { padding: 20px 22px; max-height: 55vh; overflow-y: auto; }
.wiz-body.wiz-body-result { max-height: 68vh; }
.wiz-sec { margin-bottom: 16px; }
.wiz-sec-head {
  font-size: 0.82rem; font-weight: 700; color: var(--text-heading);
  display: flex; align-items: center; gap: 6px; margin-bottom: 8px;
}
.wiz-sec-head i { color: var(--accent); font-size: 0.9rem; }
.wiz-hint { font-size: 0.78rem; color: var(--text-secondary); margin: 0 0 12px 0; line-height: 1.4; }
.wiz-empty-note {
  padding: 14px 16px; border-radius: var(--radius-xs); font-size: 0.8rem;
  color: var(--text-secondary); background: var(--bg-hover);
  display: flex; align-items: center; gap: 8px;
}
.wiz-empty-note i { font-size: 1rem; color: var(--info); }

/* Domain Grid */
.wiz-domain-grid { display: flex; flex-direction: column; gap: 6px; }
.wiz-domain-card {
  display: flex; align-items: center; gap: 12px; padding: 12px 16px;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--bg-card); cursor: pointer; transition: all 0.2s;
  text-align: left; width: 100%; color: var(--text-primary); font-family: inherit;
}
.wiz-domain-card:hover { border-color: var(--accent-glow); background: var(--bg-hover); transform: translateX(2px); }
.wiz-domain-card.selected { border-color: var(--accent); background: rgba(99,102,241,0.08); box-shadow: 0 0 12px var(--accent-glow); }
.wiz-dc-icon { width: 36px; height: 36px; border-radius: 10px; display: flex; align-items: center; justify-content: center; background: var(--accent-glow); color: var(--accent); font-size: 1rem; flex-shrink: 0; }
.wiz-domain-card.selected .wiz-dc-icon { background: var(--accent); color: #fff; }
.wiz-dc-info { flex: 1; display: flex; flex-direction: column; gap: 1px; }
.wiz-dc-name { font-size: 0.88rem; font-weight: 600; }
.wiz-dc-tag { font-size: 0.68rem; color: var(--success); display: flex; align-items: center; gap: 3px; }
.wiz-dc-tag.ready i { font-size: 0.6rem; }
.wiz-dc-check { color: var(--border); font-size: 1.1rem; transition: all 0.2s; }
.wiz-domain-card.selected .wiz-dc-check { color: var(--accent); }
.wiz-domain-card.selected .wiz-dc-check i::before { content: "\f26a"; }

/* Already enabled pills */
.wiz-already { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin: 10px 0 4px 0; }
.wiz-already-lbl { font-size: 0.7rem; color: var(--text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: 0.3px; }
.wiz-already-pill {
  display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px;
  border-radius: 20px; font-size: 0.7rem; font-weight: 600;
  background: var(--success-bg); color: var(--success); border: 1px solid var(--success-border);
}
.wiz-already-pill i { font-size: 0.65rem; }

/* Divider */
.wiz-divider {
  display: flex; align-items: center; gap: 12px; margin: 18px 0;
  color: var(--text-muted); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 1px;
}
.wiz-divider::before, .wiz-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }

/* Domain Input */
.wiz-input-wrap { position: relative; }
.wiz-domain-input { padding-right: 38px !important; font-family: 'SF Mono', 'Fira Code', monospace; font-size: 0.9rem !important; letter-spacing: 0.3px; }
.wiz-input-icon { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); font-size: 1rem; }
.wiz-domain-feedback { margin-top: 6px; min-height: 18px; }
.wiz-fb-ok { color: var(--success); font-size: 0.75rem; display: flex; align-items: center; gap: 4px; }
.wiz-fb-ok i { font-size: 0.7rem; }
.wiz-fb-err { color: var(--danger); font-size: 0.75rem; display: flex; align-items: center; gap: 4px; }
.wiz-fb-err i { font-size: 0.7rem; }

/* Step 2: Config Grid */
.wiz-config-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.wiz-cfg-card {
  padding: 16px; border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--bg-card); display: flex; flex-direction: column; gap: 6px;
}
.wiz-cfg-card label { margin: 0; font-size: 0.78rem; font-weight: 700; color: var(--text-heading); text-transform: none; letter-spacing: 0; }
.wiz-cfg-icon { color: var(--accent); font-size: 1.1rem; margin-bottom: 2px; }
.wiz-cfg-note { font-size: 0.68rem; color: var(--text-muted); margin-top: 2px; }
.wiz-cfg-card .form-control { margin-top: 2px; }

/* Toggle Switch */
.wiz-switch { position: relative; display: inline-block; width: 40px; height: 22px; cursor: pointer; margin: 4px 0 0 0; }
.wiz-switch input { opacity: 0; width: 0; height: 0; }
.wiz-switch-slider {
  position: absolute; inset: 0; background: var(--bg-tertiary); border: 1px solid var(--border);
  border-radius: 22px; transition: all 0.3s;
}
.wiz-switch-slider::before {
  content: ''; position: absolute; left: 2px; top: 2px; width: 16px; height: 16px;
  border-radius: 50%; background: var(--text-muted); transition: all 0.3s;
}
.wiz-switch input:checked + .wiz-switch-slider { background: var(--accent); border-color: var(--accent); }
.wiz-switch input:checked + .wiz-switch-slider::before { background: #fff; transform: translateX(18px); }

/* Step 3: Mailbox */
.wiz-mb-toggle { display: flex; gap: 8px; margin-bottom: 16px; }
.wiz-mb-opt {
  flex: 1; padding: 12px; border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--bg-card); cursor: pointer; text-align: center;
  font-size: 0.8rem; font-weight: 600; color: var(--text-secondary);
  transition: all 0.2s; display: flex; align-items: center; justify-content: center; gap: 6px;
  font-family: inherit;
}
.wiz-mb-opt:hover { border-color: var(--accent-glow); }
.wiz-mb-opt.active { border-color: var(--accent); background: rgba(99,102,241,0.1); color: var(--accent); }
.wiz-mb-opt i { font-size: 1rem; }
.wiz-optional-badge {
  font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 2px 8px; border-radius: 10px; background: var(--info-bg); color: var(--info);
  margin-left: 6px; vertical-align: middle;
}
.wiz-mb-form { animation: wizSlideIn 0.25s ease; }
@keyframes wizSlideIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.wiz-mb-preview {
  padding: 12px 16px; border-radius: var(--radius-sm); background: var(--accent-glow);
  border: 1px dashed var(--accent); color: var(--accent); font-size: 0.9rem;
  font-weight: 600; display: flex; align-items: center; gap: 8px;
  margin-bottom: 14px; font-family: 'SF Mono', 'Fira Code', monospace;
}
.wiz-mb-preview i { font-size: 1.1rem; }
.wiz-form-row { display: flex; gap: 12px; margin-bottom: 12px; }
.wiz-form-row.single { display: block; }
.wiz-form-field { flex: 1; }
.wiz-form-field label { display: block; font-size: 0.72rem; font-weight: 600; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.3px; margin-bottom: 4px; }
.wiz-form-field label small { text-transform: none; letter-spacing: 0; color: var(--text-muted); }
.wiz-pass-wrap { position: relative; }
.wiz-pass-wrap .form-control { padding-right: 38px; }
.wiz-pass-toggle {
  position: absolute; right: 8px; top: 50%; transform: translateY(-50%);
  background: none; border: none; color: var(--text-muted); cursor: pointer;
  padding: 2px 4px; font-size: 0.85rem; transition: color 0.2s;
}
.wiz-pass-toggle:hover { color: var(--accent); }

/* Step 4: Complete */
.wiz-complete { text-align: center; }
.wiz-done-icon { font-size: 3rem; color: var(--success); margin-bottom: 8px; animation: wizPop 0.5s cubic-bezier(0.34,1.56,0.64,1); }
@keyframes wizPop { from { opacity: 0; transform: scale(0.5); } to { opacity: 1; transform: scale(1); } }
.wiz-complete h4 { margin: 0; font-size: 1.1rem; color: var(--text-heading); }
.wiz-done-sub { font-size: 0.82rem; color: var(--text-secondary); margin: 4px 0 16px 0; }
.wiz-summary-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-bottom: 16px; }
.wiz-sum-card {
  padding: 12px 8px; border-radius: var(--radius-sm); background: var(--bg-card);
  border: 1px solid var(--border); display: flex; flex-direction: column; align-items: center; gap: 3px;
}
.wiz-sum-card i { font-size: 1.1rem; color: var(--accent); }
.wiz-sum-label { font-size: 0.62rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.3px; }
.wiz-sum-card strong { font-size: 0.82rem; color: var(--text-heading); }
.wiz-mb-created {
  padding: 10px 16px; border-radius: var(--radius-sm); background: var(--success-bg);
  border: 1px solid var(--success-border); color: var(--success);
  font-size: 0.82rem; font-weight: 600; display: flex; align-items: center; gap: 8px;
  margin-bottom: 16px; justify-content: center;
}
.wiz-mb-created i { font-size: 1rem; }

/* DNS Hint */
.wiz-dns-hint {
  text-align: left; padding: 16px; border-radius: var(--radius-sm);
  background: rgba(59,130,246,0.05); border: 1px solid var(--info-border);
}
.wiz-dns-title { font-size: 0.82rem; font-weight: 700; color: var(--info); display: flex; align-items: center; gap: 6px; margin-bottom: 6px; }
.wiz-dns-hint p { font-size: 0.76rem; color: var(--text-secondary); margin: 0 0 10px 0; }
.wiz-dns-records { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.wiz-dns-row {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  background: var(--bg-card); border-radius: var(--radius-xs); font-size: 0.76rem; color: var(--text-primary);
}
.wiz-dns-row code { font-size: 0.74rem; color: var(--accent-hover); background: rgba(99,102,241,0.08); padding: 2px 6px; border-radius: 3px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wiz-dns-type {
  display: inline-block; padding: 2px 8px; border-radius: 4px; font-size: 0.62rem;
  font-weight: 800; text-transform: uppercase; letter-spacing: 0.5px; flex-shrink: 0; min-width: 30px; text-align: center;
}
.wiz-dns-type.mx { background: var(--accent-glow); color: var(--accent); }
.wiz-dns-type.txt { background: var(--warning-bg); color: var(--warning); }
.wiz-dns-type.a { background: var(--success-bg); color: var(--success); }
.wiz-dns-pri { font-size: 0.65rem; color: var(--text-muted); margin-left: auto; flex-shrink: 0; }
.wiz-dns-detail { flex: 1; display: flex; align-items: center; gap: 6px; min-width: 0; overflow: hidden; }
.wiz-dns-host { font-size: 0.72rem; color: var(--text-secondary); flex-shrink: 0; }
.wiz-dns-arrow { color: var(--text-muted); font-size: 0.7rem; flex-shrink: 0; }
.wiz-dns-dkim { font-size: 0.62rem; max-width: 180px; }
.wiz-dns-note { font-size: 0.72rem; color: var(--text-muted); margin: 0 !important; display: flex; align-items: center; gap: 4px; }
.wiz-dns-note i { color: var(--warning); }

/* Copy Button */
.wiz-copy-btn {
  background: none; border: 1px solid var(--border); color: var(--text-muted);
  border-radius: var(--radius-xs); padding: 3px 7px; cursor: pointer;
  font-size: 0.72rem; flex-shrink: 0; transition: all 0.2s;
  display: inline-flex; align-items: center;
}
.wiz-copy-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-glow); }
.wiz-copy-btn.copied { border-color: var(--success); color: var(--success); background: var(--success-bg); }

/* Security Status */
.wiz-security-status {
  padding: 14px 16px; border-radius: var(--radius-sm);
  background: rgba(16,185,129,0.04); border: 1px solid var(--success-border);
  margin-bottom: 14px; text-align: left;
}
.wiz-sec-head2 {
  font-size: 0.82rem; font-weight: 700; color: var(--success);
  display: flex; align-items: center; gap: 6px; margin-bottom: 8px;
}
.wiz-sec-checks { display: flex; flex-direction: column; gap: 4px; }
.wiz-sec-chk {
  font-size: 0.76rem; display: flex; align-items: center; gap: 6px; padding: 2px 0;
}
.wiz-sec-chk.ok { color: var(--success); }
.wiz-sec-chk.ok i { color: var(--success); }
.wiz-sec-chk.warn { color: var(--warning); }
.wiz-sec-chk.warn i { color: var(--warning); }

/* Connect Info */
.wiz-connect-info {
  text-align: left; padding: 16px; border-radius: var(--radius-sm);
  background: rgba(99,102,241,0.04); border: 1px solid var(--border);
  margin-top: 14px;
}
.wiz-connect-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 10px; }
.wiz-conn-card {
  padding: 12px; border-radius: var(--radius-sm); background: var(--bg-card);
  border: 1px solid var(--border);
}
.wiz-conn-head {
  font-size: 0.78rem; font-weight: 700; color: var(--text-heading);
  display: flex; align-items: center; gap: 6px; margin-bottom: 8px; padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}
.wiz-conn-head i { color: var(--accent); }
.wiz-conn-row {
  display: flex; align-items: center; gap: 6px; padding: 4px 0;
  font-size: 0.76rem; color: var(--text-primary);
}
.wiz-conn-row span:first-child {
  min-width: 68px; font-size: 0.68rem; color: var(--text-muted); font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.3px;
}
.wiz-conn-row code {
  flex: 1; font-size: 0.76rem; color: var(--accent-hover);
  background: rgba(99,102,241,0.06); padding: 2px 8px; border-radius: 3px;
}
.wiz-conn-note {
  font-size: 0.74rem; color: var(--text-secondary); line-height: 1.5;
  padding: 10px 12px; border-radius: var(--radius-xs);
  background: var(--bg-hover); display: flex; gap: 6px; align-items: flex-start;
}
.wiz-conn-note i { color: var(--info); flex-shrink: 0; margin-top: 2px; }

/* DNS Verification Step */
.wiz-dns-verify-section { margin-top: 16px; }
.wiz-dns-checking {
  display: flex; align-items: center; gap: 10px; padding: 16px;
  border-radius: var(--radius-sm); background: rgba(99,102,241,0.06);
  border: 1px solid var(--accent-glow); color: var(--accent);
  font-size: 0.82rem; font-weight: 600;
}
.wiz-dns-results {
  border-radius: var(--radius-sm); border: 1px solid var(--border);
  overflow: hidden;
}
.wiz-dns-results.all-pass { border-color: var(--success-border); }
.wiz-dns-results.has-fail { border-color: var(--danger-border, rgba(239,68,68,0.2)); }
.wiz-dns-score-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; font-size: 0.82rem; font-weight: 700;
}
.all-pass .wiz-dns-score-bar { background: var(--success-bg); color: var(--success); }
.has-fail .wiz-dns-score-bar { background: rgba(239,68,68,0.08); color: var(--danger); }
.wiz-dns-score-label { display: flex; align-items: center; gap: 6px; }
.wiz-dns-score-pct {
  font-size: 1.1rem; font-weight: 800; padding: 2px 10px;
  border-radius: 20px; background: rgba(255,255,255,0.1);
}
.all-pass .wiz-dns-score-pct { background: var(--success); color: #fff; }
.has-fail .wiz-dns-score-pct { background: var(--danger); color: #fff; }
.wiz-dns-checklist { padding: 8px 12px; display: flex; flex-direction: column; gap: 4px; }
.wiz-dns-chk {
  display: flex; align-items: center; gap: 8px; padding: 6px 10px;
  border-radius: var(--radius-xs); font-size: 0.78rem; transition: background 0.15s;
}
.wiz-dns-chk:hover { background: var(--bg-hover); }
.wiz-dns-chk.pass { color: var(--success); }
.wiz-dns-chk.pass i { color: var(--success); }
.wiz-dns-chk.fail { color: var(--danger); }
.wiz-dns-chk.fail i { color: var(--danger); }
.wiz-dns-chk-name { font-weight: 600; min-width: 110px; }
.wiz-dns-chk-val {
  flex: 1; font-size: 0.72rem; color: var(--text-muted); font-family: 'SF Mono', 'Fira Code', monospace;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.wiz-dns-chk.fail .wiz-dns-chk-val { color: var(--danger); }
.wiz-dns-fail-hint {
  padding: 10px 14px; margin: 0 12px 10px; border-radius: var(--radius-xs);
  background: rgba(234,179,8,0.06); border: 1px solid var(--warning-border);
  font-size: 0.76rem; color: var(--text-secondary); line-height: 1.5;
  display: flex; gap: 8px; align-items: flex-start;
}
.wiz-dns-fail-hint i { color: var(--warning); flex-shrink: 0; margin-top: 2px; }
.wiz-dns-ready-hint {
  padding: 16px; border-radius: var(--radius-sm);
  background: rgba(99,102,241,0.04); border: 1px dashed var(--accent-glow);
  font-size: 0.82rem; color: var(--text-secondary); line-height: 1.5;
  display: flex; align-items: center; gap: 8px;
}
.wiz-dns-ready-hint i { color: var(--accent); font-size: 1.1rem; flex-shrink: 0; }

/* DNS Guide Steps */
.wiz-guide-steps { display: flex; flex-direction: column; gap: 6px; margin-top: 10px; }
.wiz-guide-step {
  display: flex; align-items: center; gap: 10px; padding: 8px 12px;
  border-radius: var(--radius-xs); background: var(--bg-hover); font-size: 0.78rem;
  color: var(--text-secondary); line-height: 1.4;
}
.wiz-guide-num {
  width: 22px; height: 22px; border-radius: 50%; background: var(--accent);
  color: #fff; font-size: 0.68rem; font-weight: 800; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}

/* DNS Guide Cards */
.wiz-dns-table-wrap { display: flex; flex-direction: column; gap: 12px; margin-bottom: 14px; }
.wiz-dns-guide-card {
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--bg-card); overflow: hidden;
}
.wiz-dg-head {
  display: flex; align-items: center; gap: 8px; padding: 10px 14px;
  border-bottom: 1px solid var(--border); background: rgba(99,102,241,0.03);
}
.wiz-dg-head strong { font-size: 0.8rem; color: var(--text-heading); flex: 1; }
.wiz-dg-badge {
  font-size: 0.58rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.5px;
  padding: 2px 8px; border-radius: 10px; flex-shrink: 0;
}
.wiz-dg-badge.required { background: var(--danger-bg, rgba(239,68,68,0.1)); color: var(--danger); }
.wiz-dg-badge.recommended { background: var(--warning-bg); color: var(--warning); }
.wiz-dg-badge.info { background: var(--info-bg); color: var(--info); }
.wiz-dg-desc {
  font-size: 0.76rem; color: var(--text-secondary); line-height: 1.5;
  padding: 10px 14px 6px; margin: 0;
}
.wiz-dg-desc code { font-size: 0.72rem; background: rgba(99,102,241,0.08); padding: 1px 5px; border-radius: 3px; color: var(--accent-hover); }
.wiz-dg-table { padding: 4px 10px 8px; }
.wiz-dg-row {
  display: grid; grid-template-columns: 120px 1fr 36px; align-items: center;
  gap: 8px; padding: 5px 6px; font-size: 0.76rem; border-radius: var(--radius-xs);
}
.wiz-dg-row:hover:not(.head) { background: var(--bg-hover); }
.wiz-dg-row.head {
  font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.4px;
  color: var(--text-muted); border-bottom: 1px solid var(--border); padding-bottom: 4px; margin-bottom: 2px;
}
.wiz-dg-row span:first-child { font-weight: 600; color: var(--text-secondary); font-size: 0.72rem; }
.wiz-dg-row code {
  font-size: 0.74rem; color: var(--accent-hover); background: rgba(99,102,241,0.06);
  padding: 2px 8px; border-radius: 3px; word-break: break-all;
}
.wiz-dg-long { font-size: 0.68rem; display: block; max-height: 3.6em; overflow-y: auto; line-height: 1.5; }
.wiz-dg-dkim { font-size: 0.6rem; max-height: 4.2em; }
.wiz-dg-tip {
  padding: 8px 14px; background: rgba(234,179,8,0.05); border-top: 1px solid var(--border);
  font-size: 0.72rem; color: var(--text-secondary); display: flex; align-items: flex-start; gap: 6px;
  line-height: 1.4;
}
.wiz-dg-tip i { color: var(--warning); flex-shrink: 0; margin-top: 1px; }
.wiz-dg-tip code { font-size: 0.68rem; background: rgba(99,102,241,0.08); padding: 1px 4px; border-radius: 2px; }
.wiz-dg-note-card { border-style: dashed; opacity: 0.85; }
.wiz-dns-type.ptr { background: rgba(139,92,246,0.1); color: #8b5cf6; }

/* Registrar Tips */
.wiz-registrar-tips {
  margin-bottom: 14px; padding: 14px; border-radius: var(--radius-sm);
  background: rgba(99,102,241,0.03); border: 1px solid var(--border);
}
.wiz-registrar-tips .wiz-sec-head { margin-bottom: 10px; }
.wiz-reg-tip-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.wiz-reg-tip {
  padding: 8px 12px; border-radius: var(--radius-xs); background: var(--bg-card);
  border: 1px solid var(--border); font-size: 0.72rem; color: var(--text-secondary); line-height: 1.5;
}
.wiz-reg-tip strong { color: var(--text-heading); }
.wiz-reg-tip code { font-size: 0.68rem; background: rgba(99,102,241,0.08); padding: 1px 4px; border-radius: 2px; }

/* Footer */
.wiz-foot { justify-content: flex-start; }

/* Responsive */
@media (max-width: 680px) {
  .wiz-modal { width: 95vw; max-width: 95vw; }
  .wiz-config-grid { grid-template-columns: 1fr; }
  .wiz-summary-cards { grid-template-columns: repeat(2, 1fr); }
  .wiz-form-row { flex-direction: column; }
  .wiz-stepper { padding: 12px 14px; }
  .wiz-step span { font-size: 0.58rem; }
  .wiz-step-icon { width: 28px; height: 28px; font-size: 0.72rem; }
  .wiz-connect-grid { grid-template-columns: 1fr; }
  .wiz-reg-tip-grid { grid-template-columns: 1fr; }
  .wiz-dg-row { grid-template-columns: 90px 1fr 32px; }
}

/* â”€â”€ Password Strength â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.password-strength { margin-top: 6px; }

/* â”€â”€ Search Input â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-search {
  padding: 6px 12px 6px 32px; border: 1px solid var(--border);
  background: var(--bg-input); color: var(--text-primary);
  border-radius: var(--radius-xs); font-size: 0.8rem; width: 180px;
  transition: border-color 0.2s, box-shadow 0.2s;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 16 16'%3E%3Cpath fill='%235c6380' d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85zm-5.242.656a5 5 0 1 1 0-10 5 5 0 0 1 0 10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: 10px center;
}
.em-search:focus { border-color: var(--accent); outline: none; box-shadow: 0 0 0 3px var(--accent-glow); }

/* â”€â”€ Log Table â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.em-log-filters {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.em-log-filters select, .em-log-filters input[type="date"] {
  padding: 6px 10px; border: 1px solid var(--border); background: var(--bg-input);
  color: var(--text-primary); border-radius: var(--radius-xs); font-size: 0.8rem;
  cursor: pointer;
}
.em-log-filters select:focus, .em-log-filters input[type="date"]:focus {
  border-color: var(--accent); outline: none;
}
.em-log-badge {
  display: inline-block; padding: 2px 8px; border-radius: 4px;
  font-size: 0.68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.3px;
}
.em-log-badge.sent { background: var(--success-bg); color: var(--success); }
.em-log-badge.bounced { background: var(--danger-bg); color: var(--danger); }
.em-log-badge.deferred { background: var(--warning-bg); color: var(--warning); }
.em-log-badge.rejected { background: var(--danger-bg); color: var(--danger); }
.em-log-badge.connect { background: var(--info-bg); color: var(--info); }
.em-log-badge.info { background: rgba(92,99,128,0.12); color: var(--text-muted); }

/* ── Next-Gen Logs & Queue ──────────────────────────────────── */

/* AI Health Dashboard */
.eml-health-dashboard {
  display: grid; grid-template-columns: auto 1fr auto; gap: 24px; align-items: center;
  padding: 20px 24px; margin-bottom: 16px; border-radius: 16px;
  background: linear-gradient(135deg, rgba(99,102,241,0.06) 0%, rgba(139,92,246,0.04) 50%, rgba(16,185,129,0.04) 100%);
  border: 1px solid rgba(99,102,241,0.12);
  animation: emlFadeIn 0.4s ease;
}
@keyframes emlFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

.eml-health-score { position: relative; width: 90px; height: 90px; flex-shrink: 0; }
.eml-health-ring { width: 90px; height: 90px; transform: rotate(-90deg); }
.eml-health-arc { transition: stroke-dasharray 1.2s cubic-bezier(0.4, 0, 0.2, 1); }
.eml-health-center {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); text-align: center;
}
.eml-health-pct { font-size: 1.4rem; font-weight: 800; line-height: 1; }
.eml-health-label { font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; margin-top: 2px; }

.eml-health-info { min-width: 0; }
.eml-health-info h5 {
  margin: 0 0 10px; font-size: 0.92rem; font-weight: 700; color: var(--text-heading);
  display: flex; align-items: center; gap: 8px;
}
.eml-health-info h5 i { color: var(--accent); }
.eml-health-stats { display: flex; gap: 20px; margin-bottom: 10px; }
.eml-hstat { display: flex; flex-direction: column; }
.eml-hstat-val { font-size: 1.3rem; font-weight: 800; line-height: 1; }
.eml-hstat-lbl { font-size: 0.62rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.3px; margin-top: 2px; }

.eml-sparkline-wrap { display: flex; align-items: center; gap: 8px; }
.eml-sparkline-label { font-size: 0.62rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.3px; white-space: nowrap; }
.eml-sparkline { width: 160px; height: 32px; }

.eml-health-issues { display: flex; flex-direction: column; gap: 6px; max-width: 340px; }
.eml-issue-item {
  display: flex; align-items: flex-start; gap: 8px; font-size: 0.72rem; color: var(--text-secondary);
  line-height: 1.4; padding: 6px 10px; border-radius: 8px; background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.04); animation: emlFadeIn 0.5s ease both;
}
.eml-issue-item i { flex-shrink: 0; margin-top: 1px; font-size: 0.8rem; }

/* Section Headers */
.eml-section-header {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  margin-bottom: 14px; flex-wrap: wrap;
}
.eml-section-title {
  display: flex; align-items: center; gap: 8px; font-size: 0.95rem; font-weight: 700; color: var(--text-heading);
}
.eml-section-title i { color: var(--accent); font-size: 1.05em; }
.eml-section-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.eml-count-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 22px; height: 22px; padding: 0 7px; border-radius: 12px;
  font-size: 0.68rem; font-weight: 800; background: rgba(99,102,241,0.1); color: var(--accent);
  transition: all 0.3s;
}
.eml-count-badge.has-items { background: rgba(245,158,11,0.15); color: #f59e0b; }

/* Queue Action Buttons */
.eml-action-btn {
  display: inline-flex; align-items: center; gap: 5px; padding: 6px 14px;
  border-radius: 8px; font-size: 0.76rem; font-weight: 600; cursor: pointer;
  border: 1px solid var(--border); background: rgba(255,255,255,0.03);
  color: var(--text-primary); transition: all 0.2s;
}
.eml-action-btn:hover { transform: translateY(-1px); }
.eml-action-btn.flush { border-color: rgba(99,102,241,0.25); color: var(--accent); }
.eml-action-btn.flush:hover { background: rgba(99,102,241,0.08); border-color: var(--accent); }
.eml-action-btn.danger { border-color: rgba(239,68,68,0.25); color: #ef4444; }
.eml-action-btn.danger:hover { background: rgba(239,68,68,0.08); border-color: #ef4444; }

/* Queue Cards Grid */
.eml-queue-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 12px;
}
.eml-queue-card {
  border-radius: 12px; border: 1px solid var(--border); background: var(--bg-card);
  overflow: hidden; transition: all 0.25s; animation: emlFadeIn 0.4s ease both;
}
.eml-queue-card:hover { border-color: var(--border-light); transform: translateY(-2px); box-shadow: 0 4px 20px rgba(0,0,0,0.1); }
.eml-queue-card.active { border-left: 3px solid #10b981; }
.eml-queue-card.hold { border-left: 3px solid #f59e0b; }
.eml-queue-card.pending { border-left: 3px solid var(--accent); }

.eml-qc-header {
  display: flex; align-items: center; gap: 8px; padding: 10px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.eml-qc-status {
  display: inline-flex; align-items: center; gap: 4px; padding: 3px 10px;
  border-radius: 20px; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px;
}
.eml-qc-status.active { background: rgba(16,185,129,0.12); color: #10b981; }
.eml-qc-status.hold { background: rgba(245,158,11,0.12); color: #f59e0b; }
.eml-qc-status.pending { background: rgba(99,102,241,0.1); color: var(--accent); }
.eml-qc-id { font-size: 0.65rem; color: var(--text-muted); margin-left: auto; background: rgba(255,255,255,0.03); padding: 2px 8px; border-radius: 4px; }
.eml-qc-size { font-size: 0.7rem; font-weight: 600; color: var(--text-secondary); }

.eml-qc-body { padding: 10px 14px; }
.eml-qc-flow { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.eml-qc-addr {
  display: flex; align-items: center; gap: 5px; font-size: 0.76rem; color: var(--text-primary);
  min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.eml-qc-addr i { color: var(--text-muted); font-size: 0.8rem; flex-shrink: 0; }
.eml-qc-arrow { color: var(--accent); font-size: 0.7rem; flex-shrink: 0; opacity: 0.5; }
.eml-qc-reason {
  display: flex; align-items: flex-start; gap: 6px; margin-top: 8px; padding: 8px 10px;
  border-radius: 6px; background: rgba(239,68,68,0.04); border: 1px solid rgba(239,68,68,0.08);
  font-size: 0.7rem; color: var(--text-muted); line-height: 1.4;
}
.eml-qc-reason i { color: #f59e0b; flex-shrink: 0; margin-top: 1px; }

.eml-qc-footer {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 14px; border-top: 1px solid rgba(255,255,255,0.04);
}
.eml-qc-time { display: flex; align-items: center; gap: 5px; font-size: 0.68rem; color: var(--text-muted); }
.eml-qc-actions { display: flex; gap: 4px; }
.eml-qc-btn {
  width: 28px; height: 28px; border-radius: 6px; border: 1px solid var(--border);
  background: transparent; color: var(--text-muted); cursor: pointer;
  display: flex; align-items: center; justify-content: center; font-size: 0.78rem;
  transition: all 0.2s;
}
.eml-qc-btn:hover { transform: scale(1.1); }
.eml-qc-btn.view:hover { color: var(--accent); border-color: var(--accent); background: rgba(99,102,241,0.08); }
.eml-qc-btn.retry:hover { color: #10b981; border-color: #10b981; background: rgba(16,185,129,0.08); }
.eml-qc-btn.release:hover { color: #10b981; border-color: #10b981; background: rgba(16,185,129,0.08); }
.eml-qc-btn.hold:hover { color: #f59e0b; border-color: #f59e0b; background: rgba(245,158,11,0.08); }
.eml-qc-btn.delete:hover { color: #ef4444; border-color: #ef4444; background: rgba(239,68,68,0.08); }

/* Empty Queue State */
.eml-empty-queue {
  display: flex; align-items: center; gap: 14px; padding: 20px;
  border-radius: 10px; background: rgba(16,185,129,0.04);
  border: 1px dashed rgba(16,185,129,0.2); margin-top: 4px;
}
.eml-empty-queue > i { font-size: 1.6rem; color: #10b981; flex-shrink: 0; }
.eml-empty-queue strong { font-size: 0.85rem; color: var(--text-heading); display: block; }
.eml-empty-queue span { font-size: 0.75rem; color: var(--text-muted); }

/* Status Chip Filters */
.eml-log-controls { margin-bottom: 14px; display: flex; flex-direction: column; gap: 10px; }
.eml-status-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.eml-chip {
  display: inline-flex; align-items: center; gap: 6px; padding: 6px 14px;
  border-radius: 20px; border: 1px solid var(--border); background: rgba(255,255,255,0.02);
  font-size: 0.74rem; font-weight: 600; color: var(--text-secondary); cursor: pointer;
  transition: all 0.2s; font-family: inherit;
}
.eml-chip:hover { border-color: var(--border-light); background: rgba(255,255,255,0.05); }
.eml-chip.active { background: rgba(99,102,241,0.1); border-color: rgba(99,102,241,0.3); color: var(--accent); }
.eml-chip-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.eml-chip-dot.all { background: linear-gradient(135deg, #6366f1, #8b5cf6); }
.eml-chip-dot.sent { background: #10b981; }
.eml-chip-dot.bounced { background: #ef4444; }
.eml-chip-dot.deferred { background: #f59e0b; }
.eml-chip-dot.rejected { background: #8b5cf6; }
.eml-chip-count {
  padding: 1px 7px; border-radius: 10px; font-size: 0.62rem; font-weight: 800;
  background: rgba(255,255,255,0.06); min-width: 18px; text-align: center;
}

/* Log Search Bar */
.eml-log-search-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.eml-search-wrap {
  position: relative; flex: 1; min-width: 200px;
}
.eml-search-wrap > i {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  font-size: 0.82rem; color: var(--text-muted); pointer-events: none;
}
.eml-search-wrap input {
  width: 100%; padding: 8px 14px 8px 34px; border: 1px solid var(--border);
  background: var(--bg-input); color: var(--text-primary); border-radius: 10px;
  font-size: 0.8rem; transition: all 0.2s;
}
.eml-search-wrap input:focus { border-color: var(--accent); outline: none; box-shadow: 0 0 0 3px var(--accent-glow); }

.eml-date-range { display: flex; align-items: center; gap: 6px; }
.eml-date-range input[type="date"] {
  padding: 7px 10px; border: 1px solid var(--border); background: var(--bg-input);
  color: var(--text-primary); border-radius: 8px; font-size: 0.78rem;
}
.eml-date-range input[type="date"]:focus { border-color: var(--accent); outline: none; }
.eml-date-sep { color: var(--text-muted); font-size: 0.85rem; }

/* Log List */
.eml-log-list { display: flex; flex-direction: column; gap: 2px; }
.eml-log-row {
  border-radius: 8px; border: 1px solid transparent; background: rgba(255,255,255,0.01);
  transition: all 0.2s; cursor: pointer; overflow: hidden;
}
.eml-log-row:hover { background: var(--bg-hover); border-color: rgba(255,255,255,0.04); }
.eml-log-row.expanded { background: var(--bg-card); border-color: var(--border); }

.eml-log-main {
  display: grid; grid-template-columns: 24px minmax(100px,140px) minmax(80px,1fr) 16px minmax(80px,1fr) 70px 50px 20px;
  align-items: center; gap: 8px; padding: 8px 12px; font-size: 0.78rem;
}
.eml-log-status { display: flex; align-items: center; justify-content: center; }
.eml-log-status.sent i { color: #10b981; }
.eml-log-status.bounced i { color: #ef4444; }
.eml-log-status.deferred i { color: #f59e0b; }
.eml-log-status.rejected i { color: #8b5cf6; }
.eml-log-status.connect i { color: #3b82f6; }
.eml-log-status.info i { color: var(--text-muted); }

.eml-log-time { font-size: 0.7rem; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.eml-log-from, .eml-log-to {
  font-size: 0.75rem; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.eml-log-arrow { color: var(--text-muted); font-size: 0.6rem; opacity: 0.4; }
.eml-log-badge {
  display: inline-block; padding: 2px 8px; border-radius: 4px;
  font-size: 0.62rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.3px; text-align: center;
}
.eml-log-badge.sent { background: rgba(16,185,129,0.12); color: #10b981; }
.eml-log-badge.bounced { background: rgba(239,68,68,0.12); color: #ef4444; }
.eml-log-badge.deferred { background: rgba(245,158,11,0.12); color: #f59e0b; }
.eml-log-badge.rejected { background: rgba(139,92,246,0.12); color: #8b5cf6; }
.eml-log-badge.connect { background: rgba(59,130,246,0.12); color: #3b82f6; }
.eml-log-badge.info { background: rgba(100,116,139,0.12); color: #64748b; }
.eml-log-size { font-size: 0.68rem; color: var(--text-muted); text-align: right; }
.eml-log-expand-icon {
  font-size: 0.65rem; color: var(--text-muted); transition: transform 0.3s; opacity: 0.4;
}
.eml-log-row.expanded .eml-log-expand-icon { transform: rotate(180deg); opacity: 1; color: var(--accent); }

/* Expandable Log Detail */
.eml-log-detail {
  max-height: 0; overflow: hidden; transition: max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1), padding 0.2s;
  padding: 0 14px;
}
.eml-log-row.expanded .eml-log-detail { max-height: 200px; padding: 10px 14px 14px; }

.eml-log-ai-hint {
  display: flex; align-items: flex-start; gap: 8px; padding: 10px 14px;
  border-radius: 8px; background: linear-gradient(135deg, rgba(99,102,241,0.06), rgba(139,92,246,0.04));
  border: 1px solid rgba(99,102,241,0.1); margin-bottom: 8px;
  font-size: 0.75rem; color: var(--text-secondary); line-height: 1.5;
}
.eml-log-ai-hint i { color: var(--accent); font-size: 0.85rem; flex-shrink: 0; margin-top: 1px; }

.eml-log-raw { }
.eml-log-raw-label {
  display: inline-block; font-size: 0.6rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text-muted); margin-bottom: 4px;
}
.eml-log-raw code {
  display: block; padding: 8px 12px; border-radius: 6px; background: rgba(0,0,0,0.15);
  font-size: 0.68rem; color: var(--text-muted); line-height: 1.5; word-break: break-all;
  max-height: 60px; overflow-y: auto;
}

/* Pagination */
.eml-pagination {
  display: flex; align-items: center; justify-content: center; gap: 4px;
  margin-top: 16px; padding: 8px 0;
}
.eml-page-btn {
  min-width: 32px; height: 32px; border-radius: 8px; border: 1px solid var(--border);
  background: transparent; color: var(--text-secondary); font-size: 0.78rem; font-weight: 600;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all 0.2s; font-family: inherit;
}
.eml-page-btn:hover:not(:disabled) { border-color: var(--accent); color: var(--accent); background: rgba(99,102,241,0.06); }
.eml-page-btn.active { background: var(--accent); color: #fff; border-color: var(--accent); }
.eml-page-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.eml-page-dots { color: var(--text-muted); font-size: 0.85rem; padding: 0 4px; }

/* Empty Logs State */
.eml-empty-logs {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 40px 20px; gap: 6px; text-align: center;
}
.eml-empty-logs > i { font-size: 2rem; color: var(--text-muted); opacity: 0.3; margin-bottom: 4px; }
.eml-empty-logs strong { font-size: 0.9rem; color: var(--text-heading); }
.eml-empty-logs span { font-size: 0.78rem; color: var(--text-muted); }

/* Responsive */
@media (max-width: 900px) {
  .eml-health-dashboard { grid-template-columns: 1fr; gap: 16px; }
  .eml-health-score { margin: 0 auto; }
  .eml-health-issues { max-width: none; }
  .eml-queue-grid { grid-template-columns: 1fr; }
  .eml-log-main { grid-template-columns: 24px 90px 1fr 16px 1fr 60px 20px; }
  .eml-log-size { display: none; }
}
@media (max-width: 600px) {
  .eml-log-main { grid-template-columns: 24px 1fr 60px 20px; }
  .eml-log-time, .eml-log-from, .eml-log-arrow { display: none; }
  .eml-status-chips { gap: 4px; }
  .eml-chip { padding: 5px 10px; font-size: 0.68rem; }
  .eml-health-stats { gap: 12px; }
  .eml-hstat-val { font-size: 1rem; }
}

/* â”€â”€ Button xs â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn-xs { padding: 2px 6px; font-size: 0.72rem; line-height: 1.5; }

/* â”€â”€ Progress bars small â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.progress-sm { height: 6px; }

/* ── SSL Section ─────────────────────────────────────────────── */
.em-ssl-actions { display: flex; gap: 8px; flex-wrap: wrap; }

/* ── Templates Tab ───────────────────────────────────────────── */
.em-templates-wrap { padding: 4px 2px; }
.em-tpl-header { margin-bottom: 18px; }
.em-tpl-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 18px; }
.em-tpl-card { background: var(--card-bg, #fff); border: 1px solid var(--border-color, #e5e7eb); border-radius: 14px; overflow: hidden; box-shadow: 0 1px 3px rgba(15,23,42,.04); }
.em-tpl-card-head { padding: 14px 18px; font-weight: 700; font-size: 14px; background: linear-gradient(135deg, rgba(79,70,229,.06), rgba(219,39,119,.04)); border-bottom: 1px solid var(--border-color, #e5e7eb); display: flex; align-items: center; gap: 8px; }
.em-tpl-card-head i { color: #6366f1; }
.em-tpl-list { padding: 12px; display: flex; flex-direction: column; gap: 10px; }
.em-tpl-item { display: grid; grid-template-columns: 88px 1fr auto; gap: 14px; align-items: center; padding: 12px; border: 1px solid var(--border-color, #e5e7eb); border-radius: 12px; background: var(--input-bg, #fafbff); transition: all .15s; }
.em-tpl-item:hover { border-color: #6366f1; box-shadow: 0 4px 12px rgba(79,70,229,.08); }
.em-tpl-item.is-builtin { background: linear-gradient(135deg, rgba(79,70,229,.04), rgba(219,39,119,.03)); }
.em-tpl-preview { width: 88px; height: 62px; border-radius: 8px; overflow: hidden; background: #fff; border: 1px solid rgba(99,102,241,.18); box-shadow: 0 2px 6px rgba(15,23,42,.06); position: relative; }
.em-tpl-preview-hero { height: 28px; background: linear-gradient(135deg, #4f46e5 0%, #7c3aed 50%, #db2777 100%); }
.em-tpl-preview-body { padding: 5px 6px; display: flex; flex-direction: column; gap: 3px; }
.em-tpl-preview-body div { height: 3px; border-radius: 2px; background: #e2e8f0; }
.em-tpl-preview-body div:first-child { width: 85%; }
.em-tpl-preview-body div:nth-child(2) { width: 70%; }
.em-tpl-meta { min-width: 0; }
.em-tpl-name { font-weight: 700; font-size: 14px; color: var(--text-color, #0f172a); display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.em-tpl-badge { font-size: 10px; padding: 2px 7px; border-radius: 999px; background: linear-gradient(90deg,#4f46e5,#db2777); color: #fff; font-weight: 700; letter-spacing: .3px; }
.em-tpl-desc { font-size: 12.5px; color: var(--text-muted, #64748b); margin-top: 3px; line-height: 1.4; }
.em-tpl-mailboxes { padding: 10px; display: flex; flex-direction: column; gap: 8px; max-height: 600px; overflow-y: auto; }
.em-tpl-mb { display: grid; grid-template-columns: 52px 1fr auto; gap: 12px; align-items: center; padding: 10px 12px; border: 1px solid var(--border-color, #e5e7eb); border-radius: 10px; background: var(--input-bg, #fafbff); }
.em-tpl-mb-logo { width: 48px; height: 48px; border-radius: 10px; background: #fff; border: 1px solid rgba(99,102,241,.18); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.em-tpl-mb-logo img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; }
.em-tpl-mb-logo span { font-size: 18px; font-weight: 700; color: #6366f1; }
.em-tpl-mb-info { min-width: 0; }
.em-tpl-mb-email { font-weight: 600; font-size: 13.5px; color: var(--text-color, #0f172a); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.em-tpl-mb-brand { font-size: 12px; color: var(--text-muted, #64748b); margin-top: 3px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.em-tpl-chip { display: inline-block; padding: 2px 8px; border-radius: 999px; background: rgba(99,102,241,.1); color: #4338ca; font-size: 11px; font-weight: 600; letter-spacing: .2px; }
.em-tpl-chip.default { background: rgba(100,116,139,.1); color: #64748b; }
.em-empty-inline { padding: 28px 20px; text-align: center; color: var(--text-muted, #64748b); font-size: 13px; }

/* Logo upload widget in branding modal */
.em-logo-upload { display: grid; grid-template-columns: 120px 1fr; gap: 18px; align-items: start; }
.em-logo-preview { width: 120px; height: 120px; border-radius: 14px; background: linear-gradient(135deg, #f1f5f9, #e0e7ff); border: 2px dashed rgba(99,102,241,.3); display: flex; align-items: center; justify-content: center; overflow: hidden; text-align: center; }
.em-logo-preview img { max-width: 104px; max-height: 104px; width: auto; height: auto; object-fit: contain; }
.em-logo-empty { font-size: 11px; color: #94a3b8; }
.em-logo-empty i { font-size: 28px; display: block; margin-bottom: 4px; color: #cbd5e1; }
.em-logo-actions { display: flex; flex-direction: column; gap: 8px; }
.em-logo-hint { font-size: 11.5px; color: var(--text-muted, #64748b); line-height: 1.5; margin-top: 4px; }

/* ── Responsive ──────────────────────────────────────────────── */
@media (max-width: 1100px) {
  .email-stats-grid { grid-template-columns: repeat(3, 1fr); }
  .em-connect-grid { grid-template-columns: 1fr; }
  .em-tpl-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .email-tabs { flex-wrap: wrap; }
  .email-tab { padding: 7px 12px; font-size: 0.75rem; }
  .email-tab i { display: none; }
  .email-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .em-connect-grid { grid-template-columns: 1fr; }
  .em-hostname { display: none; }
  .em-logo-upload { grid-template-columns: 1fr; }
  .em-logo-preview { width: 100%; max-width: 160px; margin: 0 auto; }
  .em-tpl-item { grid-template-columns: 72px 1fr; }
  .em-tpl-item button { grid-column: 1 / -1; justify-self: end; }
  .em-tpl-mb { grid-template-columns: 44px 1fr; }
  .em-tpl-mb button { grid-column: 1 / -1; justify-self: stretch; }
  .email-overview-actions { flex-wrap: wrap; }
  .em-modal { width: 95vw; }
}
.clp-hist-auto { background: rgba(99,102,241,0.12); color: var(--accent); }
.clp-hist-all { background: rgba(239,68,68,0.12); color: #ef4444; }
.clp-hist-manual { background: rgba(16,185,129,0.12); color: #10b981; }
.clp-hist-detail { flex: 1; color: var(--text-secondary); }
.clp-hist-time { font-size: 0.75rem; color: var(--text-muted); flex-shrink: 0; }

/* â”€â”€ Largest Files â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.clp-largest { margin-bottom: 24px; background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.clp-largest-header { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px; border-bottom: 1px solid var(--border); }
.clp-largest-header h3 { margin: 0; font-size: 1rem; font-weight: 600; color: var(--text-heading); display: flex; align-items: center; gap: 10px; }
.clp-largest-list { padding: 0; max-height: 480px; overflow-y: auto; }
.clp-largest-item { display: flex; align-items: center; gap: 14px; padding: 10px 24px; border-bottom: 1px solid rgba(99,102,241,0.04); }
.clp-largest-item:last-child { border-bottom: none; }
.clp-largest-rank { font-size: 0.75rem; font-weight: 700; color: var(--text-muted); min-width: 28px; }
.clp-largest-info { flex: 1; min-width: 0; }
.clp-largest-path { font-size: 0.78rem; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-family: 'JetBrains Mono', monospace; }
.clp-largest-bar { height: 4px; background: rgba(99,102,241,0.08); border-radius: 2px; margin-top: 6px; overflow: hidden; }
.clp-largest-bar-fill { height: 100%; background: var(--accent); border-radius: 2px; transition: width 0.3s; }
.clp-largest-size { font-size: 0.85rem; font-weight: 600; color: var(--accent); white-space: nowrap; min-width: 80px; text-align: right; }

/* â”€â”€ Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 768px) {
  .clp-hero { padding: 20px; gap: 20px; flex-direction: column; align-items: center; text-align: center; }
  .clp-hero-left { flex-direction: column; }
  .clp-hero-stats { justify-content: center; flex-wrap: wrap; gap: 16px; }
  .clp-hero-actions { justify-content: center; }
  .clp-hero-trend { min-width: unset; width: 100%; }
  .clp-cat-header { padding: 12px 14px; }
  .clp-item { padding: 10px 14px; flex-wrap: wrap; }
  .clp-cat-actions .btn-sm { display: none; }
  .clp-sched-row { flex-direction: column; gap: 6px; }
  .clp-bottom-grid { grid-template-columns: 1fr; }
  .clp-largest-item { padding: 8px 16px; }
}

/* â”€â”€ Server Tools â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-server-tools { display: flex; flex-direction: column; gap: 1.5rem; }
.db-st-section h4 {
  font-size: 0.92rem; font-weight: 600; color: var(--text-heading);
  margin: 0 0 0.75rem; display: flex; align-items: center; gap: 8px;
}

/* â”€â”€ Create Table columns â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-ct-col-row {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 6px; flex-wrap: wrap;
}
.db-ct-col-row input[type="text"] { width: 160px; padding: 0.45rem 0.7rem; font-size: 0.82rem; }
.db-ct-col-row select { width: 150px; padding: 0.45rem 0.7rem; font-size: 0.82rem; }
.db-ct-check {
  display: flex; align-items: center; gap: 4px;
  font-size: 0.72rem; font-weight: 600; color: var(--text-muted);
  cursor: pointer; white-space: nowrap;
}
.db-ct-check input[type="checkbox"] { width: auto; accent-color: var(--accent); }

/* â”€â”€ Table Summary Bar â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-table-summary {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  padding: 0.6rem 1rem; margin-bottom: 0.75rem;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius-sm); font-size: 0.78rem; color: var(--text-muted);
}
.db-ts-item {
  display: flex; align-items: center; gap: 5px; white-space: nowrap;
}
.db-ts-item i { font-size: 0.7rem; opacity: 0.6; }
.db-ts-item strong { color: var(--text-primary); font-weight: 600; }

/* â”€â”€ Connection String Copy â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-conn-item-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 0.4rem;
}
.db-conn-item-header label { margin: 0; }
.db-copy-btn {
  background: rgba(99,102,241,0.08); border: 1px solid var(--border);
  border-radius: var(--radius-xs); padding: 3px 10px;
  color: var(--accent); font-size: 0.72rem; cursor: pointer;
  display: flex; align-items: center; gap: 4px;
  transition: all var(--duration) var(--ease);
}
.db-copy-btn:hover { background: rgba(99,102,241,0.15); border-color: var(--accent); }

/* â”€â”€ Custom Column Type Input â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.db-mc-custom-type {
  width: 100%; padding: 0.5rem 0.8rem; margin-top: 0.4rem;
  font-size: 0.85rem; font-family: 'JetBrains Mono', 'Fira Code', monospace;
  background: var(--bg-primary); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text-primary);
}
.db-mc-custom-type:focus {
  border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow);
}

/* â”€â”€ Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 768px) {
  .db-card-grid { grid-template-columns: 1fr; }
  .db-server-bar { flex-direction: column; align-items: flex-start; }
  .db-server-metrics { justify-content: flex-start; }
  .db-detail-header { flex-direction: column; }
  .db-tabs { overflow-x: auto; }
  .db-user-grid { grid-template-columns: 1fr; }
  .db-perf-grid { grid-template-columns: 1fr 1fr; }
  .db-section-bar { flex-direction: column; align-items: flex-start; }
  .db-browser-header { flex-direction: column; align-items: flex-start; }
  .db-search-box input { width: 100%; }
  .db-table-summary { gap: 0.5rem; padding: 0.5rem 0.8rem; }
}
.sec-tabs-bar::-webkit-scrollbar { display:none }
.sec-tab {
  padding:.6rem 1.2rem;font-size:.82rem;font-weight:500;color:var(--text-secondary);
  background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;
  white-space:nowrap;transition:all .2s var(--ease);position:relative;
}
.sec-tab:hover { color:var(--text-primary);background:rgba(99,102,241,.04) }
.sec-tab.active { color:var(--primary);border-bottom-color:var(--primary);font-weight:600 }
.sec-tab-panel { animation:fadeIn .3s var(--ease) both }

/* Overview info cards */
.sec-overview-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;margin-bottom:1.2rem }
.sec-info-card {
  display:flex;align-items:center;gap:.8rem;padding:1rem 1.1rem;
  background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);
  transition:all .25s var(--ease);animation:slideUp .35s var(--ease) both;
}
.sec-info-card:hover { border-color:var(--border-light);transform:translateY(-1px) }
.sec-info-icon { width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:rgba(99,102,241,.08);border-radius:10px;flex-shrink:0 }
.sec-info-val { font-size:1.1rem;font-weight:700;line-height:1.2 }
.sec-info-label { font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px }

/* Timeline chart */
.sec-tl-chart { display:flex;align-items:flex-end;gap:2px;height:80px;padding:.5rem 0 }
.sec-tl-chart-lg { height:120px;padding:.8rem .3rem .3rem }
.sec-tl-bar-wrap { flex:1;display:flex;flex-direction:column;align-items:center;height:100% }
.sec-tl-bar { width:100%;min-width:4px;border-radius:3px 3px 0 0;margin-top:auto;transition:height .5s var(--ease) }
.sec-tl-bar-stacked { width:100%;min-width:4px;border-radius:3px 3px 0 0;margin-top:auto;display:flex;flex-direction:column-reverse;overflow:hidden }
.sec-tl-bar-stacked > div { width:100% }
.sec-tl-hour { font-size:.5rem;color:var(--text-muted);margin-top:2px }
.sec-tl-summary { display:flex;gap:1.5rem;justify-content:center;padding-top:.6rem }
.sec-tl-stat { display:flex;flex-direction:column;align-items:center }
.sec-tl-stat-val { font-size:1.4rem;font-weight:700;line-height:1 }
.sec-tl-stat-lbl { font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-top:.15rem }
.sec-tl-legend { display:flex;gap:1rem;justify-content:center;padding:.5rem 0;font-size:.68rem }
.sec-tl-legend-item { display:flex;align-items:center;gap:.3rem;color:var(--text-secondary) }
.sec-tl-dot { width:8px;height:8px;border-radius:2px;flex-shrink:0 }

/* Score bars */
.sec-score-bars { display:flex;flex-direction:column;gap:.5rem;padding:.5rem .8rem }
.sec-score-row { display:flex;align-items:center;gap:.6rem }
.sec-score-domain { font-size:.72rem;font-weight:600;min-width:0;flex:0 0 120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary) }
.sec-score-bar-bg { flex:1;height:12px;background:rgba(255,255,255,.04);border-radius:6px;overflow:hidden }
.sec-score-bar-fill { height:100%;border-radius:6px;transition:width .6s var(--ease) }
.sec-score-pct { font-size:.75rem;font-weight:700;min-width:36px;text-align:right }

/* Quick actions */
.sec-quick-actions { display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.6rem;padding:.8rem }
.sec-action-btn {
  display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1rem;
  border:1px solid var(--border);border-radius:var(--radius);background:rgba(255,255,255,.03);
  color:var(--text-primary);font-size:.8rem;font-weight:600;cursor:pointer;
  transition:all .2s var(--ease);
}
.sec-action-btn:hover { transform:translateY(-1px);border-color:var(--border-light) }
.sec-action-btn.primary { border-color:rgba(99,102,241,.3);color:#818cf8 }
.sec-action-btn.primary:hover { background:rgba(99,102,241,.08) }
.sec-action-btn.success { border-color:rgba(34,197,94,.3);color:#22c55e }
.sec-action-btn.success:hover { background:rgba(34,197,94,.08) }
.sec-action-btn.danger { border-color:rgba(239,68,68,.3);color:#ef4444 }
.sec-action-btn.danger:hover { background:rgba(239,68,68,.08) }
.sec-action-btn.warning { border-color:rgba(245,158,11,.3);color:#f59e0b }
.sec-action-btn.warning:hover { background:rgba(245,158,11,.08) }
.sec-action-btn.secondary { border-color:rgba(148,163,184,.2);color:var(--text-secondary) }
.sec-action-btn.secondary:hover { background:rgba(148,163,184,.06) }

/* Attack analysis */
.sec-analysis-content { min-height:100px }
.sec-analysis-grid { display:grid;gap:1.2rem }
.sec-analysis-section { padding:.6rem 0 }
.sec-analysis-title { font-size:.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;margin-bottom:.6rem }

.sec-intel-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem }
.sec-intel-card { display:flex;flex-direction:column;align-items:center;padding:.6rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:8px }
.sec-intel-val { font-size:1.2rem;font-weight:700;line-height:1.2 }
.sec-intel-lbl { font-size:.58rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-top:.1rem;text-align:center }

.sec-endpoints-list { display:grid;gap:.3rem }
.sec-endpoint-row { display:flex;align-items:center;gap:.5rem;font-size:.72rem }
.sec-endpoint-path { flex:0 0 200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-secondary) }
.sec-endpoint-bar-bg { flex:1;height:10px;background:rgba(239,68,68,.06);border-radius:4px;overflow:hidden }
.sec-endpoint-bar { height:100%;background:rgba(239,68,68,.45);border-radius:4px;transition:width .4s var(--ease) }
.sec-endpoint-count { min-width:40px;text-align:right;font-weight:600;color:var(--danger) }

.sec-offenders-list { display:grid;gap:.25rem }
.sec-offender-row { display:flex;align-items:center;gap:.5rem;padding:.3rem .5rem;background:rgba(239,68,68,.04);border-radius:6px;font-size:.75rem }
.sec-offender-count { color:var(--text-secondary);flex:1 }

.sec-ua-list { display:grid;gap:.2rem }
.sec-ua-row { display:flex;align-items:center;gap:.5rem;font-size:.7rem;padding:.25rem .4rem;background:rgba(0,0,0,.1);border-radius:4px }
.sec-ua-count { font-weight:700;color:var(--text-secondary);min-width:30px }
.sec-ua-text { flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-muted) }

.sec-rt-grid { display:grid;grid-template-columns:repeat(5,1fr);gap:.4rem }
.sec-rt-card { display:flex;flex-direction:column;align-items:center;padding:.5rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06);border-radius:6px }
.sec-rt-val { font-size:1rem;font-weight:700 }
.sec-rt-lbl { font-size:.55rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px }

/* Activity graph */
.sec-activity-grid { display:flex;align-items:flex-end;gap:3px;height:80px;padding:.3rem }
.sec-activity-col { flex:1;display:flex;flex-direction:column;align-items:center;height:100% }
.sec-activity-bar { width:100%;min-width:6px;margin-top:auto;background:linear-gradient(180deg,rgba(99,102,241,.6),rgba(139,92,246,.3));border-radius:3px 3px 0 0;transition:height .4s var(--ease) }
.sec-activity-date { font-size:.48rem;color:var(--text-muted);margin-top:2px;white-space:nowrap }
.sec-activity-legend { display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;padding:.5rem 0 }

/* Server health */
.sec-server-grid { display:grid;grid-template-columns:repeat(2,1fr);gap:1rem }
.sec-server-stats { display:grid;gap:.4rem;padding:.5rem .8rem }
.sec-srv-item { display:flex;justify-content:space-between;align-items:center;padding:.4rem .5rem;background:rgba(0,0,0,.1);border-radius:6px;font-size:.78rem }
.sec-srv-label { color:var(--text-secondary) }
.sec-srv-value { font-weight:600;color:var(--text-primary) }

.sec-resource-bar-item { padding:.3rem 0 }
.sec-resource-header { display:flex;justify-content:space-between;font-size:.72rem;color:var(--text-secondary);margin-bottom:.3rem }
.sec-resource-bar-bg { height:14px;background:rgba(255,255,255,.04);border-radius:7px;overflow:hidden }
.sec-resource-bar-fill { height:100%;border-radius:7px;transition:width .6s var(--ease) }

.sec-ports-grid { display:flex;gap:.4rem;flex-wrap:wrap;padding:.5rem .8rem }
.sec-port-badge { padding:.3rem .6rem;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:6px;font-size:.72rem;font-weight:600 }
.sec-port-badge small { font-weight:400;color:var(--text-muted);margin-left:.2rem }

/* Responsive */
@media (max-width: 768px) {
  .sec-dash-hero { flex-direction:column;text-align:center }
  .sec-dash-chips { justify-content:center }
  .sec-domains-grid { grid-template-columns:1fr }
  .sec-domain-stats { grid-template-columns:repeat(3,1fr) }
  .sec-overview-grid { grid-template-columns:repeat(2,1fr) }
  .sec-intel-grid { grid-template-columns:repeat(2,1fr) }
  .sec-rt-grid { grid-template-columns:repeat(3,1fr) }
  .sec-server-grid { grid-template-columns:1fr }
  .sec-tabs-bar { gap:0 }
  .sec-tab { padding:.5rem .8rem;font-size:.75rem }
  .sec-quick-actions { grid-template-columns:1fr 1fr }
  .sec-endpoint-path { flex:0 0 120px }
}
@media (max-width: 480px) {
  .sec-overview-grid { grid-template-columns:1fr }
  .sec-quick-actions { grid-template-columns:1fr }
  .sec-intel-grid { grid-template-columns:1fr 1fr }
}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   Security Shield Styles
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.shield-stat-card { display:flex;flex-direction:column;align-items:center;padding:.5rem;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.06);border-radius:8px;gap:.1rem }
.shield-stat-card.threat { padding:.4rem .3rem }
.shield-stat-num { font-size:1.1rem;font-weight:700;line-height:1.2 }
.shield-stat-label { font-size:.65rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px;text-align:center }
.shield-toggle-item { display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:6px;cursor:pointer;transition:background .2s }
.shield-toggle-item:hover { background:rgba(255,255,255,0.05) }
.shield-toggle-label { font-size:.78rem;color:var(--text-primary);user-select:none }
.shield-toggle-switch { position:relative;width:36px;height:20px;flex-shrink:0 }
.shield-toggle-switch input { opacity:0;width:0;height:0 }
.shield-toggle-slider { position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,0.1);border-radius:10px;transition:.3s }
.shield-toggle-slider::before { content:'';position:absolute;height:14px;width:14px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s }
.shield-toggle-switch input:checked + .shield-toggle-slider { background:var(--success) }
.shield-toggle-switch input:checked + .shield-toggle-slider::before { transform:translateX(16px) }
.shield-tab { transition:all .2s }
.shield-tab.active { color:var(--primary)!important;font-weight:600 }

/* Shield â€“ Audit Log */
.shield-audit-entry { display:flex;gap:.4rem;align-items:center;padding:.3rem .5rem;background:rgba(0,0,0,0.12);border-radius:4px;font-size:.72rem }
.shield-audit-time { color:var(--text-secondary);min-width:120px;font-size:.68rem }
.shield-audit-action { font-weight:600;min-width:130px }
.shield-audit-detail { color:var(--text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap }
/* Shield â€“ Quarantine */
.shield-quarantine-item { display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:rgba(245,158,11,.06);border-left:3px solid var(--warning);border-radius:0 6px 6px 0;font-size:.78rem }
/* Shield â€“ Whitelist */
.shield-wl-item { display:flex;align-items:center;gap:.5rem;padding:.35rem .5rem;background:rgba(34,197,94,.05);border-radius:6px;font-size:.8rem }
/* Shield â€“ F2B Stats */
.shield-f2b-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.4rem }
/* Shield â€“ Live Stats */
.shield-live-bar { display:flex;gap:.6rem;font-size:.72rem;flex-wrap:wrap }
.shield-live-chip { padding:.15rem .4rem;border-radius:4px;font-size:.72rem }
/* Shield â€“ Bulk Import */
.shield-bulk-textarea { width:100%;min-height:60px;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.08);border-radius:6px;color:var(--text-primary);padding:.4rem;font-family:monospace;font-size:.75rem;resize:vertical }
/* Shield â€“ Tab Content */
.shield-tab-section { padding:.5rem 0 }
.shield-tab-section h4 { font-size:.82rem;margin-bottom:.4rem;color:var(--text-primary) }
.shield-config-row { display:flex;gap:.5rem;align-items:center;margin-bottom:.35rem }
.shield-config-row label { font-size:.78rem;min-width:90px;color:var(--text-secondary) }
.shield-config-row input[type="number"] { width:100px;padding:.25rem .4rem;background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.08);border-radius:4px;color:var(--text-primary);font-size:.78rem }

/* Shield IP Detail Popup */
.shield-ip-detail { animation:shieldFadeIn .2s ease }
@keyframes shieldFadeIn { from { opacity:0;transform:translateY(-4px) } to { opacity:1;transform:translateY(0) } }

/* Shield Analytics Content */
#wp-analytics-content { min-height:80px }
#wp-analytics-content .shield-stat-card { min-width:auto }

/* Shield Scan Schedule */
.shield-scan-schedule { display:flex;gap:.4rem;align-items:center;padding:.4rem .5rem;background:rgba(59,130,246,.05);border:1px solid rgba(59,130,246,.1);border-radius:6px }
.shield-scan-schedule select { background:rgba(0,0,0,.2);border:1px solid rgba(255,255,255,.08);border-radius:4px;color:var(--text-primary) }

/* Shield Rollback Button */
#wp-shield-rollback-btn { color:var(--warning);border-color:rgba(245,158,11,.2) }
#wp-shield-rollback-btn:hover { background:rgba(245,158,11,.1);border-color:rgba(245,158,11,.4) }

/* Shield Audit Pagination */
#wp-audit-pagination { display:flex;gap:.3rem;justify-content:center;align-items:center;margin-top:.5rem }
#wp-audit-pagination button:disabled { opacity:.4;cursor:not-allowed }

@media (max-width: 600px) {
  .wz-progress { padding: 14px 10px; gap: 0; }
  .wz-step-label { font-size: 0.55rem; }
  .wz-step-line { width: 20px; }
  .wz-step-circle { width: 30px; height: 30px; }
  .wz-step-content { padding: 16px; }
  .wz-type-grid { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); }
  .wz-config-grid { grid-template-columns: 1fr; }
  .wz-dns-records-table { font-size: 0.72rem; grid-template-columns: 50px 60px 1fr 50px; }
}

/* â”€â”€ Settings / Profile Page â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.settings-page { max-width: 900px; }
.settings-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
@media (max-width: 768px) { .settings-grid { grid-template-columns: 1fr; } }
.profile-info { display: flex; gap: 1.5rem; align-items: flex-start; }
.profile-avatar { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--purple)); display: flex; align-items: center; justify-content: center; font-size: 2rem; font-weight: 700; color: #fff; flex-shrink: 0; }
.profile-details { flex: 1; display: flex; flex-direction: column; gap: 0.6rem; }
.profile-field { display: flex; justify-content: space-between; align-items: center; padding: 0.4rem 0; border-bottom: 1px solid var(--border); font-size: 0.875rem; }
.profile-field label { color: var(--text-secondary); font-weight: 500; }
.profile-field span { color: var(--text-primary); }
#change-password-form .form-group { margin-bottom: 1rem; }
#change-password-form label { display: block; margin-bottom: 0.35rem; font-size: 0.85rem; color: var(--text-secondary); font-weight: 500; }
#change-password-form input { width: 100%; padding: 0.6rem 0.75rem; background: var(--bg-input); border: 1px solid var(--border); border-radius: var(--radius-xs); color: var(--text-primary); font-size: 0.9rem; transition: border-color 0.2s; }
#change-password-form input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-glow); }
.form-hint { display: block; margin-top: 0.25rem; font-size: 0.75rem; color: var(--text-muted); }

/* â”€â”€ Intelligent CAPTCHA â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.captcha-section {
  margin: 1rem 0 0.5rem;
  animation: fadeInUp 0.5s 0.55s var(--ease) both;
}
.captcha-loading {
  display: flex; align-items: center; justify-content: center; gap: 0.6rem;
  padding: 1rem; color: var(--text-muted); font-size: 0.82rem;
}
.captcha-spinner {
  width: 18px; height: 18px; border-radius: 50%;
  border: 2px solid rgba(99,102,241,0.15);
  border-top-color: var(--accent);
  animation: spin 0.7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.captcha-challenge {
  background: rgba(8,11,22,0.5);
  border: 1px solid rgba(99,102,241,0.1);
  border-radius: 12px;
  padding: 0.8rem 1rem;
  animation: fadeInUp 0.3s var(--ease) both;
}
.captcha-header {
  display: flex; align-items: center; gap: 0.5rem;
  margin-bottom: 0.6rem; font-size: 0.78rem; font-weight: 600;
  color: var(--text-secondary);
}
.captcha-header svg { color: var(--accent); flex-shrink: 0; }
.captcha-header span { flex: 1; }
.captcha-refresh-btn {
  display: flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 8px;
  background: rgba(99,102,241,0.08); border: 1px solid rgba(99,102,241,0.12);
  color: var(--accent); cursor: pointer;
  transition: all 0.2s var(--ease);
}
.captcha-refresh-btn:hover {
  background: rgba(99,102,241,0.15); border-color: rgba(99,102,241,0.25);
  transform: rotate(90deg);
}
.captcha-display {
  text-align: center; padding: 0.4rem 0;
  font-size: 1.1rem; font-weight: 700; letter-spacing: 0.02em;
  color: var(--text-primary);
}
#captcha-canvas {
  display: block; margin: 0.4rem auto;
  border-radius: 8px; border: 1px solid rgba(99,102,241,0.08);
}
.captcha-input {
  width: 100%; padding: 0.65rem 0.9rem;
  background: rgba(8,11,22,0.6);
  border: 1.5px solid rgba(99,102,241,0.1);
  border-radius: 10px; color: var(--text-primary);
  font-size: 0.95rem; text-align: center;
  letter-spacing: 0.15em; font-weight: 600;
  margin-top: 0.5rem;
  transition: all 0.3s var(--ease);
}
.captcha-input:focus {
  outline: none;
  border-color: rgba(99,102,241,0.5);
  box-shadow: 0 0 0 4px rgba(99,102,241,0.1), 0 0 20px rgba(99,102,241,0.06);
  background: rgba(8,11,22,0.9);
}
.captcha-input::placeholder {
  color: var(--text-muted); font-weight: 400; letter-spacing: 0.02em;
}
.captcha-pow-status {
  display: flex; align-items: center; gap: 0.5rem;
  padding: 0.5rem 0 0; font-size: 0.72rem;
  color: var(--text-muted);
}
.captcha-pow-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: rgba(99,102,241,0.3);
  transition: all 0.3s var(--ease);
}
.captcha-pow-dot.solving {
  background: var(--warning);
  box-shadow: 0 0 8px rgba(245,158,11,0.4);
  animation: powPulse 1s ease-in-out infinite;
}
.captcha-pow-dot.solved {
  background: var(--success);
  box-shadow: 0 0 8px rgba(34,197,94,0.4);
}
@keyframes powPulse {
  0%, 100% { transform: scale(1); opacity: 0.8; }
  50% { transform: scale(1.4); opacity: 1; }
}
.captcha-invisible {
  display: flex; align-items: center; justify-content: center; gap: 0.4rem;
  color: var(--success); font-size: 0.82rem; font-weight: 600;
  padding: 0.3rem 0;
}
.captcha-invisible svg { color: var(--success); }

/* ═══════════════════════════════════════════════════════════
   BACKUP CENTER v4 — Websites Grid/List + Inline Detail Panel
   ═══════════════════════════════════════════════════════════ */

/* ── Core Layout ─────────────────────────────────────────── */
.bk-center { animation: bkFadeIn 0.4s var(--ease) both; }
.bk-tabs {
  display: flex; gap: 4px; padding: 4px;
  background: var(--bg-input); border-radius: 12px; margin-bottom: 1.4rem;
}
.bk-tab {
  flex: 1; padding: 10px 16px; border: none; border-radius: 10px;
  background: transparent; color: var(--text-muted); cursor: pointer;
  font-size: 0.82rem; font-weight: 600; font-family: var(--font);
  transition: all 0.2s var(--ease);
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.bk-tab:hover { color: var(--text-primary); background: var(--bg-hover); }
.bk-tab.active {
  background: var(--accent); color: #fff;
  box-shadow: 0 2px 8px rgba(99,102,241,0.25);
}
.bk-loading {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 3rem; color: var(--text-muted); font-size: 0.85rem;
}

/* ── Stats Grid ──────────────────────────────────────────── */
.bk-stats-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px; margin-bottom: 1.2rem;
}
.bk-stat-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 0.9rem 1rem; text-align: center;
  transition: all 0.2s var(--ease); animation: bkSlideUp 0.35s var(--ease) both;
}
.bk-stat-card:hover { transform: translateY(-2px); box-shadow: 0 4px 16px rgba(0,0,0,0.08); }
.bk-stat-icon {
  width: 32px; height: 32px; border-radius: 8px; margin: 0 auto 6px;
  display: flex; align-items: center; justify-content: center; font-size: 1rem;
}
.bk-stat-icon.grade { background: rgba(16,185,129,0.1); color: var(--success); }
.bk-stat-icon.sites { background: rgba(99,102,241,0.1); color: var(--accent); }
.bk-stat-icon.total { background: rgba(168,85,247,0.1); color: var(--purple); }
.bk-stat-icon.size { background: rgba(6,182,212,0.1); color: var(--cyan); }
.bk-stat-icon.cloud { background: rgba(59,130,246,0.1); color: var(--info); }
.bk-stat-icon.sched { background: rgba(245,158,11,0.1); color: var(--warning); }
.bk-stat-value { font-size: 1.3rem; font-weight: 700; color: var(--text-heading); }
.bk-stat-label { font-size: 0.68rem; color: var(--text-muted); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.5px; font-weight: 600; }

/* ── Alert Banner ────────────────────────────────────────── */
.bk-alert {
  display: flex; align-items: center; gap: 10px; padding: 0.75rem 1rem;
  border-radius: 10px; margin-bottom: 1rem; font-size: 0.82rem;
  animation: bkSlideUp 0.35s var(--ease) both;
}
.bk-alert.danger { background: var(--danger-bg); color: var(--danger); border: 1px solid rgba(239,68,68,0.15); }
.bk-alert.warning { background: var(--warning-bg); color: var(--warning); border: 1px solid rgba(245,158,11,0.15); }
.bk-alert.success { background: var(--success-bg); color: var(--success); border: 1px solid rgba(16,185,129,0.15); }

/* ── Toolbar ─────────────────────────────────────────────── */
.bk-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 1rem; gap: 10px; flex-wrap: wrap;
}
.bk-toolbar-left { display: flex; align-items: center; gap: 10px; }

/* ── View Toggle ─────────────────────────────────────────── */
.bk-view-toggle {
  display: flex; background: var(--bg-input); border-radius: 8px;
  padding: 2px; gap: 2px; border: 1px solid var(--border);
}
.bk-vt-btn {
  border: none; background: transparent; color: var(--text-muted);
  padding: 5px 10px; border-radius: 6px; cursor: pointer;
  font-size: 0.85rem; transition: all 0.2s var(--ease);
}
.bk-vt-btn:hover { color: var(--text-primary); }
.bk-vt-btn.active { background: var(--accent); color: #fff; box-shadow: 0 1px 4px rgba(99,102,241,0.2); }

/* ── Site Container (Grid / List) ────────────────────────── */
.bk-site-container.grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 12px;
}
.bk-site-container.list {
  display: flex; flex-direction: column; gap: 6px;
}

/* ── Site Card ───────────────────────────────────────────── */
.bk-site-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 14px; padding: 1rem 1.1rem; cursor: pointer;
  transition: all 0.25s var(--ease); position: relative; overflow: hidden;
  display: flex; gap: 12px;
  animation: bkSlideUp 0.35s var(--ease) both;
}
.bk-site-card::before {
  content: ''; position: absolute; top: 0; left: 0; width: 3px; height: 100%;
  border-radius: 14px 0 0 14px; transition: all 0.2s var(--ease);
}
.bk-site-card.status-success::before { background: var(--success); }
.bk-site-card.status-danger::before { background: var(--danger); }
.bk-site-card.status-warning::before { background: var(--warning); }
.bk-site-card:hover {
  border-color: var(--accent); transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(99,102,241,0.1);
}
.bk-site-card.selected {
  border-color: var(--accent); background: rgba(99,102,241,0.04);
  box-shadow: 0 4px 16px rgba(99,102,241,0.12);
}

/* ── List mode tweaks ────────────────────────────────────── */
.bk-site-container.list .bk-site-card {
  border-radius: 10px; padding: 0.7rem 1rem;
}
.bk-site-container.list .bk-sc-body {
  display: flex; align-items: center; gap: 16px; flex: 1;
}
.bk-site-container.list .bk-sc-header { min-width: 200px; }
.bk-site-container.list .bk-sc-metrics { flex-direction: row; gap: 20px; margin: 0; }
.bk-site-container.list .bk-sc-footer { margin: 0; }

/* ── Card Interior ───────────────────────────────────────── */
.bk-sc-status { display: flex; align-items: flex-start; padding-top: 2px; }
.bk-status-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}
.bk-status-dot.success { background: var(--success); box-shadow: 0 0 6px rgba(16,185,129,0.4); }
.bk-status-dot.danger { background: var(--danger); box-shadow: 0 0 6px rgba(239,68,68,0.4); }
.bk-status-dot.warning { background: var(--warning); box-shadow: 0 0 6px rgba(245,158,11,0.4); animation: bkPulse 2s infinite; }
.bk-sc-body { flex: 1; min-width: 0; }

.bk-sc-header { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
.bk-sc-title { min-width: 0; }
.bk-sc-domain {
  font-size: 0.88rem; font-weight: 700; color: var(--text-heading);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.bk-sc-status-label {
  font-size: 0.62rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.5px; margin-top: 1px;
}
.bk-sc-status-label.success { color: var(--success); }
.bk-sc-status-label.danger { color: var(--danger); }
.bk-sc-status-label.warning { color: var(--warning); }

/* ── Card Metrics ────────────────────────────────────────── */
.bk-sc-metrics {
  display: flex; gap: 12px; margin: 8px 0; flex-wrap: wrap;
}
.bk-sc-metric {
  display: flex; flex-direction: column; gap: 1px;
}
.bk-sc-metric-val {
  font-size: 0.78rem; font-weight: 700; color: var(--text-heading);
}
.bk-sc-metric-lbl {
  font-size: 0.6rem; color: var(--text-muted); text-transform: uppercase;
  letter-spacing: 0.4px; font-weight: 600;
}

/* ── Card Footer ─────────────────────────────────────────── */
.bk-sc-footer {
  display: flex; align-items: center; gap: 8px; margin-top: 8px; flex-wrap: wrap;
}
.bk-sched-badge {
  font-size: 0.65rem; font-weight: 600; padding: 3px 8px;
  border-radius: 6px; display: inline-flex; align-items: center; gap: 4px;
}
.bk-sched-badge.active { background: var(--success-bg); color: var(--success); }
.bk-sched-badge.paused { background: var(--bg-input); color: var(--text-muted); }
.bk-cloud-mini {
  font-size: 0.75rem; color: var(--info);
  display: inline-flex; align-items: center;
}
.bk-sc-actions { margin-left: auto; display: flex; gap: 4px; }

/* ── App Badge ───────────────────────────────────────────── */
.bk-app-badge {
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 0.6rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.5px; min-width: 28px; height: 28px;
  border-radius: 8px; padding: 0 6px; flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   INLINE DETAIL PANEL
   ═══════════════════════════════════════════════════════════ */
.bk-detail {
  background: var(--bg-card); border: 1px solid var(--accent);
  border-radius: 16px; padding: 1.2rem; margin-top: 1rem;
  animation: bkDetailOpen 0.35s var(--ease) both;
  box-shadow: 0 8px 32px rgba(99,102,241,0.08);
}
.bk-detail-loading {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  padding: 2rem; color: var(--text-muted); font-size: 0.85rem;
}
#bk-detail-panel.closing .bk-detail {
  animation: bkDetailClose 0.3s var(--ease) both;
}

/* ── Detail Header ───────────────────────────────────────── */
.bk-detail-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1rem; gap: 12px; flex-wrap: wrap;
}
.bk-dh-left { display: flex; align-items: center; gap: 10px; }
.bk-dh-domain { font-size: 1rem; font-weight: 700; color: var(--text-heading); }
.bk-dh-path { font-size: 0.72rem; color: var(--text-muted); }
.bk-dh-right { display: flex; align-items: center; gap: 6px; }

/* ── Detail Stats ────────────────────────────────────────── */
.bk-detail-stats {
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  padding: 0.7rem 1rem; background: var(--bg-input); border-radius: 10px;
  margin-bottom: 1rem; font-size: 0.78rem;
}
.bk-ds { display: flex; align-items: center; gap: 5px; }
.bk-ds i { font-size: 0.85rem; }
.bk-ds strong { color: var(--text-heading); }

/* ── Detail Toolbar ──────────────────────────────────────── */
.bk-detail-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 0.8rem; gap: 10px; flex-wrap: wrap;
}
.bk-dt-left { display: flex; align-items: center; gap: 8px; }
.bk-dt-right { display: flex; align-items: center; gap: 8px; }
.bk-filter-select {
  background: var(--bg-input); border: 1px solid var(--border);
  color: var(--text-primary); font-size: 0.75rem; font-family: var(--font);
  padding: 5px 10px; border-radius: 8px; cursor: pointer;
}

/* ── Detail Empty State ──────────────────────────────────── */
.bk-detail-empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 2.5rem; color: var(--text-muted); font-size: 0.85rem;
  text-align: center;
}

/* ── Detail List ─────────────────────────────────────────── */
.bk-detail-list {
  display: flex; flex-direction: column; gap: 6px;
  max-height: 500px; overflow-y: auto; padding-right: 4px;
}
.bk-detail-list::-webkit-scrollbar { width: 5px; }
.bk-detail-list::-webkit-scrollbar-thumb { background: var(--border); border-radius: 10px; }

/* ── Detail Row (single backup) ──────────────────────────── */
.bk-drow {
  display: flex; align-items: center; gap: 10px;
  padding: 0.7rem 0.8rem; border-radius: 10px;
  border: 1px solid var(--border); background: var(--bg-card);
  transition: all 0.2s var(--ease);
  animation: bkSlideUp 0.3s var(--ease) both;
}
.bk-drow:hover { border-color: var(--accent); background: rgba(99,102,241,0.02); }

.bk-drow-check { flex-shrink: 0; }
.bk-drow-icon {
  width: 32px; height: 32px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem; flex-shrink: 0;
}
.bk-drow-icon.full { background: rgba(168,85,247,0.1); color: var(--purple); }
.bk-drow-icon.files { background: rgba(59,130,246,0.1); color: var(--info); }
.bk-drow-icon.database { background: rgba(245,158,11,0.1); color: var(--warning); }
.bk-drow-icon.email { background: rgba(6,182,212,0.1); color: var(--cyan); }

.bk-drow-info { flex: 1; min-width: 0; }
.bk-drow-title {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  margin-bottom: 3px;
}
.bk-drow-status-tag {
  font-size: 0.6rem; font-weight: 700; text-transform: uppercase;
  padding: 2px 6px; border-radius: 4px; letter-spacing: 0.4px;
}
.bk-drow-status-tag.success { background: var(--success-bg); color: var(--success); }
.bk-drow-status-tag.warning { background: var(--warning-bg); color: var(--warning); }
.bk-drow-status-tag.danger { background: var(--danger-bg); color: var(--danger); }
.bk-drow-status-tag.info { background: var(--info-bg); color: var(--info); }
.bk-drow-type {
  font-size: 0.68rem; font-weight: 600; color: var(--text-secondary);
  text-transform: capitalize;
}
.bk-drow-auto {
  font-size: 0.58rem; font-weight: 700; text-transform: uppercase;
  padding: 1px 5px; border-radius: 3px;
  background: rgba(99,102,241,0.1); color: var(--accent);
}
.bk-drow-notes {
  font-size: 0.68rem; color: var(--text-muted); font-style: italic;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 200px;
}
.bk-drow-meta {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  font-size: 0.68rem; color: var(--text-muted);
}
.bk-drow-meta i { font-size: 0.62rem; margin-right: 2px; }
.bk-drow-verified { color: var(--success); font-weight: 600; }
.bk-drow-cloud { color: var(--info); }
.bk-drow-actions { display: flex; gap: 4px; flex-shrink: 0; align-items: center; }
.bk-drow-running {
  font-size: 0.72rem; color: var(--warning); font-weight: 600;
  display: flex; align-items: center; gap: 4px;
  animation: bkPulse 1.5s infinite;
}
.ws-btn-danger:hover { color: var(--danger) !important; }

/* Smart status live indicators */
.bk-drow-status-live {
  font-size: 0.72rem; font-weight: 600;
  display: flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 8px;
  white-space: nowrap;
}
.bk-drow-status-live.running {
  color: var(--warning); background: var(--warning-bg);
  animation: bkPulse 1.5s infinite;
}
.bk-drow-status-live.restoring {
  color: var(--info); background: var(--info-bg);
  animation: bkPulse 1.5s infinite;
}
.bk-drow-status-live.queued {
  color: var(--text-muted); background: var(--bg-hover);
}
.bk-drow-error {
  display: flex; align-items: center; cursor: help;
  padding: 4px; border-radius: 6px;
}
.bk-drow-error:hover { background: var(--danger-bg); }

/* Spin animation for live status icons */
@keyframes bkSpin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
.bk-spin { animation: bkSpin 1s linear infinite; display: inline-block; }

/* Age/freshness indicators on site cards */
.bk-site-card.stale { border-left: 3px solid var(--danger); }
.bk-site-card.aging { border-left: 3px solid var(--warning); }
.bk-age-badge {
  font-size: 0.58rem; font-weight: 700; text-transform: uppercase;
  padding: 2px 6px; border-radius: 4px; display: inline-flex; align-items: center; gap: 3px;
}
.bk-age-badge.stale { background: var(--danger-bg); color: var(--danger); }
.bk-age-badge.aging { background: var(--warning-bg); color: var(--warning); }

/* Progress mini bar for running backups */
.bk-progress-mini {
  width: 60px; height: 4px; border-radius: 2px;
  background: var(--bg-hover); overflow: hidden; flex-shrink: 0;
}
.bk-progress-fill {
  height: 100%; border-radius: 2px;
  background: var(--warning);
  transition: width 0.5s var(--ease);
}

/* Add notes pencil icon */
.bk-drow-add-notes {
  font-size: 0.62rem; color: var(--text-muted); cursor: pointer;
  opacity: 0; transition: opacity 0.2s;
}
.bk-drow:hover .bk-drow-add-notes { opacity: 1; }

/* ═══════════════════════════════════════════════════════════════
   BotPanel Webmail Engine — Custom Mail Client Styles
   ═══════════════════════════════════════════════════════════════ */

.wm-container {
  display: flex; flex-direction: column; gap: 0;
  height: calc(100vh - 340px); min-height: 500px;
  border: 1px solid var(--border); border-radius: 10px;
  overflow: hidden; background: var(--bg-secondary);
}
.wm-topbar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border-bottom: 1px solid var(--border);
  background: rgba(17, 20, 48, 0.8);
  flex-shrink: 0;
}
.wm-account-select {
  background: var(--bg-input); color: var(--text-primary);
  border: 1px solid var(--border); border-radius: 6px;
  padding: 5px 10px; font-size: 0.82rem; max-width: 260px;
  cursor: pointer; outline: none;
}
.wm-account-select:focus { border-color: var(--accent); }
.wm-search-box {
  display: flex; align-items: center; gap: 6px;
  background: var(--bg-input); border: 1px solid var(--border);
  border-radius: 6px; padding: 0 10px; flex: 1; max-width: 350px;
}
.wm-search-box i { color: var(--text-muted); font-size: 0.85rem; }
.wm-search-box input {
  background: transparent; border: none; color: var(--text-primary);
  font-size: 0.82rem; padding: 6px 0; width: 100%; outline: none;
}
.wm-layout {
  display: flex; flex: 1; overflow: hidden;
}
.wm-sidebar {
  width: 200px; min-width: 180px; border-right: 1px solid var(--border);
  overflow-y: auto; flex-shrink: 0;
  background: rgba(13, 16, 37, 0.6);
}
.wm-folder-item {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px; cursor: pointer; font-size: 0.82rem;
  color: var(--text-secondary); transition: all 0.15s ease;
  border-left: 3px solid transparent;
}
.wm-folder-item:hover { background: var(--bg-hover); color: var(--text-primary); }
.wm-folder-item.active {
  background: var(--accent-glow); color: var(--accent);
  border-left-color: var(--accent); font-weight: 600;
}
.wm-folder-item i { font-size: 0.9rem; width: 18px; text-align: center; }
.wm-folder-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wm-folder-badge {
  background: var(--accent); color: #fff; font-size: 0.65rem;
  padding: 1px 6px; border-radius: 10px; font-weight: 700; min-width: 18px; text-align: center;
}
.wm-folder-count {
  font-size: 0.7rem; color: var(--text-muted); margin-left: auto;
}
.wm-folder-actions {
  padding: 10px 12px; border-top: 1px solid var(--border);
}
.wm-main {
  display: flex; flex: 1; overflow: hidden;
}
.wm-msglist {
  width: 380px; min-width: 280px; max-width: 450px;
  border-right: 1px solid var(--border);
  overflow-y: auto; flex-shrink: 0;
}
.wm-list-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 12px; border-bottom: 1px solid var(--border);
  background: rgba(17, 20, 48, 0.5); position: sticky; top: 0; z-index: 1;
}
.wm-pagination { display: flex; align-items: center; gap: 4px; }
.wm-msg-row {
  display: grid; grid-template-columns: 24px 28px 1fr 2fr auto;
  align-items: center; gap: 6px; padding: 8px 10px;
  border-bottom: 1px solid rgba(99, 102, 241, 0.04);
  cursor: pointer; font-size: 0.8rem; color: var(--text-secondary);
  transition: background 0.12s ease;
}
.wm-msg-row:hover { background: var(--bg-hover); }
.wm-msg-row.wm-active { background: var(--accent-glow); border-left: 2px solid var(--accent); }
.wm-msg-row.wm-unread { font-weight: 600; color: var(--text-primary); }
.wm-msg-row.wm-unread .wm-msg-from { color: var(--text-heading); }
.wm-msg-row.wm-flagged .wm-star { color: #f59e0b !important; }
.wm-msg-actions-inline { display: flex; align-items: center; }
.wm-star { color: var(--text-muted); cursor: pointer; font-size: 0.85rem; transition: color 0.15s; }
.wm-star:hover { color: #f59e0b; }
.wm-msg-from {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  font-size: 0.78rem;
}
.wm-msg-subject {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  color: var(--text-primary); font-size: 0.78rem;
}
.wm-msg-date { font-size: 0.7rem; color: var(--text-muted); white-space: nowrap; padding: 0 4px; }
.wm-msg-size { font-size: 0.65rem; color: var(--text-muted); white-space: nowrap; }
.wm-reader {
  flex: 1; overflow-y: auto; background: var(--bg-primary);
}
.wm-reader-empty {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; height: 100%; gap: 10px; color: var(--text-muted);
}
.wm-reader-content { display: flex; flex-direction: column; height: 100%; }
.wm-reader-toolbar {
  display: flex; align-items: center; gap: 6px;
  padding: 8px 14px; border-bottom: 1px solid var(--border);
  background: rgba(17, 20, 48, 0.6); flex-shrink: 0;
}
.wm-reader-headers {
  padding: 14px 18px 10px; border-bottom: 1px solid rgba(99, 102, 241, 0.06);
  flex-shrink: 0;
}
.wm-reader-subject {
  font-size: 1.1rem; font-weight: 600; color: var(--text-heading);
  margin: 0 0 8px;
}
.wm-reader-meta { font-size: 0.8rem; color: var(--text-secondary); line-height: 1.7; }
.wm-reader-meta strong { color: var(--text-primary); margin-right: 4px; }
.wm-attachments {
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px;
  padding: 8px 18px; border-bottom: 1px solid rgba(99, 102, 241, 0.06);
  font-size: 0.8rem; color: var(--text-muted); flex-shrink: 0;
}
.wm-att-link {
  display: inline-flex; align-items: center; gap: 4px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 6px; padding: 3px 10px; color: var(--accent);
  text-decoration: none; font-size: 0.78rem; transition: all 0.15s;
}
.wm-att-link:hover { background: var(--accent-glow); border-color: var(--accent); }
.wm-reader-body { flex: 1; padding: 16px 18px; overflow-y: auto; }
.wm-html-frame {
  width: 100%; border: none; min-height: 300px;
  background: transparent; border-radius: 6px;
}
.wm-text-body {
  white-space: pre-wrap; word-wrap: break-word; font-family: inherit;
  font-size: 0.88rem; color: var(--text-primary); line-height: 1.6;
  background: transparent; border: none; padding: 0; margin: 0;
}
.wm-loading {
  display: flex; align-items: center; justify-content: center;
  gap: 8px; padding: 30px; color: var(--text-muted); font-size: 0.85rem;
}
.wm-empty {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; height: 200px; gap: 8px;
}
.wm-folders-loading { display: flex; justify-content: center; padding: 20px; }

/* Webmail Storage Footer */
.wm-storage-footer {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 8px 16px; background: rgba(13, 16, 37, 0.9); border-top: 1px solid var(--border);
  font-size: 0.75rem; color: var(--text-secondary); flex-shrink: 0;
}
.wm-storage-info { display: flex; align-items: center; gap: 8px; flex: 1; position: relative; }
.wm-storage-bar-wrap { flex: 1; max-width: 400px; height: 6px; background: var(--bg-input); border-radius: 4px; overflow: visible; position: relative; cursor: help; }
.wm-storage-fill { height: 100%; border-radius: 4px; background: var(--info); transition: width 0.5s var(--ease), background 0.3s; }
.wm-storage-fill.warn { background: var(--warning); box-shadow: 0 0 8px rgba(245,158,11,0.4); }
.wm-storage-fill.danger { background: var(--danger); box-shadow: 0 0 8px rgba(239,68,68,0.4); }
.wm-storage-text { white-space: nowrap; font-weight: 600; min-width: 140px; }
.wm-storage-text.danger { color: var(--danger); animation: bkPulse 1s infinite; }
.wm-storage-popover {
  position: absolute; bottom: 16px; left: 0; background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 10px; box-shadow: 0 4px 20px rgba(0,0,0,0.5);
  display: none; flex-direction: column; gap: 6px; z-index: 1000; min-width: 200px;
}
.wm-storage-bar-wrap:hover .wm-storage-popover { display: flex; animation: bkSlideUp 0.2s var(--ease); }
.wm-storage-pop-row { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.wm-storage-pop-name { color: var(--text-primary); font-weight: 500; display: flex; align-items: center; gap: 6px; }
.wm-storage-pop-name i { color: var(--accent); }
.wm-storage-pop-size { font-family: monospace; font-size: 0.7rem; color: var(--text-muted); }

/* Compose Modal */
.wm-compose-modal { display: flex; flex-direction: column; }
.wm-compose-modal .em-modal-body { padding: 10px 16px; display: flex; flex-direction: column; gap: 6px; }
.wm-compose-field { display: flex; align-items: center; gap: 8px; }
.wm-compose-field label { width: 60px; font-size: 0.8rem; color: var(--text-muted); flex-shrink: 0; }
.wm-compose-field input { flex: 1; }
.wm-compose-from { font-size: 0.82rem; color: var(--accent); font-weight: 600; }
.wm-compose-body-wrap { flex: 1; }
.wm-compose-textarea {
  resize: vertical; min-height: 200px; font-family: inherit;
  font-size: 0.88rem; background: var(--bg-input);
  color: var(--text-primary); border: 1px solid var(--border);
  border-radius: 6px; padding: 10px;
}
.wm-compose-textarea:focus { border-color: var(--accent); outline: none; }

/* Deliverability Check */
.wm-deliverability { display: flex; flex-direction: column; gap: 16px; }
.wm-score-ring { text-align: center; padding: 16px 0; }
.wm-score-val {
  font-size: 2.5rem; font-weight: 700;
}
.wm-score-val.good { color: #10b981; }
.wm-score-val.warn { color: #f59e0b; }
.wm-score-val.bad { color: #ef4444; }
.wm-score-label { font-size: 0.85rem; color: var(--text-muted); margin-top: 4px; }
.wm-checks-list { display: flex; flex-direction: column; gap: 6px; }
.wm-check-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; border-radius: 6px;
  font-size: 0.82rem; background: var(--bg-card);
  border: 1px solid var(--border);
}
.wm-check-item.pass i { color: #10b981; }
.wm-check-item.fail i { color: #ef4444; }
.wm-check-item strong { min-width: 120px; color: var(--text-primary); }
.wm-check-item .text-muted { flex: 1; font-size: 0.78rem; }

/* Webmail Bulk Bar */
.wm-bulk-bar {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 12px; background: rgba(99, 102, 241, 0.08);
  border-bottom: 1px solid var(--accent); font-size: 0.8rem;
}
.wm-bulk-count { font-weight: 600; color: var(--accent); margin-right: 6px; font-size: 0.78rem; }

/* Webmail Select All / Checkboxes */
.wm-select-all { display: flex; align-items: center; padding: 0 4px; cursor: pointer; }
.wm-select-all input { cursor: pointer; }
.wm-msg-check { display: flex; align-items: center; }
.wm-msg-check input { cursor: pointer; }

/* Message snippet */
.wm-msg-subject-col { display: flex; flex-direction: column; overflow: hidden; min-width: 0; }
.wm-msg-snippet { font-size: 0.7rem; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; margin-top: 1px; font-weight: 400; }
.wm-msg-meta-col { display: flex; align-items: center; gap: 6px; white-space: nowrap; }
.wm-att-icon { font-size: 0.75rem; color: var(--text-muted); }

/* Sort dropdown */
.wm-sort-dropdown { position: relative; display: inline-block; }
.wm-sort-menu {
  display: none; position: absolute; top: 100%; right: 0; z-index: 100;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 4px 0; min-width: 160px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.wm-sort-dropdown.open .wm-sort-menu { display: block; }
.wm-sort-item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 14px; font-size: 0.8rem; color: var(--text-secondary);
  cursor: pointer; transition: background 0.12s;
}
.wm-sort-item:hover { background: var(--bg-hover); }
.wm-sort-item.active { color: var(--accent); font-weight: 600; }

/* Folder context menu */
.wm-context-menu {
  position: absolute; z-index: 1000;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 4px 0; min-width: 140px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.wm-ctx-item {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 14px; font-size: 0.8rem; color: var(--text-secondary);
  cursor: pointer; transition: background 0.12s;
}
.wm-ctx-item:hover { background: var(--bg-hover); }
.wm-ctx-item.danger { color: #ef4444; }
.wm-ctx-item.danger:hover { background: rgba(239, 68, 68, 0.08); }

/* Folder empty button */
.wm-folder-empty-btn {
  font-size: 0.7rem; color: var(--text-muted); cursor: pointer;
  opacity: 0; transition: opacity 0.15s;
  margin-left: auto; margin-right: 4px;
}
.wm-folder-item:hover .wm-folder-empty-btn { opacity: 0.7; }
.wm-folder-empty-btn:hover { color: #ef4444 !important; opacity: 1 !important; }

/* Message-ID row in reader */
.wm-msg-id-row { font-size: 0.7rem; }

/* Keyboard shortcuts modal */
.wm-shortcuts-list { display: flex; flex-direction: column; gap: 6px; font-size: 0.85rem; }
.wm-shortcuts-list kbd {
  display: inline-block; padding: 2px 6px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 4px; font-size: 0.75rem; font-family: monospace;
  color: var(--text-primary); min-width: 20px; text-align: center;
}

/* Advanced Search Filter Button */
.wm-search-filter-btn {
  cursor: pointer; padding: 4px 6px; opacity: 0.6; transition: opacity 0.15s;
  font-size: 0.85rem;
}
.wm-search-filter-btn:hover { opacity: 1; color: var(--accent); }

/* Advanced Search Panel */
.wm-adv-search-panel {
  background: var(--bg-card); border-bottom: 1px solid var(--border);
  padding: 10px 14px; display: flex; flex-direction: column; gap: 8px;
  animation: fadeIn 0.15s ease;
}
.wm-adv-row { display: flex; gap: 10px; flex-wrap: wrap; }
.wm-adv-field { flex: 1; min-width: 140px; }
.wm-adv-field label { font-size: 0.72rem; font-weight: 600; color: var(--text-secondary); display: block; margin-bottom: 2px; }
.wm-adv-checks { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; }
.wm-adv-checks label { font-size: 0.78rem; cursor: pointer; white-space: nowrap; display: flex; align-items: center; gap: 4px; }
.wm-adv-actions { display: flex; gap: 8px; }

/* Rich Text Compose Toolbar */
.wm-compose-toolbar {
  display: flex; gap: 2px; padding: 6px 8px;
  background: var(--bg-secondary); border: 1px solid var(--border);
  border-bottom: none; border-radius: 6px 6px 0 0; flex-wrap: wrap;
}
.wm-fmt-btn {
  border: none; background: transparent; padding: 4px 7px;
  cursor: pointer; border-radius: 4px; color: var(--text-primary);
  font-size: 0.85rem; transition: background 0.12s;
}
.wm-fmt-btn:hover { background: var(--bg-hover); }
.wm-fmt-btn.active { background: var(--accent); color: #fff; }
.wm-fmt-btn:disabled { opacity: 0.35; cursor: default; }
.wm-fmt-sep { width: 1px; background: var(--border); margin: 2px 4px; align-self: stretch; }

/* Contenteditable Compose Body */
.wm-compose-editable {
  min-height: 200px; padding: 10px 12px;
  border: 1px solid var(--border); border-radius: 0 0 6px 6px;
  background: var(--bg-card); color: var(--text-primary);
  font-size: 0.88rem; line-height: 1.5; outline: none;
  overflow-y: auto; max-height: 350px;
}
.wm-compose-editable:focus { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(var(--accent-rgb, 59,130,246), 0.15); }

/* Priority & Template in compose */
.wm-tmpl-select {
  font-size: 0.75rem; padding: 2px 8px;
  border: 1px solid var(--border); border-radius: 4px;
  background: var(--bg-card); color: var(--text-primary); cursor: pointer;
}

/* Contact Autocomplete */
.wm-contact-suggest {
  position: fixed; z-index: 10001; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: 6px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15); max-height: 160px; overflow-y: auto;
}
.wm-contact-item {
  padding: 6px 12px; cursor: pointer; font-size: 0.82rem;
  color: var(--text-primary); transition: background 0.1s;
}
.wm-contact-item:hover { background: var(--bg-hover); }

/* Quick Reply */
.wm-quick-reply {
  border-top: 1px solid var(--border); padding: 10px 14px;
  margin-top: 8px;
}
.wm-qr-bar { display: flex; gap: 8px; align-items: flex-start; }
.wm-qr-input {
  flex: 1; resize: vertical; transition: height 0.2s;
  font-size: 0.85rem;
}
.wm-qr-input.expanded { min-height: 60px; }
.wm-qr-send { align-self: flex-end; }

/* Drag & Drop */
.wm-msg-row[draggable="true"] { cursor: grab; }
.wm-msg-row.wm-dragging { opacity: 0.4; }
.wm-folder-item.wm-drag-over {
  background: rgba(var(--accent-rgb, 59,130,246), 0.15) !important;
  outline: 2px dashed var(--accent);
}

/* Template item in settings */
.wm-tmpl-item {
  padding: 4px 0; border-bottom: 1px solid var(--border);
  font-size: 0.82rem;
}
.wm-tmpl-item:last-child { border-bottom: none; }

/* Message ID row */
.wm-msg-id-row { font-size: 0.75rem; }

/* Headers pre */
.wm-headers-pre { background: var(--bg-secondary); padding: 12px; border-radius: 6px; border: 1px solid var(--border); }

/* Responsive */
@media (max-width: 900px) {
  .wm-sidebar { width: 160px; min-width: 140px; }
  .wm-msglist { width: 260px; min-width: 200px; }
}
@media (max-width: 700px) {
  .wm-layout { flex-direction: column; }
  .wm-sidebar { width: 100%; border-right: none; border-bottom: 1px solid var(--border); max-height: 120px; }
  .wm-msglist { width: 100%; max-width: 100%; border-right: none; border-bottom: 1px solid var(--border); max-height: 250px; }
  .wm-msg-row { grid-template-columns: 24px 24px 1fr 2fr; }
  .wm-msg-meta-col { display: none; }
}
.bk-drow-add-notes:hover { color: var(--accent); }

/* Load more */
.bk-load-more {
  text-align: center; padding: 1rem 0;
}

/* Statistics tab */
.bk-stats-overview { max-width: 960px; margin: 0 auto; }
.bk-stat-section {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 14px; padding: 1.2rem; margin-bottom: 1rem;
}
.bk-stat-section h4 {
  font-size: 0.88rem; color: var(--text-heading); margin: 0 0 1rem;
  display: flex; align-items: center; gap: 8px;
}
.bk-type-bars { display: flex; flex-direction: column; gap: 8px; }
.bk-type-bar-row {
  display: flex; align-items: center; gap: 10px;
}
.bk-type-label {
  font-size: 0.75rem; font-weight: 600; color: var(--text-secondary);
  text-transform: capitalize; width: 70px; flex-shrink: 0;
}
.bk-type-bar {
  flex: 1; height: 8px; border-radius: 4px;
  background: var(--bg-hover); overflow: hidden;
}
.bk-type-bar-fill {
  height: 100%; border-radius: 4px;
  transition: width 0.6s var(--ease);
}
.bk-type-val {
  font-size: 0.7rem; color: var(--text-muted);
  white-space: nowrap; min-width: 100px; text-align: right;
}
.bk-site-stats-table {
  overflow-x: auto;
}
.bk-site-stats-table th {
  font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.3px; font-weight: 700;
}
.bk-site-stats-table td {
  font-size: 0.78rem; color: var(--text-primary);
}
.bk-daily-chart {
  display: flex; align-items: flex-end; gap: 3px;
  height: 80px; padding-top: 10px; overflow-x: auto;
}
.bk-daily-bar {
  display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
  min-width: 18px; flex: 1; cursor: help;
}
.bk-daily-bar-fill {
  width: 100%; border-radius: 3px 3px 0 0;
  min-height: 4px;
  transition: height 0.4s var(--ease);
}
.bk-daily-label {
  font-size: 0.5rem; color: var(--text-muted); margin-top: 3px;
  white-space: nowrap;
}

/* ═══════════════════════════════════════════════════════════
   CLOUD STORAGE TAB
   ═══════════════════════════════════════════════════════════ */
.bk-cloud-wizard { text-align: center; padding: 2rem 0; }
.bk-cloud-wizard-hero { margin-bottom: 2rem; }
.bk-hero-icon { font-size: 3.5rem; margin-bottom: 0.5rem; }
.bk-cloud-wizard h2 { color: var(--text-heading); font-size: 1.3rem; margin-bottom: 0.4rem; }
.bk-cloud-wizard p { color: var(--text-muted); font-size: 0.85rem; max-width: 520px; margin: 0 auto; line-height: 1.6; }

.bk-wizard-pcard {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 14px; padding: 1.2rem; cursor: pointer; position: relative;
  transition: all 0.25s var(--ease); animation: bkSlideUp 0.4s var(--ease) both;
}
.bk-wizard-pcard:hover { border-color: var(--accent); transform: translateY(-3px); box-shadow: 0 8px 24px rgba(99,102,241,0.1); }

.bk-provider-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px; margin-bottom: 1.5rem;
}
.bk-provider-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 14px; padding: 1.2rem; position: relative;
  transition: all 0.25s var(--ease); animation: bkSlideUp 0.35s var(--ease) both;
}
.bk-provider-card:hover { border-color: var(--accent); box-shadow: 0 4px 16px rgba(99,102,241,0.08); }
.bk-pc-status-dot {
  width: 8px; height: 8px; border-radius: 50%; position: absolute; top: 14px; right: 14px;
}
.bk-pc-status-dot.connected { background: var(--success); box-shadow: 0 0 6px rgba(16,185,129,0.4); }
.bk-pc-status-dot.error { background: var(--danger); }
.bk-pc-status-dot.pending { background: var(--warning); }
.bk-pc-header { display: flex; align-items: center; gap: 10px; margin-bottom: 0.9rem; }
.bk-pc-icon {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
}
.bk-pc-header h4 { margin: 0; font-size: 0.88rem; color: var(--text-heading); }
.bk-pc-details {
  display: flex; flex-direction: column; gap: 6px; margin-bottom: 0.9rem;
}
.bk-pc-detail {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.75rem; color: var(--text-secondary);
}
.bk-pc-detail i { font-size: 0.68rem; color: var(--text-muted); width: 14px; text-align: center; }
.bk-pc-actions { display: flex; gap: 6px; }
.bk-sm-tag {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: 6px; font-weight: 600;
}
.bk-sm-tag.success { background: var(--success-bg); color: var(--success); }
.bk-sm-tag.info { background: var(--info-bg); color: var(--info); }

/* ── Toggle Switch ───────────────────────────────────────── */
.bk-toggle { position: relative; display: inline-block; width: 36px; height: 20px; }
.bk-toggle input { opacity: 0; width: 0; height: 0; }
.bk-toggle-slider {
  position: absolute; cursor: pointer; inset: 0;
  background: var(--bg-input); border: 1px solid var(--border);
  border-radius: 20px; transition: 0.25s var(--ease);
}
.bk-toggle-slider::before {
  content: ''; position: absolute; height: 14px; width: 14px;
  left: 2px; bottom: 2px; background: var(--text-muted);
  border-radius: 50%; transition: 0.25s var(--ease);
}
.bk-toggle input:checked + .bk-toggle-slider { background: var(--accent); border-color: var(--accent); }
.bk-toggle input:checked + .bk-toggle-slider::before { transform: translateX(16px); background: #fff; }

/* ── Setup Wizard ────────────────────────────────────────── */
.bk-setup-wizard { display: flex; gap: 1.5rem; }
.bk-wizard-steps {
  flex: 0 0 220px; display: flex; flex-direction: column; gap: 12px;
  padding-right: 1.2rem; border-right: 1px solid var(--border);
}
.bk-wizard-step { display: flex; gap: 10px; align-items: flex-start; }
.bk-ws-num {
  width: 24px; height: 24px; border-radius: 50%;
  background: var(--accent); color: #fff; font-size: 0.7rem; font-weight: 700;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.bk-wizard-form { flex: 1; }

/* ── Device Auth Loading Dots ────────────────────────────── */
.bk-loading-dots span { animation: bk-dot-pulse 1.4s infinite ease-in-out both; font-size: 10px; }
.bk-loading-dots span:nth-child(1) { animation-delay: 0s; }
.bk-loading-dots span:nth-child(2) { animation-delay: 0.2s; }
.bk-loading-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes bk-dot-pulse { 0%, 80%, 100% { opacity: 0.2; } 40% { opacity: 1; } }

/* ── Check Card ──────────────────────────────────────────── */
.bk-check-card {
  display: flex; align-items: center; gap: 10px; cursor: pointer;
  padding: 0.7rem 0.9rem; border-radius: 10px; border: 1px solid var(--border);
  background: var(--bg-card); transition: all 0.2s var(--ease);
}
.bk-check-card:hover { border-color: var(--accent); }
.bk-check-card input:checked ~ .bk-cc-icon { box-shadow: 0 0 0 2px var(--accent); }
.bk-cc-icon {
  width: 32px; height: 32px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}

/* ── Type-Schedule Row (per-type wizard) ─────────────────── */
.bk-type-schedule-row {
  display: flex; align-items: center; gap: 10px;
}
.bk-type-sched-cfg {
  display: flex; flex-direction: column; gap: 4px; align-items: flex-end;
  min-width: 120px; transition: opacity 0.2s var(--ease);
}
.bk-sched-sel {
  padding: 4px 8px; font-size: 0.75rem; border-radius: 8px;
  border: 1px solid var(--border); background: var(--bg-input);
  color: var(--text-primary); cursor: pointer; width: 100%;
}
.bk-ret-wrap {
  font-size: 0.7rem; color: var(--text-muted); white-space: nowrap;
  display: flex; align-items: center; gap: 4px;
}
.bk-ret-input {
  width: 44px; padding: 3px 5px; font-size: 0.75rem; border-radius: 6px;
  border: 1px solid var(--border); background: var(--bg-input);
  color: var(--text-primary); text-align: center;
}
@media (max-width: 600px) {
  .bk-type-schedule-row { flex-direction: column; align-items: stretch; }
  .bk-type-sched-cfg { flex-direction: row; gap: 8px; min-width: unset; align-items: center; }
}

/* ── Provider Type Cards ─────────────────────────────────── */
.bk-provider-types {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 10px; margin-top: 1rem;
}
.bk-ptype-card {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 1rem; border: 1px solid var(--border); border-radius: 12px;
  background: var(--bg-card); cursor: pointer; transition: all 0.2s var(--ease);
  font-size: 0.78rem; font-weight: 600; color: var(--text-heading);
}
.bk-ptype-card:hover { border-color: var(--accent); transform: translateY(-2px); }

.bk-section-title {
  font-size: 0.85rem; font-weight: 700; color: var(--text-heading);
  display: flex; align-items: center; gap: 6px; margin: 1.5rem 0 0.8rem;
}

/* ── Cloud Badge ─────────────────────────────────────────── */
.bk-cloud-badge {
  font-size: 0.62rem; font-weight: 600; padding: 2px 6px;
  border-radius: 4px; display: inline-flex; align-items: center; gap: 3px;
}
.bk-cloud-badge.local { background: var(--success-bg); color: var(--success); }
.bk-cloud-badge.synced { background: var(--info-bg); color: var(--info); }

/* ═══════════════════════════════════════════════════════════
   STORAGE BREAKDOWN BAR
   ═══════════════════════════════════════════════════════════ */
.bk-storage-breakdown {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 12px; padding: 0.9rem 1.1rem; margin-bottom: 1rem;
  animation: bkSlideUp 0.4s var(--ease) both;
}
.bk-storage-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 0.6rem;
  font-size: 0.82rem; color: var(--text-heading);
}
.bk-storage-bar {
  display: flex; height: 10px; border-radius: 6px;
  background: var(--bg-hover); overflow: hidden; margin-bottom: 0.5rem;
}
.bk-storage-seg {
  height: 100%; transition: width 0.6s var(--ease);
  min-width: 4px; position: relative; cursor: help;
}
.bk-storage-seg:first-child { border-radius: 6px 0 0 6px; }
.bk-storage-seg:last-child { border-radius: 0 6px 6px 0; }
.bk-storage-seg:only-child { border-radius: 6px; }
.bk-storage-legend {
  display: flex; flex-wrap: wrap; gap: 10px;
}
.bk-storage-leg-item {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 0.7rem; color: var(--text-secondary); font-weight: 500;
}
.bk-storage-dot {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════
   SCHEDULE OVERVIEW STRIP
   ═══════════════════════════════════════════════════════════ */
.bk-sched-overview {
  margin-bottom: 1rem;
  animation: bkSlideUp 0.4s var(--ease) both;
}
.bk-sched-ov-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 0.6rem;
  font-size: 0.82rem; color: var(--text-heading);
}
.bk-sched-ov-strip {
  display: flex; gap: 10px; overflow-x: auto; padding-bottom: 4px;
  scrollbar-width: none;
}
.bk-sched-ov-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; padding: 0.7rem 0.9rem; min-width: 200px;
  flex-shrink: 0; transition: all 0.2s var(--ease);
  animation: bkSlideUp 0.35s var(--ease) both;
}
.bk-sched-ov-card:hover { border-color: var(--accent); }
.bk-sched-ov-card.overdue { border-left: 3px solid var(--danger); }
.bk-sched-ov-card.failed { border-left: 3px solid var(--warning); }
.bk-sched-ov-card.paused { opacity: 0.6; }
.bk-sov-top {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px; margin-bottom: 6px;
}
.bk-sov-domain {
  font-size: 0.8rem; font-weight: 700; color: var(--text-heading);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 140px;
}
.bk-sov-badge {
  font-size: 0.55rem; font-weight: 700; text-transform: uppercase;
  padding: 2px 6px; border-radius: 4px; letter-spacing: 0.3px;
  white-space: nowrap;
}
.bk-sov-badge.ok { background: var(--success-bg); color: var(--success); }
.bk-sov-badge.overdue { background: var(--danger-bg); color: var(--danger); }
.bk-sov-badge.failed { background: var(--warning-bg); color: var(--warning); }
.bk-sov-badge.paused { background: var(--bg-hover); color: var(--text-muted); }
.bk-sov-meta {
  display: flex; flex-direction: column; gap: 3px;
  font-size: 0.68rem; color: var(--text-muted);
}
.bk-sov-meta span {
  display: flex; align-items: center; gap: 4px;
}
.bk-sov-meta i { font-size: 0.6rem; }
.bk-sov-actions {
  display: flex; gap: 4px; margin-top: 6px;
}

/* ═══════════════════════════════════════════════════════════
   ACTIVITY TIMELINE TAB
   ═══════════════════════════════════════════════════════════ */
.bk-activity-container {
  max-width: 720px; margin: 0 auto;
  animation: bkFadeIn 0.4s var(--ease) both;
}
.bk-activity-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1.2rem; gap: 10px;
}
.bk-activity-timeline {
  position: relative;
  padding-left: 20px;
}
.bk-activity-timeline::before {
  content: ''; position: absolute; left: 6px; top: 0; bottom: 0;
  width: 2px; background: var(--border);
}
.bk-at-day {
  font-size: 0.72rem; font-weight: 700; color: var(--text-heading);
  text-transform: uppercase; letter-spacing: 0.5px;
  padding: 0.6rem 0 0.4rem; position: relative;
}
.bk-at-event {
  display: flex; gap: 12px; padding: 0.5rem 0;
  position: relative;
  animation: bkSlideUp 0.3s var(--ease) both;
}
.bk-at-dot {
  width: 10px; height: 10px; border-radius: 50%;
  flex-shrink: 0; margin-top: 4px;
  position: absolute; left: -17px;
  box-shadow: 0 0 0 3px var(--bg-card);
}
.bk-at-content {
  flex: 1; min-width: 0;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; padding: 0.6rem 0.9rem;
  transition: all 0.2s var(--ease);
}
.bk-at-content:hover { border-color: var(--accent); }
.bk-at-desc {
  font-size: 0.8rem; color: var(--text-primary);
  display: flex; align-items: center; gap: 6px;
  line-height: 1.5;
}
.bk-at-desc strong { color: var(--text-heading); }
.bk-at-meta {
  display: flex; gap: 12px; margin-top: 4px;
  font-size: 0.65rem; color: var(--text-muted);
}
.bk-at-meta span {
  display: inline-flex; align-items: center; gap: 3px;
}
.bk-at-meta i { font-size: 0.58rem; }

/* ═══════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════ */
@keyframes bkFadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes bkSlideUp { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes bkPulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
@keyframes bkDetailOpen {
  from { opacity: 0; transform: translateY(-8px) scaleY(0.95); max-height: 0; }
  to { opacity: 1; transform: translateY(0) scaleY(1); max-height: 2000px; }
}
@keyframes bkDetailClose {
  from { opacity: 1; transform: translateY(0) scaleY(1); }
  to { opacity: 0; transform: translateY(-8px) scaleY(0.95); }
}

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 768px) {
  .bk-stats-grid { grid-template-columns: repeat(3, 1fr); }
  .bk-site-container.grid { grid-template-columns: 1fr; }
  .bk-provider-grid { grid-template-columns: 1fr; }
  .bk-setup-wizard { flex-direction: column; }
  .bk-wizard-steps { flex: 1; border-right: none; border-bottom: 1px solid var(--border); padding-right: 0; padding-bottom: 1rem; }
  .bk-detail-header { flex-direction: column; }
  .bk-drow { flex-wrap: wrap; }
  .bk-drow-actions { width: 100%; justify-content: flex-end; margin-top: 6px; }
  .bk-provider-types { grid-template-columns: 1fr 1fr; }
  .bk-toolbar { flex-direction: column; align-items: stretch; }
  .bk-toolbar-left { flex-wrap: wrap; }
}
.text-xs { font-size: 0.75rem; }
.text-sm { font-size: 0.82rem; }
.text-center { text-align: center; }
.text-muted { color: var(--text-muted); }

/* ── DNS Export Button & Dropdown ── */
.dns-export-wrap { position: relative; display: inline-flex; margin: 12px 0 4px; }
.dns-export-btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 7px 14px; border-radius: 8px;
  background: var(--bg-card); color: var(--text-primary);
  font-size: 0.8em; font-weight: 600; font-family: inherit;
  border: 1px solid var(--border); cursor: pointer;
  transition: all 0.2s;
}
.dns-export-btn svg { flex-shrink: 0; }
.dns-export-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--bg-hover); }
.dns-export-btn:active { transform: scale(0.97); }
.dns-export-chevron { transition: transform 0.2s; margin-left: 2px; }
.dns-export-wrap.dns-export--open .dns-export-chevron { transform: rotate(180deg); }
.dns-export-menu {
  position: absolute; top: calc(100% + 5px); left: 0; z-index: 9999;
  min-width: 280px; background: rgb(17, 20, 48); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: 0 8px 28px rgba(0,0,0,0.35);
  opacity: 0; visibility: hidden; transform: translateY(-4px) scale(0.98);
  transition: opacity 0.15s, visibility 0.15s, transform 0.15s;
  overflow: hidden; backdrop-filter: none;
}
.dns-export-menu--open { opacity: 1; visibility: visible; transform: translateY(0) scale(1); }
.dns-export-opt {
  display: flex; align-items: center; gap: 10px; width: 100%;
  padding: 9px 13px; border: none; background: transparent;
  cursor: pointer; text-align: left; transition: background 0.12s;
  color: var(--text-primary); font-family: inherit; font-size: 0.82em; line-height: 1.4;
}
.dns-export-opt:hover { background: var(--bg-hover); }
.dns-export-opt:not(:last-child) { border-bottom: 1px solid var(--border); }
.dns-fmt-icon { font-size: 1.15em; width: 24px; text-align: center; flex-shrink: 0; }
.dns-fmt-info { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.dns-fmt-info strong { font-size: 0.85em; font-weight: 600; color: var(--text-heading); }
.dns-fmt-info small { font-size: 0.72em; color: var(--text-muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ═══════════════════════════════════════════════════════════════════
   SSL / TLS  —  Full Management Styles
   ═══════════════════════════════════════════════════════════════════ */

/* Tabs */
.ssl-tabs {
  display: flex; gap: 4px; margin: 0 0 16px 0;
  border-bottom: 2px solid var(--border);
  overflow-x: auto;
}
.ssl-tab {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px; background: transparent; border: none;
  border-bottom: 3px solid transparent; margin-bottom: -2px;
  color: var(--text-muted); font-weight: 500; font-size: .95em;
  cursor: pointer; transition: color .15s, border-color .15s, background .15s;
  white-space: nowrap;
}
.ssl-tab:hover { color: var(--text); background: var(--bg-hover, rgba(0,0,0,.03)); }
.ssl-tab.active { color: var(--primary, #0d6efd); border-bottom-color: var(--primary, #0d6efd); }
.ssl-tab-count {
  display: inline-block; min-width: 22px; padding: 2px 8px;
  background: var(--border); color: var(--text-muted);
  border-radius: 10px; font-size: .75em; font-weight: 600; text-align: center;
}
.ssl-tab.active .ssl-tab-count { background: var(--primary, #0d6efd); color: #fff; }
.ssl-tab-panel { animation: sslFadeIn .2s ease-out; }
@keyframes sslFadeIn { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

/* Dashboard cards */
.ssl-dashboard {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px; margin-bottom: 16px;
}
.ssl-card {
  display: flex; align-items: center; gap: 12px;
  padding: 16px 18px; border-radius: 10px;
  background: var(--bg-card); border: 1px solid var(--border);
  transition: transform .15s, box-shadow .15s;
}
.ssl-card:hover { transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.08); }
.ssl-card > i { font-size: 1.6em; opacity: .7; }
.ssl-card-body { display: flex; flex-direction: column; }
.ssl-card-num { font-size: 1.5em; font-weight: 700; line-height: 1.1; }
.ssl-card-label { font-size: .75em; color: var(--text-muted); margin-top: 2px; }
.ssl-card-active { border-left: 3px solid var(--success); }
.ssl-card-active > i { color: var(--success); }
.ssl-card-warning { border-left: 3px solid var(--warning); }
.ssl-card-warning > i { color: var(--warning); }
.ssl-card-danger { border-left: 3px solid var(--danger); }
.ssl-card-danger > i { color: var(--danger); }
.ssl-card-muted { opacity: .55; }
.ssl-card-info { border-left: 3px solid var(--info, #17a2b8); }
.ssl-card-info > i { color: var(--info, #17a2b8); }

/* Auto-renewal bar */
.ssl-renewal-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px; border-radius: 8px;
  background: var(--bg-card); border: 1px solid var(--border);
  margin-bottom: 14px; flex-wrap: wrap; gap: 8px;
}
.ssl-renewal-status { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.ssl-scheduler-badge {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 3px 10px; border-radius: 20px; font-size: .78em; font-weight: 600;
}
.ssl-sched-on { background: rgba(40,167,69,.12); color: var(--success); }
.ssl-sched-off { background: rgba(108,117,125,.12); color: var(--text-muted); }

/* Action bar */
.ssl-action-bar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px; gap: 10px; flex-wrap: wrap;
}
.ssl-action-left { flex: 0 0 240px; }
.ssl-action-right { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.ssl-search {
  border-radius: 6px; border: 1px solid var(--border);
  background: var(--bg-input, var(--bg-card)); padding: 5px 10px;
}

/* Certificate table */
.ssl-table-wrap { overflow-x: auto; }
.ssl-table {
  width: 100%; border-collapse: collapse;
  font-size: .85em;
}
.ssl-table th {
  text-align: left; padding: 8px 10px; font-size: .72em;
  text-transform: uppercase; letter-spacing: .04em; color: var(--text-muted);
  border-bottom: 2px solid var(--border); white-space: nowrap;
}
.ssl-table td { padding: 10px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.ssl-row { transition: background .12s; }
.ssl-row:hover { background: var(--bg-hover); }
.ssl-domain-cell { display: flex; align-items: center; gap: 8px; }
.ssl-domain-cell > i { font-size: 1.2em; }
.ssl-domain-name { display: block; font-size: .9em; }

/* Provider badges */
.ssl-prov {
  display: inline-block; padding: 2px 8px; border-radius: 4px;
  font-size: .72em; font-weight: 600;
  background: var(--bg-hover); color: var(--text-secondary);
}
.ssl-prov-le { background: rgba(0,128,0,.1); color: #2e7d32; }
.ssl-prov-custom { background: rgba(0,90,180,.1); color: #1565c0; }
.ssl-prov-self { background: rgba(255,152,0,.12); color: #e65100; }

/* Action buttons cell */
.ssl-actions-cell { display: flex; gap: 4px; flex-wrap: nowrap; }
.ssl-auto-toggle { margin: 0; }

/* Detail modal grid */
.ssl-detail-grid { display: flex; flex-direction: column; gap: 16px; }
.ssl-detail-section {
  padding: 12px 14px; border-radius: 8px;
  background: var(--bg-card); border: 1px solid var(--border);
}
.ssl-detail-section h6 {
  margin: 0 0 10px; font-size: .82em; font-weight: 700;
  color: var(--text-heading); display: flex; align-items: center; gap: 6px;
}
.ssl-detail-row {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 4px 0; gap: 12px;
}
.ssl-detail-row > span:first-child {
  flex: 0 0 110px; font-size: .78em; color: var(--text-muted); font-weight: 500;
}
.ssl-sans-wrap { display: flex; flex-wrap: wrap; gap: 4px; }
.ssl-san-tag {
  padding: 1px 6px; border-radius: 3px; font-size: .72em;
  background: var(--bg-hover); color: var(--text-secondary);
}
.ssl-mono { font-family: 'JetBrains Mono', 'Fira Code', monospace; }
.ssl-fp { word-break: break-all; max-width: 320px; }

/* SSL test modal */
.ssl-test-header {
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 16px; padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.ssl-grade {
  width: 64px; height: 64px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 2em; font-weight: 800; flex-shrink: 0;
}
.ssl-grade-a { background: rgba(40,167,69,.15); color: #28a745; }
.ssl-grade-b { background: rgba(255,193,7,.15); color: #d4a017; }
.ssl-grade-c { background: rgba(255,152,0,.15); color: #e65100; }
.ssl-grade-f { background: rgba(220,53,69,.15); color: #dc3545; }
.ssl-test-domain h5 { margin: 0; font-size: 1em; }
.ssl-test-grid { display: flex; flex-direction: column; gap: 12px; }
.ssl-test-section {
  padding: 10px 14px; border-radius: 8px;
  background: var(--bg-card); border: 1px solid var(--border);
}
.ssl-test-section h6 {
  margin: 0 0 8px; font-size: .78em; font-weight: 700;
  color: var(--text-heading); display: flex; align-items: center; gap: 6px;
}
.ssl-test-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 3px 0; font-size: .82em;
}
.ssl-test-protos { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 6px; }
.ssl-test-proto {
  padding: 4px 10px; border-radius: 5px; font-size: .78em; font-weight: 600;
}
.ssl-proto-ok { background: rgba(40,167,69,.1); color: #28a745; }
.ssl-proto-warn { background: rgba(255,152,0,.12); color: #e65100; }
.ssl-proto-off { background: rgba(108,117,125,.08); color: var(--text-muted); text-decoration: line-through; }
.ssl-test-warn {
  padding: 6px 10px; border-radius: 5px; font-size: .75em;
  background: rgba(255,152,0,.1); color: #e65100;
  display: flex; align-items: center; gap: 5px;
}

/* SSL check tool */
.ssl-check-ok, .ssl-check-fail {
  padding: 14px; border-radius: 8px; text-align: center;
}
.ssl-check-ok { background: rgba(40,167,69,.06); border: 1px solid rgba(40,167,69,.2); }
.ssl-check-fail { background: rgba(220,53,69,.06); border: 1px solid rgba(220,53,69,.2); }
.ssl-check-icon { font-size: 2em; margin-bottom: 6px; }

/* TLS config form */
.ssl-config-form { display: flex; flex-direction: column; gap: 10px; }
.ssl-proto-checks { display: flex; gap: 16px; margin: 6px 0; }
.ssl-proto-check {
  display: flex; align-items: center; gap: 6px;
  font-size: .85em; cursor: pointer;
}
.ssl-proto-check input { margin: 0; }

/* Warning box (self-signed) */
.ssl-warning-box {
  padding: 10px 14px; border-radius: 6px;
  background: rgba(255,152,0,.1); border: 1px solid rgba(255,152,0,.25);
  color: #e65100; font-size: .82em;
  display: flex; align-items: center; gap: 8px;
}

/* CAA box */
.ssl-caa-box {
  padding: 10px 14px; border-radius: 6px;
  background: var(--bg-card); border: 1px solid var(--border);
  font-size: .82em;
}


/* ═══════════════════════════════════════════════════════════
   Webmail v2 enhancements — attachments, nav, contacts, block
   ═══════════════════════════════════════════════════════════ */

/* Prev/Next nav + counter in reader toolbar */
.wm-reader-toolbar .wm-nav-counter {
  font-size: 0.72rem; color: var(--text-muted); padding: 0 6px;
  align-self: center; letter-spacing: 0.3px;
}
.wm-reader-toolbar .wm-fmt-sep {
  display: inline-block; width: 1px; height: 20px;
  background: var(--border); margin: 0 4px; align-self: center;
}

/* Reader subject row with per-sender actions */
.wm-reader-subject-row {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 10px;
}
.wm-reader-subject-row .wm-reader-subject { flex: 1; }
.wm-reader-sender-actions {
  display: flex; gap: 6px; flex-shrink: 0;
}
.wm-reader-sender-actions .btn-xs {
  font-size: 0.72rem; padding: 2px 8px; border-radius: 12px;
}

/* Blocked-sender banner */
.wm-blocked-banner {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 18px; background: rgba(239, 68, 68, 0.1);
  border-bottom: 1px solid rgba(239, 68, 68, 0.3);
  color: #fca5a5; font-size: 0.82rem;
}
.wm-blocked-banner .btn-link { color: #fca5a5; padding: 0 4px; font-size: 0.8rem; text-decoration: underline; }

/* Image attachment gallery (inline previews) */
.wm-att-gallery {
  display: flex; flex-wrap: wrap; gap: 10px;
  padding: 10px 18px; border-bottom: 1px solid rgba(99, 102, 241, 0.06);
}
.wm-att-thumb {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 6px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg-card); text-decoration: none;
  max-width: 160px; transition: all 0.15s;
}
.wm-att-thumb:hover { border-color: var(--accent); transform: translateY(-2px); }
.wm-att-thumb img {
  max-width: 140px; max-height: 140px; width: auto; height: auto;
  border-radius: 4px; object-fit: contain; background: #000;
}
.wm-att-thumb-name {
  font-size: 0.7rem; color: var(--text-muted); max-width: 140px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* Quoted-text toggle in plain-text reader */
.wm-quote-toggle {
  display: inline-block; margin: 4px 0; padding: 0 8px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; color: var(--text-muted);
  font-family: inherit; font-size: 0.8rem; cursor: pointer;
  letter-spacing: 2px; line-height: 1.4;
}
.wm-quote-toggle:hover { border-color: var(--accent); color: var(--accent); }
.wm-quote-block {
  display: none; color: var(--text-muted);
  padding-left: 10px; border-left: 3px solid var(--border);
  white-space: pre-wrap;
}
.wm-quote-block.wm-quote-open { display: inline-block; }

/* Compose: Cc/Bcc toggle link */
.wm-ccbcc-toggle {
  background: none; border: none; color: var(--accent);
  font-size: 0.75rem; padding: 0 6px; cursor: pointer;
  text-decoration: none; letter-spacing: 0.3px;
  flex-shrink: 0;
}
.wm-ccbcc-toggle:hover { text-decoration: underline; }

/* Autosave status */
.wm-autosave-status {
  font-size: 0.72rem; color: var(--text-muted); margin-left: 12px;
  opacity: 0.8; letter-spacing: 0.2px;
}
.wm-autosave-status.saved { color: #4ade80; }

/* Attachment chips in compose */
.wm-attach-list {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin: 6px 0 8px; min-height: 0;
}
.wm-attach-list:empty { margin: 0; }
.wm-attach-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 8px 4px 10px; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: 14px;
  font-size: 0.76rem; color: var(--text-primary); max-width: 260px;
}
.wm-attach-chip i { color: var(--accent); font-size: 0.9rem; }
.wm-attach-chip .wm-attach-chip-name {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 150px;
}
.wm-attach-chip small { color: var(--text-muted); font-size: 0.7rem; }
.wm-attach-chip-rm {
  background: none; border: none; color: var(--text-muted);
  cursor: pointer; font-size: 1.1rem; line-height: 1; padding: 0 2px;
  transition: color 0.15s;
}
.wm-attach-chip-rm:hover { color: #ef4444; }

/* Drag-and-drop overlay for compose */
.wm-compose-body-wrap { position: relative; }
.wm-drop-overlay {
  position: absolute; inset: 0; display: none;
  align-items: center; justify-content: center; gap: 10px;
  background: rgba(79, 70, 229, 0.12);
  border: 2px dashed var(--accent); border-radius: 8px;
  color: var(--accent); font-weight: 600; font-size: 0.95rem;
  pointer-events: none; z-index: 5;
}
.wm-compose-body-wrap.drag-over .wm-drop-overlay {
  display: flex;
}

/* Shrink Cc/Bcc toggle + priority row on small screens */
@media (max-width: 600px) {
  .wm-reader-subject-row { flex-direction: column; }
  .wm-reader-sender-actions { width: 100%; }
  .wm-att-thumb { max-width: 120px; }
  .wm-att-thumb img { max-width: 100px; max-height: 100px; }
}
/* ═══════════════════════════════════════════════════════════
   Webmail v2 enhancements — attachments, nav, contacts, block
   ═══════════════════════════════════════════════════════════ */

/* Prev/Next nav + counter in reader toolbar */
.wm-reader-toolbar .wm-nav-counter {
  font-size: 0.72rem; color: var(--text-muted); padding: 0 6px;
  align-self: center; letter-spacing: 0.3px;
}
.wm-reader-toolbar .wm-fmt-sep {
  display: inline-block; width: 1px; height: 20px;
  background: var(--border); margin: 0 4px; align-self: center;
}

/* Reader subject row with per-sender actions */
.wm-reader-subject-row {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 10px;
}
.wm-reader-subject-row .wm-reader-subject { flex: 1; }
.wm-reader-sender-actions {
  display: flex; gap: 6px; flex-shrink: 0;
}
.wm-reader-sender-actions .btn-xs {
  font-size: 0.72rem; padding: 2px 8px; border-radius: 12px;
}

/* Blocked-sender banner */
.wm-blocked-banner {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 18px; background: rgba(239, 68, 68, 0.1);
  border-bottom: 1px solid rgba(239, 68, 68, 0.3);
  color: #fca5a5; font-size: 0.82rem;
}
.wm-blocked-banner .btn-link { color: #fca5a5; padding: 0 4px; font-size: 0.8rem; text-decoration: underline; }

/* Image attachment gallery (inline previews) */
.wm-att-gallery {
  display: flex; flex-wrap: wrap; gap: 10px;
  padding: 10px 18px; border-bottom: 1px solid rgba(99, 102, 241, 0.06);
}
.wm-att-thumb {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 6px; border: 1px solid var(--border); border-radius: 8px;
  background: var(--bg-card); text-decoration: none;
  max-width: 160px; transition: all 0.15s;
}
.wm-att-thumb:hover { border-color: var(--accent); transform: translateY(-2px); }
.wm-att-thumb img {
  max-width: 140px; max-height: 140px; width: auto; height: auto;
  border-radius: 4px; object-fit: contain; background: #000;
}
.wm-att-thumb-name {
  font-size: 0.7rem; color: var(--text-muted); max-width: 140px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* Quoted-text toggle in plain-text reader */
.wm-quote-toggle {
  display: inline-block; margin: 4px 0; padding: 0 8px;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 10px; color: var(--text-muted);
  font-family: inherit; font-size: 0.8rem; cursor: pointer;
  letter-spacing: 2px; line-height: 1.4;
}
.wm-quote-toggle:hover { border-color: var(--accent); color: var(--accent); }
.wm-quote-block {
  display: none; color: var(--text-muted);
  padding-left: 10px; border-left: 3px solid var(--border);
  white-space: pre-wrap;
}
.wm-quote-block.wm-quote-open { display: inline-block; }

/* Compose: Cc/Bcc toggle link */
.wm-ccbcc-toggle {
  background: none; border: none; color: var(--accent);
  font-size: 0.75rem; padding: 0 6px; cursor: pointer;
  text-decoration: none; letter-spacing: 0.3px;
  flex-shrink: 0;
}
.wm-ccbcc-toggle:hover { text-decoration: underline; }

/* Autosave status */
.wm-autosave-status {
  font-size: 0.72rem; color: var(--text-muted); margin-left: 12px;
  opacity: 0.8; letter-spacing: 0.2px;
}
.wm-autosave-status.saved { color: #4ade80; }

/* Attachment chips in compose */
.wm-attach-list {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin: 6px 0 8px; min-height: 0;
}
.wm-attach-list:empty { margin: 0; }
.wm-attach-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 8px 4px 10px; background: var(--bg-card);
  border: 1px solid var(--border); border-radius: 14px;
  font-size: 0.76rem; color: var(--text-primary); max-width: 260px;
}
.wm-attach-chip i { color: var(--accent); font-size: 0.9rem; }
.wm-attach-chip .wm-attach-chip-name {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  max-width: 150px;
}
.wm-attach-chip small { color: var(--text-muted); font-size: 0.7rem; }
.wm-attach-chip-rm {
  background: none; border: none; color: var(--text-muted);
  cursor: pointer; font-size: 1.1rem; line-height: 1; padding: 0 2px;
  transition: color 0.15s;
}
.wm-attach-chip-rm:hover { color: #ef4444; }

/* Drag-and-drop overlay for compose */
.wm-compose-body-wrap { position: relative; }
.wm-drop-overlay {
  position: absolute; inset: 0; display: none;
  align-items: center; justify-content: center; gap: 10px;
  background: rgba(79, 70, 229, 0.12);
  border: 2px dashed var(--accent); border-radius: 8px;
  color: var(--accent); font-weight: 600; font-size: 0.95rem;
  pointer-events: none; z-index: 5;
}
.wm-compose-body-wrap.drag-over .wm-drop-overlay {
  display: flex;
}

/* Shrink Cc/Bcc toggle + priority row on small screens */
@media (max-width: 600px) {
  .wm-reader-subject-row { flex-direction: column; }
  .wm-reader-sender-actions { width: 100%; }
  .wm-att-thumb { max-width: 120px; }
  .wm-att-thumb img { max-width: 100px; max-height: 100px; }
}