*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--canvas-bg:#0a0a14;--surface-0:#0d0d1e;--surface-1:#13132d;--surface-2:#1c1c3e;--surface-3:#25254e;--gold:#d4a836;--gold-light:#f0c84a;--gold-dim:#7a6010;--crimson:#c0392b;--teal:#16a085;--jade:#27ae60;--lavender:#9b59b6;--text-primary:#f0e8d8;--text-secondary:#c0a888;--text-muted:#7a6b5a;--text-inverse:#0a0a14;--status-active:#2ecc71;--status-paused:#f39c12;--status-draft:#7f8c8d;--status-complete:#3498db;--radius-sm:8px;--radius-md:14px;--radius-lg:22px;--radius-xl:32px;--radius-full:9999px;--shadow-sm:0 2px 8px #00000073;--shadow-md:0 4px 18px #0000008c;--shadow-lg:0 8px 36px #000000a6;--glow-gold:0 0 24px #d4a83647;--glow-active:0 0 20px #2ecc7140}html,body{background:var(--canvas-bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.5;overflow-x:hidden}html{scroll-behavior:smooth}body{min-height:100dvh}#root{background:var(--canvas-bg);flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}h1,h2,h3,h4,p{margin:0}button,input,select,textarea{font:inherit}img{max-width:100%;display:block}input[type=file]{display:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:4px}.screen{background:var(--canvas-bg);flex-direction:column;min-height:100dvh;display:flex;overflow-x:hidden}.screen-header{background:var(--surface-0);z-index:20;border-bottom:1px solid #d4a8361f;align-items:center;gap:12px;padding:16px;display:flex;position:sticky;top:0}.screen-header h2{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:1.1rem;font-weight:700;overflow:hidden}.btn-back{color:var(--gold);border-radius:var(--radius-sm);background:0 0;justify-content:center;align-items:center;min-width:40px;min-height:40px;padding:6px 10px;font-size:1.3rem;line-height:1;transition:background .15s;display:flex}.btn-back:hover{background:#d4a8361a}.btn-primary{background:linear-gradient(135deg, var(--gold), #c47a1a);color:#0a0a14;border-radius:var(--radius-md);border:none;padding:12px 20px;font-size:.95rem;font-weight:700;transition:opacity .15s,transform .1s}.btn-primary:active{opacity:.9;transform:scale(.97)}.btn-primary:disabled{opacity:.4;pointer-events:none}.btn-primary.btn-sm{padding:8px 14px;font-size:.85rem}.btn-primary.btn-full{text-align:center;width:100%;padding:15px;font-size:1rem}.btn-ghost{color:var(--text-secondary);border-radius:var(--radius-md);background:#ffffff12;border:1px solid #ffffff1a;padding:10px 16px;font-size:.88rem;transition:background .15s}.btn-ghost:hover{background:#ffffff21}.btn-ghost.btn-sm{padding:7px 12px;font-size:.82rem}.btn-action{border-radius:var(--radius-sm);border:none;padding:8px 14px;font-size:.82rem;font-weight:600;transition:opacity .15s}.btn-action:active{opacity:.75}.btn-activate{background:var(--jade);color:#fff}.btn-pause{background:var(--status-paused);color:#0a0a14}.btn-danger{background:var(--crimson);color:#fff}.btn-ghost.btn-action{color:var(--text-secondary);background:#ffffff14}.form-group{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.form-label{text-transform:uppercase;letter-spacing:.1em;color:var(--gold);font-size:.8rem;font-weight:600}.form-hint{color:var(--text-muted);margin:0;font-size:.8rem}.form-input{background:var(--surface-2);border-radius:var(--radius-md);color:var(--text-primary);border:1px solid #d4a83633;outline:none;width:100%;padding:12px 16px;font-size:1rem;transition:border-color .15s}.form-input:focus{border-color:var(--gold)}.error-msg{color:#ff6b6b;border-radius:var(--radius-sm);background:#c0392b1f;margin:0;padding:10px 14px;font-size:.88rem}.toggle-btn{border-radius:var(--radius-full);color:var(--text-muted);background:#ffffff12;border:1px solid #ffffff1a;padding:7px 14px;font-size:.82rem;font-weight:600;transition:all .15s}.toggle-btn.active{color:var(--gold-light);border-color:var(--gold-dim);background:#d4a83633}.gallery-screen{background:radial-gradient(ellipse at top, #13132d 0%, var(--canvas-bg) 60%)}.gallery-header{border-bottom:1px solid #d4a8361a;justify-content:space-between;align-items:center;padding:20px 20px 16px;display:flex}.gallery-brand{align-items:center;gap:12px;display:flex}.brand-icon{filter:drop-shadow(0 0 12px #d4a83680);font-size:2rem}.brand-title{letter-spacing:-.03em;color:var(--gold);font-size:1.6rem;font-style:italic;font-weight:800;line-height:1}.brand-sub{color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin:0;font-size:.72rem}.btn-add{border-radius:var(--radius-full);background:linear-gradient(135deg, var(--gold), #a37010);color:#0a0a14;width:46px;height:46px;box-shadow:var(--glow-gold);justify-content:center;align-items:center;font-size:1.6rem;font-weight:300;transition:transform .15s,box-shadow .15s;display:flex}.btn-add:active{transform:scale(.93)}.gallery-body{flex:1;padding:0 0 80px;overflow-y:auto}.gallery-section-label{text-transform:uppercase;letter-spacing:.14em;color:var(--text-muted);padding:20px 20px 10px;font-size:.72rem;font-weight:700}.gallery-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;min-height:60vh;padding:32px;display:flex}.gallery-empty-art{filter:drop-shadow(0 0 20px #d4a8364d);margin-bottom:8px;font-size:4rem}.gallery-empty h2{color:var(--text-primary);font-size:1.4rem;font-weight:700}.gallery-empty p{color:var(--text-muted);font-size:.9rem}.commission-list{flex-direction:column;gap:12px;margin:0;padding:0 12px;list-style:none;display:flex}.commission-card{background:var(--surface-1);border-radius:var(--radius-lg);border:1px solid #ffffff0f;gap:12px;transition:border-color .2s;display:flex;overflow:hidden}.commission-card.status-active{box-shadow:var(--glow-active);border-color:#2ecc7140}.commission-thumb{background:var(--surface-2);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:96px;min-height:96px;padding:0;display:flex;position:relative}.thumb-img{object-fit:cover;width:100%;height:100%}.thumb-placeholder{opacity:.4;font-size:2.2rem}.status-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:var(--radius-full);background:#000000b3;padding:3px 7px;font-size:.65rem;font-weight:700;position:absolute;top:6px;right:6px}.status-badge--active{color:var(--status-active)}.status-badge--paused{color:var(--status-paused)}.status-badge--draft{color:var(--status-draft)}.status-badge--complete{color:var(--status-complete)}.commission-info{flex-direction:column;flex:1;gap:6px;min-width:0;padding:12px 12px 12px 0;display:flex}.commission-title-btn{color:var(--text-primary);text-align:left;white-space:nowrap;text-overflow:ellipsis;background:0 0;padding:0;font-size:1rem;font-weight:700;overflow:hidden}.commission-meta{color:var(--text-muted);flex-wrap:wrap;gap:10px;font-size:.75rem;display:flex}.commission-progress{align-items:center;gap:8px;display:flex}.progress-bar{background:var(--surface-3);border-radius:var(--radius-full);flex:1;height:4px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--jade), var(--teal));border-radius:var(--radius-full);height:100%;transition:width .4s}.progress-pct{color:var(--jade);text-align:right;min-width:30px;font-size:.75rem;font-weight:700}.commission-time{color:var(--text-muted);font-size:.75rem}.commission-actions{flex-wrap:wrap;gap:6px;margin-top:2px;display:flex}.gallery-footer{text-align:center;width:100%;max-width:480px;color:var(--text-muted);background:linear-gradient(to top, var(--canvas-bg) 60%, transparent);pointer-events:none;padding:12px;font-size:.72rem;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.setup-body{flex-direction:column;flex:1;padding:24px 20px;display:flex}.setup-art{text-align:center;filter:drop-shadow(0 0 16px #d4a8364d);margin-bottom:12px;font-size:3.5rem}.setup-body h3{color:var(--text-primary);text-align:center;margin-bottom:24px;font-size:1.2rem;font-weight:700}.color-count-row{flex-wrap:wrap;gap:8px;margin-bottom:10px;display:flex}.color-count-btn{border-radius:var(--radius-md);background:var(--surface-2);min-width:44px;color:var(--text-secondary);border:1px solid #ffffff14;flex:1;padding:10px;font-size:1rem;font-weight:700;transition:all .15s}.color-count-btn.active{color:var(--gold-light);border-color:var(--gold-dim);background:#d4a83633}.scanning-body{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:32px 24px;display:flex}.scanning-spinner{border:4px solid var(--surface-3);border-top-color:var(--gold);border-radius:var(--radius-full);width:60px;height:60px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.scanning-status{color:var(--text-primary);max-width:280px;font-size:1rem;font-weight:500}.scanning-bar{background:var(--surface-3);border-radius:var(--radius-full);width:100%;max-width:300px;height:6px;overflow:hidden}.scanning-fill{background:linear-gradient(90deg, var(--gold-dim), var(--gold-light));border-radius:var(--radius-full);height:100%;transition:width .3s}.scanning-pct{color:var(--gold);margin:0;font-size:1.2rem;font-weight:800}.scanning-hint{color:var(--text-muted);margin:0;font-size:.82rem}.capture-body{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex}.auto-prompt{background:var(--surface-1);border-radius:var(--radius-lg);text-align:center;border:1px solid #f39c124d;flex-direction:column;align-items:center;gap:12px;padding:20px;display:flex}.auto-prompt-icon{font-size:2rem}.auto-prompt-msg{color:var(--text-primary);margin:0;font-size:.92rem;line-height:1.5}.auto-prompt-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.zone-guide{background:var(--surface-1);border-radius:var(--radius-lg);flex-direction:column;align-items:center;gap:12px;padding:16px;display:flex}.zone-grid{gap:6px;width:100%;max-width:240px;display:grid}.zone-cell{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-muted);border:1px solid #ffffff1a;justify-content:center;align-items:center;font-size:.82rem;font-weight:700;transition:all .2s;display:flex}.zone-cell.zone-done{color:var(--jade);background:#2ecc7126;border-color:#2ecc7166}.zone-cell.zone-next{border-color:var(--gold-dim);color:var(--gold-light);background:#d4a83626;animation:1.5s ease-in-out infinite pulse-border}@keyframes pulse-border{0%,to{border-color:var(--gold-dim)}50%{border-color:var(--gold);box-shadow:0 0 10px #d4a83666}}.zone-instruction{color:var(--text-secondary);text-align:center;margin:0;font-size:.88rem}.capture-actions{grid-template-columns:1fr 1fr;gap:12px;display:grid}.btn-capture{background:var(--surface-1);border-radius:var(--radius-lg);cursor:pointer;color:var(--text-secondary);border:1px solid #d4a83633;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px 12px;font-size:.88rem;font-weight:600;transition:all .15s;display:flex}.btn-capture:active{background:var(--surface-2);transform:scale(.97)}.btn-capture-icon{font-size:2rem}.btn-undo{align-self:center;font-size:.82rem}.scan-layout-selector{background:var(--surface-1);border-radius:var(--radius-lg);flex-direction:column;gap:8px;padding:14px;display:flex}.layout-btns{gap:8px;display:flex}.layout-btn{border-radius:var(--radius-md);background:var(--surface-2);color:var(--text-muted);border:1px solid #ffffff14;flex:1;padding:9px;font-size:.85rem;font-weight:700;transition:all .15s}.layout-btn.active{color:var(--gold-light);border-color:var(--gold-dim);background:#d4a8362e}.preview-body{flex-direction:column;flex:1;gap:14px;padding:16px 16px 24px;display:flex;overflow-y:auto}.preview-stats{color:var(--text-secondary);gap:16px;font-size:.85rem;display:flex}.preview-stats strong{color:var(--gold-light)}.scheme-selector{flex-wrap:wrap;gap:7px;display:flex}.scheme-btn{border-radius:var(--radius-full);background:var(--surface-2);color:var(--text-muted);border:1px solid #ffffff14;padding:8px 12px;font-size:.78rem;font-weight:600;transition:all .15s}.scheme-btn.active{color:var(--gold-light);border-color:var(--gold-dim);background:#d4a8362e}.preview-toggles{gap:8px;display:flex}.preview-canvas-wrap{border-radius:var(--radius-md);background:#000;border:1px solid #d4a83626;position:relative;overflow:hidden}.preview-canvas-container{width:100%;position:relative}.preview-base-img{width:100%;height:auto;display:block}.preview-overlay{width:100%;height:100%;position:absolute;top:0;left:0}.preview-no-img{text-align:center;color:var(--text-muted);padding:40px}.cell-editor{background:var(--surface-1);border-radius:var(--radius-lg);border:1px solid #d4a83633;flex-direction:column;gap:10px;padding:14px;display:flex}.cell-editor-header{color:var(--text-primary);justify-content:space-between;align-items:center;font-size:.9rem;font-weight:600;display:flex}.cell-confidence{color:var(--text-muted);font-size:.78rem;font-weight:400}.cell-editor-actions{flex-wrap:wrap;gap:8px;display:flex}.edit-number-row{align-items:center;gap:8px;display:flex}.number-input{text-align:center;max-width:100px;font-size:1.2rem;font-weight:700}.deleted-cells{background:var(--surface-1);border-radius:var(--radius-md);flex-direction:column;gap:8px;padding:12px;display:flex}.deleted-list{flex-wrap:wrap;gap:6px;display:flex}.colour-legend{background:var(--surface-1);border-radius:var(--radius-lg);flex-direction:column;gap:10px;padding:14px;display:flex}.legend-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin:0;font-size:.78rem;font-weight:700}.legend-grid{flex-wrap:wrap;gap:6px;display:flex}.legend-chip{border-radius:var(--radius-sm);cursor:pointer;border:none;flex-direction:column;align-items:center;min-width:44px;padding:6px 10px;transition:transform .1s,box-shadow .1s;display:flex}.legend-chip:active{transform:scale(.93)}.legend-chip.legend-chip--active{box-shadow:0 0 0 2px #fff}.legend-num{font-size:1rem;font-weight:800;line-height:1}.legend-count{opacity:.75;margin-top:2px;font-size:.65rem}.btn-accept{margin-top:8px}.game-screen{flex-direction:column;display:flex;overflow:hidden}.game-title{color:var(--gold);font-size:1rem;font-style:italic}.game-progress-bar{background:var(--surface-2);flex-shrink:0;height:3px}.game-progress-fill{background:linear-gradient(90deg, var(--jade), var(--teal));height:100%;transition:width .4s}.game-stats-row{color:var(--text-muted);background:var(--surface-0);flex-shrink:0;justify-content:space-between;padding:8px 16px;font-size:.8rem;display:flex}.game-pct{color:var(--jade);font-weight:800}.selected-num-panel{background:var(--surface-1);border-bottom:1px solid #d4a83626;flex-shrink:0;align-items:center;gap:12px;padding:10px 16px;display:flex}.selected-num-swatch{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;font-weight:800;display:flex}.selected-num-info{flex-direction:column;flex:1;gap:2px;font-size:.88rem;display:flex}.selected-num-info span:first-child{color:var(--text-primary);font-weight:600}.selected-num-info span:last-child{color:var(--text-muted);font-size:.78rem}.game-canvas-wrap{-webkit-overflow-scrolling:touch;background:#000;flex:1;position:relative;overflow:auto}.game-canvas-container{justify-content:center;align-items:center;width:100%;min-height:100%;display:flex;position:relative}.game-base-img{object-fit:contain;width:100%;height:auto;display:block}.game-overlay-canvas{touch-action:none;width:100%;height:100%;position:absolute;top:0;left:0}.hold-hint{color:var(--gold-light);background:#ffd70014;border-top:1px solid #ffd70033;flex-shrink:0;justify-content:center;align-items:center;gap:12px;padding:10px 16px;font-size:.85rem;display:flex}.hold-ring{border-radius:var(--radius-full);flex-shrink:0;width:28px;height:28px}.game-toolbar{background:var(--surface-0);border-top:1px solid #ffffff0f;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;display:flex}.game-overlay-controls{flex:1;align-items:center;gap:10px;display:flex}.overlay-label{color:var(--text-muted);flex:1;align-items:center;gap:8px;font-size:.78rem;display:flex}.overlay-slider{height:4px;accent-color:var(--gold);cursor:pointer;flex:1}.btn-legend{white-space:nowrap;padding:8px 14px;font-size:.82rem}.legend-sheet{z-index:50;background:#000000b3;align-items:flex-end;animation:.15s fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.legend-sheet-inner{background:var(--surface-1);border-radius:var(--radius-xl) var(--radius-xl) 0 0;flex-direction:column;gap:14px;width:100%;max-width:480px;max-height:70dvh;margin:0 auto;padding:20px;animation:.2s ease-out slide-up;display:flex;overflow-y:auto}@keyframes slide-up{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.legend-sheet-header{justify-content:space-between;align-items:center;display:flex}.legend-sheet-header h3{color:var(--gold);font-size:1rem;font-weight:700}.legend-hint{color:var(--text-muted);text-align:center;font-size:.75rem}.game-hint{text-align:center;color:var(--text-muted);background:var(--surface-0);flex-shrink:0;padding:8px 16px;font-size:.72rem}.toolbar-right{gap:6px;display:flex}.partial-toggle-row{grid-template-columns:1fr 1fr;gap:8px;display:grid}.partial-toggle-btn{border-radius:var(--radius-md);background:var(--surface-2);color:var(--text-muted);border:1px solid #ffffff14;padding:11px 10px;font-size:.85rem;font-weight:600;line-height:1.3;transition:all .15s}.partial-toggle-btn.active{color:var(--gold-light);border-color:var(--gold-dim);background:#d4a8362e}.num-chip-hint{color:var(--text-muted);justify-content:space-between;align-items:center;margin-bottom:4px;font-size:.8rem;display:flex}.num-chip-grid{grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:20px;display:grid}.num-chip{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--surface-2);color:var(--text-secondary);border:1px solid #ffffff14;justify-content:center;align-items:center;font-size:.88rem;font-weight:700;transition:all .12s;display:flex;position:relative}.num-chip:active{transform:scale(.92)}.num-chip--done{color:var(--jade);background:#2ecc712e;border-color:#2ecc7173}.num-chip-check{color:var(--jade);font-size:.55rem;position:absolute;top:2px;right:3px}.header-badge{color:var(--jade);border-radius:var(--radius-full);white-space:nowrap;background:#2ecc7133;padding:3px 8px;font-size:.72rem;font-weight:700}.checkpoint-all-good{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:20px;display:flex}.checkpoint-all-good span{font-size:2rem}.checkpoint-all-good p{color:var(--text-secondary);margin:0;font-size:.9rem}.checkpoint-issues{flex-direction:column;gap:10px;max-height:40dvh;display:flex;overflow-y:auto}.checkpoint-issue-card{background:var(--surface-2);border-radius:var(--radius-md);border:1px solid #ffffff0f;align-items:flex-start;gap:10px;padding:12px;display:flex}.checkpoint-issue-swatch{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1rem;font-weight:800;display:flex}.checkpoint-issue-body{flex-direction:column;flex:1;gap:8px;display:flex}.checkpoint-issue-msg{color:var(--text-secondary);margin:0;font-size:.85rem;line-height:1.4}.checkpoint-issue-msg strong{color:var(--text-primary)}.checkpoint-issue-actions{flex-wrap:wrap;gap:6px;display:flex}
