:root{color-scheme:dark;font-family:Geist,Inter,PingFang SC,Microsoft YaHei,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;--background: #09090b;--surface: #0f0f10;--surface-muted: #1f1f22;--surface-hover: #171719;--text: #f4f4f5;--text-muted: #a1a1aa;--border: #27272a;--border-strong: #3f3f46;--primary: #fafafa;--primary-strong: #e4e4e7;--primary-soft: #27272a;--warning: #fbbf24;--warning-soft: #2a2110;--success: #22c55e;--success-soft: #0d1f14;--danger: #f87171;--danger-soft: #2a1215;--ring: rgb(250 250 250 / 20%);--shadow: 0 22px 70px rgb(0 0 0 / 42%);--radius: 8px}:root[data-theme=light]{color-scheme:light;--background: #fafafa;--surface: #ffffff;--surface-muted: #f4f4f5;--surface-hover: #f4f4f5;--text: #09090b;--text-muted: #71717a;--border: #e4e4e7;--border-strong: #d4d4d8;--primary: #18181b;--primary-strong: #27272a;--primary-soft: #f4f4f5;--warning-soft: #fef3c7;--success-soft: #dcfce7;--danger-soft: #fee2e2;--ring: rgb(24 24 27 / 18%);--shadow: 0 22px 70px rgb(24 24 27 / 12%)}*{box-sizing:border-box}html{min-width:320px;background:var(--background)}body{margin:0;min-width:320px;min-height:100vh;color:var(--text);background:var(--background);font-size:14px;line-height:1.5}button,input,textarea,select{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.52}#root{min-height:100vh}.boot-screen{display:grid;min-height:100vh;place-items:center;gap:12px;color:var(--text-muted)}.loader{width:34px;height:34px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:999px;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{display:flex;min-height:100vh;align-items:center;justify-content:center;padding:24px;background:var(--background)}.login-panel{display:flex;width:min(420px,100%);flex-direction:column;justify-content:center;gap:28px;padding:32px;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:none}.login-brand{display:flex;align-items:center;gap:12px}.brand-mark{display:grid;width:32px;height:32px;flex:0 0 auto;place-items:center;border-radius:7px;color:var(--background);background:var(--primary);font-size:12px;font-weight:800}.login-brand strong,.brand-title{display:block;font-size:15px;font-weight:700}.login-brand span,.brand-subtitle{display:block;margin-top:2px;color:var(--text-muted);font-size:12px}.login-copy h1,.page-header h1{margin:8px 0;font-size:30px;line-height:1.15;letter-spacing:0}.login-copy p,.page-header p,.panel-header p{margin:0;color:var(--text-muted);line-height:1.6}.eyebrow{color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.login-form,.form-panel{display:flex;flex-direction:column;gap:18px}.field{display:grid;gap:8px}.field>span{color:var(--text);font-size:13px;font-weight:600}.input-with-icon{display:flex;align-items:center;gap:10px;min-height:38px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.input-with-icon svg{color:var(--text-muted);flex:0 0 auto}input,textarea{width:100%;min-width:0;border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface);outline:none}.input-with-icon input{border:0;border-radius:0;background:transparent}input{height:38px;padding:0 12px}textarea{min-height:92px;resize:vertical;padding:12px;line-height:1.5}select{height:36px;padding:0 32px 0 10px;border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface);outline:none}input:focus,textarea:focus,.input-with-icon:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}input::placeholder,textarea::placeholder{color:#71717a}.input-with-icon,input,textarea{background:var(--background)}.form-error{padding:10px 12px;border:1px solid #7f1d1d;border-radius:var(--radius);color:var(--danger);background:var(--danger-soft);font-size:13px}.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:36px;padding:0 14px;border:1px solid transparent;border-radius:var(--radius);font-size:13px;font-weight:600;white-space:nowrap;transition:background .18s ease,border-color .18s ease,color .18s ease}.button-primary{color:var(--background);background:var(--primary)}.button-primary:hover{background:var(--primary-strong)}.button-secondary{color:var(--text);border-color:var(--border);background:var(--primary-soft)}.button-destructive{color:var(--danger);border-color:#7f1d1d;background:var(--danger-soft)}.button-ghost{color:var(--text);border-color:var(--border);background:var(--surface)}.button-ghost:hover,.icon-button:hover{background:var(--surface-hover)}.button-full{width:100%}.sidebar-provider{display:grid;min-height:100vh;grid-template-columns:288px minmax(0,1fr);gap:8px;padding:8px}.sidebar-provider.sidebar-collapsed{grid-template-columns:88px minmax(0,1fr)}.sidebar{position:sticky;top:8px;display:flex;height:calc(100vh - 16px);flex-direction:column;gap:12px;padding:10px;border:1px solid var(--border);border-radius:12px;background:var(--surface)}.sidebar-header{display:flex;align-items:center;gap:8px;min-height:48px}.sidebar-content{display:flex;min-height:0;flex:1;flex-direction:column}.sidebar-menu{display:grid;gap:6px}.sidebar-menu-item{min-width:0}.sidebar-menu-button{display:grid;grid-template-columns:22px minmax(0,1fr);gap:10px;align-items:center;width:100%;min-height:38px;padding:7px 9px;border:1px solid transparent;border-radius:var(--radius);color:var(--text-muted);background:transparent;text-align:left}.sidebar-provider.sidebar-collapsed .sidebar-menu-button{grid-template-columns:1fr;justify-items:center;padding:8px}.sidebar-provider.sidebar-collapsed .sidebar-menu-button strong,.sidebar-provider.sidebar-collapsed .sidebar-menu-button span:not(.sr-only),.sidebar-provider.sidebar-collapsed .sidebar-user,.sidebar-provider.sidebar-collapsed .sidebar-brand>span{display:none}.sidebar-menu-button strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-menu-button strong{color:var(--text);font-size:14px;font-weight:500;line-height:1.2}.sidebar-menu-button:hover{background:var(--surface-hover)}.sidebar-menu-button.active{color:var(--text);border-color:var(--border-strong);background:var(--primary-soft)}.sidebar-brand{grid-template-columns:32px minmax(0,1fr);gap:8px;min-height:40px;padding:4px 6px}.sidebar-brand span{color:var(--text);font-size:14px;font-weight:650}.sidebar-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding:8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted)}.sidebar-footer svg{color:var(--text);flex:0 0 auto}.sidebar-footer strong,.sidebar-footer span{display:block;font-size:12px}.sidebar-footer span{margin-top:2px;color:var(--text-muted)}.content-shell{min-width:0}.sidebar-inset{min-width:0;min-height:calc(100vh - 16px);overflow:hidden;border:1px solid var(--border);border-radius:12px;background:var(--background)}.sidebar-user{display:flex;min-width:0;align-items:center;gap:9px}.mobile-sidebar-overlay{display:none}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:18px;height:66px;padding:0 20px;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--background) 86%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar-left,.topbar-actions{display:flex;align-items:center;gap:10px;min-width:0}.sidebar-toggle{width:44px;height:44px}.theme-toggle{width:40px;height:40px}.site-header-divider{width:1px;height:32px;background:var(--border)}.site-header-eyebrow{display:block;color:var(--text-muted);font-size:12px;line-height:1.2}.topbar-left strong{display:block;margin-top:2px;font-size:14px}.topbar-actions{color:var(--text-muted);font-size:13px}.icon-button{display:inline-grid;width:34px;height:34px;place-items:center;border:1px solid var(--border);border-radius:var(--radius);color:var(--text-muted);background:var(--surface)}.icon-button:hover{color:var(--text);border-color:var(--border-strong)}.search-box{display:flex;align-items:center;gap:8px;width:min(360px,36vw);height:38px;padding:0 12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.search-box,.user-menu,.icon-button{box-shadow:none}.search-box input{height:auto;padding:0;border:0;background:transparent}.user-menu{display:flex;align-items:center;gap:9px;min-width:0;padding:4px 8px 4px 4px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.avatar{display:grid;width:32px;height:32px;place-items:center;border-radius:7px;color:var(--background);background:var(--primary);font-size:13px;font-weight:800}.user-meta{display:grid;min-width:0}.user-meta strong,.user-meta span{overflow:hidden;max-width:120px;text-overflow:ellipsis;white-space:nowrap}.user-meta strong{font-size:13px}.user-meta span{color:var(--text-muted);font-size:12px}.main-content{padding:24px}.page-stack{display:grid;gap:18px}.page-actions-row{display:flex;justify-content:flex-end}.page-header{display:flex;align-items:flex-end;justify-content:space-between;gap:18px}.page-header-action{flex:0 0 auto}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.stat-card,.panel{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:none}.stat-card{display:grid;gap:12px;min-height:118px;padding:16px}.stat-card-header{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--text-muted);font-size:13px;font-weight:600}.stat-card strong{font-size:26px;line-height:1.15}.stat-card p{margin:0;color:var(--text-muted);font-size:12px;line-height:1.45}.stat-card.success,.stat-card.warning{border-color:var(--border);background:var(--surface)}.panel{padding:18px}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}.panel-header h2{margin:0 0 4px;font-size:16px}.bar-chart{display:grid;min-height:280px;grid-template-columns:repeat(7,minmax(28px,1fr));align-items:end;gap:12px;padding-top:12px}.bar-item{display:grid;height:260px;grid-template-rows:24px 1fr 22px;gap:8px;align-items:end;justify-items:center}.bar-item span,.bar-item small{color:var(--text-muted);font-size:12px}.bar-item div{width:100%;min-height:12px;border-radius:6px 6px 2px 2px;background:#71717a}.generated-list{display:grid;gap:10px}.generated-result{display:grid;gap:10px;padding-top:4px}.generated-result-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.generated-result-header strong{font-size:14px}.generated-result-header span{color:var(--text-muted);font-size:12px}.generated-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--background)}.generated-card strong,.generated-card span{display:block;overflow-wrap:anywhere}.generated-card strong{font-size:13px}.generated-card span{margin-top:3px;color:var(--text-muted);font-size:12px}.package-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.package-option{display:inline-flex;min-height:42px;align-items:center;justify-content:center;padding:0 14px;border:1px solid var(--border);border-radius:10px;color:var(--text);background:var(--background);text-align:center}.package-option:hover{border-color:var(--border-strong);background:var(--surface-hover)}.package-option strong{display:block;font-size:14px;font-weight:650}.package-option.selected{border-color:var(--border-strong);background:var(--surface-muted);box-shadow:none}.form-grid,.cost-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.cost-summary{padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted)}.cost-summary span,.cost-summary strong{display:block}.cost-summary span{color:var(--text-muted);font-size:12px}.cost-summary strong{margin-top:4px;font-size:16px}.result-placeholder,.empty-state{display:grid;min-height:230px;place-items:center;align-content:center;gap:8px;padding:28px;border:1px dashed var(--border-strong);border-radius:var(--radius);color:var(--text-muted);text-align:center;background:var(--background)}.result-placeholder strong,.empty-state strong{color:var(--text)}.table-panel{padding:0;overflow:hidden;background:var(--surface)}.table-toolbar{display:flex;align-items:center;gap:12px;padding:0}.table-toolbar input{max-width:360px}.date-picker{position:relative;display:inline-flex;align-items:center;gap:6px}.date-picker-trigger{min-width:168px;justify-content:flex-start}.date-picker-placeholder{color:var(--text-muted)}.date-picker-clear{width:34px;height:34px}.date-picker-popover{position:absolute;top:calc(100% + 8px);left:0;z-index:30;width:284px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.date-picker-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.date-picker-header strong{font-size:14px;font-weight:650}.date-picker-weekdays,.date-picker-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}.date-picker-weekdays{margin-bottom:6px}.date-picker-weekdays span{display:grid;height:28px;place-items:center;color:var(--text-muted);font-size:12px}.date-picker-grid button,.date-picker-grid span{display:grid;width:100%;height:34px;place-items:center}.date-picker-grid button{border:0;border-radius:7px;color:var(--text);background:transparent;font-size:13px}.date-picker-grid button:hover{background:var(--surface-hover)}.date-picker-grid button.today{color:var(--primary);background:var(--primary-soft)}.date-picker-grid button.active{color:var(--background);background:var(--primary)}.table-recharge{margin-left:auto}.table-create{margin-left:0}.table-create+.table-refresh{margin-left:0}.segmented-control{display:inline-flex;flex-wrap:wrap;gap:4px;padding:4px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted)}.segmented-control{background:var(--background)}.segmented-control button{min-height:30px;padding:0 10px;border:0;border-radius:6px;color:var(--text-muted);background:transparent;font-size:13px}.segmented-control button.active{color:var(--text);background:var(--surface-muted);box-shadow:none}.table-scroll{overflow-x:auto}.data-table{width:100%;min-width:900px;border-collapse:separate;border-spacing:0;background:var(--surface)}.data-table th,.data-table td{height:54px;padding:0 16px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle;font-size:13px;line-height:1.45}.data-table tr:last-child td{border-bottom:0}.data-table tbody tr{transition:background .16s ease}.data-table tbody tr:hover{background:var(--surface-hover)}.data-table th{height:44px;color:var(--text-muted);background:#ffffff05;font-size:12px;font-weight:500}.data-table th:first-child{border-top-left-radius:var(--radius)}.data-table th:last-child{border-top-right-radius:var(--radius)}.table-key strong,.table-key span{display:block}.table-key strong{overflow-wrap:anywhere;color:var(--text);font-size:13px;font-weight:500}.table-key span{margin-top:3px;color:var(--text-muted);font-size:12px}.point-change{font-weight:600}.point-change.positive{color:var(--success)}.point-change.negative{color:var(--danger)}.table-actions{display:flex;gap:6px;justify-content:flex-end}.row-action{position:relative;display:inline-flex;justify-content:flex-end}.copy-toast{position:fixed;right:24px;bottom:24px;z-index:60;display:inline-flex;min-height:40px;align-items:center;padding:0 14px;border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface);box-shadow:var(--shadow);font-size:13px;font-weight:500}.row-action-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:20;display:grid;min-width:128px;padding:4px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.row-action-menu button{display:flex;align-items:center;gap:8px;min-height:34px;padding:0 9px;border:0;border-radius:6px;color:var(--text);background:transparent;font-size:13px;text-align:left;white-space:nowrap}.row-action-menu button:hover{background:var(--surface-hover)}.data-table th:last-child,.data-table td:last-child{text-align:right}.table-footer{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 16px;border-top:1px solid var(--border)}.table-count,.table-page-label,.table-page-size span{color:var(--text-muted);font-size:13px}.table-pagination,.table-page-size,.table-page-actions{display:flex;align-items:center;gap:8px}.table-page-actions{gap:6px}.status-badge{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border:1px solid var(--border);border-radius:999px;font-size:12px;font-weight:500;white-space:nowrap}.status-badge.badge-success{color:var(--success);border-color:#14532d;background:var(--success-soft)}.status-badge.badge-default{color:var(--text);border-color:var(--border);background:var(--primary-soft)}.status-badge.badge-destructive{color:var(--danger);border-color:#7f1d1d;background:var(--danger-soft)}.status-badge.badge-warning{color:var(--warning);border-color:#713f12;background:var(--warning-soft)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:20px;background:#0000006b}.modal-panel{width:min(480px,100%);max-height:min(720px,calc(100vh - 40px));overflow-y:auto;padding:20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.generate-modal-panel{width:min(560px,100%)}.modal-header,.modal-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-header{margin-bottom:18px}.modal-header h2{margin:6px 0 0;font-size:20px;line-height:1.2}.recharge-form{display:grid;gap:16px}.balance-strip{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:54px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted)}.balance-strip.muted{border-color:var(--border);background:var(--surface-muted)}.balance-strip span{color:var(--text-muted);font-size:13px}.balance-strip strong{font-size:18px}.quick-points{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.quick-points button{min-height:34px;border:1px solid var(--border);border-radius:var(--radius);color:var(--text);background:var(--surface-muted);font-size:13px;font-weight:650}.quick-points button.active{color:var(--primary);border-color:var(--primary);background:var(--primary-soft)}@media(max-width:1180px){.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:860px){.login-panel{padding:28px}.sidebar-provider{display:block;grid-template-columns:1fr}.sidebar-provider.sidebar-collapsed{grid-template-columns:1fr}.sidebar{position:fixed;top:8px;left:8px;z-index:40;width:min(288px,calc(100vw - 32px));height:calc(100vh - 16px);transform:translate(calc(-100% - 16px));transition:transform .2s ease}.sidebar-provider.sidebar-collapsed .sidebar-menu-button{grid-template-columns:22px minmax(0,1fr);justify-items:start;padding:7px 9px}.sidebar-provider.sidebar-collapsed .sidebar-menu-button strong,.sidebar-provider.sidebar-collapsed .sidebar-menu-button span:not(.sr-only),.sidebar-provider.sidebar-collapsed .sidebar-user,.sidebar-provider.sidebar-collapsed .sidebar-brand>span{display:block}.sidebar-provider.sidebar-mobile-open .sidebar{transform:translate(0)}.mobile-sidebar-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:block;border:0;background:#00000075}.desktop-collapse,.search-box,.user-menu,.topbar-actions .button-ghost{display:none}.sidebar-inset{min-height:calc(100vh - 16px)}.main-content{padding:20px}.page-header,.table-toolbar{align-items:stretch;flex-direction:column}.table-recharge,.table-refresh{margin-left:0}.date-picker{width:100%}.date-picker-trigger{flex:1}.page-header-action,.page-header-action .button{width:100%}.package-grid{min-width:0;grid-template-columns:repeat(2,minmax(0,1fr))}.modal-actions{align-items:stretch;flex-direction:column-reverse}.modal-actions .button{width:100%}.table-footer{align-items:stretch;flex-direction:column}.table-pagination{justify-content:space-between}}@media(max-width:560px){.stats-grid,.form-grid,.cost-summary,.package-grid{grid-template-columns:1fr}.login-copy h1,.page-header h1{font-size:26px}.topbar{padding:0 16px}.main-content{padding:16px}.table-toolbar input{max-width:none}.quick-points{grid-template-columns:repeat(2,minmax(0,1fr))}}
