*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0b0f1a;--bg2:#111827;--bg3:#1a2233;--card:#1e2840;--card2:#243050;
  --border:#2a3555;--border2:#3a4870;
  --blue:#3b82f6;--blue2:#60a5fa;--blue-dim:#1d4ed8;
  --green:#10b981;--green2:#34d399;
  --amber:#f59e0b;--amber2:#fbbf24;
  --red:#ef4444;--red2:#f87171;
  --purple:#8b5cf6;--purple2:#a78bfa;
  --t1:#f1f5f9;--t2:#c4cfe0;--t3:#8fa3bc;
  --r:10px;--r2:14px;--r3:20px;
  --shadow:0 4px 24px rgba(0,0,0,.4);--shadow2:0 8px 40px rgba(0,0,0,.5);
}
html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--t1);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;line-height:1.6}
a{color:var(--blue2);text-decoration:none}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}

/* Auth */
#auth-screen{display:none;height:100vh;overflow:hidden;background:var(--bg);
  background-image:radial-gradient(ellipse 80% 60% at 50% -20%,rgba(59,130,246,.18),transparent);
  align-items:center;justify-content:center;flex-direction:column;gap:32px}
.auth-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r3);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow2)}
.auth-logo{text-align:center;margin-bottom:32px}
.auth-logo .logo-mark{width:48px;height:48px;background:linear-gradient(135deg,var(--blue),var(--purple));border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-size:22px;font-weight:800;margin-bottom:12px}
.auth-logo h1{font-size:22px;font-weight:700;color:var(--t1)}
.auth-logo p{color:var(--t2);font-size:13px;margin-top:4px}
.auth-title{font-size:20px;font-weight:700;margin-bottom:6px}
.auth-sub{color:var(--t2);font-size:13px;margin-bottom:28px}
.form-group{margin-bottom:16px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--t2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.form-input{width:100%;background:var(--bg2);border:1px solid var(--border);color:var(--t1);padding:11px 14px;border-radius:var(--r);font-size:14px;outline:none;transition:.2s}
.form-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(59,130,246,.15)}
.form-input::placeholder{color:var(--t3)}
.form-select{width:100%;background:var(--bg2);border:1px solid var(--border);color:var(--t1);padding:11px 14px;border-radius:var(--r);font-size:14px;outline:none;transition:.2s;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 12 12'%3E%3Cpath fill='%2364748b' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.form-select:focus{border-color:var(--blue)}
.form-select option{background:var(--bg2);color:var(--t1)}
textarea.form-input{resize:vertical;min-height:80px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:10px 18px;border-radius:var(--r);font-size:13px;font-weight:600;border:none;transition:.2s;white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:var(--blue-dim)}
.btn-success{background:var(--green);color:#fff}.btn-success:hover{background:#059669}
.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#dc2626}
.btn-ghost{background:transparent;color:var(--t2);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--border2);color:var(--t1);background:var(--bg3)}
.btn-amber{background:var(--amber);color:#000}.btn-amber:hover{background:var(--amber2)}
.btn-full{width:100%}.btn-sm{padding:7px 13px;font-size:12px}.btn-xs{padding:4px 10px;font-size:11px;border-radius:6px}
.auth-link{text-align:center;margin-top:20px;font-size:13px;color:var(--t2)}
.auth-link a{color:var(--blue2);font-weight:600}
.auth-reset-result{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.3);border-radius:var(--r);padding:16px;margin-top:16px;font-size:13px;color:var(--blue2)}
.auth-reset-token{background:var(--bg);border:1px solid var(--border2);border-radius:var(--r);padding:10px;font-family:monospace;word-break:break-all;margin-top:8px;color:var(--amber2)}

/* App Shell */
#app{display:none;height:100vh;overflow:hidden;flex-direction:row}
.sidebar{width:240px;min-width:240px;background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100%;overflow:hidden}
.sidebar-logo{padding:20px 20px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
.sidebar-logo .mark{width:34px;height:34px;background:linear-gradient(135deg,var(--blue),var(--purple));border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;flex-shrink:0}
.sidebar-logo span{font-size:16px;font-weight:700;color:var(--t1)}
.sidebar-logo small{display:block;font-size:10px;font-weight:500;color:var(--t2);margin-top:1px}
.sidebar-nav{flex:1;overflow-y:auto;padding:12px 10px}
.nav-section{margin-bottom:5px}
.nav-section-label{font-size:10px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.8px;padding:8px 10px 4px}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r);color:var(--t2);font-size:13px;font-weight:500;cursor:pointer;transition:.15s;user-select:none;margin-bottom:2px}
.nav-item:hover{background:var(--bg3);color:var(--t1)}
.nav-item.active{background:rgba(59,130,246,.15);color:var(--blue2);font-weight:600}
.nav-item .icon{width:16px;height:16px;flex-shrink:0;opacity:.7}
.nav-item.active .icon{opacity:1}
.sidebar-user{padding:14px 16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:10px;cursor:pointer;transition:.15s;border-radius:0}
.sidebar-user:hover{background:var(--bg3)}
.sidebar-user:hover .user-name{color:var(--blue2)}
.user-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--blue-dim),var(--purple));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.user-info{flex:1;overflow:hidden}
.user-name{font-size:13px;font-weight:600;color:var(--t1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:.15s}
.user-role{font-size:11px;color:var(--t2);text-transform:capitalize}
.btn-logout{background:none;border:none;color:var(--t3);padding:4px;border-radius:6px;display:flex;align-items:center;transition:.15s;flex-shrink:0}
.btn-logout:hover{color:var(--red2);background:rgba(239,68,68,.1)}

/* Main */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}
.topbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:0 28px;height:58px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.topbar h2{font-size:18px;font-weight:700;color:var(--t1)}
.topbar-right{display:flex;align-items:center;gap:10px}
.content{flex:1;overflow-y:auto;padding:28px}

