:root{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,PingFang SC,Microsoft YaHei,sans-serif;color:#11233e;background:#edf2f7;font-synthesis:none;text-rendering:optimizeLegibility;--navy: #031f3d;--blue: #0969e8;--red: #eb252b;--green: #1fad5b;--text: #11233e;--muted: #6d7b92;--line: #e3e9f1;--soft: #f6f8fb}*{box-sizing:border-box}html{min-width:320px;background:#edf2f7}body{margin:0;min-width:320px;min-height:100vh;background:#edf2f7}button,input,select,textarea{font:inherit}button{cursor:pointer}.prototype-stage{min-height:100vh}.mobile-app{position:relative;width:min(100%,430px);min-height:100vh;margin:0 auto;background:#fff;box-shadow:0 0 42px #11233e17;overflow-x:hidden}.app-header{position:sticky;z-index:30;top:0;height:54px;display:grid;grid-template-columns:48px 1fr 64px;align-items:center;color:#fff;background:var(--navy)}.app-header h1{margin:0;overflow:hidden;text-align:center;white-space:nowrap;font-size:17px;line-height:1;font-weight:700;letter-spacing:.01em}.icon-button,.sync-button{height:44px;border:0;color:inherit;background:transparent;display:flex;align-items:center;justify-content:center}.icon-button svg{width:25px;height:25px}.sync-button{gap:4px;justify-content:flex-start;font-size:13px}.sync-button svg{width:18px;height:18px}.sync-button:disabled{opacity:.72;cursor:wait}.spinning{animation:spin .9s linear infinite}.app-content{min-height:calc(100vh - 54px);padding-bottom:76px}.screen{min-height:calc(100vh - 130px)}.status-band{padding:10px 18px 8px;border-bottom:6px solid #f3f6f9}.status-band>div{display:inline-flex;align-items:baseline;gap:4px;font-size:14px}.status-band strong{color:var(--blue);font-size:18px}.status-band .synced{float:right;display:flex;align-items:center;gap:7px;color:var(--green);font-size:13px}.status-dot,.status-band .synced i{width:9px;height:9px;border-radius:50%;background:var(--green);box-shadow:0 0 0 4px #1fad5b1a}.status-band .synced.loading i,.status-dot.loading{background:#ef9b17;box-shadow:0 0 0 4px #ef9b171f}.status-band .synced.error i,.status-dot.error{background:#e55259;box-shadow:0 0 0 4px #e552591f}.status-band p{margin:5px 0 0;color:var(--muted);font-size:12px;line-height:1.35}.result-hero{padding:12px 18px 10px;border-bottom:6px solid #f3f6f9}.result-hero header,.content-section>header,.quick-section>h2,.overview-section>h2{display:flex;align-items:center}.result-hero h2,.quick-section h2,.overview-section h2{margin:0;display:flex;align-items:center;gap:7px;font-size:16px;line-height:1}.result-hero h2 svg,.quick-section h2 svg,.overview-section h2 svg{width:18px;height:18px;color:#123b68}.result-hero header button{margin-left:auto;min-height:32px;padding:0;border:0;display:flex;align-items:center;gap:5px;color:var(--blue);background:transparent;font-size:13px}.ball-row{width:100%;margin-top:9px;display:flex;align-items:center;gap:8px}.red-balls{min-width:0;flex:1;display:flex;justify-content:space-between;gap:5px}.lottery-ball{flex:0 0 auto;width:42px;height:42px;border:1.7px solid currentColor;border-radius:50%;display:grid;place-items:center;background:#fff;font-size:16px;font-weight:700;font-variant-numeric:tabular-nums}.lottery-ball.red{color:var(--red)}.lottery-ball.blue{color:var(--blue)}.ball-row>i{width:1px;height:32px;background:#cfd7e2}.ball-labels{margin:6px 0 10px;display:grid;grid-template-columns:1fr 50px;color:var(--red);text-align:center;font-size:12px}.ball-labels span:last-child{color:var(--blue);white-space:nowrap}.overview-cost{margin:0 0 10px;padding:8px 10px;border-radius:7px;background:#f5f8fc;display:flex;justify-content:space-between;gap:8px;color:var(--muted);font-size:10px}.overview-cost span:last-child{text-align:right}.overview-cost strong{display:block;margin-top:2px;color:var(--text);font-size:12px}.primary-button{min-height:44px;border:0;border-radius:8px;color:#fff;background:linear-gradient(90deg,#0872f4,#075edb);display:flex;align-items:center;justify-content:center;gap:8px;font-size:16px;font-weight:700;box-shadow:0 5px 12px #0969e82e}.result-hero .primary-button{width:100%}.result-hero>p{margin:7px 0 0;color:var(--muted);text-align:center;font-size:12px}.overview-section,.quick-section{padding:10px 18px;border-bottom:6px solid #f3f6f9}.metric-grid{margin-top:10px;display:grid;grid-template-columns:1fr 1fr;gap:8px}.metric{min-height:68px;padding:7px 13px;border:1px solid var(--line);border-radius:9px;display:flex;align-items:flex-start;gap:10px}.metric-icon{flex:0 0 auto;width:34px;height:34px;border-radius:50%;display:grid;place-items:center}.metric-icon svg{width:20px;height:20px}.metric-icon.red{color:var(--red);background:#fff0f1}.metric-icon.blue{color:var(--blue);background:#edf4ff}.metric-icon.amber{color:#ed8c00;background:#fff5e4}.metric-icon.violet{color:#6d46e8;background:#f3efff}.metric small{display:block;color:#516078;font-size:11px;line-height:1.3}.metric strong{display:block;margin-top:4px;font-size:23px;line-height:1}.metric strong.red{color:var(--red)}.metric strong.blue{color:var(--blue)}.metric p{margin:6px 0 0;color:var(--muted);font-size:11px}.quick-list{margin-top:10px;border:1px solid var(--line);border-radius:10px;overflow:hidden}.quick-list button{width:100%;min-height:44px;padding:3px 11px;border:0;border-bottom:1px solid var(--line);background:#fff;display:grid;grid-template-columns:34px 1fr 24px;align-items:center;gap:9px;text-align:left}.quick-list button:last-child{border-bottom:0}.quick-list button>span:nth-child(2){min-width:0}.quick-list strong,.quick-list small{display:block}.quick-list strong{color:var(--text);font-size:13px}.quick-list small{margin-top:2px;overflow:hidden;color:var(--muted);font-size:10px;white-space:nowrap;text-overflow:ellipsis}.quick-list button>svg{width:18px;height:18px;color:#9aa7b8}.quick-icon{width:32px;height:32px;border-radius:8px;display:grid;place-items:center}.quick-icon svg{width:20px;height:20px}.quick-icon.red{color:var(--red);background:#fff0f1}.quick-icon.blue{color:var(--blue);background:#edf4ff}.quick-icon.green{color:var(--green);background:#ecf9f1}.bottom-nav{position:fixed;z-index:25;bottom:0;left:50%;width:min(100%,430px);height:72px;transform:translate(-50%);display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);background:#fffffffa;box-shadow:0 -4px 18px #17304f0d;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav button{border:0;color:#65738a;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:12px}.bottom-nav svg{width:24px;height:24px}.bottom-nav button.active{color:var(--blue);font-weight:600}.sub-screen{padding:18px 14px 22px;background:#f5f7fa}.screen-heading{margin:0 3px 14px;display:flex;align-items:center}.screen-heading h2{margin:0;font-size:22px}.screen-heading p{margin:3px 0 0;color:var(--muted);font-size:12px}.screen-heading>span{margin-left:auto;color:var(--muted);font-size:11px}.screen-heading>svg{margin-left:auto;width:28px;height:28px;color:var(--blue)}.screen-heading>button{margin-left:auto;min-height:40px;padding:0 3px;border:0;display:flex;align-items:center;gap:5px;color:var(--blue);background:transparent;font-size:13px}.content-section{margin-bottom:12px;padding:15px;border:1px solid var(--line);border-radius:10px;background:#fff}.content-section>header{margin-bottom:13px}.content-section h3{margin:0;display:flex;align-items:center;gap:6px;font-size:15px}.content-section h3 svg{width:18px;height:18px}.content-section>header>small{margin-left:auto;color:var(--muted);font-size:10px}.mobile-number-grid{display:grid;gap:7px}.mobile-number-grid.red{grid-template-columns:repeat(6,1fr)}.mobile-number-grid.blue{grid-template-columns:repeat(4,1fr)}.mobile-number-grid button{min-width:0;min-height:43px;padding:4px 2px;border:1px solid transparent;border-radius:6px;background:var(--soft)}.mobile-number-grid b,.mobile-number-grid small{display:block}.mobile-number-grid b{font-size:12px}.mobile-number-grid small{margin-top:2px;color:inherit;opacity:.72;font-size:8px;white-space:nowrap}.mobile-number-grid.red button.hot{color:#fff;background:var(--red)}.mobile-number-grid.red button.warm{color:#d9282e;background:#ffeded}.mobile-number-grid.red button.cold{color:#176fdc;border-color:#a6caf8;background:#eef5ff}.mobile-number-grid.blue button.hot{color:#fff;background:var(--blue)}.mobile-number-grid.blue button.warm{color:#176fdc;background:#eef5ff}.mobile-number-grid.blue button.cold{color:#526078;border-color:#d9e1eb;background:#f5f7fa}.heatmap-legend{margin-top:12px;display:flex;justify-content:flex-end;gap:14px;color:var(--muted);font-size:10px}.heatmap-legend span{display:flex;align-items:center;gap:4px}.heatmap-legend i{width:9px;height:9px;border-radius:2px}.heatmap-legend i.hot{background:var(--red)}.heatmap-legend i.warm{background:#ffb5b7}.heatmap-legend i.cold{background:#8ab8f3}.rank-columns{display:grid;grid-template-columns:1fr 1fr;gap:17px}.rank-columns>div:first-child{padding-right:14px;border-right:1px solid var(--line)}.rank-columns h4{margin:0 0 8px;color:var(--muted);font-size:11px}.rank-columns p{margin:0;min-height:34px;display:grid;grid-template-columns:18px 28px 1fr;align-items:center;gap:5px}.rank-columns em{color:#9aa7b8;font-size:10px;font-style:normal}.rank-columns span{color:var(--muted);text-align:right;font-size:10px}.mini-number{width:25px;height:25px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:9px}.mini-number.red{background:var(--red)}.mini-number.blue{background:var(--blue)}.zone-row{min-height:45px;display:grid;grid-template-columns:83px 1fr 28px;align-items:center;gap:8px;border-bottom:1px solid #edf1f5}.zone-row:last-child{border-bottom:0}.zone-row span b,.zone-row span small{display:block}.zone-row span b{font-size:12px}.zone-row span small{margin-top:2px;color:var(--muted);font-size:9px}.zone-row>div{height:7px;border-radius:5px;background:#edf1f5;overflow:hidden}.zone-row i{display:block;height:100%;border-radius:inherit;background:var(--blue)}.zone-row>strong{text-align:right;font-size:12px}.mode-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:7px}.mode-grid button{min-height:67px;padding:5px 8px;border:1px solid #dce4ef;border-radius:7px;color:#4f5f76;background:#fff}.mode-grid strong,.mode-grid small,.mode-grid em{display:block}.mode-grid strong{font-size:13px}.mode-grid small{margin-top:4px;font-size:9px}.mode-grid em{margin-top:3px;overflow:hidden;font-size:9px;font-style:normal;opacity:.76;white-space:nowrap;text-overflow:ellipsis}.mode-grid button.active{border-color:var(--blue);color:#fff;background:var(--blue);box-shadow:0 5px 12px #0969e829}.form-row,.text-row,.range-row{min-height:48px;display:flex;align-items:center;border-bottom:1px solid #edf1f5;color:#4e5e74;font-size:13px}.form-section>label:last-child{border-bottom:0}.form-row>div{margin-left:auto;display:grid;grid-template-columns:35px 52px 35px}.form-row button,.form-row input{height:34px;border:1px solid #dce4ee;background:#fff;text-align:center}.form-row button:first-child{border-radius:6px 0 0 6px}.form-row button:last-child{border-radius:0 6px 6px 0}.form-row input{min-width:0;border-left:0;border-right:0;outline:none}.range-row{min-height:63px;display:block;padding:10px 0}.range-row span{display:flex;justify-content:space-between}.range-row b{color:var(--blue)}.range-row input{width:100%;margin:10px 0 0;accent-color:var(--blue)}.text-row{gap:12px}.text-row span{width:70px}.text-row input{min-width:0;flex:1;height:36px;padding:0 10px;border:1px solid #dce4ee;border-radius:6px;outline:none}.text-row input:focus{border-color:var(--blue);box-shadow:0 0 0 3px #0969e817}.filter-actions{display:grid;grid-template-columns:1fr 1.5fr;gap:9px}.filter-actions button{min-height:50px}.secondary-button{border:1px solid #ccd7e5;border-radius:8px;color:#4f6077;background:#fff;display:flex;align-items:center;justify-content:center;gap:7px}.purchase-card{position:relative;margin:0 0 12px;padding:14px;border:1px solid #b7d2f5;border-radius:10px;background:#f5f9ff;display:flex;align-items:flex-start;gap:11px}.purchase-icon{flex:0 0 auto;width:36px;height:36px;border-radius:9px;color:var(--blue);background:#e2efff;display:grid;place-items:center}.purchase-icon svg{width:21px;height:21px}.purchase-card div{min-width:0}.purchase-card small{color:#52657d;font-size:11px}.purchase-card strong{display:block;margin-top:3px;color:var(--blue);font-size:18px;font-variant-numeric:tabular-nums}.purchase-card p{margin:4px 0 0;color:var(--muted);font-size:9px}.purchase-card>em{position:absolute;right:10px;top:10px;padding:3px 5px;border-radius:4px;color:#a86600;background:#fff0ce;font-size:8px;font-style:normal}.purchase-card.warning{padding-top:24px;border-color:#eccb86;background:#fffaf0}.purchase-card.warning .purchase-icon{color:#bd7700;background:#ffedc9}.purchase-card.warning strong{color:#a86600}.final-result{padding:18px 13px;text-align:center}.final-result .ball-row{margin-top:0}.final-result>p{margin:13px 0 7px;color:var(--muted);font-size:12px}.final-result .score{color:var(--blue);font-size:13px}.purchase-summary{margin-top:14px;padding-top:12px;border-top:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;gap:8px;text-align:left}.purchase-summary>div{padding:9px 10px;border-radius:7px;background:#f5f8fc}.purchase-summary small{display:block;color:var(--muted);font-size:9px}.purchase-summary strong{display:block;margin-top:3px;color:var(--text);font-size:12px;font-variant-numeric:tabular-nums}.purchase-summary>div:last-child strong{color:var(--blue)}.reason-section>p{margin:0;min-height:37px;display:flex;align-items:center;gap:8px;color:#4e5d72;border-bottom:1px solid #edf1f5;font-size:12px}.reason-section>p:last-child{border-bottom:0}.reason-section>p svg{color:var(--green)}.candidate-section h4{margin:11px 0 7px;color:var(--muted);font-size:11px}.candidate-section>div{display:flex;flex-wrap:wrap;gap:7px}.candidate{min-width:52px;padding:7px 8px;border:1px solid;border-radius:6px;text-align:center}.candidate b,.candidate small{display:block}.candidate b{font-size:13px}.candidate small{margin-top:3px;opacity:.65;font-size:9px}.candidate.red{color:var(--red);border-color:#f2b4b6;background:#fff8f8}.candidate.blue{color:var(--blue);border-color:#aecdf5;background:#f5f9ff}.candidate-section .cost-warning{margin:12px 0 0;padding:8px 9px;border-radius:6px;color:#966000;background:#fff4da;font-size:10px;line-height:1.5}.ai-note p{margin:0;color:#57667b;font-size:12px;line-height:1.7}.ai-note h3 svg{color:#8b5fd1}.ai-note header button{margin-left:auto;min-height:34px;padding:0 10px;border:1px solid #cbb9ed;border-radius:6px;color:#7950bd;background:#faf7ff;font-size:11px}.ai-note header button:disabled{opacity:.65;cursor:wait}.ai-note .ai-error{color:#bd343a}.result-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px}.result-actions button{min-height:47px;border:1px solid #a9c8ee;border-radius:8px;color:var(--blue);background:#fff;display:flex;align-items:center;justify-content:center;gap:7px;font-weight:600}.meta-line{color:var(--muted);text-align:center;font-size:10px}.inline-error{width:100%;padding:12px;border-radius:7px;color:#b9252b;background:#fff0f1;text-align:center;font-size:12px}.drawer-backdrop{position:fixed;z-index:80;top:0;right:0;bottom:0;left:0;background:#01102180}.app-drawer{width:min(82vw,320px);height:100%;padding:20px 14px;color:#fff;background:var(--navy);box-shadow:18px 0 45px #0000003d;animation:slide-in .2s ease-out}.app-drawer header{height:49px;padding:0 9px 14px;display:flex;align-items:center;border-bottom:1px solid rgba(255,255,255,.12)}.app-drawer header strong{font-size:17px}.app-drawer header button{margin-left:auto;border:0;color:#fff;background:transparent}.app-drawer header svg{width:22px;height:22px}.drawer-status{margin:15px 8px;padding:13px;border:1px solid rgba(255,255,255,.13);border-radius:8px;display:flex;align-items:center;gap:8px;font-size:13px}.drawer-status small{margin-left:auto;color:#aebdd0;font-size:10px}.app-drawer>button{width:100%;min-height:48px;padding:0 12px;border:0;border-radius:7px;color:#dbe6f3;background:transparent;display:flex;align-items:center;gap:11px;text-align:left}.app-drawer>button svg{width:21px;height:21px}.app-drawer>button.active{color:#fff;background:#0969e8}.app-drawer>p{margin:20px 10px;color:#8fa3ba;font-size:11px;line-height:1.6}.modal-backdrop{position:fixed;z-index:100;top:0;right:0;bottom:0;left:0;padding:18px;background:#0110218f;display:grid;place-items:center}.modal{width:min(100%,390px);max-height:90vh;overflow:auto;border-radius:12px;background:#fff;box-shadow:0 25px 65px #0000004d}.modal header{min-height:54px;padding:0 16px;display:flex;align-items:center;border-bottom:1px solid var(--line)}.modal header div{display:flex;align-items:center;gap:8px}.modal header h2{margin:0;font-size:17px}.modal header svg{color:var(--blue)}.modal header button{margin-left:auto;min-width:44px;min-height:44px;border:0;background:transparent}.modal>p{margin:14px 16px 8px;color:var(--muted);font-size:12px;line-height:1.6}.modal textarea{width:calc(100% - 32px);height:210px;margin:0 16px;padding:11px;border:1px solid #d8e1ec;border-radius:7px;resize:vertical;font-family:ui-monospace,monospace;font-size:11px;line-height:1.6}.modal footer{padding:13px 16px 16px;display:flex;justify-content:flex-end;gap:8px}.modal footer button{min-height:42px;padding:0 17px;border:1px solid #d3dce7;border-radius:7px;background:#fff}.modal footer .primary{border-color:var(--blue);color:#fff;background:var(--blue)}.import-errors{margin:8px 16px 0;padding:8px 10px;border-radius:6px;color:#be3137;background:#fff0f1}.import-errors p{margin:3px 0;font-size:10px}.toast{position:fixed;z-index:120;left:50%;bottom:84px;min-height:43px;padding:0 16px;transform:translate(-50%);border-radius:8px;color:#fff;background:#102d4a;box-shadow:0 10px 28px #00000040;display:flex;align-items:center;gap:7px;white-space:nowrap;font-size:12px}.toast svg{color:#50d389}@keyframes slide-in{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:370px){.lottery-ball{width:38px;height:38px;font-size:14px}.ball-row{gap:5px}.red-balls{gap:3px}.status-band,.result-hero,.overview-section,.quick-section{padding-inline:14px}}@media(min-width:700px){.prototype-stage{padding:24px 0}.mobile-app{min-height:calc(100vh - 48px);border-radius:18px}.app-header{border-radius:18px 18px 0 0}.bottom-nav{bottom:24px;border-radius:0 0 18px 18px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;animation:none!important;transition:none!important}}
