/* BMS Project Lifecycle — Premium Enterprise Theme */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root {
  --c-bg: #f0f2f5; --c-surface: #ffffff; --c-sidebar: #0b1929; --c-sidebar-2: #132f4c;
  --c-text: #1a2433; --c-muted: #637381; --c-border: #e5e9f0; --c-hover: #f8fafc;
  --c-primary: #1565c0; --c-primary-light: #42a5f5; --c-primary-dark: #0d47a1;
  --c-success: #2e7d32; --c-success-light: #e8f5e9; --c-warn: #ed6c02; --c-warn-light: #fff3e0;
  --c-danger: #d32f2f; --c-danger-light: #ffebee; --c-info: #0288d1; --c-info-light: #e1f5fe;
  --c-purple: #7b1fa2; --c-purple-light: #f3e5f5;
  --radius: 10px; --radius-sm: 6px; --radius-lg: 16px;
  --shadow-sm: 0 1px 3px rgba(0,0,0,.06); --shadow-md: 0 4px 16px rgba(0,0,0,.08);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.12); --sidebar-w: 260px;
  --transition: all .2s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--c-bg);color:var(--c-text);font-size:14px;line-height:1.6}
a{color:var(--c-primary);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--c-primary-dark)}
h1,h2,h3,h4{margin:0 0 .5em;font-weight:600;line-height:1.3}
p{margin:0 0 1em}