/* Cards */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:20px;position:relative;overflow:hidden;transition:.2s}
.stat-card::before{content:'';position:absolute;top:0;right:0;width:80px;height:80px;border-radius:50%;background:var(--accent,var(--blue));opacity:.07;transform:translate(20px,-20px)}
.stat-card .stat-icon{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;margin-bottom:12px;font-size:18px}
.stat-card .stat-value{font-size:28px;font-weight:800;color:var(--t1);line-height:1}
.stat-card .stat-label{font-size:12px;color:var(--t2);font-weight:500;margin-top:4px}
.stat-card .stat-sub{font-size:11px;color:var(--t3);margin-top:6px}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.section-title{font-size:16px;font-weight:700;color:var(--t1)}
.section-sub{font-size:12px;color:var(--t2);margin-top:2px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden}
.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-body{padding:20px}
.card-footer{padding:12px 20px;border-top:1px solid var(--border);background:var(--bg3)}

/* Tables */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
th{background:var(--bg3);text-align:left;padding:10px 16px;font-size:11px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:1px solid var(--border)}
td{padding:12px 16px;border-bottom:1px solid rgba(42,53,85,.5);font-size:13px;color:var(--t1);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.025)}

/* Badges */
.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600}
.badge-blue{background:rgba(59,130,246,.15);color:var(--blue2)}
.badge-green{background:rgba(16,185,129,.15);color:var(--green2)}
.badge-amber{background:rgba(245,158,11,.15);color:var(--amber2)}
.badge-red{background:rgba(239,68,68,.15);color:var(--red2)}
.badge-purple{background:rgba(139,92,246,.15);color:var(--purple2)}
.badge-gray{background:rgba(100,116,139,.15);color:var(--t2)}
/* Article status badges */
.badge-pending{background:rgba(100,116,139,.15);color:var(--t2)}
.badge-submitted{background:rgba(245,158,11,.15);color:var(--amber2)}
.badge-approved{background:rgba(16,185,129,.15);color:var(--green2)}

/* Progress */
.progress-bar{height:6px;background:var(--bg3);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;background:var(--blue);transition:.3s}
.progress-fill.green{background:var(--green)}
.progress-fill.amber{background:var(--amber)}
.progress-fill.red{background:var(--red)}

