/* ---- DUTY MODAL ---- */
.duty-modal-overlay { position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(0,0,0,.6); z-index:9999; display:flex; align-items:center; justify-content:center; }
.duty-modal { background:var(--navy-800); border:1px solid var(--navy-600); border-radius:8px; padding:20px; width:420px; max-width:90vw; max-height:80vh; overflow-y:auto; box-shadow:0 20px 60px rgba(0,0,0,.5); }
.duty-modal h3 { margin:0 0 16px; font-size:14px; color:#f59e0b; font-weight:700; display:flex; align-items:center; gap:8px; }
.duty-modal .duty-pos-row { display:flex; align-items:center; gap:8px; margin-bottom:10px; padding:8px; background:var(--navy-700); border-radius:6px; border:1px solid var(--navy-600); }
.duty-modal .duty-pos-label { font-size:11px; font-weight:600; color:var(--slate-200); min-width:100px; }
.duty-modal .duty-pos-input { flex:1; padding:4px 8px; background:var(--navy-800); border:1px solid var(--navy-600); color:var(--white); border-radius:4px; font-size:11px; font-family:inherit; }
.duty-modal .duty-pos-input:focus { outline:none; border-color:#f59e0b; }
.duty-modal .duty-pos-clear { font-size:9px; padding:2px 6px; border-radius:4px; border:1px solid var(--navy-600); background:var(--navy-700); color:var(--slate-400); cursor:pointer; font-family:inherit; }
.duty-modal .duty-pos-clear:hover { border-color:#ef4444; color:#ef4444; }
.duty-modal-actions { display:flex; gap:8px; margin-top:16px; justify-content:flex-end; }
.duty-modal-actions button { padding:6px 16px; border-radius:4px; font-size:11px; font-family:inherit; cursor:pointer; font-weight:600; }
.duty-modal-actions .duty-save { border:none; background:#f59e0b; color:var(--navy-900); }
.duty-modal-actions .duty-save:hover { background:#d97706; }
.duty-modal-actions .duty-cancel { border:1px solid var(--navy-600); background:var(--navy-700); color:var(--slate-200); }
.duty-modal-actions .duty-cancel:hover { border-color:var(--slate-400); }
.duty-suggest-dropdown { position:absolute; top:100%; left:0; right:0; background:var(--navy-800); border:1px solid var(--navy-600); border-radius:0 0 4px 4px; max-height:150px; overflow-y:auto; z-index:10000; }
.duty-suggest-item { padding:4px 8px; font-size:11px; color:var(--slate-200); cursor:pointer; }
.duty-suggest-item:hover, .duty-suggest-item.active { background:rgba(245,158,11,.15); color:#f59e0b; }

/* ---- DATE PICKER MODAL ---- */
.cal-overlay { display:none; position:fixed; inset:0; z-index:149; }
.cal-overlay.open { display:block; }
.cal-modal { display:none; position:absolute; top:100%; left:0; margin-top:6px; background:var(--navy-800); border:1px solid var(--navy-600); border-radius:var(--radius); width:320px; box-shadow:0 16px 48px rgba(0,0,0,.5); overflow:hidden; z-index:150; }
.cal-modal.open { display:block; }
.cal-header { padding:10px 14px; border-bottom:1px solid var(--navy-600); display:flex; align-items:center; justify-content:space-between; }
.cal-header .cal-nav { display:flex; align-items:center; gap:8px; }
.cal-header .cal-nav button { background:none; border:1px solid var(--navy-600); color:var(--slate-300); width:28px; height:28px; border-radius:4px; cursor:pointer; font-size:13px; transition:var(--transition); }
.cal-header .cal-nav button:hover { border-color:var(--accent); color:var(--white); }
.cal-header .cal-title { font-size:14px; font-weight:600; color:var(--white); cursor:pointer; padding:2px 8px; border-radius:4px; transition:var(--transition); }
.cal-header .cal-title:hover { background:var(--navy-600); }
.cal-header .cal-close { background:none; border:none; color:var(--slate-400); cursor:pointer; font-size:18px; }
.cal-body { padding:8px 12px 12px; }
.cal-weekdays { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; margin-bottom:4px; }
.cal-weekdays span { text-align:center; font-size:10px; font-weight:600; color:var(--slate-400); padding:4px 0; }
.cal-days { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.cal-day { text-align:center; font-size:12px; padding:6px 0; border-radius:4px; cursor:pointer; transition:var(--transition); color:var(--slate-200); }
.cal-day:hover { background:var(--navy-600); }
.cal-day.today { border:1px solid var(--accent); }
.cal-day.selected { background:var(--accent); color:white; font-weight:600; }
.cal-day.other-month { color:var(--navy-500); }
.cal-day.empty { cursor:default; }
.cal-months { display:grid; grid-template-columns:repeat(3,1fr); gap:6px; }
.cal-month-btn { text-align:center; font-size:12px; padding:10px 0; border-radius:4px; cursor:pointer; transition:var(--transition); color:var(--slate-200); background:var(--navy-700); border:1px solid var(--navy-600); }
.cal-month-btn:hover { border-color:var(--accent); }
.cal-month-btn.current { background:var(--accent); color:white; border-color:var(--accent); }
.cal-years { display:grid; grid-template-columns:repeat(3,1fr); gap:6px; }
.cal-year-btn { text-align:center; font-size:12px; padding:10px 0; border-radius:4px; cursor:pointer; transition:var(--transition); color:var(--slate-200); background:var(--navy-700); border:1px solid var(--navy-600); }
.cal-year-btn:hover { border-color:var(--accent); }
.cal-year-btn.current { background:var(--accent); color:white; border-color:var(--accent); }
.cal-footer { padding:8px 12px; border-top:1px solid var(--navy-600); display:flex; justify-content:space-between; }
.cal-footer button { padding:5px 14px; border-radius:var(--radius-sm); border:1px solid var(--navy-600); background:var(--navy-700); color:var(--slate-200); font-size:12px; font-family:inherit; cursor:pointer; transition:var(--transition); }
.cal-footer button:hover { border-color:var(--accent); }
.cal-footer button.primary { background:var(--accent); border-color:var(--accent); color:white; }

/* ---- QUAL EDIT POPUP ---- */
.qual-edit-popup { display:none; position:fixed; z-index:200; background:var(--navy-800); border:1px solid var(--navy-600); border-radius:var(--radius); box-shadow:0 8px 24px rgba(0,0,0,.5); padding:10px; width:200px; }
.qual-edit-popup.open { display:block; }
.qual-edit-popup .qep-title { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; color:var(--slate-400); margin-bottom:6px; }
.qual-edit-popup .qep-options { display:flex; gap:4px; margin-bottom:8px; }
.qual-edit-popup .qep-opt { width:32px; height:28px; border-radius:4px; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; cursor:pointer; border:2px solid transparent; transition:var(--transition); }
.qual-edit-popup .qep-opt:hover { border-color:var(--accent); }
.qual-edit-popup .qep-opt.selected { border-color:var(--accent); box-shadow:0 0 0 1px var(--accent); }
.qual-edit-popup .qep-opt.d { background:rgba(59,130,246,.15); color:var(--accent); }
.qual-edit-popup .qep-opt.q { background:rgba(34,197,94,.15); color:var(--green); }
.qual-edit-popup .qep-opt.s { background:rgba(245,158,11,.12); color:#f59e0b; }
.qual-edit-popup .qep-opt.x { background:rgba(239,68,68,.1); color:#ef4444; }
.qual-edit-popup .qep-opt.none { background:var(--navy-700); color:var(--slate-400); }
.qual-edit-popup input { width:100%; background:var(--navy-700); border:1px solid var(--navy-600); color:var(--white); padding:5px 8px; border-radius:4px; font-size:11px; font-family:inherit; outline:none; margin-bottom:6px; }
.qual-edit-popup input:focus { border-color:var(--accent); }
.qual-edit-popup .qep-actions { display:flex; gap:4px; justify-content:flex-end; }
.qual-edit-popup .qep-actions button { padding:4px 10px; border-radius:4px; font-size:11px; border:1px solid var(--navy-600); background:var(--navy-700); color:var(--slate-200); cursor:pointer; font-family:inherit; }
.qual-edit-popup .qep-actions button.primary { background:var(--accent); border-color:var(--accent); color:white; }
.qual-cell.edited { position:relative; }
.qual-cell.edited::after { content:'*'; position:absolute; top:-2px; right:-2px; font-size:8px; color:#f59e0b; }

/* ---- THEME SELECTOR ---- */
.theme-selector { position:relative; }
.theme-selector .theme-btn { background:none; border:1px solid var(--navy-600); color:var(--slate-300); padding:4px 8px; border-radius:6px; font-size:12px; cursor:pointer; transition:var(--transition); font-family:inherit; display:flex; align-items:center; gap:4px; }
.theme-selector .theme-btn:hover { border-color:var(--accent); color:var(--white); }
.theme-selector .theme-btn .theme-dot { width:10px; height:10px; border-radius:50%; border:1px solid var(--navy-500); }
.theme-dropdown { display:none; position:absolute; top:100%; right:0; margin-top:6px; background:var(--navy-700); border:1px solid var(--navy-600); border-radius:var(--radius); box-shadow:0 8px 24px rgba(0,0,0,.4); min-width:180px; z-index:200; overflow:hidden; }
.theme-dropdown.open { display:block; }
.theme-option { display:flex; align-items:center; gap:8px; padding:8px 12px; cursor:pointer; transition:var(--transition); font-size:12px; color:var(--slate-200); }
.theme-option:hover { background:var(--navy-600); }
.theme-option.active { background:rgba(59,130,246,.1); }
.theme-option .to-dots { display:flex; gap:3px; }
.theme-option .to-dot { width:12px; height:12px; border-radius:50%; border:1px solid rgba(255,255,255,.2); }

/* ---- PROFILE DROPDOWN ---- */
.profile-selector { position:relative; }
.profile-selector>button { display:flex; align-items:center; gap:6px; }
.profile-selector>button svg { width:16px; height:16px; stroke:var(--slate-300); fill:none; stroke-width:2; }
.profile-dropdown { display:none; position:absolute; top:calc(100% + 6px); right:0; min-width:220px; background:var(--navy-800); border:1px solid var(--navy-500); border-radius:var(--radius); box-shadow:0 8px 24px rgba(0,0,0,.4); z-index:1000; overflow:hidden; }
.profile-dropdown.open { display:block; }
.profile-info { padding:12px 16px; border-bottom:1px solid var(--navy-600); }
.profile-info .profile-username { font-size:13px; font-weight:600; color:var(--white); margin-bottom:4px; }
.profile-role-badge { display:inline-block; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; padding:2px 8px; border-radius:3px; background:var(--accent); color:var(--white); }
.profile-role-badge.role-scheduler { background:var(--navy-500); }
.profile-dropdown .divider { height:1px; background:var(--navy-600); }
.profile-menu-item { display:flex; align-items:center; gap:8px; width:100%; padding:10px 16px; background:transparent; border:none; color:var(--slate-200); font-size:12px; cursor:pointer; transition:var(--transition); text-align:left; font-family:inherit; }
.profile-menu-item:hover { background:var(--navy-700); color:var(--white); }
.profile-menu-item svg { width:15px; height:15px; stroke:var(--slate-400); fill:none; stroke-width:2; }
.profile-menu-item:hover svg { stroke:var(--accent); }
.profile-menu-item.danger { color:#ef4444; }
.profile-menu-item.danger svg { stroke:#ef4444; }
.profile-menu-item.danger:hover { background:rgba(239,68,68,.1); }

/* ---- CHANGE PASSWORD MODAL ---- */
.cp-modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:2000; justify-content:center; align-items:center; }
.cp-modal-overlay.open { display:flex; }
.cp-modal { background:var(--navy-800); border:1px solid var(--navy-500); border-radius:var(--radius); padding:24px; width:380px; max-width:90vw; box-shadow:0 12px 40px rgba(0,0,0,.5); }
.cp-modal h3 { margin:0 0 20px; font-size:16px; color:var(--white); }
.cp-field { margin-bottom:14px; }
.cp-field label { display:block; font-size:11px; color:var(--slate-300); margin-bottom:4px; text-transform:uppercase; letter-spacing:.3px; }
.cp-field input { width:100%; padding:8px 12px; background:var(--navy-900); border:1px solid var(--navy-500); border-radius:var(--radius); color:var(--white); font-size:13px; transition:var(--transition); box-sizing:border-box; font-family:inherit; }
.cp-field input:focus { outline:none; border-color:var(--accent); }
.cp-actions { display:flex; justify-content:flex-end; gap:10px; margin-top:20px; }
.cp-actions button { padding:8px 18px; border-radius:var(--radius); font-size:12px; cursor:pointer; transition:var(--transition); border:none; font-family:inherit; }
.cp-actions .cp-cancel { background:var(--navy-600); color:var(--slate-200); }
.cp-actions .cp-cancel:hover { background:var(--navy-500); }
.cp-actions .cp-submit { background:var(--accent); color:var(--white); }
.cp-actions .cp-submit:hover { background:var(--accent-hover); }
.cp-message { margin-top:12px; padding:8px 12px; border-radius:var(--radius); font-size:12px; display:none; }
.cp-message.success { display:block; background:rgba(34,197,94,.15); color:#4ade80; border:1px solid rgba(34,197,94,.3); }
.cp-message.error { display:block; background:rgba(239,68,68,.15); color:#f87171; border:1px solid rgba(239,68,68,.3); }

/* ---- HELP MODAL ---- */
.help-overlay { position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,.6); display:none; align-items:center; justify-content:center; backdrop-filter:blur(2px); }
.help-overlay.active { display:flex; }
.help-modal { position:relative; display:flex; width:92vw; max-width:1100px; height:82vh; background:var(--navy-900); border-radius:var(--radius); border:1px solid var(--navy-600); box-shadow:0 24px 48px rgba(0,0,0,.4); overflow:hidden; }
.help-close { position:absolute; top:12px; right:14px; z-index:10; background:none; border:none; color:var(--slate-400); font-size:1.4rem; cursor:pointer; padding:4px 8px; border-radius:var(--radius); transition:var(--transition); line-height:1; }
.help-close:hover { color:var(--white); background:var(--navy-700); }
.help-sidebar { width:240px; min-width:240px; background:var(--navy-800); border-right:1px solid var(--navy-600); display:flex; flex-direction:column; overflow:hidden; }
.help-sidebar-header { padding:16px 16px 12px; border-bottom:1px solid var(--navy-700); flex-shrink:0; }
.help-sidebar-header h3 { margin:0 0 10px; font-size:11px; text-transform:uppercase; letter-spacing:.08em; color:var(--slate-400); font-weight:600; }
.help-search { width:100%; padding:7px 10px; background:var(--navy-900); border:1px solid var(--navy-600); border-radius:var(--radius); color:var(--white); font-size:12px; outline:none; transition:var(--transition); box-sizing:border-box; font-family:inherit; }
.help-search::placeholder { color:var(--slate-400); }
.help-search:focus { border-color:var(--accent); }
.help-nav { flex:1; overflow-y:auto; padding:8px 0; }
.hs-topic { display:flex; align-items:center; width:100%; padding:9px 14px; background:none; border:none; border-left:3px solid transparent; color:var(--slate-300); font-size:13px; font-weight:600; cursor:pointer; text-align:left; gap:8px; transition:var(--transition); line-height:1.3; font-family:inherit; }
.hs-topic:hover { background:var(--navy-700); color:var(--white); }
.hs-topic .hs-chevron { font-size:10px; transition:transform .2s ease; flex-shrink:0; width:12px; text-align:center; }
.hs-topic.active { color:var(--white); background:var(--navy-700); border-left-color:var(--accent); }
.hs-topic.active .hs-chevron { transform:rotate(90deg); }
.hs-subs { max-height:0; overflow:hidden; transition:max-height .25s ease; }
.hs-topic.active + .hs-subs { max-height:300px; }
.hs-sub { display:block; width:100%; padding:6px 14px 6px 38px; background:none; border:none; color:var(--slate-400); font-size:12px; cursor:pointer; text-align:left; transition:var(--transition); position:relative; font-family:inherit; }
.hs-sub:hover, .hs-sub.active { color:var(--accent); }
.hs-sub:hover::before, .hs-sub.active::before { content:''; position:absolute; left:26px; top:50%; transform:translateY(-50%); width:4px; height:4px; border-radius:50%; background:var(--accent); }
.help-search-results { display:none; padding:8px 0; }
.help-search-results.active { display:block; }
.help-search-results .hs-result { display:block; width:100%; padding:7px 14px; background:none; border:none; color:var(--slate-300); font-size:12px; cursor:pointer; text-align:left; transition:var(--transition); font-family:inherit; }
.help-search-results .hs-result:hover { background:var(--navy-700); color:var(--accent); }
.help-search-results .hs-result-topic { font-size:10px; color:var(--slate-400); display:block; margin-top:1px; }
.help-content { flex:1; overflow-y:auto; padding:32px 36px; scroll-behavior:smooth; }
.help-page { display:none; }
.help-page.active { display:block; }
.help-page h2 { margin:0 0 6px; font-size:20px; color:var(--white); font-weight:700; }
.help-page .help-page-desc { color:var(--slate-400); font-size:13px; margin:0 0 24px; }
.help-page h4 { margin:28px 0 10px; font-size:15px; color:var(--white); font-weight:600; padding-top:8px; }
.help-page h4:first-of-type { margin-top:0; }
#help-page-skeddy h4 { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0); margin:-1px; padding:0; border:0; }
.help-section-intro { color:var(--slate-300); font-size:13px; margin:0 0 12px; line-height:1.5; }
.help-step { display:flex; align-items:flex-start; gap:14px; margin-bottom:18px; }
.help-step-num { flex-shrink:0; width:28px; height:28px; background:var(--accent); color:var(--white); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:12px; font-weight:700; margin-top:1px; }
.help-step-body { flex:1; }
.help-step-body strong { color:var(--white); font-size:13px; display:block; margin-bottom:3px; }
.help-step-body p, .help-step-body ul { margin:0; color:var(--slate-300); font-size:13px; line-height:1.55; }
.help-step-body ul { padding-left:16px; margin-top:4px; }
.help-step-body li { margin-bottom:3px; }
.help-img { display:block; max-width:600px; width:100%; margin:14px auto 20px; border-radius:var(--radius); border:1px solid var(--navy-600); box-shadow:0 4px 12px rgba(0,0,0,.25); }
.help-tip { background:rgba(59,130,246,.08); border:1px solid rgba(59,130,246,.2); border-radius:var(--radius); padding:10px 14px; margin:14px 0; font-size:12px; color:var(--slate-300); line-height:1.5; }
.help-tip::before { content:'TIP: '; font-weight:700; color:var(--accent); }
.help-kbd { display:inline-block; background:var(--navy-700); border:1px solid var(--navy-500); border-radius:4px; padding:1px 7px; font-size:11px; font-family:monospace; color:var(--slate-200); margin:0 2px; }
.help-page ul:not(.help-step-body ul) { padding-left:18px; margin:8px 0 14px; color:var(--slate-300); font-size:13px; line-height:1.6; }
.help-page li { margin-bottom:4px; }
.help-def { margin-bottom:10px; }
.help-def dt { color:var(--white); font-weight:600; font-size:13px; }
.help-def dd { margin:2px 0 0 0; color:var(--slate-300); font-size:12px; line-height:1.5; }
.help-shortcuts { width:100%; border-collapse:collapse; margin:10px 0 18px; }
.help-shortcuts td { padding:6px 10px; font-size:12px; color:var(--slate-300); border-bottom:1px solid var(--navy-700); }
.help-shortcuts td:first-child { width:140px; white-space:nowrap; }
@media(max-width:700px) {
  .help-modal { flex-direction:column; width:98vw; height:90vh; }
  .help-sidebar { width:100%; min-width:unset; border-right:none; border-bottom:1px solid var(--navy-600); }
  .help-nav { display:flex; overflow-x:auto; overflow-y:hidden; padding:0 8px 8px; gap:4px; }
  .hs-topic { white-space:nowrap; padding:6px 12px; font-size:12px; border-left:none; border-bottom:2px solid transparent; flex-shrink:0; }
  .hs-topic.active { border-left-color:transparent; border-bottom-color:var(--accent); }
  .hs-topic .hs-chevron { display:none; }
  .hs-subs { display:none; }
  .help-content { padding:20px 16px; }
  .help-img { max-width:100%; }
}

/* ---- CONFLICTS PANEL ---- */
.conflicts-panel { display:none; position:absolute; top:60px; right:16px; width:480px; max-height:70vh; background:var(--navy-800); border:1px solid var(--navy-600); border-radius:var(--radius); box-shadow:0 8px 24px rgba(0,0,0,.4); z-index:60; overflow:hidden; }
.conflicts-panel.open { display:flex; flex-direction:column; }
.conflicts-panel .cp-header { padding:10px 14px; border-bottom:1px solid var(--navy-600); display:flex; align-items:center; justify-content:space-between; }
.conflicts-panel .cp-header h4 { font-size:13px; font-weight:600; }
.conflicts-panel .cp-header button { background:none; border:none; color:var(--slate-400); cursor:pointer; font-size:16px; }
.conflicts-panel .cp-list { flex:1; overflow-y:auto; padding:4px 0; }
.conflict-item { padding:8px 14px; border-bottom:1px solid var(--navy-700); display:flex; gap:10px; align-items:flex-start; cursor:pointer; transition:var(--transition); }
.conflict-item:hover { background:var(--navy-700); }
.conflict-item .ci-icon { font-size:14px; flex-shrink:0; margin-top:1px; }
.conflict-item .ci-body { flex:1; }
.conflict-item .ci-title { font-size:12px; font-weight:500; color:var(--white); }
.conflict-item .ci-detail { font-size:10px; color:var(--slate-400); margin-top:2px; }
.conflict-item .ci-severity { font-size:9px; font-weight:600; padding:2px 6px; border-radius:8px; flex-shrink:0; }
.conflict-item .ci-severity.high { background:rgba(239,68,68,.12); color:#ef4444; }
.conflict-item .ci-severity.med { background:rgba(245,158,11,.12); color:#f59e0b; }
.conflict-item .ci-severity.low { background:rgba(59,130,246,.12); color:var(--accent); }
.conflict-item.resolved { opacity:.5; }
.conflict-item.resolved .ci-title { text-decoration:line-through; }
.conflict-item.resolved .ci-resolved-badge { color:var(--green); font-size:12px; margin-left:4px; }
.ci-resolve-btn { font-size:10px; font-weight:600; padding:3px 8px; border-radius:6px; background:rgba(59,130,246,.12); color:var(--accent); border:1px solid rgba(59,130,246,.3); cursor:pointer; transition:var(--transition); flex-shrink:0; margin-top:2px; }
.ci-resolve-btn:hover { background:rgba(59,130,246,.25); }
.ci-resolve-form { margin-top:8px; padding:8px; background:var(--navy-700); border-radius:var(--radius-sm); border:1px solid var(--navy-500); }
.ci-resolve-form select, .ci-resolve-form textarea { width:100%; background:var(--navy-800); border:1px solid var(--navy-600); color:var(--white); padding:5px 8px; border-radius:4px; font-size:11px; font-family:inherit; outline:none; margin-bottom:6px; }
.ci-resolve-form select:focus, .ci-resolve-form textarea:focus { border-color:var(--accent); }
.ci-resolve-form textarea { resize:vertical; min-height:40px; }
.ci-resolve-form .ci-form-actions { display:flex; gap:6px; justify-content:flex-end; }
.ci-resolve-form .ci-form-actions button { font-size:10px; font-weight:600; padding:3px 10px; border-radius:4px; cursor:pointer; font-family:inherit; transition:var(--transition); }
.ci-resolve-form .ci-confirm-btn { background:var(--green); color:white; border:none; }
.ci-resolve-form .ci-confirm-btn:hover { background:#16a34a; }
.ci-resolve-form .ci-cancel-btn { background:none; border:1px solid var(--navy-500); color:var(--slate-300); }
.ci-resolve-form .ci-cancel-btn:hover { border-color:var(--accent); }
.cp-section-header { padding:6px 14px; font-size:11px; font-weight:600; color:var(--slate-400); text-transform:uppercase; letter-spacing:.5px; background:var(--navy-700); cursor:pointer; user-select:none; display:flex; align-items:center; gap:6px; }
.cp-section-header:hover { background:var(--navy-600); }
.cp-section-header .cp-toggle { font-size:8px; transition:transform var(--transition); }
.cp-section-header .cp-toggle.collapsed { transform:rotate(-90deg); }
.watchbill-table { width:100%; border-collapse:separate; border-spacing:0; font-size:12px; }
.watchbill-table th { padding:8px 12px; text-align:left; font-weight:600; font-size:11px; color:var(--slate-300); background:var(--navy-800); border-bottom:2px solid var(--navy-600); position:sticky; top:0; z-index:5; }
.watchbill-table td { padding:8px 12px; border-bottom:1px solid var(--navy-700); vertical-align:top; }
.watchbill-table tr:hover td { background:var(--navy-700); }
.watchbill-table select { background:var(--navy-700); border:1px solid var(--navy-600); color:var(--white); padding:4px 8px; border-radius:4px; font-size:11px; font-family:inherit; cursor:pointer; outline:none; min-width:180px; }
.watchbill-table select:focus { border-color:var(--accent); }
.wb-times { font-size:11px; color:var(--slate-300); }
.wb-status { font-size:10px; font-weight:600; padding:2px 8px; border-radius:8px; }
.wb-status.assigned { background:rgba(168,85,247,.12); color:var(--purple); }
.wb-status.unassigned { background:rgba(100,116,139,.12); color:var(--slate-dim); }
.wb-role-tag { font-size:9px; font-weight:600; padding:1px 6px; border-radius:4px; margin-left:6px; }
.wb-role-tag.instructor { background:rgba(34,197,94,.12); color:var(--green); }
.wb-role-tag.student { background:rgba(59,130,246,.12); color:var(--accent); }
.wb-warning { font-size:10px; color:#f59e0b; margin-top:4px; display:flex; align-items:center; gap:4px; }
.wb-blocked { font-size:10px; color:#ef4444; margin-top:4px; display:flex; align-items:center; gap:4px; }
.wb-field-selector { padding:12px 16px; border-bottom:1px solid var(--navy-600); }
.wb-field-selector .wb-field-label { font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; color:var(--slate-400); margin-bottom:8px; }
.wb-field-btns { display:flex; gap:6px; flex-wrap:wrap; }
.wb-field-btn { padding:6px 14px; border-radius:4px; border:1px solid var(--navy-500); background:var(--navy-700); color:var(--slate-300); cursor:pointer; font-size:12px; font-family:inherit; transition:var(--transition); }
.wb-field-btn:hover { border-color:var(--slate-300); }
.wb-field-btn.active { background:var(--green); color:#000; border-color:var(--green); font-weight:600; }

/* ---- Login Overlay ---- */
.login-overlay { display:flex; position:fixed; inset:0; background:rgba(10,22,40,.95); z-index:9999; align-items:center; justify-content:center; backdrop-filter:blur(8px); }
.login-overlay.dismissed { display:none; }
body.authenticated .login-overlay:not(.active) { display:none; }
.login-box { background:var(--navy-800); border:1px solid var(--navy-600); border-radius:12px; padding:32px 40px; width:360px; max-width:90vw; box-shadow:0 20px 60px rgba(0,0,0,.5); }
.login-box h2 { font-size:18px; font-weight:700; color:var(--white); margin-bottom:4px; text-align:center; }
.login-box .login-sub { font-size:12px; color:var(--slate-400); text-align:center; margin-bottom:20px; }
.login-box label { display:block; font-size:11px; font-weight:600; text-transform:uppercase; letter-spacing:.5px; color:var(--slate-400); margin-bottom:4px; }
.login-box input { width:100%; background:var(--navy-700); border:1px solid var(--navy-600); color:var(--white); padding:8px 12px; border-radius:6px; font-size:13px; font-family:inherit; outline:none; margin-bottom:12px; }
.login-box input:focus { border-color:var(--accent); }
.login-role-btn { flex:1; padding:8px; border-radius:6px; border:1px solid var(--navy-600); background:var(--navy-700); color:var(--slate-300); font-size:12px; font-weight:600; font-family:inherit; cursor:pointer; transition:var(--transition); }
.login-role-btn:hover { border-color:var(--accent); color:var(--white); }
.login-role-btn.active { background:var(--accent); border-color:var(--accent); color:white; }
.login-box .login-btn { width:100%; padding:10px; background:var(--accent); color:white; border:none; border-radius:6px; font-size:13px; font-weight:600; font-family:inherit; cursor:pointer; transition:var(--transition); }
.login-box .login-btn:hover { background:var(--accent-hover); }
.login-box .login-btn:disabled { opacity:.6; cursor:not-allowed; }
.login-box .login-error { font-size:11px; color:#ef4444; margin-top:8px; text-align:center; display:none; }

/* ---- Audit Log Modal ---- */
.audit-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:10000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;}
.audit-overlay.open{opacity:1;visibility:visible;}
.audit-panel{width:680px;max-height:80vh;background:var(--navy-800);border:1px solid var(--navy-600);border-radius:12px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.5);}
.audit-hdr{padding:12px 16px;background:var(--navy-900);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--navy-700);}
.audit-hdr h3{margin:0;font-size:14px;color:var(--white);font-weight:700;}
.audit-hdr button{background:none;border:none;color:var(--slate-400);cursor:pointer;font-size:18px;}
.audit-body{flex:1;overflow-y:auto;padding:0;}
.audit-entry{display:flex;align-items:flex-start;gap:12px;padding:10px 16px;border-bottom:1px solid var(--navy-700);font-size:12px;transition:background .15s;}
.audit-entry:hover{background:var(--navy-700);}
.audit-entry .ae-time{color:var(--slate-400);white-space:nowrap;min-width:70px;font-size:11px;}
.audit-entry .ae-user{color:var(--accent);font-weight:600;min-width:80px;}
.audit-entry .ae-action{flex:1;color:var(--slate-200);}
.audit-entry .ae-type{display:inline-block;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;margin-right:4px;}
.ae-type.create{background:rgba(34,197,94,.2);color:#22c55e;}
.ae-type.update{background:rgba(59,130,246,.2);color:#3b82f6;}
.ae-type.delete{background:rgba(239,68,68,.2);color:#ef4444;}
.ae-type.revert{background:rgba(245,158,11,.2);color:#f59e0b;}
.audit-entry .ae-undo{background:none;border:1px solid var(--navy-600);color:var(--slate-300);padding:2px 8px;border-radius:4px;cursor:pointer;font-size:10px;white-space:nowrap;}
.audit-entry .ae-undo:hover{border-color:var(--accent);color:var(--accent);}
.audit-empty{padding:40px;text-align:center;color:var(--slate-500);font-size:13px;}
.audit-loading{padding:40px;text-align:center;color:var(--slate-400);font-size:12px;}
.dww-banner{background:repeating-linear-gradient(-45deg,rgba(245,158,11,.08),rgba(245,158,11,.08) 10px,rgba(245,158,11,.04) 10px,rgba(245,158,11,.04) 20px);border:1px solid rgba(245,158,11,.3);border-radius:8px;padding:10px 14px;margin-bottom:12px;display:flex;align-items:flex-start;gap:10px;}
.dww-badge{background:#f59e0b;color:#1a1a2e;font-size:9px;font-weight:800;padding:2px 6px;border-radius:4px;white-space:nowrap;flex-shrink:0;letter-spacing:.04em;margin-top:1px;}
.dww-text{font-size:11px;color:var(--slate-300);line-height:1.5;}
.dww-text strong{color:#fbbf24;font-weight:600;}
.dww-admin-card{background:var(--navy-800);border:1px solid var(--navy-600);border-radius:10px;padding:16px;margin-bottom:12px;}
.dww-admin-card:hover{border-color:rgba(245,158,11,.3);}
.dww-admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.dww-admin-badge{background:#f59e0b;color:#1a1a2e;font-size:10px;font-weight:800;padding:2px 8px;border-radius:4px;}
.dww-admin-cat{font-size:10px;color:var(--slate-400);background:var(--navy-700);padding:2px 8px;border-radius:4px;margin-left:8px;}
.dww-admin-delete{background:none;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:4px 10px;font-size:10px;font-weight:600;border-radius:5px;cursor:pointer;font-family:inherit;}
.dww-admin-delete:hover{background:rgba(239,68,68,.1);border-color:#ef4444;}
.dww-admin-title{font-size:13px;font-weight:600;color:var(--white);margin-bottom:4px;}
.dww-admin-desc{font-size:11px;color:var(--slate-300);line-height:1.5;margin-bottom:8px;}
.dww-admin-meta{font-size:10px;color:var(--slate-500);display:flex;gap:12px;}
.dww-admin-screenshot{border:1px solid var(--navy-600);border-radius:6px;max-width:100%;margin-top:8px;cursor:pointer;}
.dww-admin-screenshot:hover{border-color:var(--accent);}
.sup-btn{position:fixed;bottom:60px;right:16px;width:48px;height:48px;border-radius:50%;background:var(--accent,#4a90d9);border:none;cursor:pointer;z-index:9999;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(74,144,217,.4);transition:transform .2s}
.sup-btn:hover{transform:scale(1.1);background:var(--accent-hover,#3a7fc8)}
.sup-btn svg{width:24px;height:24px;color:#fff}
.sup-badge{position:absolute;top:-2px;right:-2px;background:#ef4444;color:#fff;font-size:11px;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}
.sup-panel{position:fixed;bottom:116px;right:16px;width:380px;height:480px;background:var(--navy-800,#0d1b2a);border:1px solid var(--navy-600,rgba(74,144,217,.2));border-radius:12px;z-index:9999;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.6);opacity:0;visibility:hidden;transform:translateY(12px) scale(.97);transition:opacity .2s ease,visibility .2s ease,transform .2s ease;pointer-events:none}
.sup-panel.open{opacity:1;visibility:visible;transform:translateY(0) scale(1);pointer-events:auto}
.sup-hdr{padding:12px 16px;background:var(--navy-900,#1b2838);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--navy-600,rgba(74,144,217,.15))}
.sup-hdr span{color:var(--accent,#4a90d9);font-weight:700;font-size:14px}
.sup-hdr button{background:none;border:none;color:#aaa;cursor:pointer;font-size:18px}
.sup-body{flex:1;overflow-y:auto;padding:12px;min-height:200px}
.sup-msgs{display:flex;flex-direction:column;gap:8px}
.sup-msg{max-width:85%;padding:8px 12px;border-radius:12px;font-size:13px;line-height:1.4;word-wrap:break-word}
.sup-msg.user{align-self:flex-end;background:var(--accent,#4a90d9);color:#fff;border-bottom-right-radius:4px}
.sup-msg.team{align-self:flex-start;background:var(--navy-700,#1b2838);color:var(--slate-200,#e0e0e0);border-bottom-left-radius:4px}
.sup-msg .sup-name{font-size:11px;opacity:.7;margin-bottom:2px}
.sup-msg .sup-time{font-size:10px;opacity:.5;margin-top:4px}
.sup-input-row{padding:8px 12px;border-top:1px solid rgba(255,255,255,.1);display:flex;gap:8px;align-items:center}
.sup-input-row input,.sup-input-row textarea{flex:1;background:var(--navy-900,#0a1628);border:1px solid var(--navy-600,rgba(74,144,217,.2));border-radius:8px;padding:8px;color:var(--white,#fff);font-size:13px;outline:none;resize:none}
.sup-input-row button{background:var(--accent,#4a90d9);border:none;border-radius:8px;padding:8px 14px;color:#fff;cursor:pointer;font-size:13px;font-weight:600}
.sup-input-row button:hover{background:var(--accent-hover,#3a7fc8)}
.sup-form label{color:#ccc;font-size:12px;display:block;margin-bottom:4px}
.sup-form input,.sup-form textarea{width:100%;box-sizing:border-box;background:var(--navy-900,#0a1628);border:1px solid var(--navy-600,rgba(74,144,217,.2));border-radius:8px;padding:8px;color:var(--white,#fff);font-size:13px;margin-bottom:10px;outline:none}
.sup-empty{text-align:center;color:#666;padding:40px 20px;font-size:13px}
.sup-session-card{background:var(--navy-700,#1b2838);border:1px solid var(--navy-600,rgba(74,144,217,.1));border-radius:10px;padding:10px 14px;margin-bottom:8px;cursor:pointer;transition:border-color .2s}
.sup-session-card:hover{border-color:var(--accent,#4a90d9)}
.sup-session-card .sup-sid{color:var(--accent,#4a90d9);font-weight:700;font-size:13px}
.sup-session-card .sup-status{font-size:11px;padding:2px 8px;border-radius:10px;margin-left:8px}
.sup-status-OPEN{background:#166534;color:#4ade80}
.sup-status-LOGGED{background:#854d0e;color:#fbbf24}
.sup-status-RESOLVED,.sup-status-CLOSED{background:#374151;color:#9ca3af}
.sup-resolve-btn{background:none;border:1px solid #4ade80;color:#4ade80;border-radius:8px;padding:4px 12px;cursor:pointer;font-size:12px;margin-left:auto}
.sup-resolve-btn:hover{background:#166534}
.sup-back{background:none;border:none;color:var(--accent,#4a90d9);cursor:pointer;font-size:13px;padding:0;margin-right:8px}
.sup-file-btn{background:none;border:none;color:#aaa;cursor:pointer;font-size:18px}
@media(max-width:640px){.sup-panel{width:calc(100vw - 32px);right:16px;bottom:84px}}
