@import "https://fonts.googleapis.com/css2?family=Lexend+Zetta:wght@400;700;800;900&family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap";@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-leading:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial}}}:root{--plotty-pink:#ff4d88;--mint-fizz:#00ffc2;--safety-orange:#ff8a00;--electric-lemon:#f9ff00;--night-navy:#0d1117;--canvas-white:#f5f5f5;--ink-200:#e6e7e9;--ink-300:#c8cbd0;--ink-500:#4d525c;--stroke-2:3px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-full:999px;--shadow-sm:4px 4px 0 0 var(--night-navy);--shadow-md:6px 6px 0 0 var(--night-navy);--shadow-pressed:2px 2px 0 0 var(--night-navy);--ease-snap:cubic-bezier(.2, .9, .2, 1.2);--dur-instant:80ms;--dur-fast:.14s;--press-x:2px;--press-y:2px;--canvas-bg:var(--canvas-white);--surface-0:var(--canvas-white);--surface-1:#fffef7;--surface-2:#fff;--text-primary:var(--night-navy);--text-secondary:var(--ink-500);--text-muted:var(--ink-500);--gold:var(--plotty-pink);--gold-light:var(--plotty-pink);--gold-dim:var(--night-navy);--jade:var(--mint-fizz);--crimson:var(--safety-orange);--status-paused:var(--electric-lemon);--glow-gold:var(--shadow-sm);--glow-active:var(--shadow-sm)}.invisible{visibility:hidden}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.container{width:100%}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.h-full{height:100%}.w-full{width:100%}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.rounded-full{border-radius:3.40282e38px}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t-2{border-top-style:var(--tw-border-style);border-top-width:2px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.leading-none{--tw-leading:1;line-height:1}.uppercase{text-transform:uppercase}.italic{font-style:italic}.line-through{text-decoration-line:line-through}.overline{text-decoration-line:overline}.underline{text-decoration-line:underline}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.opacity-60{opacity:.6}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.transition-shadow{transition-property:box-shadow;transition-timing-function:var(--tw-ease,ease);transition-duration:var(--tw-duration,0s)}.duration-300{--tw-duration:.3s;transition-duration:.3s}@media (hover:hover){.hover\:brightness-85:hover{--tw-brightness:brightness(85%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.hover\:brightness-90:hover{--tw-brightness:brightness(90%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.hover\:brightness-95:hover{--tw-brightness:brightness(95%);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}body{background-color:var(--canvas-white);color:var(--night-navy);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;margin:0;padding:0;font-family:Space Grotesk,system-ui,sans-serif;font-size:16px;line-height:1.5;overflow-x:hidden}#root{background-color:var(--canvas-white);flex-direction:column;max-width:480px;min-height:100vh;margin:0 auto;display:flex}h1{letter-spacing:-.02em;color:#0d1117;margin:0;font-family:Lexend Zetta,system-ui,sans-serif;font-size:48px;font-weight:900;line-height:1.1}h2{letter-spacing:-.02em;color:#0d1117;margin:0;font-family:Lexend Zetta,system-ui,sans-serif;font-size:36px;font-weight:900;line-height:1.1}h3{letter-spacing:-.02em;color:#0d1117;margin:0;font-family:Lexend Zetta,system-ui,sans-serif;font-size:30px;font-weight:900;line-height:1.1}h4{letter-spacing:-.02em;color:#0d1117;margin:0;font-family:Lexend Zetta,system-ui,sans-serif;font-size:24px;font-weight:900;line-height:1.1}h5{letter-spacing:-.02em;color:#0d1117;margin:0;font-family:Lexend Zetta,system-ui,sans-serif;font-size:20px;font-weight:900;line-height:1.1}h6{letter-spacing:-.02em;color:#0d1117;margin:0;font-family:Lexend Zetta,system-ui,sans-serif;font-size:18px;font-weight:900;line-height:1.1}p{margin:0;font-family:Space Grotesk,system-ui,sans-serif}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-color:#0d1117;border-radius:4px}.haptic-cell-check{transition:all .1s}.haptic-color-clear{transition:all .3s}.eagle-eye-active{border:3px solid #f9ff00;animation:2s ease-in-out infinite eagle-pulse;box-shadow:6px 6px #0d1117}.status-badge{border:3px solid #0d1117;border-radius:8px;align-items:center;gap:8px;padding:4px 12px;font-size:14px;font-weight:700;display:inline-flex}.status-badge-processing{color:#fff;background-color:#ff8a00;animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.status-badge-complete{color:#0d1117;background-color:#00ffc2}.status-badge-error{color:#fff;background-color:#ff8a00}.focus-brutal{box-shadow:0 0 0 2px var(--canvas-white), 0 0 0 4px var(--electric-lemon);outline:none}:focus-visible{outline:2px solid var(--electric-lemon);outline-offset:2px}@keyframes confetti-burst{0%{opacity:1;transform:translate(0)rotate(0)scale(1)}to{opacity:0;transform:translate(var(--tx), var(--ty)) rotate(720deg) scale(0)}}.confetti{animation:2.5s cubic-bezier(.25,.46,.45,.94) forwards confetti-burst}.stacked-shadow{position:relative}.stacked-shadow:after{content:"";z-index:-1;opacity:.3;border:3px solid #0d1117;border-radius:8px;width:100%;height:100%;position:absolute;top:-2px;left:-2px}.stacked-shadow:before{content:"";z-index:-2;opacity:.15;border:3px solid #0d1117;border-radius:8px;width:100%;height:100%;position:absolute;top:-4px;left:-4px}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}.screen{background:var(--canvas-bg);flex-direction:column;min-height:100dvh;display:flex;overflow-x:hidden}.screen-header{border-bottom:var(--stroke-2) solid var(--night-navy);background:var(--surface-0);z-index:20;align-items:center;gap:12px;padding:16px;display:flex;position:sticky;top:0}.screen-header h2{text-transform:uppercase;letter-spacing:-.02em;color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-family:Lexend Zetta,system-ui,sans-serif;font-size:1rem;font-weight:800;overflow:hidden}.btn-back{background:var(--electric-lemon);color:var(--night-navy);border-radius:var(--radius-sm);border:var(--stroke-2) solid var(--night-navy);box-shadow:var(--shadow-sm);min-width:40px;min-height:40px;transition:transform var(--dur-fast) var(--ease-snap), box-shadow var(--dur-fast) var(--ease-snap);justify-content:center;align-items:center;padding:6px 10px;font-size:1.3rem;line-height:1;display:flex}.btn-back:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-pressed)}.btn-primary{background:var(--plotty-pink);color:var(--night-navy);border-radius:var(--radius-md);text-transform:uppercase;border:var(--stroke-2) solid var(--night-navy);box-shadow:var(--shadow-sm);transition:transform var(--dur-fast) var(--ease-snap), box-shadow var(--dur-fast) var(--ease-snap);padding:12px 20px;font-size:.95rem;font-weight:700}.btn-primary:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-pressed)}.btn-primary:disabled{opacity:1;background:var(--ink-300);color:var(--ink-500);box-shadow:none;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{background:var(--canvas-white);color:var(--night-navy);border-radius:var(--radius-md);text-transform:uppercase;border:var(--stroke-2) solid var(--night-navy);box-shadow:var(--shadow-sm);transition:transform var(--dur-fast) var(--ease-snap), box-shadow var(--dur-fast) var(--ease-snap);padding:10px 16px;font-size:.88rem}.btn-ghost:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-pressed)}.btn-ghost.btn-sm{padding:7px 12px;font-size:.82rem}.btn-action{border-radius:var(--radius-sm);border:var(--stroke-2) solid var(--night-navy);box-shadow:var(--shadow-sm);transition:transform var(--dur-fast) var(--ease-snap), box-shadow var(--dur-fast) var(--ease-snap);padding:8px 14px;font-size:.82rem;font-weight:600}.btn-action:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-pressed)}.btn-activate{background:var(--jade);color:var(--night-navy)}.btn-pause{background:var(--status-paused);color:#0a0a14}.btn-danger{background:var(--crimson);color:var(--night-navy)}.btn-ghost.btn-action{background:var(--canvas-white);color:var(--night-navy)}.form-group{flex-direction:column;gap:8px;margin-bottom:20px;display:flex}.form-label{text-transform:uppercase;letter-spacing:.1em;color:var(--night-navy);font-size:.8rem;font-weight:700}.form-hint{color:var(--text-muted);margin:0;font-size:.8rem}.form-input{border:var(--stroke-2) solid var(--night-navy);box-shadow:var(--shadow-sm);border-radius:var(--radius-md);color:var(--text-primary);transition:transform var(--dur-fast) var(--ease-snap), box-shadow var(--dur-fast) var(--ease-snap);background:#fff;outline:none;width:100%;padding:12px 16px;font-size:1rem}.form-input:focus{box-shadow:0 0 0 2px var(--canvas-white), 0 0 0 4px var(--electric-lemon), var(--shadow-sm)}.error-container{align-items:center;gap:12px;width:100%;display:flex}.error-msg{color:var(--night-navy);background:var(--safety-orange);border-radius:var(--radius-sm);border:var(--stroke-2) solid var(--night-navy);box-shadow:var(--shadow-sm);flex:1;margin:0;padding:10px 14px;font-size:.88rem}.btn-retry{background:var(--plotty-pink);color:var(--night-navy);border-radius:var(--radius-sm);border:var(--stroke-2) solid var(--night-navy);box-shadow:var(--shadow-sm);white-space:nowrap;cursor:pointer;transition:transform var(--dur-fast) var(--ease-snap), box-shadow var(--dur-fast) var(--ease-snap);padding:8px 14px;font-size:.82rem;font-weight:600}.btn-retry:active:not(:disabled){transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-pressed)}.btn-retry:disabled{opacity:1;background:var(--ink-300);box-shadow:none;cursor:not-allowed}.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:var(--canvas-bg)}.gallery-header{border-bottom:var(--stroke-2) solid var(--night-navy);justify-content:space-between;align-items:center;padding:20px 20px 16px;display:flex}.gallery-brand{align-items:center;display:flex}.brand-title{letter-spacing:-.04em;color:var(--night-navy);text-transform:uppercase;margin:0;font-family:Lexend Zetta,sans-serif;font-size:2rem;font-weight:800;line-height:1}.btn-add{border-radius:var(--radius-full);background:var(--plotty-pink);width:46px;height:46px;color:var(--night-navy);border:var(--stroke-2) solid var(--night-navy);box-shadow:var(--shadow-sm);transition:transform var(--dur-fast) var(--ease-snap), box-shadow var(--dur-fast) var(--ease-snap);justify-content:center;align-items:center;font-size:1.6rem;font-weight:300;display:flex}.btn-add:active{transform:translate(var(--press-x), var(--press-y));box-shadow:var(--shadow-pressed)}.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 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-sm);border:var(--stroke-2) solid var(--night-navy);box-shadow:var(--shadow-sm);transition:transform var(--dur-fast) var(--ease-snap), box-shadow var(--dur-fast) var(--ease-snap);gap:12px;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}.job-status-badge{border-radius:var(--radius-sm);white-space:nowrap;padding:2px 6px;font-size:.7rem;font-weight:600;display:inline-block}.job-status-processing{color:#64c8ff;background:#64c8ff26}.job-status-complete{color:#4cc864;background:#4cc86426}.job-status-error{color:#ff6b6b;background:#ff6b6b26}.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}.modal-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface-0);border:3pt solid var(--ink);border-radius:8px;flex-direction:column;width:100%;max-width:420px;max-height:90dvh;display:flex;overflow-y:auto;box-shadow:4px 4px #0003}.modal-header{border-bottom:3pt solid var(--ink);justify-content:space-between;align-items:center;gap:12px;padding:16px;display:flex}.modal-header h3{color:var(--text-primary);flex:1;margin:0;font-size:1rem;font-weight:700}.btn-close{color:var(--text-primary);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:1.3rem;line-height:1}.crop-editor{flex-direction:column;align-items:center;gap:12px;padding:16px;display:flex}.crop-hint{color:var(--text-secondary);text-align:center;margin:0;font-size:.8rem}.crop-canvas{border:3pt solid var(--ink);cursor:grab;background:#000;border-radius:4px;max-width:100%;display:block}.crop-canvas:active{cursor:grabbing}.crop-actions{border-top:1px solid #0d11171a;justify-content:flex-end;gap:8px;padding:16px;display:flex}.captures-preview{padding:16px 0}.captures-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 16px 8px;font-size:.85rem;font-weight:600}.captures-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;margin-bottom:12px;padding:0 16px;display:grid}.capture-item{aspect-ratio:1;border:2pt solid var(--ink);cursor:pointer;background:#000;border-radius:4px;position:relative;overflow:hidden}.capture-item img{object-fit:cover;width:100%;height:100%;display:block}.capture-overlay{opacity:0;background:#0009;justify-content:center;align-items:center;gap:4px;transition:opacity .2s;display:flex;position:absolute;inset:0}.capture-item:hover .capture-overlay{opacity:1}.btn-crop,.btn-remove{background:var(--surface-0);border:2pt solid var(--ink);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:1rem;transition:all .2s;display:flex}.btn-crop:active,.btn-remove:active{transform:translate(1px,1px)}.btn-crop:hover{background:var(--success);color:#fff}.btn-remove:hover{background:var(--danger);color:#fff}.capture-label{color:#fff;text-align:center;white-space:nowrap;text-overflow:ellipsis;background:#ff4d88e6;border-radius:2px;padding:2px 4px;font-size:.65rem;font-weight:600;position:absolute;bottom:2px;left:2px;right:2px;overflow:hidden}