/* Resource/Test cards */
.resource-list{display:flex;flex-direction:column;gap:12px}
.resource-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:18px 20px;display:flex;align-items:flex-start;gap:16px;transition:.2s}
.resource-card:hover{border-color:var(--border2)}
.resource-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.resource-icon.video{background:rgba(239,68,68,.15)}
.resource-icon.document{background:rgba(59,130,246,.15)}
.resource-icon.webpage{background:rgba(6,182,212,.15)}
.resource-icon.text{background:rgba(139,92,246,.15)}
.resource-info{flex:1;min-width:0}
.resource-title{font-size:14px;font-weight:700;color:var(--t1);margin-bottom:3px}
.resource-desc{font-size:12px;color:var(--t2);margin-bottom:8px}
.resource-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.resource-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap}

/* Category pill */
.cat-pill{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600}

/* 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}
@media(max-width:900px){.grid-2,.grid-3{grid-template-columns:1fr}}

/* Modal */
#modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:1000;align-items:center;justify-content:center;padding:20px}
.modal{background:var(--card2);border:1px solid var(--border2);border-radius:var(--r3);width:100%;max-width:620px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow2);animation:modalIn .2s ease}
@keyframes modalIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.modal.lg{max-width:860px}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-title{font-size:16px;font-weight:700;color:var(--t1)}
.modal-close{background:none;border:none;color:var(--t3);font-size:20px;line-height:1;padding:4px;border-radius:6px;cursor:pointer;transition:.15s}
.modal-close:hover{color:var(--t1);background:var(--bg3)}
.modal-body{padding:24px;overflow-y:auto}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;flex-shrink:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-hint{font-size:11px;color:var(--t3);margin-top:4px}

/* Dept multi-checkbox */
.dept-check-list{display:flex;flex-direction:column;gap:6px;padding:10px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r)}
.dept-check-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:7px;cursor:pointer;transition:.15s}
.dept-check-item:hover{background:var(--bg2)}
.dept-check-item input[type=checkbox]{width:16px;height:16px;accent-color:var(--blue);flex-shrink:0;cursor:pointer}
.dept-check-item span{font-size:13px;font-weight:500;color:var(--t1)}

/* User assign list */
.user-check-list{max-height:220px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--r);padding:8px}
.user-check-item{display:flex;align-items:center;gap:8px;padding:7px 8px;cursor:pointer;border-radius:6px;transition:.15s}
.user-check-item:hover{background:var(--bg3)}
.user-check-item.assigned{background:rgba(245,158,11,.06)}
.user-check-item input{width:16px;height:16px;accent-color:var(--blue);flex-shrink:0;cursor:pointer}

