.input-search{padding:9px 14px 9px 36px;border-radius:999px;border:1px solid rgba(226,228,238,.92);background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23777987' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='m21 21-4.3-4.3'/></svg>") no-repeat 12px center;font-size:13px;width:100%;font-family:inherit}.role-switcher{position:relative;display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;cursor:pointer;background:#38bdf81a;border:1px solid rgba(56,189,248,.28);color:#1f5fbf;font-size:12px;font-weight:700;font-family:inherit}.role-switcher:hover{background:#38bdf829}.role-switcher .arrow{font-size:9px;transition:transform .2s ease}.role-switcher.open .arrow{transform:rotate(180deg)}.role-pop{display:none;position:absolute;top:calc(100% + 6px);right:0;z-index:50;min-width:240px;padding:6px;border-radius:12px;background:#fff;border:1px solid rgba(232,234,244,.9);box-shadow:0 20px 50px #0f101a2e}.role-switcher.open+.role-pop{display:block}.role-item{padding:10px 12px;border-radius:8px;cursor:pointer;margin-bottom:2px;display:flex;gap:10px;align-items:flex-start}.role-item:hover{background:#f0eefc80}.role-item.active{background:#38bdf80f}.role-item .body strong{display:block;font-size:13px;color:#20212b}.role-item .body .meta{color:#777987;font-size:11px;margin-top:2px}.role-item .check{width:16px;height:16px;border-radius:50%;flex-shrink:0;background:transparent;margin-top:2px}.role-item.active .check{background:#38bdf8;box-shadow:0 0 0 3px #38bdf82e}.role-pop .role-divider{height:1px;background:#e8eaf4e6;margin:4px 0}.role-pop .role-foot{padding:8px 12px;color:#a9abb8;font-size:11px}[data-role-visible]{display:none!important}body[data-role=super] [data-role-visible~=super],body[data-role=manager] [data-role-visible~=manager],body[data-role=station] [data-role-visible~=station]{display:revert!important}[data-role-visible-inline]{display:none!important}body[data-role=super] [data-role-visible-inline~=super],body[data-role=manager] [data-role-visible-inline~=manager],body[data-role=station] [data-role-visible-inline~=station]{display:inline-flex!important}.login-visual{position:relative;overflow:hidden;background:linear-gradient(135deg,#1a2440,#2d3a58 45%,#3a3f78);color:#fff;padding:60px;display:flex;flex-direction:column;justify-content:space-between}.login-visual:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(at 80% 20%,rgba(56,189,248,.34),transparent 40%),radial-gradient(at 20% 80%,rgba(124,103,255,.36),transparent 50%),radial-gradient(at 60% 60%,rgba(255,79,134,.16),transparent 45%)}.visual-logo{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#38bdf8,#7c67ff,#ff4f86);font-weight:900;font-size:22px}.visual-roles{margin-top:20px;display:grid;gap:8px;padding:14px 16px;background:#ffffff14;border:1px solid rgba(255,255,255,.14);border-radius:14px;max-width:420px}.visual-roles .role-row{display:flex;gap:8px;align-items:baseline;font-size:13px}.visual-roles .role-row .lvl{color:#ffffff8c;width:80px;font-weight:700}.visual-roles .role-row .desc{color:#ffffffd9}.login-card-head .role-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;background:#38bdf824;color:#1f5fbf;font-size:11px;font-weight:800;margin-bottom:14px}.login-form .pwd-wrap .input{padding-right:40px;width:100%;box-sizing:border-box}.login-options a{color:#2582ff;text-decoration:none;font-weight:700}.login-foot{text-align:center;color:#a9abb8;font-size:11px;margin-top:18px}.login-foot .demo-hint{margin-top:12px;padding:10px 12px;background:#38bdf80f;border:1px dashed rgba(56,189,248,.24);border-radius:10px;color:#1f5fbf;font-size:11px;line-height:1.6;text-align:left}.login-foot .demo-hint code{font-family:SFMono-Regular,Consolas,monospace;background:#fff9;padding:1px 4px;border-radius:4px}body{font-family:var(--sans, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif);color:var(--text, #20212b);background:linear-gradient(135deg,#fafbff,#f3f0ff 32%,#ecfbff 68%,#fff7f3);background-attachment:fixed;margin:0;min-height:100vh}.app-shell{width:min(1480px,calc(100% - 32px));margin:20px auto 44px}.topbar{position:sticky;top:14px;z-index:30;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:14px 16px;border:1px solid rgba(255,255,255,.76);border-radius:26px;background:#ffffffc7;box-shadow:0 22px 60px #20212b1a;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.brand{display:flex;align-items:center;gap:12px;min-width:260px}.logo-square{display:grid;place-items:center;width:44px;height:44px;border-radius:14px;background:linear-gradient(135deg,#ff4f86,#7c67ff 54%,#38bdf8);color:#fff;font-weight:800;box-shadow:0 12px 28px #ff4f8647}.brand-copy strong{display:block;font-size:15px}.brand-copy span{color:#777987;font-size:12px}.nav{display:flex;gap:7px;flex-wrap:wrap}.nav a{padding:9px 14px;border-radius:999px;border:1px solid transparent;color:#777987;font-size:13px;font-weight:600;transition:.16s ease;text-decoration:none}.nav a:hover{color:#11121a}.nav a.active{color:#fff;background:#171821;border-color:#171821;box-shadow:0 10px 24px #17182126}.topbar-right{display:flex;align-items:center;gap:12px}.quota-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:#7c67ff1a;color:#5f45d8;font-size:12px;font-weight:700}.quota-chip.warn{background:#e84d631a;color:#c43349}.bell{position:relative;width:38px;height:38px;display:grid;place-items:center;border-radius:999px;background:#ffffffd1;border:1px solid rgba(226,228,238,.92);cursor:pointer}.bell-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:50%;background:#ff4f86}.avatar{display:inline-flex;align-items:center;gap:8px;padding:5px 12px 5px 5px;border-radius:999px;background:#ffffffd1;border:1px solid rgba(226,228,238,.92);cursor:pointer;font-size:13px;font-weight:700}.avatar-dot{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#7c67ff,#38bdf8);color:#fff;display:grid;place-items:center;font-size:12px}.main{display:grid;gap:16px;margin-top:18px}.panel{padding:22px;border-radius:26px;background:#ffffffd1;border:1px solid rgba(255,255,255,.78);box-shadow:0 22px 60px #20212b1a;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:18px}.page-head h1{margin:6px 0 4px;font-size:28px}.page-head .sub{color:#777987;font-size:13px}.eyebrow{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;border:1px solid rgba(124,103,255,.18);background:#f0eefcc7;color:#6d5bf1;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.btn{display:inline-flex;min-height:38px;align-items:center;justify-content:center;gap:6px;padding:0 14px;border-radius:999px;border:1px solid transparent;cursor:pointer;font-size:13px;font-weight:800;transition:transform .16s ease,box-shadow .16s ease;font-family:inherit}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn.primary{background:linear-gradient(135deg,#151620,#2d2937);color:#fff;box-shadow:0 12px 24px #1718212e}.btn.secondary{background:#ffffffeb;color:#20212b;border-color:#e2e4eeeb}.btn.ghost{background:transparent;color:#11121a}.btn.danger{background:#fff0f3;color:#e84d63;border-color:#f3c4c1}.btn.success{background:#e9f8ef;color:#16a06a;border-color:#b9e8cc}.btn.sm{min-height:30px;padding:0 10px;font-size:12px}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.kpi{position:relative;overflow:hidden;padding:18px;border-radius:18px;background:#ffffffd1;border:1px solid rgba(255,255,255,.76);box-shadow:0 12px 34px #20212b14;cursor:pointer;transition:transform .16s ease}.kpi:hover{transform:translateY(-2px)}.kpi:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,#ff4f86,#7c67ff,#38bdf8)}.kpi-label{color:#777987;font-size:12px;font-weight:600}.kpi-num{display:block;margin:8px 0 4px;font-family:SFMono-Regular,Consolas,monospace;font-size:28px;font-weight:800}.kpi-arrow{color:#6d5bf1;font-size:12px;font-weight:700}.table-wrap{overflow-x:auto;border-radius:18px;background:#fff9;border:1px solid rgba(232,234,244,.9)}.tbl{width:100%;border-collapse:collapse;min-width:700px}.tbl th,.tbl td{padding:12px 14px;text-align:left;font-size:13px}.tbl th{background:#f0eefc66;color:#6d5bf1;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.tbl tr{border-bottom:1px solid rgba(232,234,244,.6)}.tbl tr:last-child{border-bottom:none}.tbl tr:hover td{background:#f0eefc2e}.badge{display:inline-flex;align-items:center;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:700}.badge.blue{background:#eaf3ff;color:#2582ff}.badge.purple{background:#f0eefc;color:#6d5bf1}.badge.orange{background:#fff3dc;color:#d97706}.badge.green{background:#e9f8ef;color:#16a06a}.badge.gray{background:#eef0f7;color:#777987}.badge.red{background:#fff0f3;color:#e84d63}.badge.amber{background:#fef3c7;color:#92400e}.format-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.format-card{padding:18px 14px;border-radius:14px;cursor:pointer;text-align:center;background:#fff;border:1.5px solid rgba(232,234,244,.9);transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.format-card:hover{transform:translateY(-2px);border-color:#7c67ff52;box-shadow:0 12px 30px #7c67ff1f}.format-card .ic{font-size:28px;margin-bottom:6px}.format-card strong{display:block;font-size:14px}.format-card .desc{color:#777987;font-size:11px;margin-top:4px}.share-state-tip{padding:10px 12px;border-radius:10px;font-size:12px;margin-bottom:14px;display:flex;gap:8px;align-items:flex-start}.share-state-tip.done{background:#16a06a14;color:#14905f;border:1px solid rgba(22,160,106,.18)}.share-state-tip.processing{background:#2582ff14;color:#1f5fbf;border:1px solid rgba(37,130,255,.18)}.share-state-tip.idle{background:#fff3dc;color:#7b520f;border:1px solid #f3dfb6}.filter-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}.filter-bar .grow{flex:1;min-width:200px}.filter-bar>.select,.filter-bar>select.select{width:auto;flex:0 0 auto;min-width:140px;padding:8px 12px;font-size:13px}.input-search{padding:9px 14px 9px 36px;border-radius:999px;border:1px solid rgba(226,228,238,.92);background:#fff url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23777987' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='11' cy='11' r='8'/><path d='m21 21-4.3-4.3'/></svg>") no-repeat 12px center;font-size:13px;width:100%;font-family:inherit}.date-range{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#fff;border:1px solid rgba(226,228,238,.92);font-size:13px}.date-range input[type=date]{border:none;outline:none;padding:4px 6px;font:inherit;background:#e8eaf466;border-radius:6px;color:#20212b;min-width:124px}.date-range .sep{color:#a9abb8}.date-presets{display:inline-flex;gap:4px}.date-presets button{padding:5px 10px;border-radius:999px;background:#fff;border:1px solid rgba(226,228,238,.92);cursor:pointer;font-size:12px;font-weight:700;color:#777987;font-family:inherit}.date-presets button.active{background:#171821;color:#fff;border-color:#171821}.date-presets button:hover:not(.active){color:#20212b;border-color:#7c67ff52}.filter-label{color:#777987;font-size:12px;font-weight:700}.field{display:grid;gap:6px;margin-bottom:14px}.field label{color:#777987;font-size:12px;font-weight:600}.field label .req{color:#e84d63;margin-left:2px}.input,.textarea,.select{font:inherit;padding:10px 14px;border-radius:12px;border:1px solid rgba(226,228,238,.92);background:#fff;font-size:14px;transition:border-color .16s ease,box-shadow .16s ease}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:#7c67ff;box-shadow:0 0 0 3px #7c67ff24}.textarea{min-height:80px;resize:vertical;font-family:inherit}.row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.spacer{flex:1}.divider{height:1px;background:#e8eaf4e6;margin:16px 0;border:none}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:none;align-items:stretch;justify-content:flex-end;background:#0f101a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.drawer-backdrop.open{display:flex}.drawer{width:min(440px,100%);padding:24px;background:#fff;box-shadow:-22px 0 60px #0f101a2e;overflow-y:auto}.drawer h2{margin:0 0 6px;font-size:18px}.drawer-close{width:32px;height:32px;border:none;background:#e2e4ee99;border-radius:50%;cursor:pointer;font-size:16px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90;display:none;align-items:center;justify-content:center;background:#0f101a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-backdrop.open{display:flex}.modal{width:min(520px,92%);padding:28px;background:#fff;border-radius:22px;box-shadow:0 30px 80px #0f101a4d}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(80px);padding:12px 18px;background:#171821;color:#fff;border-radius:12px;font-size:13px;font-weight:700;box-shadow:0 18px 40px #00000040;opacity:0;transition:opacity .2s ease,transform .25s ease;z-index:100;pointer-events:none}.toast.show{opacity:1;transform:translate(-50%) translateY(0);pointer-events:auto}.dev-index{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}.dev-card{padding:18px;border-radius:18px;background:#ffffffd9;border:1px solid rgba(232,234,244,.9);text-decoration:none;color:inherit;box-shadow:0 8px 22px #20212b0f;transition:transform .16s ease,box-shadow .16s ease}.dev-card:hover{transform:translateY(-3px);box-shadow:0 18px 42px #20212b1a}.dev-card strong{display:block;font-size:15px;margin-bottom:6px}.dev-card .num{display:inline-block;font-family:monospace;color:#6d5bf1;font-size:11px;margin-bottom:8px}.dev-card .desc{color:#777987;font-size:12px;line-height:1.5}.dev-card .meta{color:#a9abb8;font-size:11px;margin-top:8px}.login-page{min-height:100vh;display:grid;grid-template-columns:1.1fr .9fr;gap:0}.login-visual{position:relative;overflow:hidden;background:linear-gradient(135deg,#1a1b29,#2d2937 45%,#3a2b58);color:#fff;padding:60px;display:flex;flex-direction:column;justify-content:space-between}.login-visual:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(at 80% 20%,rgba(255,79,134,.3),transparent 40%),radial-gradient(at 20% 80%,rgba(124,103,255,.32),transparent 50%),radial-gradient(at 60% 60%,rgba(56,189,248,.18),transparent 45%)}.login-visual>*{position:relative;z-index:1}.visual-brand{display:flex;align-items:center;gap:14px}.visual-logo{width:54px;height:54px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#ff4f86,#7c67ff,#38bdf8);font-weight:900;font-size:22px}.visual-brand-name strong{display:block;font-size:18px}.visual-brand-name span{font-size:12px;opacity:.7}.visual-pitch h1{font-size:42px;line-height:1.1;margin-bottom:20px}.visual-pitch p{color:#ffffffc7;font-size:15px;line-height:1.7;max-width:420px}.visual-foot{font-size:12px;opacity:.55}.login-form-area{display:grid;place-items:center;padding:40px;background:linear-gradient(135deg,#fafbff,#f3f0ff,#ecfbff)}.login-card{width:min(420px,100%);padding:36px;background:#ffffffeb;border:1px solid rgba(255,255,255,.78);border-radius:28px;box-shadow:0 30px 80px #0f101a1f}.login-card-head{text-align:center;margin-bottom:22px}.login-card-head .role-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;background:#7c67ff1f;color:#5f45d8;font-size:11px;font-weight:800;margin-bottom:14px}.login-card-head h2{margin:0;font-size:22px}.login-card-head .sub{color:#777987;font-size:13px;margin-top:6px}.login-form .field{margin-bottom:16px}.login-form .field>label{display:block;font-size:12px;font-weight:700;margin-bottom:6px;color:#444656}.login-form .input{width:100%;padding:10px 12px;border-radius:10px;border:1px solid rgba(226,228,238,.92);background:#fff;font:inherit;font-size:13px;box-sizing:border-box}.login-form .input:focus{outline:none;border-color:#7c67ff;box-shadow:0 0 0 3px #7c67ff1f}.login-form .pwd-wrap{position:relative}.login-form .pwd-wrap .input{padding-right:40px;width:100%}.pwd-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:6px;color:#777987;font-size:14px}.login-options{display:flex;justify-content:space-between;align-items:center;margin:6px 0 20px;font-size:12px}.login-options label{display:inline-flex;align-items:center;gap:6px;color:#777987}.login-options a{color:#6d5bf1;text-decoration:none;font-weight:700}.btn-block{width:100%;min-height:46px;font-size:14px}.login-foot{text-align:center;color:#a9abb8;font-size:11px;margin-top:18px;line-height:1.7}.demo-hint{margin-top:14px;padding:10px 12px;border-radius:10px;background:#7c67ff0f;border:1px dashed rgba(124,103,255,.32);color:#5f45d8;font-size:11px;line-height:1.7;text-align:left}.demo-hint code{font-family:monospace;background:#7c67ff14;padding:1px 4px;border-radius:4px}.tiny{font-size:11px}.muted{color:#777987}@media (max-width: 880px){.login-page{grid-template-columns:1fr}.login-visual{padding:36px}.visual-pitch h1{font-size:30px}.login-form-area{padding:24px}}.login-err{margin:0 0 14px;padding:12px 14px;border-radius:12px;background:#fff0f3;border:1px solid #f3c4c1;color:#c43349;font-size:13px}.login-err strong{display:inline-block;margin-right:6px}
