/* =============================================
   Capix Nexus v2
   Apple / Shadcn-inspired · Metallic Red & Black
   ============================================= */

:root {
  --bg: #050505;
  --bg-elevated: #0c0c0c;
  --bg-surface: #111111;
  --bg-card: rgba(255,255,255,0.03);
  --bg-card-hover: rgba(255,255,255,0.06);
  --bg-glass: rgba(10,10,10,0.85);
  --bg-sidebar: rgba(8,8,8,0.95);
  --text: #f5f5f7;
  --text-secondary: rgba(245,245,247,0.6);
  --text-tertiary: rgba(245,245,247,0.32);
  --red: #cc0000;
  --red-hover: #e61919;
  --red-subtle: rgba(204,0,0,0.12);
  --red-glow: rgba(204,0,0,0.2);
  --red-muted: rgba(204,0,0,0.06);
  --green: #22c55e;
  --green-subtle: rgba(34,197,94,0.1);
  --yellow: #f59e0b;
  --yellow-subtle: rgba(245,158,11,0.1);
  --amber: #f97316;
  --border: rgba(255,255,255,0.06);
  --border-hover: rgba(255,255,255,0.1);
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.3);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.25);
  --shadow-lg: 0 8px 40px rgba(0,0,0,0.35);
  --shadow-glow: 0 0 20px var(--red-glow);
  --transition: 0.2s cubic-bezier(0.25,0.1,0.25,1);
  --transition-slow: 0.4s cubic-bezier(0.25,0.1,0.25,1);
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --mono: 'JetBrains Mono', 'SF Mono', 'Fira Code', monospace;
  --sidebar-w: 260px;
  --topbar-h: 56px;
}

/* =============================================
   RESET
   ============================================= */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit;border:none;background:none;color:inherit}
input{font-family:inherit}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,0.08);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,0.14)}

/* =============================================
   LOGIN
   ============================================= */