/* Question editor */
.question-item{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:12px}
.question-item-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.question-num{background:var(--blue);color:#fff;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.option-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.option-radio{width:18px;height:18px;accent-color:var(--green);flex-shrink:0;cursor:pointer}
.option-input{flex:1}

/* Test taking */
.test-shell{display:flex;flex-direction:column;gap:20px}
.test-header-bar{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:16px 20px;display:flex;align-items:center;justify-content:space-between}
.timer{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--t1)}
.timer.warning{color:var(--amber2)}
.timer.danger{color:var(--red2);animation:pulse 1s infinite}
@keyframes pulse{50%{opacity:.5}}
.test-progress{font-size:13px;color:var(--t2)}
.question-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:24px}
.question-text{font-size:15px;font-weight:600;color:var(--t1);margin-bottom:16px;line-height:1.5}
.option-btn{width:100%;text-align:left;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--r);padding:12px 16px;color:var(--t1);font-size:13px;font-weight:500;display:flex;align-items:center;gap:12px;transition:.15s;margin-bottom:8px}
.option-btn:hover{border-color:var(--border2);background:var(--bg2)}
.option-btn.selected{border-color:var(--blue);background:rgba(59,130,246,.1);color:var(--blue2)}
.option-letter{width:28px;height:28px;border-radius:50%;background:var(--bg2);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.option-btn.selected .option-letter{background:var(--blue);border-color:var(--blue);color:#fff}
.test-nav{display:flex;align-items:center;justify-content:space-between}
.question-dots{display:flex;gap:5px;flex-wrap:wrap}
.q-dot{width:10px;height:10px;border-radius:50%;background:var(--border2);cursor:pointer;transition:.15s}
.q-dot.answered{background:var(--blue)}
.q-dot.current{outline:2px solid var(--blue2);outline-offset:2px}

/* Iframe viewer */
.iframe-container{width:100%;height:70vh;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;background:#000;display:flex;align-items:center;justify-content:center}
.iframe-container iframe{width:100%;height:100%;border:none}
.iframe-container video{width:100%;height:100%;outline:none;background:#000}
.viewer-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;margin-bottom:10px;border-radius:var(--r);font-size:12px}
.viewer-bar.blue{background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.2);color:var(--blue2)}

/* Text resource viewer */
.text-viewer{width:100%;max-height:70vh;overflow-y:auto;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:24px 28px;line-height:1.7;color:var(--t1);font-size:14px}
.text-viewer h1,.text-viewer h2,.text-viewer h3{color:var(--t1);margin:16px 0 8px;font-weight:700}
.text-viewer h1{font-size:22px}.text-viewer h2{font-size:18px}.text-viewer h3{font-size:15px}
.text-viewer p{margin-bottom:12px;color:var(--t2)}
.text-viewer ul,.text-viewer ol{padding-left:20px;margin-bottom:12px;color:var(--t2)}
.text-viewer li{margin-bottom:4px}
.text-viewer strong{color:var(--t1);font-weight:700}
.text-viewer em{color:var(--t2);font-style:italic}
.text-viewer blockquote{border-left:3px solid var(--blue);padding:8px 16px;margin:12px 0;background:rgba(59,130,246,.06);border-radius:0 var(--r) var(--r) 0;color:var(--t2)}
.text-viewer code{background:var(--bg2);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:monospace;font-size:12px;color:var(--blue2)}
.text-viewer pre{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r);padding:12px 16px;overflow-x:auto;margin-bottom:12px}
.text-viewer pre code{border:none;background:none;padding:0}
.text-viewer a{color:var(--blue2)}
.text-viewer img{max-width:100%;border-radius:var(--r);margin:8px 0}

/* Result */
.result-card{text-align:center;padding:32px}
.result-score{font-size:64px;font-weight:800;line-height:1;margin:16px 0}
.result-score.pass{color:var(--green2)}.result-score.fail{color:var(--red2)}

/* Dept pills */
.dept-pill{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700}
.dept-PM{background:rgba(139,92,246,.15);color:var(--purple2)}
.dept-Technical{background:rgba(59,130,246,.15);color:var(--blue2)}
.dept-Functional{background:rgba(245,158,11,.15);color:var(--amber2)}

/* Activity feed */
.activity-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(42,53,85,.4)}
.activity-item:last-child{border-bottom:none}
.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:5px}

/* Empty state */
.empty{text-align:center;padding:60px 20px;color:var(--t3)}
.empty .empty-icon{font-size:48px;margin-bottom:12px;opacity:.3}
.empty p{font-size:14px;color:var(--t2)}
.empty small{font-size:12px;color:var(--t3);margin-top:6px;display:block}

/* Toast */
#toast{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast-item{background:var(--card2);border:1px solid var(--border2);border-radius:var(--r);padding:12px 18px;font-size:13px;color:var(--t1);box-shadow:var(--shadow);animation:slideUp .25s ease;pointer-events:auto;display:flex;align-items:center;gap:8px;min-width:240px}
.toast-item.success{border-left:3px solid var(--green)}
.toast-item.error{border-left:3px solid var(--red)}
.toast-item.info{border-left:3px solid var(--blue)}
@keyframes slideUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* Tabs */
.tabs{display:flex;gap:2px;background:var(--bg3);border-radius:var(--r);padding:4px;margin-bottom:20px;width:fit-content}
.tab{padding:7px 16px;border-radius:7px;font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;transition:.15s}
.tab.active{background:var(--card2);color:var(--t1);font-weight:600}
.tab:hover:not(.active){color:var(--t1)}

