:root{--bg: #1a1a1a;--panel: #242424;--panel-2: #2e2e2e;--line: #333;--text: #f5f5f5;--muted: #999;--accent: #ff8a3d;--commit: #4ade80;--bad: #ef4444;--hot: #fb7185;color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font:16px/1.4 system-ui,-apple-system,sans-serif;overscroll-behavior-y:contain;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;height:100%}body{padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);height:100dvh}#app{height:100%}.app{max-width:480px;margin:0 auto;padding:8px 12px 4px;display:flex;flex-direction:column;gap:8px;height:100%}.scoreboard{display:flex;gap:8px;align-items:stretch;flex:0 0 auto}.scoreboard .chip{flex:1;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:8px 10px;position:relative;display:flex;flex-direction:column;justify-content:center;min-width:0}.scoreboard .chip.current{background:var(--panel-2);border-color:var(--accent)}.scoreboard .chip-name{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scoreboard .chip.current .chip-name{color:var(--accent)}.scoreboard .chip-score{font-size:22px;font-weight:700;font-variant-numeric:tabular-nums}.scoreboard .chip-not-in{font-size:10px;color:var(--muted)}.scoreboard .chip-farkles{position:absolute;top:4px;right:8px;color:var(--bad);font-size:16px;letter-spacing:2px}.scoreboard .gear{flex:0 0 36px;background:transparent;border:1px solid var(--line);border-radius:12px;color:var(--muted);font-size:18px;cursor:pointer}.meta{display:flex;align-items:center;justify-content:space-between;gap:8px;flex:0 0 auto;font-size:13px}.meta-left{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.meta-name{font-weight:600}.meta-sep,.meta-dice{color:var(--muted)}.meta-turn{color:var(--accent);font-weight:600}.meta-hot{background:var(--hot);color:#000;font-weight:700;padding:1px 6px;border-radius:4px;font-size:11px;letter-spacing:.05em}.meta-tag-along{color:var(--accent)}.modes{display:flex;gap:4px;flex:0 0 auto}.mode-pill{width:28px;height:28px;border-radius:8px;background:var(--panel);border:1px solid var(--line);color:var(--muted);font-size:12px;font-weight:700;cursor:pointer;padding:0}.mode-pill.active{background:var(--text);color:#000;border-color:var(--text)}.tray{flex:1 1 auto;display:flex;align-items:center;justify-content:center;min-height:0;padding:4px 0}.tray-empty .placeholder{width:100%;text-align:center;color:var(--muted);font-size:14px}.tray-flow{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;width:100%}.tray-grouped{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:14px;width:100%}.dice-group{display:flex;gap:6px;padding:6px;border-radius:12px;flex:0 1 auto}.dice-group.scoring{background:#ff8a3d14;box-shadow:inset 0 0 0 1px #ff8a3d66}.dice-group.scoring.group-0{box-shadow:inset 0 0 0 2px #f97316;background:#f973161a}.dice-group.scoring.group-1{box-shadow:inset 0 0 0 2px #06b6d4;background:#06b6d41a}.dice-group.scoring.group-2{box-shadow:inset 0 0 0 2px #a855f7;background:#a855f71a}.dice-group.scoring.group-3{box-shadow:inset 0 0 0 2px #facc15;background:#facc151a}.dice-group.scoring.group-4{box-shadow:inset 0 0 0 2px #ec4899;background:#ec48991a}.dice-group.scoring.group-5{box-shadow:inset 0 0 0 2px #22c55e;background:#22c55e1a}.dice-group.leftover{opacity:.45}.tray-grouped .die{width:52px}.die{aspect-ratio:1;background:#f5f5f5;border:3px solid transparent;border-radius:12px;padding:0;cursor:pointer;transition:transform .1s,border-color .1s}.die svg{width:100%;height:100%;display:block}.die svg rect{fill:#f5f5f5}.die svg circle{fill:#1a1a1a}.die.selected{border-color:var(--accent);transform:translateY(-4px)}.die.auto{border-color:var(--commit)}.die.hint-0{box-shadow:inset 0 0 0 3px #f97316}.die.hint-1{box-shadow:inset 0 0 0 3px #06b6d4}.die.hint-2{box-shadow:inset 0 0 0 3px #a855f7}.die.hint-3{box-shadow:inset 0 0 0 3px #facc15}.die.hint-4{box-shadow:inset 0 0 0 3px #ec4899}.die.hint-5{box-shadow:inset 0 0 0 3px #22c55e}.die:disabled{opacity:.7}.preview-row{flex:0 0 24px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;font-variant-numeric:tabular-nums;min-height:24px}.preview-row.hidden{display:none}.preview-row.valid .preview-points{color:var(--commit);font-weight:700;font-size:15px}.preview-row .preview-desc{color:var(--muted)}.preview-row .preview-hint{color:var(--muted);font-style:italic}.preview-row.invalid .preview-hint{color:var(--bad);font-style:normal}.actions{display:flex;gap:8px;flex-wrap:wrap;flex:0 0 auto;padding-top:4px}.actions .btn-primary{flex:1;min-height:56px;border-radius:14px;border:none;background:var(--accent);color:#000;font-size:18px;font-weight:700;font-variant-numeric:tabular-nums;cursor:pointer;letter-spacing:.01em}.actions .btn-primary.commit{background:var(--commit)}.actions .btn-primary.press{background:var(--accent)}.actions .btn-primary:disabled{opacity:.45;cursor:not-allowed}.actions .btn-secondary{flex:0 0 auto;min-height:56px;padding:0 16px;border-radius:14px;background:var(--panel);border:1px solid var(--line);color:var(--text);font-size:15px;font-weight:500;cursor:pointer}.actions-note{flex-basis:100%;text-align:center;font-size:11px;color:var(--muted);margin-top:2px}.tertiary{flex-basis:100%;display:flex;justify-content:center;gap:16px}.tertiary-btn{background:transparent;border:none;color:var(--muted);font-size:11px;padding:4px 0;cursor:pointer}.log-peek{flex:0 0 auto;display:flex;align-items:center;gap:6px;padding:6px 0;background:transparent;border:none;color:var(--muted);font-size:11px;text-align:left;cursor:pointer;border-top:1px solid var(--line)}.log-peek .chev{flex:0 0 auto;color:var(--accent)}.log-peek .log-peek-text{flex:1 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-sheet{position:fixed;inset:auto 0 0 0;background:var(--panel);border-top:1px solid var(--line);border-radius:16px 16px 0 0;max-height:70vh;display:flex;flex-direction:column;z-index:15;padding:8px 12px env(safe-area-inset-bottom)}.log-sheet header{display:flex;justify-content:space-between;align-items:center}.log-sheet header h2{margin:0;font-size:16px}.log-sheet header button{background:transparent;border:none;color:var(--text);font-size:24px;width:36px;height:36px}.log-list{overflow-y:auto;display:flex;flex-direction:column;gap:4px;padding:8px 0;font-size:13px;color:var(--text)}.log-line{color:var(--muted)}.game-over{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:24px}.game-over .trophy{font-size:64px}.game-over h1{margin:0;font-size:32px;text-align:center}.game-over .final-board{list-style:none;margin:0;padding:0;width:100%;max-width:320px;display:flex;flex-direction:column;gap:4px}.game-over .final-board li{display:flex;justify-content:space-between;background:var(--panel);padding:10px 14px;border-radius:10px;font-variant-numeric:tabular-nums}.game-over .final-board li:first-child{background:var(--panel-2);border:1px solid var(--commit);font-weight:700}.game-over .btn-primary{width:100%;max-width:320px;min-height:56px;border:none;border-radius:14px;background:var(--commit);color:#000;font-size:18px;font-weight:700;cursor:pointer}.admin-sheet{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);display:flex;flex-direction:column;z-index:10;padding:env(safe-area-inset-top) 12px env(safe-area-inset-bottom)}.admin-sheet header{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.admin-sheet header h2{margin:0}.admin-sheet header button{background:transparent;border:none;color:var(--text);font-size:28px}.admin-body{overflow-y:auto;padding-bottom:60px;display:flex;flex-direction:column;gap:8px}.admin-body h3{margin:16px 0 4px;font-size:14px;color:var(--muted);text-transform:uppercase}.admin-body .field{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 0}.admin-body .field span{flex:1;font-size:14px}.admin-body .field input{flex:0 0 120px;background:var(--panel);border:1px solid var(--line);color:var(--text);padding:6px 8px;border-radius:8px;font-size:14px;text-align:right}.admin-body .field input[type=text]{flex-basis:200px;text-align:left}.admin-body .primary{margin-top:16px;padding:12px;background:var(--accent);border:none;border-radius:12px;font-size:16px;font-weight:700;color:#000}.model-section{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--panel);border:1px solid var(--line);border-radius:12px}.model-status{font-size:14px;display:flex;align-items:center;gap:8px}.model-status .dot{width:8px;height:8px;border-radius:50%;background:var(--muted)}.model-status .dot.on{background:var(--commit)}.hint{font-size:12px;color:var(--muted);margin:0}.instructions{font-size:13px;padding-left:20px;color:var(--text)}.instructions a{color:var(--accent)}details summary{font-size:13px;color:var(--accent);cursor:pointer;padding:4px 0}.model-actions{display:flex;gap:8px;align-items:center}.model-actions .upload{flex:1;background:var(--accent);color:#000;font-weight:600;font-size:14px;padding:10px 12px;border-radius:10px;text-align:center;cursor:pointer}.model-actions .upload input{display:none}.model-actions [data-model-remove]{background:transparent;border:1px solid var(--line);color:var(--text);padding:10px 14px;border-radius:10px;font-size:14px}.model-actions [data-model-remove]:disabled{opacity:.4}.camera-sheet{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:20;display:flex;flex-direction:column;padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom)}.camera-sheet header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;color:#fff;font-size:14px}.camera-sheet header button{background:transparent;border:none;color:#fff;font-size:24px;width:36px;height:36px}.viewfinder{flex:1;display:flex;flex-direction:column}.vf-stage{flex:1;position:relative;overflow:hidden;background:#000}.vf-stage video{width:100%;height:100%;object-fit:cover;display:block}.frame-guide{position:absolute;left:var(--x);top:var(--y);width:var(--w);height:var(--h);border:2px solid var(--accent);border-radius:12px;box-shadow:0 0 0 9999px #00000073;pointer-events:none}.vf-hint{position:absolute;bottom:8px;left:0;right:0;text-align:center;color:#fff;font-size:13px;text-shadow:0 1px 2px rgba(0,0,0,.8);pointer-events:none}.capture-row{padding:24px;display:flex;justify-content:center}.shutter{width:72px;height:72px;border-radius:50%;background:#fff;border:4px solid #fff;box-shadow:0 0 0 3px #000 inset}.review{flex:1;display:flex;flex-direction:column;background:var(--bg);color:var(--text)}.review .hint{padding:8px 16px;text-align:center;font-size:14px}.review .hint.warn{color:var(--bad)}.review .dice-list{flex:1;overflow-y:auto;padding:8px 16px;display:flex;flex-direction:column;gap:8px}.die-row{display:flex;align-items:center;gap:12px;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:8px}.die-row .die-mini{width:56px;height:56px;background:transparent;border:none;padding:0}.die-row .die-mini svg{width:100%;height:100%}.die-row .die-mini svg rect{fill:#f5f5f5}.die-row .die-mini svg circle{fill:#1a1a1a}.die-row .row-num{font-size:12px;color:var(--muted);width:24px;text-align:right}.die-row .value{flex:1;font-size:24px;font-weight:700}.die-row [data-action=remove]{background:transparent;border:none;color:var(--muted);font-size:24px;width:36px;height:36px}.diag{padding:8px 16px}.diag summary{font-size:13px;color:var(--accent);cursor:pointer}.overlay-wrap{position:relative;margin-top:8px;border-radius:8px;overflow:hidden;background:#000}.overlay-wrap img{width:100%;display:block}.overlay-wrap svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.overlay-wrap svg .det{fill:none;stroke:#ff8a3d;stroke-width:4;vector-effect:non-scaling-stroke}.overlay-wrap svg .det-label{fill:#fff;font:700 32px system-ui;paint-order:stroke;stroke:#000;stroke-width:6;stroke-linejoin:round}.review .actions{display:flex;gap:8px;padding:16px}.review .actions button{flex:1;min-height:48px;background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:12px;font-size:16px}.review .actions .primary{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700}.review .actions button:disabled{opacity:.4}.status{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:var(--text);font-size:16px}.status.error .msg{color:var(--bad);padding:0 24px;text-align:center}.status button{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:12px;padding:12px 24px}