.login-screen {
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;
  background: radial-gradient(ellipse at 50% 25%, rgba(204,0,0,0.05) 0%, transparent 55%),
              radial-gradient(ellipse at 80% 70%, rgba(204,0,0,0.025) 0%, transparent 45%),
              var(--bg);
  padding:20px;
}
.login-container {
  background:var(--bg-glass);backdrop-filter:blur(60px) saturate(1.5);
  -webkit-backdrop-filter:blur(60px) saturate(1.5);
  border:1px solid var(--border);border-radius:24px;padding:52px 44px;
  width:100%;max-width:400px;box-shadow:var(--shadow-lg);
  animation:loginIn 0.5s ease;
}
@keyframes loginIn{from{opacity:0;transform:translateY(24px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.login-logo{text-align:center;margin-bottom:36px}
.login-logo img{width:72px;height:72px;border-radius:16px;margin-bottom:14px;box-shadow:0 0 30px var(--red-glow)}
.login-logo h1{font-size:28px;font-weight:700;letter-spacing:-0.5px;background:linear-gradient(135deg,#cc0000,#ff3333);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.login-logo p{font-size:13px;color:var(--text-secondary);margin-top:4px}
.login-form{display:flex;flex-direction:column;gap:14px}
.login-form input{width:100%;padding:14px 18px;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text);font-size:15px;transition:var(--transition);outline:none}
.login-form input:focus{border-color:var(--red);background:rgba(255,255,255,0.08);box-shadow:0 0 0 3px var(--red-glow)}
.login-form input::placeholder{color:var(--text-tertiary)}
.login-error{color:var(--red-hover);font-size:13px;text-align:center;min-height:20px;opacity:0;transition:var(--transition)}
.login-error.show{opacity:1}
.login-btn{padding:14px;background:linear-gradient(135deg,#cc0000,#e61919);border:none;border-radius:var(--radius-md);color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:var(--transition);letter-spacing:0.3px}
.login-btn:hover{transform:translateY(-1px);box-shadow:0 4px 24px var(--red-glow)}
.login-btn:active{transform:translateY(0)}
.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.login-footer{text-align:center;margin-top:28px;font-size:11px;color:var(--text-tertiary);letter-spacing:0.8px;text-transform:uppercase}
.login-footer strong{color:var(--text-secondary);font-weight:600}

/* =============================================
   LAYOUT
   ============================================= */
.app-layout{display:flex;min-height:100vh}

/* Sidebar */
.sidebar{
  width:var(--sidebar-w);position:fixed;top:0;left:0;bottom:0;z-index:50;
  background:var(--bg-sidebar);backdrop-filter:blur(40px) saturate(1.4);
  -webkit-backdrop-filter:blur(40px) saturate(1.4);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  transition:transform var(--transition-slow);
  overflow:hidden;
}
.sidebar-brand{
  display:flex;align-items:center;gap:12px;padding:16px 20px;
  border-bottom:1px solid var(--border);min-height:64px;
}
.sidebar-brand img{width:36px;height:36px;border-radius:10px}
.sidebar-brand-text{font-size:18px;font-weight:700;background:linear-gradient(135deg,#cc0000,#ff3333);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-0.3px}
.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}
.nav-section-title{font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1.2px;padding:16px 12px 6px}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:10px 14px;margin-bottom:2px;
  border-radius:var(--radius-sm);font-size:14px;font-weight:500;
  color:var(--text-secondary);transition:var(--transition);cursor:pointer;user-select:none;
}
.nav-item:hover{color:var(--text);background:var(--bg-card-hover)}
.nav-item.active{color:var(--red-hover);background:var(--red-subtle)}
.nav-item svg{flex-shrink:0;opacity:.7}.nav-item.active svg{opacity:1}
.nav-badge{
  margin-left:auto;font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;
  background:var(--red-subtle);color:var(--red-hover);
}
.sidebar-footer{
  padding:12px 16px;border-top:1px solid var(--border);
  font-size:9px;color:var(--text-tertiary);text-transform:none;letter-spacing:0.4px;
  text-align:center;line-height:1.5;min-height:44px;
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:3px;
}
.sidebar-footer strong{color:var(--text-secondary);font-weight:600}

/* Main */
.main-area{margin-left:var(--sidebar-w);flex:1;min-height:100vh;display:flex;flex-direction:column}

/* Top bar */
.topbar{
  height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;background:var(--bg-glass);backdrop-filter:blur(40px) saturate(1.4);
  -webkit-backdrop-filter:blur(40px) saturate(1.4);
  border-bottom:1px solid var(--border);position:sticky;top:0;z-index:40;
}
.topbar-left{display:flex;align-items:center;gap:16px}
.topbar-title{font-size:16px;font-weight:600;letter-spacing:-0.2px}
.topbar-right{display:flex;align-items:center;gap:12px}
.live-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.live-label{font-size:12px;color:var(--green);font-weight:500}
.logout-btn{
  font-size:12px;font-weight:500;padding:7px 16px;border:1px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text-secondary);transition:var(--transition);
}
.logout-btn:hover{color:var(--text);border-color:var(--border-hover);background:var(--bg-card-hover)}

/* Content */
.content{padding:28px;flex:1;max-width:1400px;width:100%;margin:0 auto}
.section{display:none;animation:fadeSlide .35s ease}
.section.active{display:block}
@keyframes fadeSlide{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.section-header{margin-bottom:24px}
.section-header h2{font-size:24px;font-weight:700;letter-spacing:-0.4px;margin-bottom:4px}
.section-header p{font-size:14px;color:var(--text-secondary)}
.section-actions{display:flex;gap:8px;margin-top:12px}

/* =============================================
   CARDS
   ============================================= */
.card{
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:20px 24px;
  transition:var(--transition);
}
.card:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-title{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:0.6px}
.card-value{font-size:32px;font-weight:700;letter-spacing:-1px;line-height:1.1}

/* Grids */
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:1200px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}

/* Metric card */
.metric-card{position:relative;overflow:hidden}
.metric-card .card-icon{
  position:absolute;top:16px;right:16px;width:40px;height:40px;
  border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;
  opacity:.5;
}
.metric-card .card-icon.red{background:var(--red-muted);color:var(--red)}
.metric-card .card-icon.green{background:var(--green-subtle);color:var(--green)}
.metric-card .card-icon.yellow{background:var(--yellow-subtle);color:var(--yellow)}
.metric-card .card-icon.amber{background:rgba(249,115,22,0.1);color:var(--amber)}
.metric-card .card-sub{font-size:12px;color:var(--text-tertiary);margin-top:4px;font-weight:400}

/* Bar in card */
.metric-bar{height:3px;background:rgba(255,255,255,0.06);border-radius:2px;margin-top:10px;overflow:hidden}
.metric-bar-fill{height:100%;border-radius:2px;transition:width 0.6s cubic-bezier(.25,.1,.25,1)}
.metric-bar-fill.red{background:linear-gradient(90deg,#cc0000,#ff3333)}
.metric-bar-fill.green{background:linear-gradient(90deg,#22c55e,#4ade80)}
.metric-bar-fill.yellow{background:linear-gradient(90deg,#f59e0b,#fbbf24)}

/* Info card */
.info-card{
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:14px 18px;transition:var(--transition);
}
.info-card:hover{border-color:var(--border-hover);background:var(--bg-card)}
.info-label{font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}
.info-value{font-size:14px;font-weight:500;word-break:break-all}

/* Service card */
.service-card{
  display:flex;align-items:center;justify-content:space-between;
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px 20px;transition:var(--transition);
}
.service-card:hover{border-color:var(--border-hover);background:var(--bg-card)}
.service-left{display:flex;align-items:center;gap:14px}
.service-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.service-dot.running{background:var(--green);box-shadow:0 0 8px rgba(34,197,94,0.35)}
.service-dot.stopped{background:var(--red);box-shadow:0 0 8px var(--red-glow)}
.service-dot.inactive,.service-dot.unknown{background:var(--text-tertiary)}
.service-name{font-size:14px;font-weight:500}
.service-status{font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px;text-transform:capitalize}
.service-status.running{color:var(--green);background:var(--green-subtle)}
.service-status.stopped{color:var(--red);background:var(--red-subtle)}
.service-btn{
  font-size:11px;font-weight:500;padding:5px 12px;border:1px solid var(--border);
  border-radius:var(--radius-xs);color:var(--text-secondary);transition:var(--transition);margin-left:8px
}
.service-btn:hover{color:var(--text);border-color:var(--border-hover);background:var(--bg-card-hover)}

/* Process card */
.process-card{
  display:grid;grid-template-columns:60px 50px 1fr 60px 60px;
  gap:12px;padding:10px 16px;border-bottom:1px solid var(--border);
  font-size:13px;align-items:center;
}
.process-card:last-child{border-bottom:none}
.process-card .proc-cmd{font-family:var(--mono);font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.process-card .proc-pid{color:var(--text-tertiary);font-family:var(--mono);font-size:12px}
.process-card .proc-cpu{font-weight:600}
.process-card .proc-mem{font-weight:600}
.process-header{color:var(--text-tertiary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px}

/* Project card */
.project-card{
  display:flex;align-items:center;justify-content:space-between;
  border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px 20px;transition:var(--transition);
}
.project-card:hover{border-color:var(--border-hover);background:var(--bg-card)}
.project-left h3{font-size:15px;font-weight:600;margin-bottom:2px}
.project-left p{font-size:13px;color:var(--text-secondary)}
.project-badge{font-size:10px;font-weight:700;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}
.project-badge.active{color:var(--green);background:var(--green-subtle)}
.project-badge.pending{color:var(--yellow);background:var(--yellow-subtle)}
.project-progress{width:120px}.project-progress .bar{height:4px;background:rgba(255,255,255,0.06);border-radius:2px;overflow:hidden;margin-top:4px}
.project-progress .bar-fill{height:100%;border-radius:2px;background:var(--red-gradient,linear-gradient(90deg,#cc0000,#ff3333));transition:width .6s}

/* Chart card */
.chart-card{padding:20px 24px}
.chart-card canvas{width:100%!important;height:200px!important;display:block}

/* Log viewer */
.log-viewer{
  background:rgba(0,0,0,0.4);border:1px solid var(--border);border-radius:var(--radius-md);
  padding:16px;max-height:500px;overflow-y:auto;font-family:var(--mono);font-size:12px;line-height:1.6;
}
.log-viewer .log-line{color:var(--text-secondary);white-space:pre-wrap;word-break:break-all}
.log-viewer .log-line:hover{color:var(--text);background:rgba(255,255,255,0.02)}

/* Status card */
.status-card{display:flex;align-items:center;gap:12px;padding:16px 20px;border:1px solid var(--border);border-radius:var(--radius-md);transition:var(--transition)}
.status-card:hover{border-color:var(--border-hover);background:var(--bg-card)}
.status-card .status-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px}
.status-card .status-value{font-size:15px;font-weight:600;margin-top:2px}

/* Info grid */
.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}

/* Loading skeleton */
.skeleton{background:linear-gradient(90deg,var(--bg-card) 25%,rgba(255,255,255,0.04) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skeleton-h{height:16px;margin-bottom:8px}.skeleton-w50{width:50%}.skeleton-w75{width:75%}.skeleton-w25{width:25%}

/* Tabs */
.tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:0}
.tab{font-size:13px;font-weight:500;padding:10px 18px;color:var(--text-secondary);border-bottom:2px solid transparent;transition:var(--transition);margin-bottom:-1px}
.tab:hover{color:var(--text)}
.tab.active{color:var(--red);border-bottom-color:var(--red)}

/* Log selector */
.log-selector{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.log-selector button{font-size:12px;font-weight:500;padding:6px 14px;border:1px solid var(--border);border-radius:20px;transition:var(--transition)}
.log-selector button:hover{border-color:var(--border-hover);color:var(--text)}
.log-selector button.active{background:var(--red-subtle);color:var(--red);border-color:var(--red)}

/* Toast */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:8px}
.toast{
  padding:12px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  box-shadow:var(--shadow-md);animation:toastIn .25s ease;max-width:360px;
}
.toast.success{background:rgba(34,197,94,0.15);border:1px solid rgba(34,197,94,0.3);color:var(--green)}
.toast.error{background:rgba(204,0,0,0.15);border:1px solid rgba(204,0,0,0.3);color:var(--red)}
.toast.info{background:rgba(59,130,246,0.15);border:1px solid rgba(59,130,246,0.3);color:#60a5fa}
@keyframes toastIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* Tool buttons */
.tool-btn{font-size:12px;font-weight:500;padding:6px 14px;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);transition:var(--transition);cursor:pointer}
.tool-btn:hover{background:rgba(255,255,255,0.1);color:var(--text)}.tool-btn.primary{background:var(--red-subtle);color:var(--red);border-color:var(--red)}.tool-btn.primary:hover{background:rgba(204,0,0,0.2)}
.tool-btn:disabled{opacity:.4;cursor:not-allowed}

/* Log line colors */
.log-line{padding:3px 12px;font-size:12px;font-family:var(--mono);border-bottom:1px solid rgba(255,255,255,0.02);display:flex;gap:8px}
.log-line:hover{background:rgba(255,255,255,0.02)}
.log-line.log-error{color:#ef4444;background:rgba(239,68,68,0.04)}
.log-line.log-warn{color:#f59e0b;background:rgba(245,158,11,0.04)}
.log-num{color:var(--text-tertiary);min-width:32px;text-align:right;user-select:none;font-size:10px;line-height:18px}

/* Toolbar */
.toolbar-row{display:flex;gap:8px;flex-wrap:wrap}
.toolbar-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);transition:var(--transition)}
.toolbar-btn:hover{background:rgba(255,255,255,0.05);color:var(--text)}

/* Service dot colors */
.service-dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.service-dot.running,.service-dot.active{background:#22c55e;box-shadow:0 0 8px rgba(34,197,94,0.3)}
.service-dot.stopped,.service-dot.inactive{background:var(--text-tertiary)}

/* Process card improvements */
.process-card{display:grid;grid-template-columns:60px 50px 1fr 60px 60px;gap:12px;padding:8px 16px;border-bottom:1px solid var(--border);font-size:13px;align-items:center;transition:var(--transition)}
.process-card:hover{background:rgba(255,255,255,0.02)}
.process-card:last-child{border-bottom:none}
.proc-cmd{font-family:var(--mono);font-size:12px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.proc-pid{color:var(--text-tertiary);font-family:var(--mono);font-size:12px}
.proc-cpu{font-weight:600}.proc-mem{font-weight:600}
.process-header{color:var(--text-tertiary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px}

/* Info grid */
.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.info-card{border:1px solid var(--border);border-radius:var(--radius-md);padding:14px 18px;transition:var(--transition)}
.info-card:hover{border-color:var(--border-hover)}
.info-label{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.info-value{font-size:14px;font-weight:600}

/* Project card */
.project-card{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 20px;transition:var(--transition);margin-bottom:8px}
.project-card:hover{border-color:var(--border-hover);background:var(--bg-card)}
.project-left h3{font-size:15px;font-weight:600;margin-bottom:2px}
.project-left p{font-size:13px;color:var(--text-secondary);margin-bottom:2px}
.project-badge{font-size:10px;font-weight:700;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}
.project-badge.active{color:var(--green);background:var(--green-subtle)}
.project-badge.pending{color:var(--yellow);background:var(--yellow-subtle)}
.project-badge.high{color:var(--red);background:var(--red-subtle)}
.project-badge.medium{color:var(--amber);background:var(--yellow-subtle)}
.project-badge.low{color:var(--text-tertiary);background:rgba(255,255,255,0.04)}
.project-badge.goal{color:var(--amber);background:var(--yellow-subtle)}
.project-progress{width:120px;text-align:right}
.project-progress .bar{height:4px;background:rgba(255,255,255,0.06);border-radius:2px;overflow:hidden;margin-top:4px}
.project-progress .bar-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,#cc0000,#ff3333);transition:width .6s}

/* Service status colors */
.service-status.running{color:var(--green);background:var(--green-subtle)}
.service-status.stopped{color:var(--text-tertiary);background:rgba(255,255,255,0.04)}
.service-status.warning{color:var(--yellow);background:var(--yellow-subtle)}
.service-status.danger{color:var(--red);background:var(--red-subtle)}
.service-status.critical{color:#fff;background:rgba(204,0,0,0.4)}
.service-status.ok{color:var(--green);background:var(--green-subtle)}
.service-status.info{color:#60a5fa;background:rgba(59,130,246,0.1)}
.service-status{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600}

/* Service card */
.service-card{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--border);border-radius:var(--radius-md);padding:16px 20px;transition:var(--transition);margin-bottom:8px}
.service-card:hover{border-color:var(--border-hover)}
.service-left{display:flex;align-items:center;gap:12px}
.service-name{font-size:14px;font-weight:600}
.service-btn{font-size:11px;padding:5px 12px;border:1px solid var(--border);border-radius:var(--radius-xs);color:var(--text-secondary);transition:var(--transition);cursor:pointer}
.service-btn:hover{background:rgba(255,255,255,0.05);color:var(--text)}
.service-btn:disabled{opacity:.3;cursor:not-allowed}

/* Log viewer */
.log-viewer{background:rgba(0,0,0,0.4);border:1px solid var(--border);border-radius:var(--radius-md);padding:0;max-height:500px;overflow-y:auto;font-size:12px;font-family:var(--mono);line-height:1.6}

/* Chart card */
.chart-card{padding:20px 24px}
.chart-card canvas{width:100%!important;height:200px!important;display:block}

/* Section header */
.section-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
.section-header h2{font-size:24px;font-weight:700;letter-spacing:-.4px;margin-bottom:4px}
.section-header p{font-size:13px;color:var(--text-secondary)}

/* Navigation section titles */
.nav-section-title{font-size:10px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;padding:16px 14px 6px}

/* Fullscreen adjustments */
.app-layout:fullscreen .topbar{padding:0 28px}
.app-layout:fullscreen .content{padding:24px 32px}

/* Grid helpers */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:900px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* Metric card */
.metric-card{position:relative;padding:20px 24px}
.metric-card .card-icon{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;opacity:.5}
.metric-card .card-icon.red{background:var(--red-subtle);color:var(--red)}
.metric-card .card-icon.green{background:var(--green-subtle);color:var(--green)}
.metric-card .card-icon.yellow{background:var(--yellow-subtle);color:var(--yellow)}
.metric-card .card-icon.amber{background:rgba(249,115,22,0.1);color:var(--amber)}
.card-value{font-size:28px;font-weight:800;letter-spacing:-1px;margin-bottom:4px}
.card-sub{font-size:12px;color:var(--text-tertiary);font-weight:400}
.metric-bar{height:4px;background:rgba(255,255,255,0.06);border-radius:2px;overflow:hidden;margin-top:8px}
.metric-bar-fill{height:100%;border-radius:2px;transition:width .6s cubic-bezier(.25,.1,.25,1)}
.metric-bar-fill.red{background:var(--red)}.metric-bar-fill.yellow{background:var(--yellow)}.metric-bar-fill.green{background:var(--green)}

/* Responsive */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main-area{margin-left:0}
  .content{padding:16px}
  .topbar{padding:0 16px}
  .sidebar-brand{padding:12px 16px}
  .sidebar-footer{display:none}
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
  .process-card{grid-template-columns:40px 1fr;font-size:12px}
  .process-card .proc-cpu,.process-card .proc-mem,.process-card .proc-pid{display:none}
  .project-progress{display:none}
  .tabs{overflow-x:auto;flex-wrap:nowrap;gap:0}
  .log-viewer{font-size:11px;max-height:350px}
}
.mobile-menu-btn{display:none}
@media(max-width:768px){
  .mobile-menu-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-secondary)}
}

/* =============================================
   ANIMATIONS — Life & Aesthetic
   ============================================= */

/* Keyframes */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes slideInDown{from{transform:translateY(-100%)}to{transform:translateY(0)}}
@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{transform:scale(1.05)}70%{transform:scale(.9)}100%{opacity:1;transform:scale(1)}}
@keyframes scaleIn{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
@keyframes rotateIn{from{opacity:0;transform:rotate(-180deg) scale(.3)}to{opacity:1;transform:rotate(0) scale(1)}}
@keyframes flipIn{from{opacity:0;transform:perspective(400px) rotateX(90deg)}to{opacity:1;transform:perspective(400px) rotateX(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 8px var(--red-glow)}50%{box-shadow:0 0 24px var(--red-glow)}}
@keyframes glow{0%,100%{box-shadow:0 0 5px var(--red-glow)}50%{box-shadow:0 0 20px var(--red-glow),0 0 40px var(--red-glow)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes shake{0%,100%{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}
@keyframes wave{0%{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}100%{transform:rotate(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes breathing{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.02);opacity:.8}}
@keyframes typing{from{width:0}to{width:100%}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes progressFill{from{width:0%}}
@keyframes countUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes ping{0%{transform:scale(1);opacity:1}75%,100%{transform:scale(2);opacity:0}}
@keyframes ringExpand{0%{transform:scale(1);opacity:1}100%{transform:scale(3);opacity:0}}
@keyframes neonPulse{0%,100%{text-shadow:0 0 7px var(--red),0 0 10px var(--red),0 0 21px var(--red),0 0 42px var(--red)}50%{text-shadow:0 0 14px var(--red),0 0 20px var(--red),0 0 42px var(--red),0 0 82px var(--red)}}
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes hueRotate{from{filter:hue-rotate(0)}to{filter:hue-rotate(360deg)}}
@keyframes slideDown{from{opacity:0;max-height:0}to{opacity:1;max-height:500px}}
@keyframes fadeSlide{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes glitch{0%{transform:translate(0)}20%{transform:translate(-3px,3px)}40%{transform:translate(3px,-3px)}60%{transform:translate(-2px,2px)}80%{transform:translate(2px,-1px)}100%{transform:translate(0)}}
@keyframes matrixRain{0%{transform:translateY(-100%)}100%{transform:translateY(100vh)}}
@keyframes textScramble{0%{opacity:0;filter:blur(10px);transform:scale(1.1)}100%{opacity:1;filter:blur(0);transform:scale(1)}}
@keyframes elasticIn{0%{transform:scale(0);opacity:0}60%{transform:scale(1.2)}80%{transform:scale(.95)}100%{transform:scale(1);opacity:1}}
@keyframes loadingDots{0%,80%,100%{opacity:0}40%{opacity:1}}
@keyframes colorPulse{0%,100%{color:var(--text)}50%{color:var(--red)}}
@keyframes borderGlow{0%,100%{border-color:var(--border)}50%{border-color:var(--red)}}
@keyframes shadowGrow{from{box-shadow:none}to{box-shadow:var(--shadow-lg)}}
@keyframes bounceDot{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes ripple{0%{transform:scale(0);opacity:.5}100%{transform:scale(4);opacity:0}}
@keyframes confettiFall{0%{transform:translateY(-10vh) rotate(0);opacity:1}100%{transform:translateY(100vh) rotate(720deg);opacity:0}}

/* Animation utility classes */
.anim-fade-in{animation:fadeIn .5s ease}
.anim-fade-up{animation:fadeInUp .5s ease}
.anim-fade-down{animation:fadeInDown .5s ease}
.anim-scale-in{animation:scaleIn .4s cubic-bezier(.25,.1,.25,1)}
.anim-bounce-in{animation:bounceIn .6s cubic-bezier(.25,.1,.25,1)}
.anim-slide-up{animation:slideInUp .4s ease}
.anim-rotate-in{animation:rotateIn .6s ease}
.anim-flip-in{animation:flipIn .6s ease}
.anim-elastic{animation:elasticIn .6s cubic-bezier(.68,-.55,.27,1.55)}
.anim-glitch{animation:glitch .3s ease}
.anim-shake{animation:shake .5s ease}
.anim-wave{animation:wave 1s ease}
.anim-float{animation:float 3s ease-in-out infinite}
.anim-breathing{animation:breathing 3s ease-in-out infinite}
.anim-pulse{animation:pulse 2s ease-in-out infinite}
.anim-glow{animation:glow 2s ease-in-out infinite}
.anim-spin{animation:spin 1s linear infinite}
.anim-neon{animation:neonPulse 2s ease-in-out infinite}
.anim-gradient{background-size:200% 200%;animation:gradientShift 4s ease infinite}
.anim-hue{animation:hueRotate 3s linear infinite}

/* Staggered entrance */
.stagger>*{opacity:0;animation:fadeInUp .4s ease forwards}
.stagger>*:nth-child(1){animation-delay:0ms}
.stagger>*:nth-child(2){animation-delay:60ms}
.stagger>*:nth-child(3){animation-delay:120ms}
.stagger>*:nth-child(4){animation-delay:180ms}
.stagger>*:nth-child(5){animation-delay:240ms}
.stagger>*:nth-child(6){animation-delay:300ms}
.stagger>*:nth-child(7){animation-delay:360ms}
.stagger>*:nth-child(8){animation-delay:420ms}
.stagger>*:nth-child(9){animation-delay:480ms}
.stagger>*:nth-child(10){animation-delay:540ms}

/* Loading dots */
.loading-dots{display:flex;gap:4px;align-items:center}
.loading-dots span{width:6px;height:6px;border-radius:50%;background:var(--red);animation:loadingDots 1.4s infinite}
.loading-dots span:nth-child(2){animation-delay:.2s}
.loading-dots span:nth-child(3){animation-delay:.4s}

/* Bounce dots */
.bounce-dots{display:flex;gap:4px;align-items:center}
.bounce-dots span{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary);animation:bounceDot 1.4s infinite}
.bounce-dots span:nth-child(2){animation-delay:.2s}
.bounce-dots span:nth-child(3){animation-delay:.4s}

/* Confetti */
.confetti-piece{position:fixed;width:10px;height:10px;z-index:9999;pointer-events:none;animation:confettiFall 3s ease-in forwards}

/* Particle */
.particle{position:fixed;width:3px;height:3px;background:var(--red);border-radius:50%;pointer-events:none;opacity:.3}

/* Top loading bar */
#loadingBar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--red),#ff6b6b);z-index:10000;transition:width .3s ease;border-radius:0 2px 2px 0}

/* Scroll progress */
#scrollProgress{position:fixed;top:0;left:0;height:2px;background:var(--red);z-index:9999;transition:width .1s linear}

/* Typing cursor */
.typing-cursor{display:inline-block;width:2px;height:1em;background:var(--red);margin-left:2px;animation:blink 1s step-end infinite;vertical-align:text-bottom}

/* Keyboard shortcuts modal */
.kbd-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);z-index:9000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}
.kbd-modal{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;max-width:480px;width:90%;max-height:80vh;overflow-y:auto;animation:scaleIn .3s ease}
.kbd-modal h2{font-size:18px;margin-bottom:16px}
.kbd-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.kbd-row kbd{background:rgba(255,255,255,.08);padding:3px 8px;border-radius:4px;font-family:var(--mono);font-size:11px;border:1px solid var(--border)}

/* Quick actions toolbar */
.quick-actions{display:flex;gap:6px;padding:8px 0}
.quick-action-btn{width:34px;height:34px;border-radius:var(--radius-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:var(--transition);font-size:16px}
.quick-action-btn:hover{background:rgba(255,255,255,.05);color:var(--text);border-color:var(--border-hover)}

/* Theme accent color variables */
[data-accent=red]{--red:#cc0000;--red-hover:#e61919;--red-subtle:rgba(204,0,0,0.12);--red-glow:rgba(204,0,0,0.2)}
[data-accent=blue]{--red:#2563eb;--red-hover:#3b82f6;--red-subtle:rgba(37,99,235,0.12);--red-glow:rgba(37,99,235,0.2)}
[data-accent=green]{--red:#16a34a;--red-hover:#22c55e;--red-subtle:rgba(22,163,74,0.12);--red-glow:rgba(22,163,74,0.2)}
[data-accent=purple]{--red:#7c3aed;--red-hover:#8b5cf6;--red-subtle:rgba(124,58,237,0.12);--red-glow:rgba(124,58,237,0.2)}
[data-accent=amber]{--red:#d97706;--red-hover:#f59e0b;--red-subtle:rgba(217,119,6,0.12);--red-glow:rgba(217,119,6,0.2)}
[data-accent=pink]{--red:#e11d48;--red-hover:#f43f5e;--red-subtle:rgba(225,29,72,0.12);--red-glow:rgba(225,29,72,0.2)}

/* Compact mode */
[data-mode=compact] .card{padding:12px 16px}
[data-mode=compact] .metric-card{padding:12px 16px}
[data-mode=compact] .card-value{font-size:22px}
[data-mode=compact] .section-header{margin-bottom:12px}
[data-mode=compact] .content{padding:12px 16px}
[data-mode=compact] .sidebar-brand{padding:10px 14px;min-height:52px}
[data-mode=compact] .topbar{height:44px;padding:0 16px}

/* Spacious mode */
[data-mode=spacious] .card{padding:28px 32px}
[data-mode=spacious] .metric-card{padding:28px 32px}
[data-mode=spacious] .content{padding:32px 40px}
[data-mode=spacious] .sidebar-brand{padding:20px 24px;min-height:72px}

/* Light theme */
[data-theme=light]{--bg:#f5f5f7;--bg-elevated:#fff;--bg-surface:#fff;--bg-card:rgba(0,0,0,0.02);--bg-card-hover:rgba(0,0,0,0.04);--bg-glass:rgba(255,255,255,0.85);--bg-sidebar:rgba(255,255,255,0.95);--text:#1d1d1f;--text-secondary:rgba(0,0,0,0.55);--text-tertiary:rgba(0,0,0,0.3);--border:rgba(0,0,0,0.08);--border-hover:rgba(0,0,0,0.12)}

/* Live clock in topbar */
.live-clock{font-size:12px;color:var(--text-tertiary);font-family:var(--mono);margin-right:12px;letter-spacing:.5px}

/* Sidebar right */
[data-sidebar=right] .sidebar{left:auto;right:0;border-right:none;border-left:1px solid var(--border)}
[data-sidebar=right] .main-area{margin-left:0;margin-right:var(--sidebar-w)}
@media(max-width:768px){[data-sidebar=right] .main-area{margin-right:0}}

/* Reduced motion */
@media(prefers-reduced-motion){.anim-fade-in,.anim-fade-up,.anim-bounce-in,.stagger>*,.anim-float,.anim-breathing,.anim-pulse{animation:none!important;opacity:1!important;transform:none!important}}

/* Live connection indicator */
.connection-status{display:inline-flex;align-items:center;gap:6px;font-size:11px;padding:4px 10px;border-radius:12px;border:1px solid var(--border);transition:var(--transition)}
.connection-status.online{color:#22c55e;border-color:rgba(34,197,94,.3)}
.connection-status.offline{color:#ef4444;border-color:rgba(239,68,68,.3);animation:glow 2s ease-in-out infinite}

/* FPS counter */
.fps-counter{position:fixed;bottom:8px;left:8px;font-size:10px;font-family:var(--mono);color:var(--text-tertiary);background:var(--bg-glass);padding:2px 8px;border-radius:4px;z-index:999;border:1px solid var(--border);opacity:.6}

/* Progress ring animation */
.progress-ring-circle{transition:stroke-dashoffset .6s cubic-bezier(.25,.1,.25,1);transform:rotate(-90deg);transform-origin:50% 50%}

/* Tooltip upgrades */
[data-tooltip]{position:relative}
[data-tooltip]:hover::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--bg-elevated);color:var(--text);font-size:11px;padding:4px 10px;border-radius:6px;border:1px solid var(--border);white-space:nowrap;z-index:100;animation:fadeIn .2s ease;box-shadow:var(--shadow-md)}

/* Neumorphism card style */
.card.neumorph{background:var(--bg-surface);box-shadow:inset 0 0 0 1px rgba(255,255,255,.02),4px 4px 12px rgba(0,0,0,.3),-4px -4px 12px rgba(255,255,255,.02);border:none}

/* Outline card style */
.card.outline{background:transparent;border:2px solid var(--border)}

/* Toast positions */
.toast-container.top-left{top:24px;left:24px;bottom:auto;right:auto}
.toast-container.top-right{top:24px;right:24px;bottom:auto;left:auto}
.toast-container.bottom-left{bottom:24px;left:24px;top:auto;right:auto}
.toast-container.bottom-right{bottom:24px;right:24px;top:auto;left:auto}

/* Calendar widget */
.calendar-widget{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;font-size:12px}
.calendar-widget .day{padding:6px;text-align:center;border-radius:4px;color:var(--text-secondary)}
.calendar-widget .day.today{background:var(--red-subtle);color:var(--red);font-weight:700}
.calendar-widget .day.other-month{opacity:.3}
.calendar-widget .day-header{font-size:10px;color:var(--text-tertiary);font-weight:600;text-transform:uppercase}

/* Weather widget */
.weather-widget{display:flex;align-items:center;gap:16px;padding:12px 0}
.weather-temp{font-size:32px;font-weight:700}
.weather-icon{font-size:36px}
.weather-detail{font-size:12px;color:var(--text-tertiary)}

/* Notification history */
.notif-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px;transition:var(--transition)}
.notif-item:hover{background:var(--bg-card)}
.notif-item .notif-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px}
.notif-item .notif-time{font-size:11px;color:var(--text-tertiary);white-space:nowrap}

/* Emoji reaction picker */
.reaction-picker{display:flex;gap:4px;padding:8px}
.reaction-btn{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;transition:var(--transition);cursor:pointer}
.reaction-btn:hover{background:var(--bg-card-hover);transform:scale(1.2)}

/* Notes widget */
.note-card{padding:14px;background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;transition:var(--transition)}
.note-card:hover{border-color:var(--border-hover)}
.note-card .note-time{font-size:10px;color:var(--text-tertiary);margin-top:4px}

/* Hover card effect */
.hover-lift{transition:transform .2s ease,box-shadow .2s ease}
.hover-lift:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}

/* Glow border */
.glow-border{border:1px solid transparent;background-clip:padding-box;position:relative}
.glow-border::before{content:'';position:absolute;inset:-1px;border-radius:inherit;background:linear-gradient(135deg,var(--red),transparent);z-index:-1;opacity:0;transition:opacity .3s}
.glow-border:hover::before{opacity:1}

/* Progress steps */
.steps{display:flex;gap:0;align-items:center}
.step{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-tertiary)}
.step.active{color:var(--red)}
.step.completed{color:var(--green)}
.step-number{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;border:2px solid var(--border)}
.step.active .step-number{border-color:var(--red);background:var(--red-subtle)}
.step.completed .step-number{border-color:var(--green);background:var(--green-subtle)}
.step-line{width:24px;height:2px;background:var(--border);margin:0 4px}
.step-line.completed{background:var(--green)}

/* Rating stars */
.star-rating{display:flex;gap:2px;cursor:pointer}
.star-rating .star{font-size:24px;color:var(--text-tertiary);transition:var(--transition)}
.star-rating .star.active{color:#f59e0b;text-shadow:0 0 8px rgba(245,158,11,.3)}
.star-rating .star:hover{transform:scale(1.2)}

/* Before/after slider */
.compare-slider{position:relative;overflow:hidden;border-radius:var(--radius-md);cursor:ew-resize}
.compare-slider img{display:block;max-width:100%}
.compare-slider .overlay{position:absolute;top:0;left:0;height:100%;overflow:hidden}
.compare-slider .handle{position:absolute;top:0;bottom:0;width:3px;background:var(--text);cursor:ew-resize;z-index:2;display:flex;align-items:center;justify-content:center}
.compare-slider .handle::before{content:'↔';font-size:14px;background:var(--bg);border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:2px solid var(--text)}

/* Tag/chip components */
.chip{display:inline-flex;align-items:center;gap:4px;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:500;background:rgba(255,255,255,.05);color:var(--text-secondary);border:1px solid var(--border)}
.chip.red{background:var(--red-subtle);color:var(--red);border-color:var(--red)}
.chip.green{background:var(--green-subtle);color:var(--green);border-color:rgba(34,197,94,.3)}
.chip.amber{background:var(--yellow-subtle);color:var(--yellow);border-color:rgba(245,158,11,.3)}
.chip .chip-close{cursor:pointer;opacity:.5;font-size:14px;line-height:1}
.chip .chip-close:hover{opacity:1}

/* Comparison table row highlight */
.table-row-highlight{transition:background .2s}
.table-row-highlight:hover{background:rgba(255,255,255,.03)}

/* Gradient text */
.gradient-text{background:linear-gradient(135deg,var(--red),#ff6b6b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Smooth section transitions */
.section{animation:fadeSlide .35s ease}

/* Fullscreen enhancements */
:-webkit-full-screen .topbar{padding:0 32px}
:-webkit-full-screen .content{padding:28px 36px}

/* Selection color */
::selection{background:var(--red-subtle);color:var(--text)}

/* BATY signature watermark */
.login-screen::after{content:'BATY';position:fixed;bottom:12px;right:20px;font-size:11px;font-weight:700;color:rgba(204,0,0,0.12);letter-spacing:2px;pointer-events:none;user-select:none;font-family:var(--font)}

/* Nexus badge on login */
.login-logo::after{content:'NE XUS';position:absolute;top:8px;right:-16px;font-size:8px;font-weight:800;color:var(--red);letter-spacing:3px;opacity:.4;transform:rotate(12deg);pointer-events:none}
.login-logo{position:relative;display:inline-block}

/* Animated pulse on the login logo */
.login-logo img{animation:glow 3s ease-in-out infinite}

/* Live dot with extra personality */
.live-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;display:inline-block;animation:pulseGlow 2s ease-in-out infinite;margin-right:6px}
.live-label{font-size:11px;font-weight:600;color:#22c55e;margin-right:16px;letter-spacing:.5px;text-transform:uppercase}

/* Custom scrollbar personality */
::-webkit-scrollbar-thumb{background:var(--red-subtle);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--red)}

/* BATY footer quote animation */
#footerQuote{transition:opacity .3s ease}

/* Loading bar brand colors */
#loadingBar{background:linear-gradient(90deg,var(--red),#ff6b6b,var(--red));background-size:200% 100%;animation:gradientShift 2s ease infinite}

/* Console watermark hidden in page */
body::after{content:'';display:none}

/* Animation speed preference */
[data-anim-speed=fast] *{animation-duration:.15s!important;transition-duration:.1s!important}
[data-anim-speed=slow] *{animation-duration:.8s!important;transition-duration:.6s!important}
[data-anim-speed=none] *{animation:none!important;transition:none!important}

/* Calculator buttons */
.calc-btn{padding:16px 8px;font-size:18px;font-weight:600;border:none;border-radius:var(--radius-sm);background:rgba(255,255,255,0.04);color:var(--text);cursor:pointer;transition:var(--transition);font-family:var(--mono)}
.calc-btn:hover{background:rgba(255,255,255,0.1)}.calc-btn:active{transform:scale(.95)}
.calc-btn.calc-op{background:rgba(204,0,0,0.08);color:var(--red)}
.calc-btn.calc-op:hover{background:rgba(204,0,0,0.15)}

/* File list styles */
#fileList{max-height:500px;overflow-y:auto}
#fileList > div:last-child{border-bottom:none!important}