/* Active test banner */
#active-test-banner{position:sticky;top:0;z-index:100;background:rgba(245,158,11,.12);border-bottom:1px solid rgba(245,158,11,.35);padding:8px 20px;font-size:13px;font-weight:600;color:var(--amber2);display:none;align-items:center;justify-content:space-between;gap:12px}
#active-test-banner.show{display:flex}

/* Misc */
.divider{height:1px;background:var(--border);margin:16px 0}
.text-sm{font-size:12px;color:var(--t2)}.text-xs{font-size:11px;color:var(--t3)}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.mt-24{margin-top:24px}
.fw-7{font-weight:700}.flex-center{display:flex;align-items:center;gap:8px}.ml-auto{margin-left:auto}.w-full{width:100%}

/* Category color swatch */
.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);cursor:pointer;flex-shrink:0}

/* ── Forecast / Search-Select ─────────────────────────────── */
.ss-wrap{position:relative;min-width:0}
.ss-list{position:absolute;top:calc(100% + 2px);left:0;right:0;z-index:500;background:var(--card2);border:1px solid var(--border2);border-radius:var(--r);max-height:200px;overflow-y:auto;box-shadow:var(--shadow2);display:none}
.ss-item{padding:9px 12px;font-size:12px;cursor:pointer;color:var(--t1);border-bottom:1px solid rgba(42,53,85,.3)}
.ss-item:last-child{border-bottom:none}
.ss-item:hover{background:rgba(59,130,246,.12);color:var(--blue2)}
.ss-readonly{background:var(--bg3)!important;color:var(--t3)!important;font-size:11px!important;cursor:default!important}
/* Forecast grid */
.fc-scroll{overflow-x:auto;border-radius:var(--r);border:1px solid var(--border)}
.fc-table{width:100%;border-collapse:collapse;font-size:12px;min-width:700px}
.fc-table th{background:var(--bg3);padding:8px 6px;text-align:center;font-size:11px;font-weight:700;color:var(--t3);white-space:nowrap;border-bottom:1px solid var(--border)}
.fc-table th.col-wide{min-width:160px;text-align:left;padding-left:10px}
.fc-table td{padding:5px 4px;border-bottom:1px solid rgba(42,53,85,.4);vertical-align:middle}
.fc-table tr:last-child td{border-bottom:none}
.fc-table tr:hover td{background:rgba(255,255,255,.015)}
.hour-input{width:52px;background:var(--bg2);border:1px solid var(--border);color:var(--t1);padding:5px 3px;border-radius:6px;font-size:12px;font-weight:600;text-align:center;outline:none;-moz-appearance:textfield}
.hour-input:focus{border-color:var(--blue);background:var(--card)}
.hour-input::-webkit-inner-spin-button,.hour-input::-webkit-outer-spin-button{-webkit-appearance:none}
.hour-input:disabled{opacity:.35!important;background:var(--bg3)!important;cursor:not-allowed!important;border-color:var(--border)!important}
.fc-total-cell{font-weight:800;color:var(--blue2);text-align:center;font-size:13px;padding:0 8px}
.today-col th,.today-col-td{background:rgba(59,130,246,.07)!important}
.today-col-td .hour-input{border-color:rgba(59,130,246,.35)}
.weekend-col{background:rgba(100,116,139,.10)!important;color:var(--t3)}
.weekend-col-td{background:rgba(100,116,139,.06)!important}
.weekend-col-td .hour-input{border-color:rgba(100,116,139,.25);background:rgba(100,116,139,.08)}
/* Week nav */
.week-nav-bar{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.week-label{font-size:13px;font-weight:700;color:var(--t1);min-width:190px;text-align:center;padding:7px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--r)}
.btn-wk{background:var(--bg3);border:1px solid var(--border);color:var(--t2);width:32px;height:32px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:.15s;flex-shrink:0}
.btn-wk:hover{border-color:var(--blue);color:var(--blue2);background:var(--card)}
/* Overdue */
.overdue-pill{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;background:rgba(239,68,68,.15);color:var(--red2)}
/* Bar chart */
.bar-chart{display:flex;flex-direction:column;gap:10px}
.bar-row{display:flex;align-items:center;gap:10px}
.bar-label{font-size:11px;color:var(--t2);width:130px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}
.bar-track{flex:1;height:10px;background:var(--bg3);border-radius:5px;overflow:hidden;position:relative}
.bar-fill{height:100%;border-radius:5px;transition:.4s}
.bar-planned{background:var(--blue)}
.bar-expected{background:var(--green);opacity:.7}
.bar-val{font-size:11px;font-weight:700;color:var(--t2);min-width:38px;text-align:right}
/* Fc tabs */
.fc-tabs{display:flex;gap:2px;background:var(--bg3);border-radius:var(--r);padding:4px;margin-bottom:20px}
.fc-tab{padding:8px 18px;border-radius:7px;font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;transition:.15s}
.fc-tab.active{background:var(--card2);color:var(--t1);font-weight:600}
.fc-tab:hover:not(.active){color:var(--t1)}
/* Milestone row inline editor */
.ms-row-edit{display:grid;grid-template-columns:1fr 60px 120px 1fr auto;gap:8px;align-items:center;padding:10px;background:var(--bg3);border-radius:var(--r);border:1px solid var(--border);margin-bottom:8px}

