:root{--c-navy-900: #0a1733;--c-navy-800: #0f2350;--c-navy-700: #16306b;--c-navy-600: #1d4ed8;--c-blue-500: #2563eb;--c-blue-400: #3b82f6;--c-blue-50: #eff5ff;--c-bg: #f4f6fb;--c-surface: #ffffff;--c-border: #e4e8f0;--c-text: #1b2436;--c-text-soft: #5a6478;--c-text-faint: #94a0b5;--c-success: #16a34a;--c-success-bg: #e7f6ec;--c-warn: #d97706;--c-warn-bg: #fdf0db;--c-danger: #dc2626;--c-danger-bg: #fdeaea;--c-info: #0891b2;--c-info-bg: #e2f5f9;--c-purple: #7c3aed;--c-purple-bg: #f0e9fd;--radius: 10px;--radius-sm: 7px;--shadow-sm: 0 1px 2px rgba(16, 35, 80, .06);--shadow: 0 4px 16px rgba(16, 35, 80, .08);--shadow-lg: 0 12px 40px rgba(10, 23, 51, .18);--sidebar-w: 224px;--topbar-h: 60px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:var(--c-bg);color:var(--c-text);font-size:14px;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}ul{list-style:none}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:radial-gradient(220px 320px at 50% 6%,rgba(147,197,253,.45) 0%,transparent 70%),radial-gradient(260px 300px at 50% 100%,rgba(196,181,253,.22) 0%,transparent 72%),#f7f9fe;color:#5a6478;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:30;border-right:1px solid #E8EDF5;box-shadow:4px 0 24px -16px #1e40af40;overflow:hidden}.sidebar .sb-glow,.sidebar .sb-top-light{display:none}.sidebar>*{position:relative;z-index:3}.sidebar-brand{height:68px;display:flex;align-items:center;padding:0 14px;color:var(--c-text);border-bottom:1px solid #EEF2F8}.sidebar-brand .brand-logo-img{height:50px;width:auto;max-width:100%;display:block}.nav{flex:1;overflow-y:auto;padding:12px}.nav-group-title{font-size:10.5px;color:#94a0b5;padding:18px 14px 6px;letter-spacing:3px;font-weight:600}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;margin-bottom:3px;color:#5a6478;font-size:13.5px;border-radius:9px;transition:all .15s;cursor:pointer;position:relative}.nav-item:hover{background:#ffffffb3;color:#1d4ed8}.nav-item.active{background:linear-gradient(90deg,#fffffff7,#eff5ffcc);color:#1d4ed8;font-weight:600;box-shadow:0 2px 10px -2px #2563eb2e,0 1px 2px #2563eb14}.nav-item .ico{width:20px;height:20px;display:grid;place-items:center;color:#94a0b5;flex-shrink:0}.nav-item:hover .ico,.nav-item.active .ico{color:#2563eb}.nav-item .badge-dot{margin-left:auto;background:#ef4444;color:#fff;font-size:10px;min-width:17px;height:17px;border-radius:9px;display:grid;place-items:center;padding:0 4px;box-shadow:0 2px 6px -1px #ef444480}.sb-user{display:flex;align-items:center;gap:10px;margin:8px 12px 14px;padding:10px 12px;border-radius:12px;background:linear-gradient(135deg,#3b82f614,#6366f10d);border:1px solid #EAEFF8}.sb-user .sb-avatar{width:34px;height:34px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,#3b82f6,#6366f1);color:#fff;display:grid;place-items:center;font-weight:700;font-size:15px;box-shadow:0 4px 10px -3px #3b82f680}.sb-user .sb-uinfo{min-width:0;flex:1}.sb-user .sb-uinfo b{font-size:13px;color:#1b2436;display:block;line-height:1.3}.sb-user .sb-uinfo span{font-size:11px;color:#9ca3af;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user .sb-logout{width:30px;height:30px;border-radius:8px;flex-shrink:0;border:1px solid transparent;background:transparent;color:#9ca3af;display:grid;place-items:center;cursor:pointer;transition:all .15s}.sb-user .sb-logout:hover{background:#fff;color:#ef4444;border-color:#fecaca}.main{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-width:0}.topbar{height:var(--topbar-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);display:flex;align-items:center;padding:0 22px;gap:16px;position:sticky;top:0;z-index:20}.topbar .crumb{color:var(--c-text-faint);font-size:13px}.topbar .crumb b{color:var(--c-text);font-weight:600}.topbar .spacer{flex:1}.topbar .top-search{display:flex;align-items:center;gap:8px;background:var(--c-bg);border:1px solid var(--c-border);border-radius:10px;padding:8px 12px;width:280px;color:var(--c-text-faint);transition:all .15s}.topbar .top-search:focus-within{border-color:#3b82f6;background:#fff;box-shadow:0 0 0 4px #3b82f61a}.topbar .top-search input{border:none;background:transparent;outline:none;flex:1;font-size:13px;color:var(--c-text)}.topbar .top-search kbd{font-size:11px;color:var(--c-text-faint);background:#fff;border:1px solid var(--c-border);border-radius:5px;padding:1px 6px;font-family:inherit}.topbar .top-search .ts-go{border:none;background:var(--c-blue-500);color:#fff;border-radius:6px;padding:3px 10px;font-size:12px;cursor:pointer;white-space:nowrap}.topbar .top-search .ts-go:hover{background:var(--c-navy-600)}.topbar .top-icon{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;background:var(--c-bg);color:var(--c-text-soft);position:relative}.topbar .top-icon .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;background:var(--c-danger);border-radius:50%;border:2px solid var(--c-surface)}.sync-pill{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 11px;border-radius:15px;border:1px solid var(--c-border);background:var(--c-bg);color:var(--c-text-soft);font-size:12px;cursor:pointer;transition:all .15s;white-space:nowrap}.sync-pill:hover{border-color:var(--c-blue-400)}.sync-pill .sync-dot{width:7px;height:7px;border-radius:50%;background:var(--c-success)}.sync-pill.off{background:var(--c-bg);color:var(--c-text-faint)}.sync-pill.off .sync-dot{background:#9ca3af}.sync-pill.has-pending{background:var(--c-warn-bg);color:var(--c-warn);border-color:#f5d48a}.sync-pill.has-pending .sync-dot{background:var(--c-warn);animation:pulse-dot 1.4s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.35}}.topbar .user{display:flex;align-items:center;gap:9px}.topbar .user .avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--c-blue-400),var(--c-navy-700));color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px}.topbar .user .uinfo b{display:block;font-size:13px}.topbar .user .uinfo span{font-size:11px;color:var(--c-text-faint)}.page{padding:22px;flex:1}.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;gap:16px;flex-wrap:wrap}.page-head h1{font-size:20px;font-weight:700}.page-head .sub{color:var(--c-text-faint);font-size:13px;margin-top:4px}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-head{display:flex;align-items:center;justify-content:space-between;padding:15px 18px;border-bottom:1px solid var(--c-border)}.card-head h3{font-size:15px;font-weight:600}.card-head .card-tools{display:flex;gap:8px;align-items:center}.card-body{padding:18px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}.stat-grid.cols-5{grid-template-columns:repeat(5,1fr);gap:12px}.stat-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.stat-card .icon{width:44px;height:44px;border-radius:11px;display:grid;place-items:center;font-size:20px;margin-bottom:14px}.stat-card .label{color:var(--c-text-faint);font-size:13px}.stat-card .value{font-size:26px;font-weight:700;margin:4px 0 6px;letter-spacing:.5px}.stat-card .trend{font-size:12px;display:flex;align-items:center;gap:5px}.trend.up{color:var(--c-success)}.trend.down{color:var(--c-danger)}.table-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}table.tbl thead th{text-align:left;padding:12px 14px;background:#f7f9fc;color:var(--c-text-soft);font-weight:600;font-size:12.5px;border-bottom:1px solid var(--c-border);white-space:nowrap}table.tbl tbody td{padding:13px 14px;border-bottom:1px solid #f0f3f8;white-space:nowrap}table.tbl tbody tr:hover{background:#fafbfe}table.tbl tbody tr:last-child td{border-bottom:none}.cell-strong{font-weight:600;color:var(--c-text)}.cell-sub{color:var(--c-text-faint);font-size:12px}.cell-money{font-weight:700;font-variant-numeric:tabular-nums}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;line-height:1.5}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.9}.badge.gray{background:#eef1f6;color:#64748b}.badge.blue{background:var(--c-blue-50);color:var(--c-blue-500)}.badge.green{background:var(--c-success-bg);color:var(--c-success)}.badge.orange{background:var(--c-warn-bg);color:var(--c-warn)}.badge.red{background:var(--c-danger-bg);color:var(--c-danger)}.badge.cyan{background:var(--c-info-bg);color:var(--c-info)}.badge.purple{background:var(--c-purple-bg);color:var(--c-purple)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 15px;border-radius:var(--radius-sm);border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text);font-size:13px;font-weight:500;transition:all .15s;white-space:nowrap}.btn:hover{border-color:var(--c-blue-400);color:var(--c-blue-500)}.btn.primary{background:var(--c-navy-600);border-color:var(--c-navy-600);color:#fff}.btn.primary:hover{background:var(--c-blue-500);border-color:var(--c-blue-500);color:#fff}.btn.ghost{background:transparent;border-color:transparent;color:var(--c-text-soft)}.btn.ghost:hover{background:var(--c-bg);color:var(--c-blue-500)}.btn.sm{padding:5px 11px;font-size:12.5px}.btn.danger{color:var(--c-danger)}.btn.danger:hover{border-color:var(--c-danger);background:var(--c-danger-bg)}.btn.success{background:#16a34a;border-color:#16a34a;color:#fff}.btn.success:hover{background:#15803d;border-color:#15803d;color:#fff}.btn.warn{background:#d97706;border-color:#d97706;color:#fff}.btn.warn:hover{background:#b45309;border-color:#b45309;color:#fff}.btn:disabled{opacity:.5;cursor:not-allowed}.link-btn{color:var(--c-blue-500);font-size:13px;background:none;border:none;padding:0}.link-btn:hover{text-decoration:underline}.link-btn.danger{color:var(--c-danger)}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:14px}.toolbar .spacer{flex:1}.date-range{display:inline-flex;align-items:center;gap:7px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:9px;padding:5px 10px;font-size:13px}.date-range .dr-label{color:var(--c-text-faint);font-size:12px}.date-range input[type=date]{border:none;background:transparent;outline:none;font-size:13px;color:var(--c-text);font-family:inherit;cursor:pointer;width:122px}.date-range .dr-preset{border:1px solid var(--c-border);background:var(--c-bg);color:var(--c-text-soft);border-radius:7px;padding:3px 9px;font-size:12px;cursor:pointer;transition:all .12s}.date-range .dr-preset:hover{border-color:var(--c-blue-400);color:var(--c-blue-500)}.date-range .dr-preset.on{background:var(--c-blue-500);border-color:var(--c-blue-500);color:#fff}.date-range .dr-sep{color:var(--c-text-faint)}.exp-input{width:84px;padding:5px 8px;border:1px solid var(--c-border);border-radius:7px;font-size:13px;background:var(--c-bg);color:var(--c-text);outline:none;transition:all .12s}.exp-input:focus{border-color:var(--c-blue-400);background:#fff;box-shadow:0 0 0 3px #3b82f61f}.date-range .dr-clear{border:none;background:var(--c-bg);color:var(--c-text-soft);width:18px;height:18px;border-radius:50%;cursor:pointer;font-size:13px;display:grid;place-items:center;line-height:1}.date-range .dr-clear:hover{background:var(--c-danger-bg);color:var(--c-danger)}.field{display:flex;align-items:center;gap:6px;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:7px 11px;font-size:13px}.field input,.field select{border:none;outline:none;background:transparent;font-size:13px;color:var(--c-text)}.field label{color:var(--c-text-faint);font-size:12.5px}.input{border:1px solid var(--c-border);border-radius:var(--radius-sm);padding:9px 12px;font-size:13.5px;width:100%;outline:none;background:var(--c-surface);color:var(--c-text);transition:border .15s}.input:focus{border-color:var(--c-blue-400);box-shadow:0 0 0 3px #3b82f61f}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23999' fill='none' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:30px}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.monthly-toggle{display:inline-flex;align-items:center;gap:8px;padding:7px 16px;border-radius:20px;border:1.5px solid var(--c-border);font-size:14px;font-weight:600;cursor:pointer;color:var(--c-text-soft);background:var(--c-surface);transition:all .15s}.monthly-toggle input{width:17px;height:17px;cursor:pointer;accent-color:var(--c-navy-600)}.monthly-toggle.on{background:var(--c-navy-600);border-color:var(--c-navy-600);color:#fff;box-shadow:0 4px 12px #1d4ed84d}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.form-item{display:flex;flex-direction:column;gap:6px}.form-item.full{grid-column:1 / -1}.form-item label{font-size:13px;color:var(--c-text-soft);font-weight:500}.form-item label .req{color:var(--c-danger);margin-left:2px}.form-item .field-hint{font-size:11.5px;color:var(--c-text-faint);margin-top:-2px;line-height:1.5}.form-section-title{font-size:13px;font-weight:600;color:var(--c-navy-700);margin:8px 0 2px;grid-column:1/-1;padding-bottom:6px;border-bottom:1px dashed var(--c-border)}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a173373;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fade .15s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.modal{background:var(--c-surface);border-radius:14px;box-shadow:var(--shadow-lg);width:100%;min-width:0;max-height:90vh;display:flex;flex-direction:column;animation:pop .18s ease}@keyframes pop{0%{transform:translateY(12px) scale(.98);opacity:0}to{transform:none;opacity:1}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--c-border)}.modal-head h3{font-size:16px;font-weight:600}.modal-head .close{width:30px;height:30px;border-radius:7px;border:none;background:transparent;color:var(--c-text-faint);font-size:18px}.modal-head .close:hover{background:var(--c-bg);color:var(--c-text)}.modal-body{padding:20px;overflow-y:auto}.modal-foot{padding:14px 20px;border-top:1px solid var(--c-border);display:flex;justify-content:flex-end;gap:10px}.pager{display:flex;align-items:center;gap:6px;justify-content:flex-end;padding:14px 4px 4px;color:var(--c-text-soft);font-size:13px}.pager button{min-width:32px;height:32px;border:1px solid var(--c-border);background:var(--c-surface);border-radius:7px;color:var(--c-text-soft)}.pager button.active{background:var(--c-navy-600);color:#fff;border-color:var(--c-navy-600)}.pager button:disabled{opacity:.45}.empty{text-align:center;padding:50px 20px;color:var(--c-text-faint)}.empty .ico{font-size:40px;opacity:.4;margin-bottom:10px}.timeline{position:relative;padding-left:8px}.tl-item{position:relative;padding:0 0 22px 26px;border-left:2px solid var(--c-border)}.tl-item:last-child{border-left-color:transparent;padding-bottom:0}.tl-item .tl-dot{position:absolute;left:-8px;top:0;width:14px;height:14px;border-radius:50%;background:#fff;border:3px solid var(--c-text-faint)}.tl-item.done .tl-dot{border-color:var(--c-success);background:var(--c-success)}.tl-item.current .tl-dot{border-color:var(--c-blue-500);box-shadow:0 0 0 4px #3b82f62e}.tl-item .tl-title{font-weight:600;font-size:13.5px}.tl-item .tl-meta{color:var(--c-text-faint);font-size:12px;margin-top:3px}.progress{background:#eef1f6;border-radius:20px;height:7px;overflow:hidden}.progress>span{display:block;height:100%;background:linear-gradient(90deg,var(--c-blue-400),var(--c-navy-600));border-radius:20px}.bar-chart{display:flex;align-items:flex-end;gap:14px;height:200px;padding-top:10px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}.bar-col .bar{width:60%;max-width:34px;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--c-blue-400),var(--c-navy-600));transition:height .3s;position:relative}.bar-col .bar:hover{filter:brightness(1.1)}.bar-col .bar-label{font-size:12px;color:var(--c-text-faint)}.bar-col .bar-val{font-size:11px;color:var(--c-text-soft);font-weight:600}.donut-wrap{display:flex;align-items:center;gap:22px}.legend{display:flex;flex-direction:column;gap:10px}.legend-item{display:flex;align-items:center;gap:8px;font-size:13px}.legend-item .sw{width:11px;height:11px;border-radius:3px}.legend-item .lv{margin-left:auto;font-weight:600;color:var(--c-text)}.flex{display:flex}.flex-c{display:flex;align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.mt-16{margin-top:16px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:2fr 1fr;gap:16px}.text-faint{color:var(--c-text-faint)}.text-right{text-align:right}.nowrap{white-space:nowrap}.route-tag{display:inline-flex;align-items:center;gap:6px;font-weight:600}.route-tag .arrow{color:var(--c-blue-400)}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%);background:var(--c-navy-800);color:#fff;padding:11px 22px;border-radius:24px;font-size:13.5px;z-index:200;box-shadow:var(--shadow-lg);animation:toastIn .25s ease;display:flex;align-items:center;gap:8px}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}@media (max-width: 1100px){.stat-grid{grid-template-columns:repeat(2,1fr)}.grid-3,.grid-2{grid-template-columns:1fr}}.login-bg{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;overflow:hidden;background:linear-gradient(135deg,#dce7f9,#d8ddf6 45%,#d2c9f1)}.login-bg .blob,.login-grid{display:none}.beian-bar{position:absolute;left:0;right:0;bottom:12px;z-index:3;text-align:center;font-size:12px}.beian-bar a{color:#1b25488c;text-decoration:none}.beian-bar a:hover{color:#2563eb;text-decoration:underline}.app-beian{text-align:center;padding:16px 0 4px;font-size:12px}.app-beian a{color:var(--c-text-faint);text-decoration:none}.app-beian a:hover{color:var(--c-blue-500);text-decoration:underline}.login-card{position:relative;z-index:2;display:flex;width:1040px;max-width:100%;min-height:620px;background:#fff;border-radius:24px;box-shadow:0 40px 90px -30px #1e296359,0 12px 32px -12px #1e29632e;overflow:hidden}.login-side{flex:1.15;padding:48px 44px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;background:radial-gradient(420px 320px at 12% 8%,rgba(99,102,241,.16) 0%,transparent 70%),radial-gradient(420px 360px at 95% 95%,rgba(59,130,246,.16) 0%,transparent 70%),linear-gradient(150deg,#eaf0fc,#e7e6fa 55%,#ede8fb);color:var(--c-text)}.login-side:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:linear-gradient(rgba(99,102,241,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.05) 1px,transparent 1px);background-size:34px 34px;-webkit-mask-image:radial-gradient(120% 120% at 50% 40%,#000 40%,transparent 100%);mask-image:radial-gradient(120% 120% at 50% 40%,#000 40%,transparent 100%)}.login-side .ls-deco{display:none}.login-side .ls-logo{display:flex;align-items:center;position:relative;z-index:3}.login-side .ls-logo .ls-logo-img{height:46px;width:auto;max-width:300px;display:block}.ls-calli-wrap{display:block;margin-top:30px;position:relative;z-index:3}.ls-tag1{font-size:26px;font-weight:800;color:#1b2436;letter-spacing:2px}.ls-tag2{font-size:38px;font-weight:900;letter-spacing:3px;margin-top:4px;line-height:1.2;background:linear-gradient(90deg,#3b82f6,#1d4ed8 55%,#7c3aed);-webkit-background-clip:text;background-clip:text;color:transparent}.ls-desc{margin-top:16px;font-size:13.5px;color:#5a6478;line-height:1.9;position:relative;z-index:3}.ls-route-card{position:relative;z-index:3;margin-top:auto;margin-bottom:18px;background:#ffffff8c;border:1px solid rgba(255,255,255,.8);border-radius:18px;padding:18px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 12px 30px -14px #1e296340}.ls-route{width:100%;display:block}.ls-route .node{animation:nodepulse 2.4s ease-in-out infinite;transform-origin:center;transform-box:fill-box}.ls-route .node.n2{animation-delay:-.6s}.ls-route .node.n3{animation-delay:-1.2s}@keyframes nodepulse{0%,to{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.12)}}.ls-route .dash{stroke-dasharray:6 6;animation:dashflow 1.6s linear infinite}@keyframes dashflow{to{stroke-dashoffset:-24}}.ls-route .plane{animation:travel 6s ease-in-out infinite;transform-box:fill-box}@keyframes travel{0%{offset-distance:0%;opacity:0}10%{opacity:1}90%{opacity:1}to{offset-distance:100%;opacity:0}}.login-side .ls-foot{font-size:11.5px;color:#8a93a8;line-height:1.7;position:relative;z-index:3}.login-form{flex:.9;padding:56px 52px;display:flex;flex-direction:column;justify-content:center;color:var(--c-text);background:#fff}.login-form h2{font-size:26px;font-weight:700;color:#1b2436;margin-bottom:8px}.login-form .lf-sub{color:var(--c-text-faint);font-size:13.5px;margin:0 0 32px}.login-form .form-item{margin-bottom:18px}.login-form .form-item label{display:block;font-size:13px;color:var(--c-text-soft);margin-bottom:8px;font-weight:500}.login-form .input-wrap{position:relative}.login-form .input-wrap .ico{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:#a9b2c3;pointer-events:none}.login-form .input-wrap .eye{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#a9b2c3;cursor:pointer}.login-form .input-wrap input.input{width:100%;height:48px;padding:0 16px 0 44px;border:1.5px solid #E4E8F0;border-radius:11px;font-size:14px;background:#f7f9fc;color:var(--c-text);transition:all .18s}.login-form .input-wrap input.input::placeholder{color:#b6becc}.login-form .input-wrap input.input:focus{outline:none;border-color:#3b82f6;background:#fff;box-shadow:0 0 0 4px #3b82f61f}.login-row{display:flex;align-items:center;justify-content:space-between;margin:4px 0 22px;font-size:13px}.login-row label{display:flex;align-items:center;gap:7px;color:var(--c-text-soft);cursor:pointer}.login-row .link{color:#2563eb;cursor:pointer}.login-row .link:hover{text-decoration:underline}.login-form .login-btn{width:100%;height:50px;border:none;border-radius:11px;font-size:15px;font-weight:600;color:#fff;letter-spacing:1px;background:linear-gradient(135deg,#2563eb,#1d4ed8);cursor:pointer;box-shadow:0 10px 24px -8px #2563eb99;transition:transform .15s,box-shadow .2s,filter .2s;display:flex;align-items:center;justify-content:center;gap:8px}.login-form .login-btn:hover:not(:disabled){transform:translateY(-2px);filter:brightness(1.05);box-shadow:0 16px 30px -10px #2563ebb3}.login-form .login-btn:disabled{opacity:.6;cursor:not-allowed}.login-form .lf-err{color:var(--c-danger);font-size:13px;margin-bottom:12px}.login-alt{margin-top:26px;text-align:center}.login-alt .div{display:flex;align-items:center;gap:12px;color:#b6becc;font-size:12px;margin-bottom:16px}.login-alt .div:before,.login-alt .div:after{content:"";flex:1;height:1px;background:#eaeef4}.login-alt .socials{display:flex;justify-content:center;gap:14px}.login-alt .soc{width:42px;height:42px;border-radius:11px;border:1px solid #E4E8F0;display:grid;place-items:center;cursor:pointer;color:#5a6478;background:#fff;transition:all .15s}.login-alt .soc:hover{border-color:#3b82f6;color:#2563eb;transform:translateY(-2px)}.login-hint{margin-top:22px;font-size:12px;color:var(--c-text-faint);text-align:center}@media (max-width: 820px){.login-card{flex-direction:column;min-height:0;width:100%;max-width:420px}.login-side{display:none}.login-form{padding:38px 28px}}.hamburger{display:none;width:38px;height:38px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-surface);align-items:center;justify-content:center;font-size:19px;color:var(--c-text);cursor:pointer}.sidebar-mask{display:none}@media (max-width: 820px){.sidebar{transform:translate(-100%);transition:transform .25s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:none}.sidebar-mask{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0a173373;z-index:25}.main{margin-left:0}.hamburger{display:inline-flex}.topbar{padding:0 12px;gap:10px}.topbar .top-search,.topbar .crumb,.topbar .user .uinfo{display:none}.page{padding:14px 12px}.page-head{gap:10px}.page-head h1{font-size:18px}.form-grid{grid-template-columns:1fr}.stat-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:14px}.stat-card .value{font-size:22px}.modal-mask{padding:8px}.modal{max-width:100%!important;max-height:96vh}.modal-body{padding:14px}.modal-foot{flex-wrap:wrap;padding:12px 14px}.modal-foot .btn{flex:1;justify-content:center}.toolbar{gap:8px}}@media (max-width: 480px){.stat-grid{grid-template-columns:1fr}.card-head{flex-wrap:wrap;gap:8px}}