/* === LAYOUT === */
.app-shell{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:linear-gradient(180deg,var(--c-sidebar) 0%,var(--c-sidebar-2) 100%);color:#c4cdd5;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .3s ease}
.sidebar.collapsed{transform:translateX(calc(var(--sidebar-w)*-1))}
.content{flex:1;display:flex;flex-direction:column;margin-left:var(--sidebar-w);min-height:100vh;transition:margin .3s ease}
.sidebar.collapsed+.content{margin-left:0}

/* Sidebar */
.brand{padding:20px 22px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:12px}
.brand-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--c-primary-light),var(--c-primary));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;font-weight:700}
.brand strong{font-size:17px;color:#fff;letter-spacing:.3px}
.brand-sub{display:block;font-size:10.5px;color:#7b8fa3;margin-top:1px;letter-spacing:.5px;text-transform:uppercase}
.sidebar nav{padding:8px 0;flex:1;overflow-y:auto;overflow-x:hidden}
.sidebar nav::-webkit-scrollbar{width:4px}
.sidebar nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.15);border-radius:4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 22px;color:#adb5c4;font-size:13.5px;font-weight:500;border-left:3px solid transparent;transition:var(--transition);cursor:pointer}
.nav-item:hover{background:rgba(255,255,255,.06);color:#fff}
.nav-item.active{background:rgba(21,101,192,.2);border-left-color:var(--c-primary-light);color:#fff}
.nav-item .icon{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.nav-divider{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;padding:18px 22px 6px;color:#4a5568;font-weight:600}
.sidebar-footer{padding:14px 18px;border-top:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.15)}
.user-chip{display:flex;gap:10px;align-items:center}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--c-primary-light),var(--c-primary));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}
.u-name{font-size:13px;color:#e2e8f0;font-weight:500}
.u-meta{font-size:11px;color:#7b8fa3}

/* Topbar */
.topbar{background:var(--c-surface);padding:14px 28px;border-bottom:1px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;backdrop-filter:blur(8px)}
.topbar-left{display:flex;align-items:center;gap:16px}
.menu-toggle{background:none;border:none;font-size:20px;cursor:pointer;color:var(--c-muted);padding:4px 8px;border-radius:var(--radius-sm);display:none}
.menu-toggle:hover{background:var(--c-hover);color:var(--c-text)}
.page-title{font-size:18px;font-weight:700;color:var(--c-text)}
.page-subtitle{font-size:13px;color:var(--c-muted);font-weight:400}
.topbar-actions{display:flex;gap:8px;align-items:center}
.page{padding:28px;flex:1}
.breadcrumb{display:flex;gap:6px;font-size:12px;color:var(--c-muted);margin-bottom:16px;align-items:center}
.breadcrumb a{color:var(--c-primary)}
.breadcrumb .sep{color:var(--c-border)}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--c-border);cursor:pointer;font-size:13px;font-weight:500;background:#fff;color:var(--c-text);font-family:inherit;transition:var(--transition);text-decoration:none}
.btn:hover{background:var(--c-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.btn-primary{background:var(--c-primary);border-color:var(--c-primary);color:#fff}
.btn-primary:hover{background:var(--c-primary-dark);border-color:var(--c-primary-dark);color:#fff}
.btn-success{background:var(--c-success);border-color:var(--c-success);color:#fff}
.btn-success:hover{background:#1b5e20;color:#fff}
.btn-danger{background:var(--c-danger);border-color:var(--c-danger);color:#fff}
.btn-danger:hover{background:#b71c1c;color:#fff}
.btn-warn{background:var(--c-warn);border-color:var(--c-warn);color:#fff}
.btn-ghost{background:transparent;border-color:transparent}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-lg{padding:11px 22px;font-size:15px}
.btn-block{display:flex;width:100%;justify-content:center}
.btn-icon{padding:7px;min-width:34px;justify-content:center}
.btn-link{background:none;border:0;color:var(--c-primary);cursor:pointer;padding:2px 6px;font-size:13px;font-family:inherit}

/* === PANELS / CARDS === */
.panel{background:var(--c-surface);border-radius:var(--radius);border:1px solid var(--c-border);margin-bottom:20px;box-shadow:var(--shadow-sm);overflow:hidden;transition:var(--transition)}
.panel:hover{box-shadow:var(--shadow-md)}
.panel-header{padding:16px 20px;font-weight:600;border-bottom:1px solid var(--c-border);color:var(--c-text);display:flex;align-items:center;justify-content:space-between;font-size:14px}
.panel-body{padding:20px}
.panel-footer{padding:14px 20px;border-top:1px solid var(--c-border);background:#fafbfc}

/* KPI Cards */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);transition:var(--transition);position:relative;overflow:hidden}
.kpi-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.kpi-card.blue::before{background:linear-gradient(90deg,var(--c-primary),var(--c-primary-light))}
.kpi-card.green::before{background:linear-gradient(90deg,var(--c-success),#66bb6a)}
.kpi-card.orange::before{background:linear-gradient(90deg,var(--c-warn),#ffa726)}
.kpi-card.red::before{background:linear-gradient(90deg,var(--c-danger),#ef5350)}
.kpi-card.purple::before{background:linear-gradient(90deg,var(--c-purple),#ab47bc)}
.kpi-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px}
.kpi-icon.blue{background:var(--c-info-light);color:var(--c-info)}
.kpi-icon.green{background:var(--c-success-light);color:var(--c-success)}
.kpi-icon.orange{background:var(--c-warn-light);color:var(--c-warn)}
.kpi-icon.red{background:var(--c-danger-light);color:var(--c-danger)}
.kpi-icon.purple{background:var(--c-purple-light);color:var(--c-purple)}
.kpi-label{font-size:12px;color:var(--c-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.kpi-value{font-size:28px;font-weight:800;color:var(--c-text);margin:4px 0}
.kpi-sub{font-size:12px;color:var(--c-muted)}

/* Grid Layouts */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.flex-center{display:flex;align-items:center;gap:8px}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}

/* === TABLES === */
.table-wrap{overflow-x:auto;border-radius:var(--radius)}
.table{width:100%;border-collapse:collapse}
.table th{text-align:left;padding:12px 16px;font-weight:600;background:#f8fafc;font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--c-muted);border-bottom:2px solid var(--c-border);white-space:nowrap}
.table td{padding:12px 16px;border-bottom:1px solid #f0f3f7;font-size:13.5px;vertical-align:middle}
.table tr{transition:var(--transition)}
.table tr:hover td{background:#f8fafc}
.table .actions{display:flex;gap:4px}

/* === BADGES === */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}
.badge-not_started,.badge-draft{background:#eef2f7;color:#64748b}
.badge-in_progress,.badge-active,.badge-execution{background:var(--c-info-light);color:var(--c-info)}
.badge-pending,.badge-pending_approval,.badge-awaiting_approval{background:var(--c-warn-light);color:var(--c-warn)}
.badge-resubmission_required,.badge-resubmit{background:#fff3e0;color:#e65100}
.badge-approved,.badge-completed,.badge-paid,.badge-verified,.badge-handed_over{background:var(--c-success-light);color:var(--c-success)}
.badge-rejected,.badge-failed{background:var(--c-danger-light);color:var(--c-danger)}
.badge-overdue{background:#fce4ec;color:#c62828}
.badge-skipped,.badge-closed{background:#eceff1;color:#546e7a}
.badge-design{background:var(--c-purple-light);color:var(--c-purple)}
.badge-procurement{background:var(--c-info-light);color:var(--c-info)}
.badge-billing{background:#e8f5e9;color:#2e7d32}
.badge-commissioning{background:#fff8e1;color:#f57f17}
.badge-validation{background:#ede7f6;color:#4527a0}
.badge-pre_project{background:#e3f2fd;color:#1565c0}
.badge-closure{background:#efebe9;color:#4e342e}
.badge-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}

/* === FORMS === */
.form-group{margin-bottom:16px}
.form-group label,.form-label{display:block;font-size:12.5px;font-weight:600;color:var(--c-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.3px}
.form-control{width:100%;padding:10px 14px;border:1px solid var(--c-border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--c-text);background:#fff;transition:var(--transition)}
.form-control:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(21,101,192,.12)}
.form-control::placeholder{color:#b0bec5}
select.form-control{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='%23637381' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
textarea.form-control{resize:vertical;min-height:80px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-hint{font-size:11px;color:var(--c-muted);margin-top:3px}

/* === KV LIST === */
.kv-list{list-style:none;padding:0;margin:0}
.kv-list li{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f0f3f7;font-size:13.5px}
.kv-list li:last-child{border-bottom:0}
.kv-list span{color:var(--c-muted)}

/* === TIMELINE === */
.timeline{list-style:none;padding:0;margin:0}
.timeline li{position:relative;padding:12px 0 16px 28px;border-left:2px solid var(--c-border);margin-left:10px}
.timeline li:last-child{border-left-color:transparent}
.timeline-dot{position:absolute;left:-7px;top:14px;width:12px;height:12px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 2px var(--c-border)}
.timeline-dot.active{background:var(--c-primary);box-shadow:0 0 0 2px var(--c-primary)}
.timeline-dot.done{background:var(--c-success);box-shadow:0 0 0 2px var(--c-success)}
.timeline-dot.pending{background:var(--c-warn);box-shadow:0 0 0 2px var(--c-warn)}
.timeline-dot.error{background:var(--c-danger);box-shadow:0 0 0 2px var(--c-danger)}
.timeline-content{font-size:13px}
.timeline-content .time{font-size:11px;color:var(--c-muted)}
.timeline-content .title{font-weight:600;color:var(--c-text)}
.quote{margin-top:6px;padding:8px 12px;background:#f8fafc;border-left:3px solid var(--c-primary-light);border-radius:var(--radius-sm);font-style:italic;font-size:13px;color:var(--c-muted)}

/* === TABS === */
.tabs{display:flex;gap:0;border-bottom:2px solid var(--c-border);margin-bottom:20px}
.tab{padding:10px 20px;font-size:13px;font-weight:600;color:var(--c-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:var(--transition);white-space:nowrap}
.tab:hover{color:var(--c-text)}
.tab.active{color:var(--c-primary);border-bottom-color:var(--c-primary)}
.tab-content{display:none}
.tab-content.active{display:block}

/* === ALERTS / TOAST === */
.alert{padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:16px;font-size:13px;display:flex;align-items:center;gap:8px}
.alert-error{background:var(--c-danger-light);color:var(--c-danger);border:1px solid #ffcdd2}
.alert-success{background:var(--c-success-light);color:var(--c-success);border:1px solid #c8e6c9}
.alert-info{background:var(--c-info-light);color:var(--c-info);border:1px solid #b3e5fc}
.alert-warn{background:var(--c-warn-light);color:var(--c-warn);border:1px solid #ffe0b2}
.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:var(--radius);background:var(--c-surface);box-shadow:var(--shadow-lg);font-size:13px;display:flex;align-items:center;gap:8px;animation:slideIn .3s ease;min-width:280px}
@keyframes slideIn{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}

/* === EMPTY STATE === */
.empty{color:var(--c-muted);padding:40px 20px;text-align:center;font-size:14px}
.empty .empty-icon{font-size:40px;margin-bottom:12px;opacity:.5}
.empty .empty-text{color:var(--c-muted);font-size:13px}

/* === PROGRESS BAR === */
.progress{height:6px;background:#e3e8ef;border-radius:3px;overflow:hidden}
.progress-bar{height:100%;border-radius:3px;transition:width .6s ease}
.progress-bar.blue{background:linear-gradient(90deg,var(--c-primary),var(--c-primary-light))}
.progress-bar.green{background:linear-gradient(90deg,var(--c-success),#66bb6a)}
.progress-bar.orange{background:linear-gradient(90deg,var(--c-warn),#ffa726)}

/* === MODAL === */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.modal-backdrop.open{display:flex}
.modal{background:var(--c-surface);border-radius:var(--radius-lg);padding:0;width:90%;max-width:560px;box-shadow:var(--shadow-lg);animation:modalIn .25s ease}
@keyframes modalIn{from{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}
.modal-header{padding:18px 24px;border-bottom:1px solid var(--c-border);font-weight:600;font-size:16px;display:flex;justify-content:space-between;align-items:center}
.modal-body{padding:24px}
.modal-footer{padding:16px 24px;border-top:1px solid var(--c-border);display:flex;justify-content:flex-end;gap:8px}
.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--c-muted);padding:4px}

/* === LOGIN === */
.login-body{background:linear-gradient(135deg,#0b1929 0%,#132f4c 50%,#1565c0 100%);display:flex;align-items:center;justify-content:center;min-height:100vh;position:relative;overflow:hidden}
.login-body::before{content:'';position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(21,101,192,.15),transparent);top:-100px;right:-100px;border-radius:50%}
.login-body::after{content:'';position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(66,165,245,.1),transparent);bottom:-80px;left:-80px;border-radius:50%}
.login-card{background:rgba(255,255,255,.97);padding:40px;border-radius:var(--radius-lg);width:380px;box-shadow:0 24px 64px rgba(0,0,0,.3);position:relative;z-index:1;backdrop-filter:blur(20px)}
.login-brand{text-align:center;margin-bottom:28px}
.login-brand .login-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--c-primary),var(--c-primary-light));border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:24px;color:#fff;margin-bottom:12px}
.login-brand h1{margin:0 0 4px;color:var(--c-primary-dark);font-size:22px;font-weight:700}
.login-brand p{margin:0;color:var(--c-muted);font-size:13px}
.login-form label{display:block;margin-bottom:16px}
.login-form label span{display:block;font-size:12px;color:var(--c-muted);margin-bottom:5px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.login-form input{width:100%;padding:11px 14px;border:1px solid var(--c-border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;transition:var(--transition)}
.login-form input:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(21,101,192,.12)}
.login-foot{margin-top:20px;text-align:center;color:var(--c-muted);font-size:12px}

/* === UTILITY === */
.muted{color:var(--c-muted)}.danger{color:var(--c-danger)}.success{color:var(--c-success)}
.text-center{text-align:center}.text-right{text-align:right}
.mt-0{margin-top:0}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mb-0{margin-bottom:0}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.p-0{padding:0}.p-16{padding:16px}.p-20{padding:20px}
.fw-500{font-weight:500}.fw-600{font-weight:600}.fw-700{font-weight:700}
.fs-12{font-size:12px}.fs-13{font-size:13px}.fs-16{font-size:16px}.fs-20{font-size:20px}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hidden{display:none!important}
.w-full{width:100%}

/* Stat mini card inside panels */
.stat-row{display:flex;gap:12px;flex-wrap:wrap}
.stat-mini{flex:1;min-width:100px;padding:12px;background:#f8fafc;border-radius:var(--radius-sm);text-align:center}
.stat-mini .val{font-size:22px;font-weight:700;color:var(--c-text)}
.stat-mini .lbl{font-size:11px;color:var(--c-muted);text-transform:uppercase;letter-spacing:.5px}

/* Responsive */
@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr 1fr}.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .sidebar{transform:translateX(calc(var(--sidebar-w)*-1))}
  .sidebar.open{transform:translateX(0)}
  .content{margin-left:0}
  .menu-toggle{display:block}
  .kpi-grid{grid-template-columns:1fr}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .page{padding:16px}
  .topbar{padding:12px 16px}
  .tabs{overflow-x:auto}
}

/* === ENTRANCE ANIMATIONS === */
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

.page{animation:fadeInUp .4s ease-out}
.kpi-card{animation:fadeInUp .5s ease-out both}
.kpi-card:nth-child(1){animation-delay:.05s}
.kpi-card:nth-child(2){animation-delay:.1s}
.kpi-card:nth-child(3){animation-delay:.15s}
.kpi-card:nth-child(4){animation-delay:.2s}

.panel{animation:fadeInUp .5s ease-out both;animation-delay:.15s}

/* Enhanced hover effects */
.kpi-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px rgba(0,0,0,.12)}
.kpi-card.blue:hover{box-shadow:0 8px 25px rgba(21,101,192,.18)}
.kpi-card.green:hover{box-shadow:0 8px 25px rgba(46,125,50,.18)}
.kpi-card.orange:hover{box-shadow:0 8px 25px rgba(237,108,2,.18)}
.kpi-card.red:hover{box-shadow:0 8px 25px rgba(211,47,47,.18)}
.kpi-card.purple:hover{box-shadow:0 8px 25px rgba(123,31,162,.18)}

.table tbody tr{animation:fadeIn .3s ease-out both}
.table tbody tr:nth-child(1){animation-delay:.05s}
.table tbody tr:nth-child(2){animation-delay:.08s}
.table tbody tr:nth-child(3){animation-delay:.11s}
.table tbody tr:nth-child(4){animation-delay:.14s}
.table tbody tr:nth-child(5){animation-delay:.17s}
.table tr:hover td{background:#f0f4ff;transition:background .15s ease}

.nav-item{transition:all .2s ease;position:relative}
.nav-item:hover{transform:translateX(3px)}
.nav-item.active{transform:translateX(0)}

.btn{transition:all .2s cubic-bezier(.4,0,.2,1)}
.btn:active{transform:scale(.97)}

.badge-overdue{animation:pulse 2s ease-in-out infinite}

/* Scrollbar polish */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:#94a3b8}
.content::-webkit-scrollbar{width:8px}
.content::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:4px}

/* Notification severity colors */
.notif-item{padding:14px 16px;border-bottom:1px solid #f0f3f7;transition:background .15s ease;display:flex;gap:12px;align-items:flex-start}
.notif-item:hover{background:#f8fafc}
.notif-item:last-child{border-bottom:0}
.notif-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}
.notif-dot.info{background:var(--c-info)}
.notif-dot.success{background:var(--c-success)}
.notif-dot.warn{background:var(--c-warn)}
.notif-dot.error{background:var(--c-danger)}
.notif-title{font-weight:600;font-size:13.5px;color:var(--c-text)}
.notif-body{font-size:12.5px;color:var(--c-muted);margin-top:2px}
.notif-time{font-size:11px;color:var(--c-muted);margin-top:4px}

