*{box-sizing:border-box;margin:0;padding:0}
body{font-family:system-ui,sans-serif;background:#f8f9fa;color:#202124;min-height:100vh}
#login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#e8f0fe 0%,#f8f9fa 100%)}
.login-card{background:#fff;border:1px solid #e0e0e0;border-radius:16px;padding:48px 40px;text-align:center;width:400px}
.login-logo{width:60px;height:60px;background:#4285F4;border-radius:16px;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;font-weight:700}
.btn-google{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:46px;border:1px solid #dadce0;border-radius:10px;background:#fff;cursor:pointer;font-size:14px;font-weight:500;color:#202124}
.btn-google:hover{background:#f8f9fa}
#org-select-page{display:none;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#e8f0fe 0%,#f8f9fa 100%)}
.org-card{background:#fff;border:1px solid #e0e0e0;border-radius:16px;padding:32px;width:460px}
.org-item{display:flex;align-items:center;gap:14px;padding:14px 16px;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;margin-bottom:10px}
.org-item:hover{border-color:#4285F4;background:#f0f4ff}
.org-item.active{border-color:#4285F4;background:#e8f0fe}
.org-avatar{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;flex-shrink:0}
.add-org-btn{width:100%;height:44px;border:2px dashed #dadce0;border-radius:10px;background:transparent;cursor:pointer;font-size:13px;color:#888;display:flex;align-items:center;justify-content:center;gap:8px}
.add-org-btn:hover{border-color:#4285F4;color:#4285F4}
#app-page{display:none;flex-direction:column;min-height:100vh}
.topbar{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid #e0e0e0}
.logo{font-size:15px;font-weight:500;display:flex;align-items:center;gap:8px}
.logo-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700}
.edu-badge{font-size:11px;padding:3px 8px;border-radius:4px;font-weight:500;background:#e8f0fe;color:#1a73e8}
.org-switcher{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;background:#f8f9fa;font-size:13px}
.org-switcher:hover{background:#e8f0fe;border-color:#4285F4}
.org-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.org-dropdown{position:absolute;top:60px;left:50%;transform:translateX(-50%);background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.12);width:300px;z-index:100;padding:12px}
.org-dd-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;font-size:13px}
.org-dd-item:hover{background:#f8f9fa}
.org-dd-item.current{background:#e8f0fe}
.org-dd-avatar{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700;flex-shrink:0}
.topbar-right{display:flex;align-items:center;gap:8px;font-size:13px;color:#666}
.btn-sm{height:32px;padding:0 12px;border:1px solid #dadce0;border-radius:6px;background:#fff;cursor:pointer;font-size:12px}
.btn-sm:hover{background:#f8f9fa}
.body{display:flex;height:calc(100vh - 56px)}
.sidebar{width:210px;background:#fff;border-right:1px solid #e0e0e0;padding:12px 0;flex-shrink:0;overflow-y:auto;display:flex;flex-direction:column}
.sidebar-banner{margin:0 12px 12px;padding:10px 12px;border-radius:8px;font-size:12px}
.nav-section{font-size:10px;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:0.06em;padding:12px 18px 5px}
.nav-item{display:flex;align-items:center;gap:10px;padding:8px 18px;font-size:13px;cursor:pointer;color:#444;border-left:3px solid transparent}
.nav-item:hover{background:#f8f9fa}
.nav-item.active{font-weight:500}
.nav-icon{font-size:14px;width:18px;text-align:center}
.sidebar-footer{margin-top:auto;padding:12px}
.sidebar-footer-btn{width:100%;height:34px;border:1px solid #dadce0;border-radius:8px;background:#fff;cursor:pointer;font-size:12px;color:#666}
.main{flex:1;overflow-y:auto}
.page{display:none;padding:24px}
.page.active{display:block}
.page-title{font-size:20px;font-weight:500;margin-bottom:4px}
.page-sub{font-size:13px;color:#888;margin-bottom:20px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.stat{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:16px}
.stat-label{font-size:11px;color:#888;margin-bottom:6px;text-transform:uppercase;letter-spacing:0.03em}
.stat-val{font-size:26px;font-weight:500}
.c-blue{color:#1a73e8}.c-green{color:#188038}.c-red{color:#d93025}.c-amber{color:#e37400}.c-purple{color:#9c27b0}
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:0}
.search-wrap{flex:1;min-width:180px;position:relative}
.search-wrap input{width:100%;height:36px;padding:0 12px 0 36px;border:1px solid #dadce0;border-radius:8px;font-size:13px;outline:none;background:#fff}
.search-wrap input:focus{border-color:#1a73e8}
.si{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:#aaa;font-size:14px;pointer-events:none}
select{height:36px;padding:0 10px;border:1px solid #dadce0;border-radius:8px;font-size:13px;outline:none;background:#fff;cursor:pointer}
.btn{height:36px;padding:0 14px;border:1px solid #dadce0;border-radius:8px;background:#fff;font-size:13px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.btn:hover{background:#f8f9fa}
.btn-primary{background:#1a73e8;border-color:#1a73e8;color:#fff}
.btn-primary:hover{background:#1557b0}
.btn-success{background:#188038;border-color:#188038;color:#fff}
.btn-success:hover{background:#145c2a}
.btn-danger{background:#d93025;border-color:#d93025;color:#fff}
.btn-danger:hover{background:#b31412}
.btn-warn{background:#e37400;border-color:#e37400;color:#fff}
.btn-warn:hover{background:#b35a00}
.bulk-bar{display:none;align-items:center;gap:12px;padding:10px 16px;border-radius:10px;margin:12px 0;color:#fff}
.bulk-bar.visible{display:flex}
.bulk-sep{width:1px;height:20px;background:rgba(255,255,255,0.3)}
.bulk-btn{height:30px;padding:0 12px;border-radius:6px;border:1.5px solid rgba(255,255,255,0.5);background:transparent;color:#fff;font-size:12px;cursor:pointer}
.bulk-btn:hover{background:rgba(255,255,255,0.15)}
.bulk-btn.red{border-color:rgba(255,180,180,0.6)}
.bulk-clear{margin-left:auto;background:none;border:none;color:rgba(255,255,255,0.7);cursor:pointer;font-size:18px}
.table-wrap{background:#fff;border:1px solid #e0e0e0;border-radius:10px;overflow:hidden}
table{width:100%;border-collapse:collapse;table-layout:fixed}
th{font-size:11px;font-weight:600;color:#888;text-align:left;padding:10px 14px;border-bottom:1px solid #e0e0e0;background:#fafafa;text-transform:uppercase;letter-spacing:0.04em}
td{font-size:13px;padding:11px 14px;border-bottom:1px solid #f1f3f4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
tr:last-child td{border-bottom:none}
tr:hover td{background:#f8f9fa}
tr.sel td{background:#e8f0fe!important}
.cb{width:16px;height:16px;cursor:pointer;accent-color:#1a73e8}
.avatar{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}
.user-cell{display:flex;align-items:center;gap:10px}
.uname{font-size:13px;font-weight:500}
.uemail{font-size:11.5px;color:#888}
.badge-st{display:inline-flex;padding:3px 9px;border-radius:4px;font-size:11.5px;font-weight:500}
.b-active{background:#e6f4ea;color:#137333}
.b-suspended{background:#fce8e6;color:#c5221f}
.b-new{background:#e8f0fe;color:#1a73e8}
.b-warn{background:#fef7e0;color:#b06000}
.act-btn{padding:4px 9px;border-radius:6px;font-size:11.5px;border:1px solid #dadce0;background:#fff;cursor:pointer;color:#444}
.act-btn:hover{background:#f8f9fa}
.act-btn.danger:hover{background:#fce8e6;color:#c5221f;border-color:#f5c6c5}
.pagination{display:flex;align-items:center;justify-content:space-between;margin-top:14px}
.page-info{font-size:12px;color:#888}
.page-btns{display:flex;gap:6px}
.page-btn{width:32px;height:32px;border-radius:6px;border:1px solid #dadce0;background:#fff;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center}
.page-btn:hover{background:#f8f9fa}
.two-col{display:flex;gap:20px}
.cfg-panel{width:340px;flex-shrink:0;background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:20px}
.prv-panel{flex:1;background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:20px;display:flex;flex-direction:column;min-height:400px}
.section-lbl{font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:0.05em;margin:14px 0 8px;padding-bottom:5px;border-bottom:1px solid #f0f0f0}
.section-lbl:first-child{margin-top:0}
.field{margin-bottom:12px}
.field label{display:block;font-size:11.5px;color:#666;margin-bottom:4px;font-weight:500;text-transform:uppercase;letter-spacing:0.03em}
.field input,.field select,.field textarea{width:100%;border:1px solid #dadce0;border-radius:8px;font-size:13px;outline:none;background:#fff;padding:0 12px;color:#202124}
.field input,.field select{height:36px}
.field textarea{padding:10px 12px;resize:vertical}
.field input:focus,.field select:focus{border-color:#1a73e8}
.fmt-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.fmt-card{border:1.5px solid #dadce0;border-radius:8px;padding:10px 12px;cursor:pointer}
.fmt-card:hover{border-color:#1a73e8;background:#f0f4ff}
.fmt-card.sel{border-color:#1a73e8;background:#e8f0fe}
.fmt-card input{display:none}
.fmt-name{font-size:12.5px;font-weight:500;margin-bottom:2px}
.fmt-ex{font-size:11px;color:#888;font-family:monospace}
.fmt-card.sel .fmt-name{color:#1a73e8}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f8f9fa;font-size:13px}
.toggle{position:relative;width:36px;height:20px;cursor:pointer;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.tslider{position:absolute;inset:0;background:#dadce0;border-radius:99px;transition:0.2s}
.tslider:before{content:'';position:absolute;width:14px;height:14px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:0.2s}
.toggle input:checked+.tslider{background:#1a73e8}
.toggle input:checked+.tslider:before{transform:translateX(16px)}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;min-height:30px}
.chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;border:1.5px solid #dadce0;background:#fff;cursor:pointer;font-size:12px;color:#444}
.chip.active{border-color:#1a73e8;background:#e8f0fe;color:#1a73e8;font-weight:500}
.chip.danger{border-color:#f5c6c5;background:#fce8e6;color:#c5221f}
.chip-x{font-size:14px;line-height:1;opacity:0.6}
.input-row{display:flex;gap:8px}
.input-row input{flex:1;height:36px;padding:0 12px;border:1px solid #dadce0;border-radius:8px;font-size:13px;outline:none}
.input-row button{height:36px;padding:0 14px;border:1px solid #1a73e8;border-radius:8px;background:#e8f0fe;color:#1a73e8;font-size:13px;cursor:pointer;font-weight:500}
.gen-btn{width:100%;height:44px;border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;margin-top:16px;display:flex;align-items:center;justify-content:center;gap:8px;background:#1a73e8}
.gen-btn:hover{opacity:0.9}
.prv-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:8px}
.pstat{background:#f8f9fa;border-radius:6px;padding:5px 12px;font-size:12.5px}
.pstat span{font-weight:600;color:#1a73e8}
.prv-table-wrap{flex:1;overflow-y:auto;border:1px solid #e0e0e0;border-radius:8px}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:250px;color:#aaa;gap:10px}
.empty-icon{font-size:44px;opacity:0.4}
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:200;align-items:center;justify-content:center}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:12px;padding:28px;width:460px;box-shadow:0 8px 32px rgba(0,0,0,0.15);max-height:90vh;overflow-y:auto}
.modal-title{font-size:17px;font-weight:500;margin-bottom:6px}
.modal-sub{font-size:13px;color:#888;margin-bottom:18px}
.modal-field{margin-bottom:12px}
.modal-field label{display:block;font-size:12px;color:#666;margin-bottom:4px;font-weight:500}
.modal-field input,.modal-field select{width:100%;height:38px;padding:0 12px;border:1px solid #dadce0;border-radius:8px;font-size:13px;outline:none}
.modal-field input:focus{border-color:#1a73e8}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}
.scroll-list{max-height:180px;overflow-y:auto;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:14px}
.uli{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid #f1f3f4;font-size:13px}
.uli:last-child{border-bottom:none}
.uli-av{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;flex-shrink:0}
.progress-wrap{margin:14px 0}
.progress-label{font-size:12.5px;color:#666;margin-bottom:5px;display:flex;justify-content:space-between}
.progress-bar{height:7px;background:#e0e0e0;border-radius:99px;overflow:hidden}
.progress-fill{height:100%;background:#1a73e8;border-radius:99px;transition:width 0.2s}
.progress-fill.done{background:#188038}
.result-list{max-height:180px;overflow-y:auto;margin-top:10px}
.ri{padding:5px 10px;border-radius:6px;font-size:12px;margin-bottom:3px}
.ri.ok{background:#e6f4ea;color:#137333}
.ri.fail{background:#fce8e6;color:#c5221f}
.fcheck{display:flex;align-items:center;gap:8px;margin-bottom:12px}
.fcheck input{width:16px;height:16px;accent-color:#1a73e8}
.fcheck label{font-size:13px;color:#444;cursor:pointer}
.card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:20px}
.dash-card{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:16px;display:flex;align-items:center;gap:14px}
.dash-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.info-box{background:#e8f0fe;color:#1a73e8;padding:12px 16px;border-radius:8px;font-size:13px;margin-bottom:12px}
.warn-box{background:#fff8e1;border:1px solid #ffe082;border-radius:8px;padding:12px 16px;font-size:12.5px;color:#795548;margin-bottom:12px}
.err-box{background:#fce8e6;color:#c5221f;padding:12px 16px;border-radius:8px;margin-bottom:14px;font-size:13px}
.drop-zone{border:2px dashed #dadce0;border-radius:10px;padding:32px;text-align:center;cursor:pointer;margin-bottom:12px}
.drop-zone:hover{border-color:#1a73e8;background:#f0f4ff}
.loading-row td{text-align:center;padding:40px;color:#888}
.spinner{width:32px;height:32px;border:3px solid #e0e0e0;border-top-color:#1a73e8;border-radius:50%;animation:spin 0.8s linear infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}
.toast{position:fixed;bottom:24px;right:24px;background:#323232;color:#fff;padding:12px 20px;border-radius:8px;font-size:13.5px;z-index:999;transform:translateY(80px);opacity:0;transition:all 0.25s;max-width:360px}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{background:#188038}
.toast.error{background:#c5221f}
.org-color-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:8px}
.org-color-dot{width:32px;height:32px;border-radius:8px;cursor:pointer;border:3px solid transparent}
.org-color-dot.selected{border-color:#202124;transform:scale(1.1)}
.age-pill{display:inline-flex;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}
.age-new{background:#e8f0fe;color:#1a73e8}.age-ok{background:#e6f4ea;color:#137333}.age-aged{background:#fef7e0;color:#b06000}.age-veteran{background:#fce8e6;color:#c5221f}
.code-box{background:#1e1e2e;color:#cdd6f4;padding:16px;border-radius:8px;font-family:monospace;font-size:12px;line-height:1.8;white-space:pre-wrap;overflow-x:auto;margin:0}
.hc-row-dead td{background:#fff5f5}.hc-row-warn td{background:#fffde7}
.tg-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
/* ===== DARK MODE ===== */
body.dark{background:#0f1117;color:#c9d1d9}
body.dark .topbar{background:#161b22;border-color:#30363d}
body.dark .sidebar{background:#161b22;border-color:#30363d}
body.dark .main{background:#0f1117}
body.dark .page-title{color:#e6edf3}
body.dark .page-sub{color:#8b949e}
body.dark .stat,.dark .dash-card,.dark .card,.dark .cfg-panel,.dark .prv-panel{background:#161b22;border-color:#30363d;color:#c9d1d9}
body.dark .table-wrap{background:#161b22;border-color:#30363d}
body.dark th{background:#21262d;color:#8b949e;border-color:#30363d}
body.dark td{border-color:#21262d;color:#c9d1d9}
body.dark tr:hover td{background:#1c2128}
body.dark tr.sel td{background:#1f3a5c!important}
body.dark .btn{background:#21262d;border-color:#30363d;color:#c9d1d9}
body.dark .btn:hover{background:#2d333b}
body.dark .btn-primary{background:#1f6feb;border-color:#1f6feb;color:#fff}
body.dark .btn-success{background:#2ea043;border-color:#2ea043;color:#fff}
body.dark .btn-danger{background:#da3633;border-color:#da3633;color:#fff}
body.dark .btn-warn{background:#bb7d00;border-color:#bb7d00;color:#fff}
body.dark select,body.dark input,body.dark textarea{background:#0d1117;border-color:#30363d;color:#c9d1d9}
body.dark .nav-item{color:#8b949e}
body.dark .nav-item:hover{background:#1c2128}
body.dark .org-switcher{background:#21262d;border-color:#30363d;color:#c9d1d9}
body.dark .org-dropdown{background:#161b22;border-color:#30363d}
body.dark .modal{background:#161b22;color:#c9d1d9;border:1px solid #30363d}
body.dark .modal-field input,.dark .modal-field select{background:#0d1117;border-color:#30363d;color:#c9d1d9}
body.dark .info-box{background:#1f3a5c;color:#79c0ff}
body.dark .warn-box{background:#2d1a00;border-color:#6e4c00;color:#ffa657}
body.dark .err-box{background:#3d0a0a;color:#ff7b72}
body.dark .code-box{background:#0d1117;color:#cdd6f4}
body.dark .section-lbl{color:#58a6ff;border-color:#21262d}
body.dark .sidebar-banner{background:#1f6feb22!important;border-color:#1f6feb!important}
body.dark .org-card{background:#161b22;border-color:#30363d}
body.dark .fmt-card{background:#161b22;border-color:#30363d;color:#c9d1d9}
body.dark .toggle-row{border-color:#21262d}
body.dark .tslider{background:#30363d}
body.dark .login-card{background:#161b22;border-color:#30363d}
body.dark .drop-zone{border-color:#30363d}
body.dark .scroll-list{border-color:#30363d}
body.dark .org-item{background:#161b22;border-color:#30363d;color:#c9d1d9}
body.dark .cmd-box{background:#161b22;border-color:#30363d}
body.dark .cmd-input{background:#161b22;border-color:#30363d;color:#c9d1d9}
body.dark .cmd-item:hover,.dark .cmd-item.active{background:#1f3a5c}
body.dark .notif-panel{background:#161b22;border-color:#30363d}
body.dark .saved-view-item{background:#161b22;border-color:#30363d;color:#c9d1d9}
body.dark .filter-chip{background:#21262d;border-color:#30363d;color:#c9d1d9}
body.dark .age-pill,.dark .badge-st,.dark .score-badge{filter:brightness(0.85)}
/* ===== TAGS ===== */
.tag-pill{display:inline-flex;align-items:center;gap:3px;padding:1px 7px;border-radius:12px;font-size:10.5px;font-weight:500;margin:1px;white-space:nowrap}
.tag-rm{font-size:12px;opacity:0.55;cursor:pointer;line-height:1;margin-left:2px}
.tag-0{background:#e8f0fe;color:#1a73e8}.tag-1{background:#e6f4ea;color:#137333}
.tag-2{background:#fef7e0;color:#b06000}.tag-3{background:#fce8e6;color:#c5221f}
.tag-4{background:#f3e8fd;color:#7b1fa2}.tag-5{background:#e0f7fa;color:#00838f}
.tag-6{background:#fff3e0;color:#e65100}.tag-7{background:#fce4ec;color:#c2185b}
/* ===== SCORE ===== */
.score-badge{display:inline-flex;align-items:center;justify-content:center;width:30px;height:18px;border-radius:4px;font-size:10.5px;font-weight:700}
.score-a{background:#e6f4ea;color:#137333}.score-b{background:#e8f0fe;color:#1a73e8}
.score-c{background:#fef7e0;color:#b06000}.score-d{background:#fce8e6;color:#c5221f}
/* ===== COMMAND PALETTE ===== */
#cmd-palette{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:500;align-items:flex-start;justify-content:center;padding-top:80px}
#cmd-palette.open{display:flex}
.cmd-box{width:520px;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.3)}
.cmd-input{width:100%;height:52px;padding:0 18px;font-size:15px;border:none;outline:none;border-bottom:1px solid #e0e0e0}
.cmd-list{max-height:340px;overflow-y:auto}
.cmd-item{display:flex;align-items:center;gap:12px;padding:10px 18px;cursor:pointer;font-size:13.5px}
.cmd-item:hover,.cmd-item.hilite{background:#e8f0fe}
.cmd-icon{font-size:15px;width:22px;text-align:center}
.cmd-key{margin-left:auto;font-size:11px;background:#f0f0f0;padding:2px 6px;border-radius:4px;color:#888}
/* ===== NOTIFICATION ===== */
.notif-btn{position:relative;cursor:pointer;width:34px;height:34px;border:1px solid #dadce0;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;font-size:16px}
.notif-btn:hover{background:#f8f9fa}
.notif-dot{position:absolute;top:4px;right:5px;width:8px;height:8px;background:#d93025;border-radius:50%;display:none;border:2px solid #fff}
.notif-dot.has{display:block}
.notif-panel{display:none;position:fixed;top:62px;right:16px;width:340px;background:#fff;border:1px solid #e0e0e0;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.12);z-index:200;max-height:460px;overflow-y:auto}
.notif-panel.open{display:block}
.notif-hdr{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #f0f0f0;font-size:13px;font-weight:500}
.notif-item{padding:10px 16px;border-bottom:1px solid #f1f3f4;font-size:12.5px;line-height:1.5}
.notif-item:last-child{border-bottom:none}
.notif-time{font-size:11px;color:#aaa;margin-top:2px}
.notif-empty{padding:24px;text-align:center;color:#aaa;font-size:13px}
/* ===== VAULT BULK SELECT ===== */
.v-bulk-bar{display:none;align-items:center;gap:10px;padding:10px 16px;background:#1a73e8;border-radius:10px;margin-bottom:12px;color:#fff}
.v-bulk-bar.visible{display:flex}
/* ===== SAVED FILTERS ===== */
.filter-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;border:1.5px solid #dadce0;background:#fff;cursor:pointer;font-size:12px;color:#444;margin:2px}
.filter-chip:hover{border-color:#1a73e8;color:#1a73e8}
.filter-chip.active{border-color:#1a73e8;background:#e8f0fe;color:#1a73e8}
.saved-view-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:6px;cursor:pointer;font-size:13px}
.saved-view-item:hover{border-color:#1a73e8;background:#f0f4ff}
/* ===== TIMELINE ===== */
.tl-wrap{padding:4px 0}
.tl-item{display:flex;gap:12px;margin-bottom:14px;align-items:flex-start}
.tl-dot{width:10px;height:10px;border-radius:50%;background:#1a73e8;margin-top:3px;flex-shrink:0}
.tl-dot.reset{background:#d93025}.tl-dot.extend{background:#188038}
.tl-dot.dead{background:#888}.tl-dot.allocate{background:#1a73e8}
.tl-body{flex:1}
.tl-action{font-size:13px;font-weight:500}
.tl-meta{font-size:11.5px;color:#888;margin-top:2px}
/* ===== SCHEDULE ===== */
.sched-card{background:#fff;border:1px solid #e0e0e0;border-radius:10px;padding:16px;margin-bottom:12px;display:flex;align-items:center;gap:16px}
.sched-card .sched-info{flex:1}
.sched-on{width:10px;height:10px;border-radius:50%;flex-shrink:0}
/* ===== INLINE EDIT ===== */
.ie-input{width:100%;border:1px solid #1a73e8;border-radius:4px;padding:2px 6px;font-size:12px;outline:none;background:#fff}