:root{color:#14213d;background:#f5f7fa;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--accent: #ff8a00;--accent-dark: #c45f00;--card: #ffffff;--line: #d8e0ea;--muted: #64748b;--danger: #ef4444;--blue: #3b82f6}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f5f7fa}button,input,select{font:inherit}button{cursor:pointer}.screen-stack{width:min(100%,430px);min-height:100vh;margin:0 auto;padding:11px 12px 20px;display:flex;flex-direction:column;gap:12px}.setup-screen{display:block}.home-screen{justify-content:flex-start;padding-top:18px;gap:12px}.home-hero-panel{width:92%;align-self:center;display:flex;flex-direction:column;align-items:center;padding:12px 8px 14px;border-radius:8px;background:#fff;box-shadow:0 4px 14px #0f172a14}.home-title{color:#111827;font-size:31px;line-height:33px;font-weight:900;letter-spacing:0;text-shadow:0 1px 0 rgba(255,255,255,.9)}.home-title.scoreboard{margin-top:1px}.home-version{margin-top:5px;padding:2px 10px;border:1px solid #e5e7eb;border-radius:999px;background:#fff;color:#64748b;font-size:12px;font-weight:800}.home-logo-img{width:min(238px,88%);height:auto;margin-top:12px;object-fit:contain}.home-menu-list{width:92%;align-self:center;display:flex;flex-direction:column;gap:7px}.home-menu-card{width:100%;height:60px;display:flex;align-items:center;justify-content:space-between;padding:8px 10px 8px 13px;border:0;border-left:4px solid #94a3b8;border-radius:6px;background:#fff;color:#111827;text-align:left;box-shadow:0 4px 14px #0f172a14}.home-menu-card span{min-width:0;display:flex;flex-direction:column}.home-menu-card strong{font-size:16px;line-height:20px;font-weight:900}.home-menu-card small{margin-top:1px;overflow:hidden;color:#64748b;font-size:12px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.home-menu-card b{color:#94a3b8;font-size:24px;line-height:24px}.home-menu-card.continue-card{border-left-color:#22c55e}.home-menu-card.new-card{border-left-color:var(--accent)}.home-menu-card.record-card{border-left-color:#8b5cf6}.setup-topbar,.summary-topbar,.page-topbar,.game-top-actions{display:grid;grid-template-columns:74px 1fr 74px;align-items:center;gap:8px;margin-bottom:10px}.setup-topbar strong,.summary-topbar strong,.page-topbar strong{text-align:center;font-size:15px;font-weight:900}.mode-switch{width:100%;display:flex;gap:6px;margin:0 auto 10px;padding:4px;border-radius:7px;background:#fff;border:1px solid #e8edf3;box-shadow:0 2px 6px #1018280a}.mode-btn{flex:1;height:34px;border:0;border-radius:5px;background-color:#eef1f5;color:#475467;font-size:14px;font-weight:700;white-space:nowrap}.active-mode{background-color:var(--accent);color:#fff}.top-card,.form-card,.notice-card,.player-card,.player-box,.status-card,.inning-card,.record-card{border-radius:8px;background:var(--card);box-shadow:0 8px 24px #14213d14}.top-card,.form-card,.notice-card,.player-card,.status-card,.inning-card{border-left:4px solid var(--accent);padding:14px}.notice-card{margin-bottom:10px;border:1px solid #fed7aa;border-left:4px solid var(--accent);background:#fffaf2}.notice-card strong{color:#9a3412}.notice-card .button-row{margin-top:10px}.notice-card .primary-button,.notice-card .ghost-button{flex:1}.notice-card .ghost-button{background:#fff;border:1px solid #fed7aa;color:#9a3412}.player-card{margin-bottom:9px;padding:12px;border:1px solid #e8edf3;border-left:4px solid var(--accent)}.card-title{margin-bottom:9px;color:#1f2937;font-size:16px;font-weight:800}.field-label{margin-bottom:5px;color:#667085;font-size:12px}.input-row{display:flex;align-items:center;margin-bottom:9px;padding:8px;border:1px solid #edf0f4;border-radius:7px;background:#f8fafc}.input-row input{margin-right:8px;background:#fff}.icon-wrapper{flex:0 0 34px;width:34px;height:34px;border:0;border-radius:50%;background-color:#eef1f5;color:#667085;font-size:20px;font-weight:900}.player-search-modal{display:flex;flex-direction:column;gap:10px}.player-option-list{display:grid;gap:8px;max-height:50vh;overflow-y:auto}.player-option{width:100%;min-height:48px;display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px;margin:0;padding:10px 12px;border:1px solid #e8edf3;border-left:5px solid var(--accent);border-radius:7px;background:#fff;color:#1f2937;text-align:left;box-sizing:border-box}.player-option strong{min-width:0;overflow:hidden;font-size:15px;text-overflow:ellipsis;white-space:nowrap}.player-option span{color:#667085;font-size:12px;font-weight:800;white-space:nowrap}.level-line{display:flex;align-items:center;gap:6px;min-height:23px;margin:4px 0 5px}.level-chip{min-width:27px;height:18px;padding:0 7px;border-radius:999px;border:1px solid #d0d5dd;background:#f2f4f7;color:#344054;font-size:12px;font-weight:800;line-height:18px;text-align:center;white-space:nowrap}.level-chip.beginner{border-color:#bde8ca;background:#e8f7ee;color:#168348}.level-chip.c{border-color:#bfdbff;background:#eaf3ff;color:#1f67b1}.level-chip.b{border-color:#d8c4ff;background:#f1eaff;color:#6f3db8}.level-chip.a{border-color:#ffc8c8;background:#ffecec;color:#c43d35}.sl-range{display:block;width:calc(100% - 32px);height:32px;margin:3px 16px 8px;padding:0}.race-row{width:100%;display:flex;align-items:center;gap:8px;margin:6px auto 0;padding-top:8px;border-top:1px solid #edf0f4}.race-label{flex:1;font-size:14px;color:#344054}.race-input{width:70px;height:33px;text-align:center;font-size:15px}.w-rule-row{display:flex;align-items:center;flex-direction:row;justify-content:flex-start;gap:10px;width:100%;margin:10px 0 0;padding:11px 12px;border-radius:5px;background:#fffaf2;border:1px solid #fed7aa;border-left:4px solid var(--accent);box-shadow:0 4px 12px #0f172a0f}.w-rule-row strong{color:#9a3412}.w-rule-row small{color:#b45309}.w-rule-row span{display:flex;flex-direction:column;gap:2px;min-width:0}.w-rule-row input{flex:0 0 auto;width:24px;height:24px}.start-button{width:100%;height:40px;margin:10px 0 8px;border:0;border-radius:5px;background:var(--accent);color:#fff;font-size:15px;font-weight:800}.top-card h1,.match-header h1,.ball-panel h2,.form-card h2{margin:2px 0 0;letter-spacing:0}.top-card h1,.match-header h1{font-size:22px}.form-card h2,.ball-panel h2{font-size:16px}.eyebrow,.muted,small{color:var(--muted)}.eyebrow,.muted{margin:0}.form-card{display:flex;flex-direction:column;gap:12px}.player-editor{display:flex;flex-direction:column;gap:8px;padding-bottom:12px;border-bottom:1px solid var(--line)}label{display:flex;flex-direction:column;gap:6px;font-weight:700}label span,.switch-row strong{font-size:13px}input,select{width:100%;height:36px;border:1px solid var(--line);border-radius:5px;background:#f8fafc;color:#14213d;padding:0 10px}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.button-row{display:flex;gap:10px;flex-wrap:wrap}.primary-button,.ghost-button,.icon-button{border:0;border-radius:8px;min-height:42px;padding:0 14px;font-weight:800}.primary-button{background:var(--accent);color:#fff}.ghost-button{background:#e8eef6;color:#26364d}.ghost-button.small{min-height:36px;padding:0 12px}.wide{width:100%}.icon-button{width:42px;background:#fff;color:#14213d;font-size:30px;line-height:1}.game-container{width:min(100%,430px);height:100vh;margin:0 auto;padding:11px 12px calc(58px + env(safe-area-inset-bottom));display:flex;flex-direction:column;overflow:hidden;background:#f5f7fa}.game-mode-title{min-height:36px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:#fff7ed;color:#9a3412;font-size:13px;font-weight:900;text-align:center;padding:0 8px;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.primary-button.small,.ghost-button.small{min-height:36px}.w-rule-banner{width:100%;padding:6px 9px;margin-bottom:6px;border-radius:4px;background:#fff7ed;color:#9a3412;font-size:12px;font-weight:800;text-align:center}.players-fixed{display:flex;gap:8px;width:100%;height:144px;min-height:144px;max-height:144px;margin-bottom:7px}.player-box{flex:1;min-width:0;border:1px solid #e8edf3;border-left:4px solid var(--accent);padding:9px 7px 15px;text-align:center;color:#111827}.player-box.active{box-shadow:0 0 0 2px #ff8a002e,0 4px 12px #1018280a}.player-name{min-width:0;display:block;font-size:17px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-stat,.player-status{display:block;min-height:18px;margin-top:4px;color:#344054;font-size:13px}.player-status.break-status{color:var(--danger);font-weight:800}.player-score{display:block;margin-top:4px;color:#000;font-size:42px;line-height:1}.player-hint{display:block;min-height:16px;color:orange;font-size:12px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-card{width:100%;margin-bottom:7px;padding:7px 9px;border:1px solid #e8edf3;border-left:4px solid var(--accent)}.status-message-slot{min-height:22px;margin:0 0 5px}.break-prompt{position:relative;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;min-height:22px;color:#d92d20;font-size:15px;font-weight:800;text-align:center}.break-prompt b{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);white-space:nowrap}.status-hint{min-height:22px;line-height:22px;border-radius:5px;background:#f8fafc;color:#344054;font-size:12px;font-weight:700;text-align:center}.status-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:5px}.status-item{min-height:36px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:5px;background:#f8fafc;border:1px solid #eef2f7}.status-label{color:#667085;font-size:11px}.status-value{margin-top:2px;color:#111827;font-size:16px}.status-item.muted .status-value{color:#667085}.ball-grid{flex:0 0 auto;margin-bottom:7px}.ball-row{display:grid;grid-template-columns:repeat(5,48px);justify-content:center;gap:6px;margin:4px 0}.ball-button{width:48px;height:48px;padding:0;border:0;border-radius:50%;overflow:hidden;background:transparent;box-shadow:0 3px 6px #0f172a14}.ball-button img{width:100%;height:100%;display:block}.ball-button.inactive{opacity:.35}.trend-compare-list{display:grid;gap:8px}.trend-compare-list.compact{max-height:158px;overflow-y:auto;padding-right:2px}.trend-compare-row{display:grid;grid-template-columns:30px 32px minmax(0,1fr) 2px minmax(0,1fr) 32px;align-items:center;gap:6px;min-height:20px;white-space:nowrap}.trend-round,.trend-score{color:#475467;font-size:12px;font-weight:800;line-height:1}.trend-round{color:#1f2937}.trend-score.left{text-align:right}.trend-score.right{text-align:left}.trend-axis{width:2px;height:18px;border-radius:999px;background:#d0d5dd}.trend-side{display:flex;align-items:center;min-width:0;height:10px}.trend-side.left{justify-content:flex-end}.trend-side.right{justify-content:flex-start}.trend-side i,.trend-side b{display:block;min-width:2px;height:7px;border-radius:999px}.trend-side i{background:var(--blue)}.trend-side b{background:var(--accent)}.record-list{display:flex;flex-direction:column;gap:10px}.records-screen{padding-bottom:76px}.record-summary-list{display:flex;flex-direction:column;gap:10px}.record-empty-card{padding:14px;border-radius:8px;border-left:4px solid #4a90e2;background:#fff;box-shadow:0 8px 24px #14213d14}.inning-list{flex:1;min-height:0;overflow-y:auto;padding:5px 6px}.inning-card{border:1px solid #e8edf3;border-left:4px solid var(--accent)}.inning-row{display:grid;grid-template-columns:1fr 38px 1fr;min-height:34px;align-items:center;border-bottom:1px solid #eef2f7}.inning-row.same-inning-next{border-bottom:0}.inning-row.same-inning-next .inning-num.merged{transform:translateY(17px)}.inning-row.same-inning-prev{border-bottom:1px solid #eef2f7}.inning-wrap:last-child .inning-row{border-bottom:0}.inning-side{min-width:0}.inning-num{color:#667085;font-weight:800;text-align:center}.balls-line{display:flex;align-items:center;flex-wrap:wrap;gap:2px;min-height:30px}.record-ball-img{width:21px;height:21px;border-radius:50%}.break-flag,.safety-flag,.timeout-flag,.dead-ball{display:inline-flex;justify-content:center;align-items:center;width:21px;height:21px;border-radius:50%;font-size:14px;font-weight:900;line-height:1}.break-flag{color:#d92d20;border:1px solid #fca5a5;background:#fef2f2}.safety-flag{color:#0891b2;border:1px solid #67e8f9;background:#ecfeff}.timeout-flag{color:#7c3aed;border:1px solid #8b5cf6;background:#f3e8ff}.dead-ball{color:#fff;background:#1f2937}.dead-ball.auto{color:#475467;background:#e5e7eb;border:1px solid #cbd5e1}.bottom-bar{position:fixed;left:50%;bottom:8px;z-index:1001;transform:translate(-50%);width:min(calc(100% - 24px),406px);display:grid;grid-template-columns:repeat(5,1fr);align-items:stretch;gap:6px;padding:8px;border-radius:10px;background:#fffffff5;box-shadow:0 -4px 18px #0f172a1f}.bottom-bar.compact{grid-template-columns:1.4fr 1fr 1fr}.bottom-bar.winner{grid-template-columns:repeat(2,minmax(0,1fr))}.menu-button{height:38px;min-width:0;padding:0 4px;border:0;border-radius:6px;background:#475467;color:#fff;font-size:13px;font-weight:800;line-height:38px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.menu-button:disabled{opacity:.45}.menu-button.is-disabled{opacity:.45}.game-notice{position:fixed;left:50%;bottom:72px;z-index:1100;transform:translate(-50%);width:min(calc(100% - 32px),360px);padding:10px 14px;border:1px solid #fed7aa;border-radius:8px;background:#fff7ed;color:#9a3412;box-shadow:0 10px 28px #0f172a24;font-size:13px;font-weight:800;text-align:center}.next-rack-action{background:#1f67b1}.record-card{width:100%;border:0;border-left:4px solid #4a90e2;padding:12px;text-align:left;display:grid;grid-template-columns:1fr auto;gap:4px 10px}.record-card-row{align-items:center;padding:0;overflow:hidden;background:#fff}.record-open{min-width:0;display:grid;grid-template-columns:1fr auto;gap:4px 10px;padding:12px;border:0;background:transparent;color:#1f2937;text-align:left}.record-open strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.record-open small{grid-column:1 / -1}.record-delete{width:58px;align-self:stretch;border:0;border-left:1px solid #fee2e2;background:#fef2f2;color:#dc2626;font-weight:900}.record-card small{grid-column:1 / -1}.record-summary-card{width:100%;padding:12px;border:1px solid #e8edf3;border-left:4px solid #8b5cf6;border-radius:8px;background:#fff;color:#1f2937;text-align:left;box-shadow:0 8px 24px #14213d14}.record-summary-card.selected{border-color:#ddd6fe;border-left-color:#7c3aed;box-shadow:0 10px 28px #7c3aed29}.record-summary-head{display:grid;grid-template-columns:1fr auto;gap:3px 8px;margin-bottom:8px;align-items:center}.record-summary-head strong{min-width:0;overflow:hidden;color:#111827;font-size:15px;font-weight:900;text-overflow:ellipsis;white-space:nowrap}.record-summary-head span{color:#ef4444;font-size:16px;font-weight:900;white-space:nowrap}.record-summary-head small{grid-column:1 / -1;color:#667085;font-size:11px;font-weight:700}.record-summary-table{overflow:hidden;border-radius:7px}.record-paper-panel{margin-top:8px}.record-paper-toggle{width:100%;height:34px;margin-top:8px;border:1px solid #dbe3ee;border-radius:7px;background:#f8fafc;color:#344054;font-size:13px;font-weight:900}.record-paper-toggle.active{border-color:#99f6e4;background:#ccfbf1;color:#0f766e}.record-menu-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1001;display:flex;align-items:flex-end;justify-content:center;padding:0 12px 10px;pointer-events:none}.record-action-sheet{width:min(calc(100% - 38px),386px);display:flex;flex-direction:column;gap:7px;padding:8px;border:1px solid #dbe3ee;border-radius:10px;background:#fffffff7;box-shadow:0 -6px 24px #0f172a29;pointer-events:auto}.record-action{height:38px;border:0;border-radius:7px;background:#475467;color:#fff;font-size:14px;font-weight:900;line-height:38px;white-space:nowrap}.record-action.danger{background:#ef4444}.record-action.trend-action{background:#1f67b1}.record-action.cancel{background:#667085}.empty-state{text-align:center}.summary-screen{width:min(100%,430px);min-height:100vh;margin:0 auto;padding:14px 12px 20px;background:#f5f7fa}.app-modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;z-index:998;display:flex;align-items:center;justify-content:center;padding:16px 12px 90px;background:#0f172a75;box-sizing:border-box}.end-dialog-mask{align-items:center;padding:8px 10px}.app-modal-card{width:min(100%,390px);max-height:75vh;overflow-y:auto;padding:14px;border-radius:9px;background:#fff;border:1px solid #e8edf3;box-shadow:0 18px 52px #0f172a38;box-sizing:border-box}.end-dialog{display:flex;flex-direction:column;max-height:calc(100vh - 16px);padding:10px}.end-dialog .end-table{max-height:none;overflow:hidden}.end-dialog-card,.summary-card{border-radius:8px;background:#fff;border:1px solid #e8edf3;border-left:8px solid var(--accent);box-shadow:0 8px 24px #14213d14}.end-dialog-card{padding:14px}.end-title{margin-bottom:8px;color:#111827;font-size:17px;font-weight:900;text-align:center}.end-table{overflow:hidden;border:1px solid #edf0f4;border-radius:7px}.end-row{display:grid;grid-template-columns:74px 1fr 1fr;min-height:29px;border-bottom:1px solid #edf0f4}.end-row:last-child{border-bottom:0}.end-cell{display:flex;align-items:center;justify-content:center;min-width:0;padding:4px 5px;color:#344054;font-size:12px;font-weight:700;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.end-row.header .end-cell{color:#111827;font-weight:900}.end-cell.span{grid-column:span 2}.end-cell.winner{color:#16a34a;font-size:15px;font-weight:900}.summary-actions{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:8px;margin-top:12px}.end-buttons.four{flex:0 0 auto;display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:10px}.paper-sheet-toggle{width:100%;min-height:34px;margin-top:8px;border:1px solid #dbe3ee;border-radius:7px;background:#f8fafc;color:#344054;font-size:13px;font-weight:800}.paper-sheet-table{margin-top:6px;overflow:hidden;border:1px solid #edf0f4;border-radius:7px;background:#fff}.paper-sheet-panel{margin-top:6px}.paper-sheet-row{display:grid;grid-template-columns:34px repeat(6,minmax(23px,1fr)) 40px 44px;min-height:28px;border-bottom:1px solid #edf0f4}.paper-sheet-row.names{grid-template-columns:34px 3fr 3fr 40px 44px}.paper-sheet-row:last-child{border-bottom:0}.paper-sheet-row span{min-width:0;display:flex;align-items:center;justify-content:center;border-left:1px solid #f1f5f9;color:#344054;font-size:12px;font-weight:800;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.paper-sheet-row span:first-child{border-left:0}.paper-sheet-row:not(.names) span:nth-child(2),.paper-sheet-row:not(.names) span:nth-child(5),.paper-sheet-row:not(.names) span:nth-child(8){border-left-color:#dbe3ee}.paper-sheet-row.names span+span{border-left-color:#dbe3ee}.paper-sheet-row.head span{color:#111827;background:#f8fafc;font-size:10px}.paper-sheet-row.sub span{color:#667085;border-left-color:#f6f8fb;font-size:9px}.paper-sheet-row.sub span:nth-child(2),.paper-sheet-row.sub span:nth-child(5),.paper-sheet-row.sub span:nth-child(8){border-left-color:#e5ebf2}.paper-sheet-row.total{border-top:1px solid #cbd5e1}.paper-sheet-row.total span{background:#f8fafc;color:#111827;font-weight:900}.paper-score-cell{position:relative;color:#111827;font-weight:900}.paper-score-cell.rack-closer:after{content:"";position:absolute;left:50%;top:50%;width:24px;height:24px;border:2px solid #ff8a00;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none}.paper-sheet-row.total .paper-score-cell.total-winner{color:#ff8a00;font-weight:950}.paper-sheet-row .player-head{padding:0 3px}.paper-sheet-row .muted{color:#667085}.trend-only-card{margin-top:0;border-left-color:#1f67b1}.trend-match-head{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:7px;margin-bottom:12px;color:#111827}.trend-match-head strong{min-width:0;overflow:hidden;font-size:15px;text-overflow:ellipsis;white-space:nowrap}.trend-match-head span{color:#ef4444;font-size:16px;font-weight:900}.trend-match-head .winner{color:#16a34a}.record-detail-card{margin-top:12px}.end-btn{min-height:38px;border:0;border-radius:6px;background:#475467;color:#fff;font-weight:800;white-space:nowrap}.end-btn.primary{background:var(--accent)}.summary-card{margin-top:12px;padding:14px}.summary-card h2{margin:0 0 10px;font-size:16px;white-space:nowrap}.end-trend-preview{margin-bottom:10px;padding:10px;border:1px solid #edf0f4;border-radius:7px;background:#f8fafc}.end-trend-title{margin-bottom:8px;color:#344054;font-size:13px;font-weight:900;text-align:center;white-space:nowrap}.confirm-modal-mask{z-index:1002}.confirm-copy{margin:0 0 12px;color:#475467;font-size:13px;font-weight:700;line-height:1.5}.timeout-modal-card{max-height:none}.timeout-count{margin:8px 0 14px;color:#111827;font-size:42px;font-weight:900;line-height:1;text-align:center}.confirm-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