/* Date picker dark theme */
input[type="date"].form-input{color-scheme:dark;cursor:pointer}
input[type="date"].form-input::-webkit-calendar-picker-indicator{filter:invert(.6) sepia(1) saturate(2) hue-rotate(180deg);cursor:pointer;opacity:.8}
input[type="date"].form-input::-webkit-calendar-picker-indicator:hover{opacity:1}

/* ── Quill dark theme overrides ───────────────────────────── */
.ql-toolbar.ql-snow{background:var(--bg3);border:1px solid var(--border)!important;border-radius:var(--r) var(--r) 0 0;padding:8px}
.ql-container.ql-snow{background:var(--bg2);border:1px solid var(--border)!important;border-top:none!important;border-radius:0 0 var(--r) var(--r)}
.ql-editor{color:var(--t1);font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;line-height:1.7;min-height:200px}
.ql-editor.ql-blank::before{color:var(--t3);font-style:italic}
.ql-snow .ql-stroke{stroke:var(--t2)!important}
.ql-snow .ql-fill{fill:var(--t2)!important}
.ql-snow .ql-picker{color:var(--t2)!important}
.ql-snow .ql-picker-options{background:var(--card2)!important;border:1px solid var(--border2)!important;border-radius:var(--r)!important}
.ql-snow .ql-picker-item{color:var(--t1)!important}
.ql-snow .ql-picker-item:hover{color:var(--blue2)!important;background:rgba(59,130,246,.1)!important}
.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke{stroke:var(--blue2)!important}
.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill{fill:var(--blue2)!important}
.ql-snow.ql-toolbar button:hover,.ql-snow.ql-toolbar button.ql-active{background:rgba(59,130,246,.1)!important;border-radius:4px}
.ql-snow .ql-editor h1,.ql-snow .ql-editor h2,.ql-snow .ql-editor h3{color:var(--t1)}
.ql-snow .ql-editor blockquote{border-left:3px solid var(--blue);color:var(--t2)}
.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background:var(--bg3)!important;color:var(--blue2)}
/* article-editor full-page Quill should be taller */
#article-quill-editor .ql-editor{min-height:420px}

