@import"https://fonts.googleapis.com/css2?family=Open+Sans:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap";:root{--brand: #0099CC;--brand-dark: #0080aa;--brand-darker: #006688;--brand-light: #e8f6fb;--brand-glow: rgba(0,153,204,.15);--nav-bg: #0D2240;--nav-bg-hover: #163459;--nav-bg-active: #1a3d6b;--nav-accent: #0099CC;--nav-text: rgba(255,255,255,.75);--nav-text-hi: #ffffff;--nav-label: rgba(255,255,255,.38);--nav-border: rgba(255,255,255,.08);--bg: #f2f5f8;--bg-card: #ffffff;--bg-raised: #f7f9fb;--bg-hover: #edf2f7;--border: #dde4ea;--border-hi: #c5d0db;--green: #16a34a;--green-dim: rgba(22,163,74,.1);--amber: #d97706;--amber-dim: rgba(217,119,6,.1);--red: #dc2626;--red-dim: rgba(220,38,38,.1);--text: #1a2332;--text-muted: #5e7183;--text-dim: #3d4f61;--font: "Open Sans", system-ui, -apple-system, sans-serif;--mono: "DM Mono", "Fira Code", "Cascadia Code", monospace;--radius: 6px;--radius-lg: 10px;--shadow: 0 1px 4px rgba(0,0,0,.06), 0 2px 12px rgba(0,0,0,.05);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 1px 4px rgba(0,0,0,.06);--shadow-lg: 0 12px 40px rgba(0,0,0,.14), 0 2px 8px rgba(0,0,0,.08);--transition: .15s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font-family:var(--font)}.app-shell{display:grid;grid-template-columns:232px 1fr;grid-template-rows:64px 1fr;grid-template-areas:"topbar topbar" "sidebar main";height:100vh;overflow:hidden}.topbar{grid-area:topbar;display:flex;align-items:center;justify-content:space-between;padding:0 24px 0 0;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 1px 0 var(--border);z-index:20}.topbar-brand{display:flex;align-items:center;width:232px;height:100%;padding:0 20px;background:#fff;border-right:1px solid var(--border);flex-shrink:0}.topbar-brand img{height:40px;width:auto;object-fit:contain;display:block}.topbar-right{display:flex;align-items:center;gap:12px}.user-badge{display:flex;align-items:center;gap:8px;padding:7px 14px;border-radius:var(--radius);background:var(--bg-raised);border:1px solid var(--border);font-size:13px;font-weight:500;color:var(--text-dim)}.user-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 2px #16a34a40;flex-shrink:0}.sidebar{grid-area:sidebar;background:var(--nav-bg);padding:12px 8px;overflow-y:auto;display:flex;flex-direction:column;gap:1px;border-right:1px solid rgba(0,0,0,.2)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:4px}.nav-item{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:var(--radius);font-size:13.5px;font-weight:500;color:var(--nav-text);cursor:pointer;transition:all var(--transition);text-decoration:none;border:none;background:none;width:100%;text-align:left;letter-spacing:.01em}.nav-item:hover{background:var(--nav-bg-hover);color:var(--nav-text-hi);text-decoration:none}.nav-item.active{background:var(--nav-bg-active);color:var(--nav-text-hi);font-weight:600;box-shadow:inset 3px 0 0 var(--nav-accent)}.nav-section-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--nav-label);padding:14px 12px 5px;border-top:1px solid var(--nav-border);margin-top:6px}.nav-section-label:first-child{border-top:none;margin-top:0;padding-top:4px}.sidebar hr{border:none;border-top:1px solid var(--nav-border);margin:6px 4px}.main{grid-area:main;overflow-y:auto;padding:28px 32px;background:var(--bg)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}.page-title{font-size:21px;font-weight:700;letter-spacing:-.025em;color:var(--text);line-height:1.2}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:3px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}.card-header{padding:13px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--bg-raised)}.card-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.card-body{padding:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:24px}.stat-tile{background:var(--bg-card);border:1px solid var(--border);border-top:3px solid var(--brand);border-radius:var(--radius-lg);padding:18px 20px;box-shadow:var(--shadow);transition:box-shadow var(--transition)}.stat-tile:hover{box-shadow:var(--shadow-md)}.stat-value{font-size:28px;font-weight:700;font-family:var(--mono);letter-spacing:-.04em;line-height:1;margin-bottom:6px;color:var(--nav-bg)}.stat-label{font-size:12px;color:var(--text-muted);font-weight:500}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13.5px}thead tr{border-bottom:2px solid var(--border)}th{padding:10px 16px;text-align:left;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);background:var(--bg-raised);white-space:nowrap}td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}tbody tr{transition:background var(--transition);cursor:pointer}tbody tr:hover{background:var(--bg-hover)}tbody tr:last-child td{border-bottom:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition);border:1px solid transparent;white-space:nowrap;line-height:1.4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}.btn-primary:hover:not(:disabled){background:var(--brand-dark);border-color:var(--brand-dark)}.btn-secondary{background:#fff;color:var(--text-dim);border-color:var(--border-hi)}.btn-secondary:hover:not(:disabled){background:var(--bg-raised);border-color:var(--brand);color:var(--brand)}.btn-danger{background:var(--red-dim);color:var(--red);border-color:#dc262640}.btn-danger:hover:not(:disabled){background:#dc26262e}.btn-ghost{background:transparent;color:var(--text-muted);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--bg-raised);color:var(--text)}.btn-sm{padding:5px 10px;font-size:12px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted)}.form-input,.form-select{background:#fff;border:1px solid var(--border-hi);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:13.5px;padding:9px 12px;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.form-input:focus,.form-select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-glow)}.form-select{cursor:pointer}.form-input::placeholder{color:var(--text-muted);opacity:.7}.search-input-wrap{position:relative}.search-input-wrap .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:15px;pointer-events:none}.search-input-wrap .form-input{padding-left:34px}.check-list{display:flex;flex-direction:column;gap:2px;max-height:200px;overflow-y:auto;border:1px solid var(--border-hi);border-radius:var(--radius);padding:5px;background:var(--bg-raised)}.check-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:4px;cursor:pointer;transition:background var(--transition);font-size:13px;-webkit-user-select:none;user-select:none}.check-item:hover{background:var(--bg-hover)}.check-item.selected{background:var(--brand-light);color:var(--brand-dark)}.check-item input[type=checkbox]{accent-color:var(--brand);width:14px;height:14px;cursor:pointer}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.02em}.badge-green{background:var(--green-dim);color:var(--green)}.badge-amber{background:var(--amber-dim);color:var(--amber)}.badge-red{background:var(--red-dim);color:var(--red)}.badge-blue{background:var(--brand-light);color:var(--brand-dark)}.badge-gray{background:var(--bg-raised);color:var(--text-muted);border:1px solid var(--border)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#08142880;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:50;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:540px;max-height:90vh;overflow-y:auto;animation:slideUp .2s cubic-bezier(.34,1.3,.64,1)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:16px 24px;border-bottom:3px solid var(--brand);display:flex;align-items:center;justify-content:space-between;background:var(--nav-bg)}.modal-title{font-size:15px;font-weight:700;color:#fff}.modal-header .btn-ghost{color:#ffffffb3}.modal-header .btn-ghost:hover{color:#fff;background:#ffffff1a}.modal-body{padding:20px 24px;display:flex;flex-direction:column;gap:16px}.modal-footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px;background:var(--bg-raised)}.toast-container{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease;min-width:240px;max-width:380px}.toast-success{background:#f0fdf4;border:1px solid #86efac;color:var(--green)}.toast-error{background:#fff5f5;border:1px solid #fca5a5;color:var(--red)}.toast-info{background:var(--brand-light);border:1px solid rgba(0,153,204,.3);color:var(--brand-dark)}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:20px}.tab-btn{padding:10px 18px;font-size:13.5px;font-weight:500;color:var(--text-muted);border:none;background:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition);font-family:var(--font)}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--brand);font-weight:700;border-bottom-color:var(--brand)}.pill{display:inline-flex;align-items:center;gap:4px;background:var(--brand-light);border:1px solid rgba(0,153,204,.2);border-radius:20px;padding:3px 10px;font-size:12px;color:var(--brand-dark);font-weight:500}.pill-amber{background:var(--amber-dim);border-color:#d9770633;color:var(--amber)}.mono{font-family:var(--mono);font-size:12px}.empty-state{text-align:center;padding:52px 20px;color:var(--text-muted)}.empty-state .icon{font-size:32px;margin-bottom:12px;opacity:.35;color:var(--nav-bg)}.empty-state p{font-size:14px}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border-hi);border-top-color:var(--brand);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.flex-center{display:flex;align-items:center;justify-content:center}.mt-4{margin-top:16px}.text-muted{color:var(--text-muted)}.text-accent{color:var(--brand)}.toggle-wrap{display:flex;align-items:center;gap:10px}.toggle{position:relative;width:40px;height:22px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border-hi);border-radius:22px;cursor:pointer;transition:background var(--transition)}.toggle-slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform var(--transition);box-shadow:0 1px 3px #0003}.toggle input:checked+.toggle-slider{background:var(--brand)}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}
