:root{--bg: #F7F8FA;--bg-card: #FFFFFF;--bg-card-hover: #F0F1F5;--bg-input: #FFFFFF;--border: #E2E4EA;--border-focus: #185FA5;--text: #1A1D2B;--text-dim: #6B7080;--text-faint: #9CA0B0;--accent: #185FA5;--accent-hover: #12508B;--accent-dim: #EFF4FF;--green: #2B7D3E;--green-dim: #EAF3DE;--red: #C53030;--red-dim: #FCEBEB;--amber: #92610A;--amber-dim: #FEF6E0;--sidebar-w: 240px;--radius: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 2px 8px rgba(0,0,0,.06)}[data-theme=dark]{--bg: #0F1117;--bg-card: #1A1D2B;--bg-card-hover: #22263A;--bg-input: #22263A;--border: #2E3347;--border-focus: #4B8FD5;--text: #E8EAF0;--text-dim: #9CA0B0;--text-faint: #5A6070;--accent: #4B8FD5;--accent-hover: #5A9EE0;--accent-dim: #1A2A44;--green: #4CAF6E;--green-dim: #152A1E;--red: #E05555;--red-dim: #2A1515;--amber: #D4A030;--amber-dim: #2A1F08;--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 2px 8px rgba(0,0,0,.4)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}input,textarea,select,button{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}.app{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:10}.sidebar-logo{padding:20px;border-bottom:1px solid var(--border)}.sidebar-logo h1{font-size:17px;font-weight:700;letter-spacing:-.3px;color:var(--text)}.sidebar-logo h1 span{color:var(--accent)}.sidebar-logo p{font-size:11px;color:var(--text-faint);font-family:JetBrains Mono,monospace;margin-top:3px}.sidebar-nav{flex:1;padding:12px 8px;display:flex;flex-direction:column;gap:1px;overflow-y:auto}.nav-section{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--text-faint);padding:14px 12px 6px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:500;color:var(--text-dim);transition:all .15s;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--bg);color:var(--text)}.nav-item.active{background:var(--accent-dim);color:var(--accent);font-weight:600}.nav-item svg{width:16px;height:16px;flex-shrink:0}.sidebar-footer{padding:12px;border-top:1px solid var(--border)}.sidebar-footer .nav-item{font-size:12px;color:var(--text-faint)}.main{margin-left:var(--sidebar-w);flex:1;padding:28px 36px;min-height:100vh}.page-header{margin-bottom:24px;display:flex;align-items:center;justify-content:space-between}.page-header h2{font-size:21px;font-weight:700;letter-spacing:-.4px;color:var(--text)}.page-header p{font-size:13px;color:var(--text-dim);margin-top:2px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-header h3{font-size:14px;font-weight:600;color:var(--text)}.stats-grid{display:flex;gap:12px;margin-bottom:24px}.stat-card{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-sm);padding:20px}.stat-card .label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-dim)}.stat-card .value-row{display:flex;align-items:baseline;gap:8px;margin-top:6px}.stat-card .value{font-size:28px;font-weight:700;color:var(--text);letter-spacing:-.02em;line-height:1}.stat-card .sub{font-size:12px;color:var(--text-faint);margin-top:4px}.trend-up{font-size:12px;font-weight:600;padding:2px 7px;border-radius:6px;color:#2b7d3e;background:#2b7d3e14}.trend-dn{font-size:12px;font-weight:600;padding:2px 7px;border-radius:6px;color:#c53030;background:#c5303014}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--bg-card);color:var(--text);transition:all .15s;box-shadow:var(--shadow-sm)}.btn:hover{background:var(--bg-card-hover);border-color:#cdd0d9}.btn:active{transform:scale(.98)}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 1px 3px #185fa533}.btn-primary:hover{background:#12508b;border-color:#12508b}.btn-danger{color:var(--red)}.btn-danger:hover{background:var(--red-dim);border-color:#f0c0c0}.btn-sm{padding:5px 10px;font-size:12px}.btn-ghost{background:transparent;border-color:transparent;box-shadow:none}.btn-ghost:hover{background:var(--bg-card-hover)}.form-group{margin-bottom:14px}.form-label{display:block;font-size:12px;font-weight:500;color:var(--text-dim);margin-bottom:5px}.form-input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input);color:var(--text);font-size:13px;outline:none;transition:all .15s;box-shadow:inset 0 1px 2px #0000000a}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #185fa51a}.form-input::placeholder{color:var(--text-faint)}textarea.form-input{min-height:100px;resize:vertical}select.form-input{cursor:pointer}input[type=date]{font-family:inherit!important}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;padding:10px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);border-bottom:2px solid var(--border);background:var(--bg)}td{padding:10px 12px;border-bottom:1px solid var(--border)}tr:hover td{background:var(--bg-card-hover)}tr{cursor:pointer}.badge{display:inline-flex;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600}.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(--accent-dim);color:var(--accent)}.tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:10px 16px;font-size:13px;font-weight:500;color:var(--text-dim);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;background:none;border-top:none;border-left:none;border-right:none;white-space:nowrap;flex-shrink:0}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1d2b66;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;width:90%;max-width:600px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-md)}.modal h3{font-size:16px;font-weight:600;margin-bottom:18px;color:var(--text)}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.search-bar{position:relative;margin-bottom:16px}.search-bar input{width:100%;padding:10px 12px 10px 36px}.search-bar svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-faint);width:16px;height:16px}.toast{position:fixed;bottom:24px;right:24px;background:var(--bg-card);border:1px solid var(--border);padding:12px 20px;border-radius:var(--radius);font-size:13px;z-index:200;box-shadow:var(--shadow-md);animation:slideIn .3s ease}@media (max-width: 959px){.toast{bottom:calc(64px + max(8px,env(safe-area-inset-bottom)));right:12px;left:12px;text-align:center}}@keyframes slideIn{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.skeleton{background:var(--border);border-radius:4px;animation:pulse 1.5s ease-in-out infinite}.border-red{border-color:var(--red)!important}.toast-success{border-left:3px solid var(--green)}.toast-error{border-left:3px solid var(--red)}.login-wrap{display:flex;min-height:100vh;background:var(--bg)}.login-left{flex:1;display:flex;flex-direction:column;justify-content:center;padding:60px 64px;background:var(--bg-card);border-right:1px solid var(--border);max-width:480px}.login-left-logo{font-size:22px;font-weight:700;letter-spacing:-.4px;color:var(--text);margin-bottom:48px}.login-left-logo span{color:var(--accent)}.login-left h2{font-size:28px;font-weight:700;letter-spacing:-.6px;line-height:1.25;margin-bottom:12px;color:var(--text)}.login-left p{font-size:14px;color:var(--text-dim);line-height:1.6;margin-bottom:40px}.login-features{display:flex;flex-direction:column;gap:16px}.login-feature{display:flex;align-items:flex-start;gap:12px}.login-feature-icon{width:32px;height:32px;border-radius:8px;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent)}.login-feature-text strong{font-size:13px;font-weight:600;color:var(--text);display:block}.login-feature-text span{font-size:12px;color:var(--text-dim)}.login-left-footer{margin-top:auto;padding-top:40px;font-size:11px;color:var(--text-faint);font-family:JetBrains Mono,monospace;display:flex;align-items:center;gap:6px}.login-left-footer:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green)}.login-right{flex:1;display:flex;align-items:center;justify-content:center;padding:40px}.login-box{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;width:100%;max-width:380px;box-shadow:var(--shadow-md)}.login-box h1{font-size:20px;font-weight:700;margin-bottom:4px;color:var(--text)}.login-box h1 span{color:var(--accent)}.login-box .sub{font-size:13px;color:var(--text-dim);margin-bottom:28px}@media (max-width: 768px){.login-left{display:none}.login-right{padding:24px}}.empty{text-align:center;padding:48px 20px;color:var(--text-dim)}.empty svg{width:48px;height:48px;margin-bottom:12px;opacity:.3}.empty p{font-size:14px}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border);padding:6px 0 max(8px,env(safe-area-inset-bottom));z-index:50;flex-direction:row;justify-content:space-around}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 10px;border:none;background:none;cursor:pointer;color:var(--text-dim);font-size:10px;font-weight:500;border-radius:8px;min-width:56px;min-height:44px;justify-content:center;transition:color .15s}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item svg{width:22px;height:22px}@media (max-width: 960px){.sidebar{display:none}.main{margin-left:0;padding:20px 16px 80px}.bottom-nav{display:flex}.stats-grid{flex-wrap:wrap}.stat-card{min-width:calc(50% - 6px)}.form-row-3{grid-template-columns:1fr 1fr}.modal{padding:20px;width:95%;max-height:92vh}.page-header h2{font-size:18px}}@media (max-width: 480px){.main{padding:16px 12px 80px}.stat-card{min-width:100%}.form-row,.form-row-3{grid-template-columns:1fr}.page-header{flex-wrap:wrap;gap:10px}.modal{padding:16px}}@supports (padding: max(0px)){.main{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}}.month-dots{display:none;gap:3px;flex-wrap:wrap;align-items:center;margin-top:2px}@media (max-width: 600px){.month-chip{display:none!important}.month-dots{display:flex!important}}@media (max-width: 599px){.col-hide-phone{display:none!important}}@media (max-width: 599px){.dash-grid{grid-template-columns:1fr!important}.dash-widget{grid-column:span 12!important}}
