:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:geometricPrecision;--bg: #f6f8fb;--surface: #ffffff;--surface-strong: #f9fbfd;--text: #152033;--muted: #607087;--line: #dfe6ee;--line-soft: #edf1f5;--teal: #169c92;--teal-soft: #e5f7f5;--blue: #2f78d6;--blue-soft: #e8f1ff;--amber: #c77a10;--amber-soft: #fff2d8;--violet: #7057d8;--violet-soft: #eeeafe;--red: #d64545;--red-soft: #ffebeb;--shadow: 0 12px 32px rgb(23 35 53 / 8%)}*{box-sizing:border-box}html{background:var(--bg)}body{margin:0;color:var(--text);min-width:320px;min-height:100vh}button,input,select{font:inherit}button{cursor:pointer}.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.home-shell{min-height:100vh;display:grid;place-items:center;padding:28px;background:linear-gradient(180deg,#ffffffd1,#f6f8fbf5),var(--bg)}.home-card{width:min(100%,460px);display:grid;gap:24px;padding:28px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:var(--shadow)}.home-brand{display:flex;align-items:center;gap:13px}.home-brand strong,.home-brand span{display:block}.home-brand strong{font-size:20px;line-height:1.2}.home-brand span{margin-top:4px;color:var(--muted);font-size:13px}.home-query{display:grid;grid-template-columns:minmax(0,1fr) 116px;gap:10px}.home-query input,.home-query button{height:44px;border-radius:8px}.home-query input{min-width:0;padding:0 14px;border:1px solid var(--line);color:var(--text);background:#fff;outline:none}.home-query input:focus{border-color:var(--teal);box-shadow:0 0 0 3px #169c921f}.home-query button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid #0f8f86;color:#fff;background:#14998f;font-weight:700}.home-query button:disabled{cursor:not-allowed;opacity:.6}.home-error{color:var(--red);font-size:13px}.app-shell{min-height:100vh;display:grid;grid-template-columns:260px minmax(0,1fr);background:var(--bg)}.sidebar{display:flex;flex-direction:column;gap:15px;padding:20px 16px;border-right:1px solid var(--line);background:linear-gradient(180deg,#fff,#f8fbfd)}.brand{display:flex;align-items:center;gap:12px;min-height:44px}.brand-mark{width:38px;height:38px;border-radius:8px;display:grid;place-items:center;color:#fff;background:linear-gradient(145deg,#14998f,#4da3d5);box-shadow:0 8px 18px #169c9233}.brand strong,.brand span{display:block}.brand strong{font-size:18px;line-height:1.2}.brand span,.label,.sidebar-footer span,.eyebrow,.panel-heading p,.metric-card p,.billing-card p,.breakdown-item small{color:var(--muted)}.brand span{margin-top:3px;font-size:12px}.identity-panel{padding:14px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.identity-panel strong,.label{display:block}.identity-panel strong{margin:5px 0 13px;font-size:15px}.label{margin:10px 0 6px;font-size:12px}.copy-line{display:flex;align-items:center;justify-content:space-between;gap:8px}code{color:#27354a;font-family:SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:13px;overflow-wrap:anywhere}.icon-button{width:30px;height:30px;border:1px solid var(--line);border-radius:7px;color:var(--muted);background:#fff}.query-input,.price-control input,.billing-example input,.detail-actions select{height:38px;border:1px solid var(--line);border-radius:7px;color:var(--text);background:#fff;outline:none}.query-input{flex:1;min-width:0;width:100%;padding:0 11px;letter-spacing:0}.query-row{display:flex;gap:6px}.query-button{flex:0 0 38px;width:38px;min-width:38px;padding:0}.query-input:focus,.price-control input:focus,.billing-example input:focus,.detail-actions select:focus{border-color:var(--teal);box-shadow:0 0 0 3px #169c921f}.query-input.has-error{border-color:var(--red)}.input-error{display:block;margin-top:6px;color:var(--red);font-size:12px}.side-nav{display:grid;gap:8px}.nav-button{width:100%;height:42px;display:flex;align-items:center;gap:10px;padding:0 12px;border:1px solid transparent;border-radius:8px;color:#42526a;background:transparent;text-align:left}.nav-button:hover,.nav-button.active{color:#0d6f69;border-color:#cfe9e7;background:var(--teal-soft)}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--line-soft);display:grid;gap:8px;font-size:12px}.main-content{min-width:0;padding:18px 24px 28px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:12px}.eyebrow{margin:0 0 4px;font-size:13px}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:24px;line-height:1.2;letter-spacing:0}h2{margin-bottom:5px;font-size:17px;line-height:1.3;letter-spacing:0}.toolbar,.detail-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.range-group{height:42px;display:flex;padding:4px;border:1px solid var(--line);border-radius:8px;background:var(--surface)}.range-button{min-width:96px;height:32px;padding:0 12px;border:0;border-radius:6px;color:var(--muted);background:transparent;font-size:14px}.range-button.active{color:var(--text);background:#edf8f7;box-shadow:inset 0 0 0 1px #cbe8e5}.secondary-button,.text-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:42px;padding:0 14px;border-radius:8px;font-weight:650}.secondary-button{border:1px solid var(--line);color:var(--text);background:var(--surface)}.text-button{border:0;color:var(--teal);background:transparent}.notice{display:flex;align-items:center;gap:9px;min-height:36px;margin-bottom:14px;padding:8px 12px;border:1px solid #cfe9e7;border-radius:8px;color:#116d66;background:#f1fbfa;font-size:14px}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,.78fr);gap:14px}.metric-grid{grid-column:1 / -1;display:grid;grid-template-columns:repeat(5,minmax(145px,1fr));gap:12px}.metric-card,.panel,.locked-state{border:1px solid var(--line);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.metric-card{position:relative;min-height:118px;padding:14px;display:grid;gap:9px;overflow:hidden}.metric-icon{width:36px;height:36px;border-radius:8px;display:grid;place-items:center}.metric-card span{display:block;color:var(--muted);font-size:13px}.metric-card strong{display:flex;align-items:baseline;gap:7px;margin-top:5px;font-size:24px;line-height:1;letter-spacing:0}.metric-card small{color:var(--muted);font-size:13px;font-weight:600}.metric-card p{margin:6px 0 0;font-size:12px}.metric-card.teal .metric-icon{color:var(--teal);background:var(--teal-soft)}.metric-card.blue .metric-icon{color:var(--blue);background:var(--blue-soft)}.metric-card.amber .metric-icon{color:var(--amber);background:var(--amber-soft)}.metric-card.violet .metric-icon{color:var(--violet);background:var(--violet-soft)}.metric-card.red .metric-icon{color:var(--red);background:var(--red-soft)}.metric-card.green .metric-icon{color:#16a34a;background:#dcfce7}.metric-card.highlight{border:1.5px solid #86efac;background:linear-gradient(135deg,#f0fdf4,#fff)}.value-banner{display:flex;align-items:center;gap:10px;padding:11px 14px;background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border:1px solid #86efac;border-radius:12px;font-size:13px;color:#166534;line-height:1.6;grid-column:1 / -1}.value-banner strong{font-weight:700}.progress-track{height:6px;border-radius:999px;background:#e7edf2;overflow:hidden}.progress-track span{height:100%;border-radius:inherit;background:currentColor}.panel{padding:15px}.chart-panel,.table-panel{min-width:0}.rules-panel{display:grid;gap:16px}.panel-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.panel-heading.compact{margin-bottom:0}.panel-heading p{margin-bottom:0;font-size:13px}.soft-tag{padding:7px 9px;border-radius:7px;color:#395066;background:var(--surface-strong);font-size:12px;white-space:nowrap}.chart-wrap{width:100%;min-height:340px;overflow-x:auto}.chart-wrap svg{display:block;width:100%;min-width:0;height:340px}.grid-line{stroke:#e5ebf2;stroke-width:1}.axis-label,.bar-value{fill:#66758a;font-size:13px}.bar-value{fill:#3e4d61;font-weight:650}.usage-bar{fill:#d9e6ee}.usage-bar.active{fill:#40b5aa}.rule-list{display:grid;border-top:1px solid var(--line-soft)}.rule-line{display:flex;justify-content:space-between;gap:14px;padding:12px 0;border-bottom:1px solid var(--line-soft);font-size:14px}.rule-line span{color:var(--muted)}.rule-line strong{text-align:right}.price-control{display:grid;gap:8px;padding-top:4px}.price-control>span{color:var(--muted);font-size:13px}.price-control div{height:42px;display:grid;grid-template-columns:24px 1fr 72px;align-items:center;padding:0 10px;border:1px solid var(--line);border-radius:8px;background:#fff}.price-control input{width:100%;height:34px;border:0;padding:0 4px}.settlement-total{padding:14px;border:1px solid #f0d99f;border-radius:8px;background:#fff8e8}.settlement-total span,.settlement-total strong{display:block}.settlement-total span{color:#7b5a1d;font-size:13px}.settlement-total strong{margin-top:4px;color:#47320b;font-size:26px}.table-panel{min-width:0}.table-scroll{width:100%;overflow-x:auto;border:1px solid var(--line-soft);border-radius:8px}table{width:100%;min-width:760px;border-collapse:collapse;background:#fff}th,td{padding:10px 11px;border-bottom:1px solid var(--line-soft);text-align:left;font-size:13px;vertical-align:middle;white-space:nowrap}.compact-table table{min-width:100%;table-layout:fixed}.compact-table th,.compact-table td{padding:9px 8px;font-size:12px}.compact-table th:nth-child(1),.compact-table td:nth-child(1){width:116px}.compact-table td:nth-child(1){line-height:1.35;white-space:normal}.compact-table th:nth-child(2),.compact-table td:nth-child(2){width:94px}.compact-table th:nth-child(4),.compact-table td:nth-child(4){width:54px}.compact-table td:nth-child(3){line-height:1.35;white-space:normal;word-break:break-word}.compact-table .model-pill{max-width:100%;min-height:24px;padding:0 7px;overflow:hidden;text-overflow:ellipsis}th{color:#39495e;background:#f8fafc;font-weight:700}.table-scroll:not(.compact-table) td:last-child{white-space:normal;min-width:190px}tr:last-child td{border-bottom:0}.model-pill,.type-pill{display:inline-flex;align-items:center;min-height:26px;padding:0 9px;border-radius:7px;font-weight:700}.model-pill{color:#0d6f45;background:#e6f7ed}.model-pill.mini{color:#5d3ec6;background:#efeafe}.type-pill{color:#2365a2;background:#e9f3ff}.negative{color:var(--red);font-weight:700}.positive{color:var(--teal);font-weight:700}.detail-view{display:grid;gap:14px}.detail-actions select{min-width:136px;padding:0 12px}.breakdown-row{display:flex;gap:12px;flex-wrap:wrap}.breakdown-item{min-width:180px;display:grid;gap:4px;padding:12px;border:1px solid var(--line-soft);border-radius:8px;background:var(--surface-strong)}.breakdown-item span{color:var(--muted);font-size:13px}.breakdown-item strong{font-size:18px}.billing-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:14px;max-width:860px}.billing-card{display:grid;gap:12px;align-content:start}.billing-card p{margin-bottom:0;max-width:760px;font-size:13px;line-height:1.6}.billing-card .billing-note{max-width:100%;color:#52627a;font-size:12px}.formula-strip{display:grid;grid-template-columns:140px minmax(0,1fr) 180px;gap:10px;align-items:center;min-height:48px;padding:12px;border:1px solid #cfe9e7;border-radius:8px;background:#f1fbfa}.formula-strip span{color:var(--muted);font-size:13px}.formula-strip strong{color:#0d6f69;font-size:18px}.billing-example{display:grid;grid-template-columns:120px minmax(0,1fr);gap:12px;align-items:center;max-width:480px}.billing-example span,.billing-example label{color:var(--muted);font-size:13px}.billing-example input{width:160px;padding:0 10px}.billing-list{display:grid;gap:7px;margin:0;padding-left:20px;color:#344256;font-size:13px;line-height:1.5}.warning-box{padding:12px;border:1px solid #f0d99f;border-radius:8px;color:#6c4b10;background:#fff8e8;font-size:13px;line-height:1.5}.locked-state{min-height:360px;display:grid;place-items:center;align-content:center;gap:12px;padding:42px;color:#324258;text-align:center}.locked-state svg{color:var(--teal)}.locked-state h2{margin-bottom:0;font-size:22px}.locked-state p{max-width:520px;margin-bottom:0;color:var(--muted);line-height:1.7}@media(max-width:1180px){.app-shell{grid-template-columns:240px minmax(0,1fr)}.metric-grid{grid-template-columns:repeat(2,minmax(190px,1fr))}.dashboard-grid,.billing-layout{grid-template-columns:1fr}}@media(max-width:820px){.home-card{padding:20px}.home-query{grid-template-columns:1fr}.app-shell{display:block}.sidebar{border-right:0;border-bottom:1px solid var(--line)}.side-nav{grid-template-columns:repeat(3,minmax(0,1fr))}.nav-button{justify-content:center;padding:0 8px}.sidebar-footer{margin-top:0}.main-content{padding:18px 14px 28px}.topbar,.panel-heading,.toolbar{align-items:stretch;flex-direction:column}.range-group,.secondary-button{width:100%}.query-button{width:38px}.range-button{min-width:0;flex:1;padding:0 6px}.metric-grid{grid-template-columns:1fr}.compact-table th,.compact-table td{padding:8px 6px;font-size:11px}.compact-table th:nth-child(1),.compact-table td:nth-child(1){width:106px}.compact-table th:nth-child(2),.compact-table td:nth-child(2){width:78px}.compact-table th:nth-child(4),.compact-table td:nth-child(4){width:42px}.formula-strip,.billing-example{grid-template-columns:1fr}.billing-example input{width:100%}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite;display:inline-block}