/* ── Articles page ────────────────────────────────────────── */
.article-list{display:flex;flex-direction:column;gap:10px}
.article-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r2);padding:16px 20px;display:flex;align-items:center;gap:16px;transition:.2s;cursor:pointer}
.article-card:hover{border-color:var(--border2);background:var(--card2)}
.article-card-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;background:rgba(245,158,11,.12)}
.article-card-info{flex:1;min-width:0}
.article-card-title{font-size:14px;font-weight:700;color:var(--t1);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.article-card-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.article-card-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
/* Full-page article editor */
.article-editor-wrap{display:flex;flex-direction:column;gap:0;height:100%}
.article-editor-toolbar{display:flex;align-items:center;gap:10px;padding:0 0 16px;border-bottom:1px solid var(--border);margin-bottom:16px;flex-wrap:wrap}
.article-editor-body{flex:1;display:flex;flex-direction:column;gap:12px}
.article-title-input{width:100%;background:transparent;border:none;border-bottom:2px solid var(--border);color:var(--t1);font-size:22px;font-weight:700;padding:8px 0;outline:none;font-family:'Plus Jakarta Sans',sans-serif;transition:.2s}
.article-title-input:focus{border-bottom-color:var(--blue)}
.article-title-input::placeholder{color:var(--t3)}
/* Article read view */
.article-read-wrap{max-width:760px;margin:0 auto}
.article-read-header{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.article-read-title{font-size:26px;font-weight:800;color:var(--t1);margin-bottom:10px;line-height:1.3}
.article-read-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--t3)}
.article-read-content{line-height:1.8;color:var(--t2)}
.article-read-content h1,.article-read-content h2,.article-read-content h3{color:var(--t1);margin:20px 0 8px;font-weight:700}
.article-read-content h1{font-size:22px}.article-read-content h2{font-size:18px}.article-read-content h3{font-size:15px}
.article-read-content p{margin-bottom:14px}
.article-read-content ul,.article-read-content ol{padding-left:22px;margin-bottom:14px}
.article-read-content li{margin-bottom:5px}
.article-read-content strong{color:var(--t1);font-weight:700}
.article-read-content blockquote{border-left:3px solid var(--blue);padding:8px 16px;margin:14px 0;background:rgba(59,130,246,.06);border-radius:0 var(--r) var(--r) 0;color:var(--t2)}
.article-read-content code{background:var(--bg3);border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-family:monospace;font-size:12px;color:var(--blue2)}
.article-read-content pre{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:14px 18px;overflow-x:auto;margin-bottom:14px}
.article-read-content pre code{border:none;background:none;padding:0}
.article-read-content img{max-width:100%;border-radius:var(--r);margin:8px 0}
.article-read-content a{color:var(--blue2)}

/* Quill color picker fix */
.ql-snow .ql-color-picker .ql-picker-label svg,
.ql-snow .ql-color-picker .ql-picker-item { border-radius: 2px; }
.ql-snow .ql-picker.ql-color .ql-picker-label::before { content: 'A'; font-weight: 700; }
.ql-snow .ql-picker.ql-background .ql-picker-label::before { content: 'A'; font-weight: 700; background: #ffd700; border-radius: 2px; padding: 0 3px; color: #000; }

/* Alerts panel */
#alerts-btn:hover { background: var(--bg3); }
#alerts-btn:hover span { color: var(--t1); }
.alert-item { padding: 10px 14px; border-bottom: 1px solid rgba(42,53,85,.4); font-size: 12px; line-height: 1.5; cursor: default; transition: .15s; }
.alert-item:last-child { border-bottom: none; }
.alert-item:hover { background: rgba(255,255,255,.03); }
.alert-item.unread { background: rgba(59,130,246,.06); border-left: 2px solid var(--blue); }
.alert-item .alert-msg { color: var(--t2); }
.alert-item .alert-time { font-size: 10px; color: var(--t3); margin-top: 3px; }
.alert-group-label { padding: 6px 14px; font-size: 10px; font-weight: 700; color: var(--t3); text-transform: uppercase; letter-spacing: .6px; background: var(--bg3); }
/* Timesheet day status */
.ts-day-pending  { color: var(--t3); }
.ts-day-submitted { color: var(--amber2); }
.ts-day-accepted  { color: var(--green2); }
.ts-day-rejected  { color: var(--red2); }

