:root{--bg: #f6f7f9;--panel: #ffffff;--border: #e5e7eb;--text: #111827;--muted: #6b7280;--primary: #2563eb;--primary-dark: #1d4ed8;--danger: #dc2626;--radius: 10px;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px}h1,h2,h3{margin:0}a{color:inherit;text-decoration:none}.btn{display:inline-flex;align-items:center;gap:6px;background:var(--primary);color:#fff;border:none;padding:8px 14px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.btn:hover{background:var(--primary-dark)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.btn.ghost:hover{background:#f3f4f6}.btn.danger{background:var(--danger)}.btn.block{width:100%;justify-content:center}.btn.sm{padding:5px 10px;font-size:13px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--muted);padding:6px;border-radius:8px;cursor:pointer}.icon-btn:hover{background:#f3f4f6;color:var(--text)}.link-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-size:13px;padding:4px}input,select,textarea{font:inherit;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--text);width:100%}input:focus,select:focus,textarea:focus{outline:2px solid #bfdbfe;border-color:var(--primary)}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field>span{font-size:13px;color:var(--muted);font-weight:500}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600;white-space:nowrap}.center-screen{height:100vh;display:grid;place-items:center}.spinner{width:28px;height:28px;border-radius:50%;border:3px solid #d1d5db;border-top-color:var(--primary);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.muted{color:var(--muted)}.empty{padding:40px;text-align:center;color:var(--muted)}.login-screen{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#eff6ff,#f6f7f9)}.login-card{width:360px;background:var(--panel);padding:32px;border-radius:14px;box-shadow:var(--shadow)}.login-brand{text-align:center;margin-bottom:24px;color:var(--primary)}.login-brand h1{font-size:20px;margin-top:8px;color:var(--text)}.login-brand .logo-fallback{justify-content:center}.login-brand .logo-img{margin:0 auto}.login-brand p{margin:2px 0 0;color:var(--muted);font-size:13px}.form-error{background:#fee2e2;color:#b91c1c;padding:8px 10px;border-radius:8px;font-size:13px;margin-bottom:12px}.form-notice{background:#dcfce7;color:#15803d;padding:8px 10px;border-radius:8px;font-size:13px;margin-bottom:12px}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:var(--panel);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;padding:18px;color:var(--primary);border-bottom:1px solid var(--border);min-height:64px}.brand-name{font-weight:700;color:var(--text)}.brand-sub{font-size:12px;color:var(--muted)}.logo-img{display:block;object-fit:contain}.logo-fallback{display:flex;align-items:center;gap:10px}.nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:var(--muted);font-weight:500}.nav-link:hover{background:#f3f4f6;color:var(--text)}.nav-link.active{background:#eff6ff;color:var(--primary)}.sidebar-foot{border-top:1px solid var(--border);padding:12px;display:flex;align-items:center;gap:8px}.user-chip{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:600;flex-shrink:0}.user-meta{min-width:0}.user-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:12px;color:var(--muted);text-transform:capitalize}.content{flex:1;padding:28px 32px;min-width:0;max-width:100%}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;gap:16px;flex-wrap:wrap}.page-head h1{font-size:22px}.page-head p{margin:4px 0 0;color:var(--muted)}.card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:18px}.grid-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow)}.stat-label{color:var(--muted);font-size:13px;display:flex;align-items:center;gap:6px}.stat-value{font-size:28px;font-weight:700;margin-top:6px}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:10px 12px;border-bottom:1px solid var(--border)}.table td{padding:11px 12px;border-bottom:1px solid var(--border)}.table tbody tr:hover{background:#fafafa}.table tr:last-child td{border-bottom:none}.row-link{cursor:pointer}.subgroup-head{background:#f3f4f6;font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.03em;color:#374151}.level-list{border:1px solid var(--border);border-radius:8px;overflow:hidden}.level-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-bottom:1px solid var(--border);cursor:pointer}.level-row:last-child{border-bottom:none}.level-row:hover{background:#f9fafb}.matrix-wrap{overflow:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel)}.matrix{border-collapse:separate;border-spacing:0;min-width:max-content}.matrix th,.matrix td{border-bottom:1px solid var(--border);border-right:1px solid var(--border)}.matrix thead th{position:sticky;top:0;z-index:3;background:#f9fafb;font-size:12px;padding:8px 10px;vertical-align:bottom;text-align:center;min-width:92px}.matrix thead th.cat-head{color:#fff;font-weight:700;text-align:center}.matrix .name-col{position:sticky;left:0;z-index:2;background:var(--panel);text-align:left;min-width:190px;box-shadow:1px 0 0 var(--border)}.matrix thead .name-col{z-index:4;background:#f9fafb}.matrix .col-group{display:block;font-size:10px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.03em}.matrix .emp-name{font-weight:600}.matrix .emp-dept{font-size:12px;color:var(--muted)}.matrix-cell{padding:0;text-align:center}.cell-btn{width:100%;height:100%;min-height:42px;border:none;cursor:pointer;font-size:12px;font-weight:600;padding:6px 4px;line-height:1.2}.cell-btn small{display:block;font-weight:500;opacity:.8;font-size:10px}.portal-panel{position:fixed;z-index:1000;background:#fff;border:1px solid var(--border);border-radius:10px;box-shadow:0 10px 30px #00000026;padding:12px}.opt-row{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:8px;cursor:pointer}.opt-row:hover{background:#f3f4f6}.dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182773;display:grid;place-items:center;z-index:900;padding:20px}.modal{width:460px;max-width:100%;background:#fff;border-radius:14px;box-shadow:0 20px 50px #00000040;max-height:90vh;display:flex;flex-direction:column}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border)}.modal-body{padding:18px;overflow:auto}.modal-foot{display:flex;justify-content:flex-end;gap:8px;padding:14px 18px;border-top:1px solid var(--border)}.video-modal{width:880px;max-width:95vw;background:#fff;border-radius:14px;box-shadow:0 20px 50px #00000040;overflow:hidden}.video-frame{position:relative;width:100%;padding-top:56.25%;background:#000}.video-frame iframe{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:0}.toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.toolbar .search{max-width:280px}.pill-row{display:flex;flex-wrap:wrap;gap:8px}.legend{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin:12px 0 4px;font-size:12px;color:var(--muted)}.legend .dot{width:12px;height:12px}.legend span{display:inline-flex;align-items:center;gap:5px}.section-title{font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:22px 0 10px;font-weight:600}.chat-log{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.chat-msg{padding:12px 14px;border-radius:10px;max-width:80%;white-space:pre-wrap;line-height:1.5}.chat-msg.user{background:#eff6ff;align-self:flex-end}.chat-msg.assistant{background:#f3f4f6;align-self:flex-start}
