*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#1a1a2e;--bg-card:#16213e;--bg-input:#0f3460;--text:#e0e0e0;--text-muted:#888;--accent:#7c3aed;--success:#4ade80;--danger:#ef4444;--warning:#facc15;--tab-height:64px;--safe-bottom:env(safe-area-inset-bottom,0px);--safe-top:env(safe-area-inset-top,0px)}html,body,#app{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;overflow:hidden}.app{flex-direction:column;height:100%;display:flex}.app-content{-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--tab-height) + var(--safe-bottom));flex:1;overflow-y:auto}.page{padding:1rem;padding-top:max(1rem, calc(var(--safe-top) + .5rem))}.page h1{margin-bottom:1rem;font-size:1.5rem}.tab-bar{height:calc(var(--tab-height) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--bg-card);z-index:100;border-top:1px solid #2a2a3e;display:flex;position:fixed;bottom:0;left:0;right:0}.tab-item{color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;min-height:44px;font-size:.65rem;display:flex}.tab-item:active{opacity:.6}.tab-item.active{color:var(--accent)}.tab-icon{font-size:1.3rem}.tab-label{font-weight:500}.settings-section{margin-bottom:1.5rem}.settings-section h3{margin-bottom:.5rem}.settings-about{color:var(--text-muted);margin-bottom:.25rem;font-size:.85rem}.inventory-form,.custom-paint-form{background:var(--bg-card);border-radius:12px;margin:.75rem 0;padding:1rem}.back-btn{text-align:left;min-height:44px;margin-bottom:.5rem;padding-left:0}.faction-list,.scheme-list{flex-direction:column;gap:.3rem;display:flex}.faction-list-item,.scheme-list-item{background:var(--bg-card);color:var(--text);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;justify-content:space-between;align-items:center;width:100%;min-height:44px;padding:.75rem;display:flex}.faction-list-item:active,.scheme-list-item:active{background:#1e2d52}.faction-count,.scheme-list-source{color:var(--text-muted);font-size:.8rem}.scheme-list-name{flex:1}.scheme-list-sub{color:var(--text-muted);margin:0 .5rem;font-size:.8rem}.scheme-detail-meta{color:var(--text-muted);margin-bottom:1rem;font-size:.85rem}.scheme-steps{flex-direction:column;gap:.3rem;display:flex}.scheme-step{border-bottom:1px solid #1e1e3a;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.scheme-step-info{flex:1}.scheme-step-name{font-size:.9rem}.scheme-step-meta{color:var(--text-muted);font-size:.75rem}.scheme-step-status{text-align:center;width:2rem;font-size:1.1rem}.scheme-step-status.owned{color:var(--success)}.scheme-step-status.missing{color:var(--danger)}.scheme-summary{color:var(--text-muted);justify-content:space-between;align-items:center;padding:1rem 0;font-size:.9rem;display:flex}.shopping-list-item{border-bottom:1px solid #1e1e3a;align-items:center;gap:.75rem;padding:.5rem 0;display:flex}.scanner-viewfinder{border-radius:12px;width:100%;max-width:500px;margin:0 auto;position:relative;overflow:hidden}.scanner-video{border-radius:12px;width:100%;height:auto;display:block}.scanner-guide{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.scanner-guide-box{border:2px solid #7c3aedcc;border-radius:8px;width:80%;height:80px;box-shadow:0 0 0 9999px #0000004d}.torch-btn{color:#fff;cursor:pointer;z-index:10;-webkit-tap-highlight-color:transparent;background:#0009;border:none;border-radius:8px;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:.6rem .8rem;font-size:.85rem;display:inline-flex;position:absolute;top:.5rem;right:.5rem}.torch-btn:active{background:#000000d9}.scanner-hint{text-align:center;color:#ffffffb3;pointer-events:none;font-size:.75rem;position:absolute;bottom:.75rem;left:0;right:0}.scan-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.scan-header h2{margin-bottom:0}.btn-active{background:var(--accent);color:#fff}.rapid-counter{color:var(--accent);margin-top:.25rem;font-size:.85rem}.scanner-error{text-align:center;padding:2rem 1rem}.scanner-error p{margin-bottom:.5rem}.scanner-error-hint{color:var(--text-muted);font-size:.85rem}.scan-page{text-align:center}.scan-page h2{margin-bottom:1rem}.scan-result{padding:1.5rem}.scan-result-banner{border-radius:12px;margin-bottom:1rem;padding:.25rem .75rem;font-size:.8rem;font-weight:600;display:inline-block}.scan-result-banner.owned{background:var(--warning);color:#000}.scan-result-banner.new{background:var(--success);color:#000}.scan-result-banner.unknown{background:var(--danger);color:#fff}.scan-result h3{margin:.75rem 0 .25rem;font-size:1.25rem}.scan-result-type{color:var(--text-muted);font-size:.85rem}.scan-result-quantity{margin:.75rem 0;font-size:1rem}.scan-result-notes{color:var(--warning);font-size:.85rem}.scan-result-upc{color:var(--text-muted);margin-bottom:1rem;font-size:.9rem}.scan-result-actions{flex-direction:column;gap:.5rem;max-width:280px;margin-top:1.25rem;margin-left:auto;margin-right:auto;display:flex}.scan-result .paint-swatch{margin:0 auto}.scan-confirmation{flex-direction:column;justify-content:center;align-items:center;min-height:50vh;display:flex}.scan-confirmation-icon{color:var(--success);margin-bottom:.5rem;font-size:3rem}.scan-confirmation h3{font-size:1.25rem}.scan-confirmation p{color:var(--text-muted)}.btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:8px;justify-content:center;align-items:center;min-height:44px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;display:inline-flex}.btn:active{opacity:.75}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{color:var(--text);background:#333}.btn-ghost{color:var(--text-muted);background:0 0}.notes-input{background:var(--bg-card);width:100%;max-width:320px;color:var(--text);resize:vertical;-webkit-overflow-scrolling:touch;border:1px solid #333;border-radius:8px;margin:1rem auto;padding:.75rem;font-size:1rem;display:block}.collection-header{justify-content:space-between;align-items:center;display:flex}.view-toggle{color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:.5rem;font-size:1.4rem;display:inline-flex}.view-toggle:active{opacity:.6}.search-bar{background:var(--bg-card);width:100%;color:var(--text);border:1px solid #333;border-radius:8px;min-height:44px;margin:.75rem 0;padding:.6rem .8rem;font-size:1rem}.filter-chips{-webkit-overflow-scrolling:touch;gap:.4rem;margin-bottom:.75rem;padding-bottom:.5rem;display:flex;overflow-x:auto}.chip{white-space:nowrap;color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#333;border:none;border-radius:16px;align-items:center;min-height:44px;padding:.6rem .75rem;font-size:.75rem;display:inline-flex}.chip:active{opacity:.7}.chip.active{background:var(--accent);color:#fff}.paint-grid{text-align:center;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:.75rem;display:grid}.paint-grid-item{color:var(--text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:.35rem .25rem;display:flex}.paint-grid-item:active{background:#ffffff0f}.paint-grid-name{text-overflow:ellipsis;max-width:70px;font-size:.6rem;line-height:1.2;overflow:hidden}.paint-grid-qty{color:var(--text-muted);font-size:.6rem}.paint-list-row{color:var(--text);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-bottom:1px solid #1e1e3a;align-items:center;gap:.75rem;width:100%;min-height:44px;padding:.7rem 0;display:flex}.paint-list-row:active{background:#ffffff0a}.paint-list-info{flex:1;min-width:0}.paint-list-name{font-size:.9rem}.paint-list-meta{color:var(--text-muted);font-size:.75rem}.paint-list-right{flex-shrink:0}.paint-list-qty{color:var(--text-muted);font-size:.8rem}.paint-list-notes{color:var(--warning);font-size:.75rem}.modal-overlay{z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:16px;width:100%;max-width:360px;max-height:80vh;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;padding:1rem 1rem 0;display:flex}.modal-body{text-align:center;padding:1rem}.modal-body .paint-swatch{margin:0 auto .5rem}.modal-footer{justify-content:center;gap:.5rem;padding:0 1rem 1rem;display:flex}.paint-detail-type{color:var(--text-muted);font-size:.85rem}.paint-detail-date{color:var(--text-muted);margin-bottom:1rem;font-size:.75rem}.field-label{color:var(--text-muted);text-transform:uppercase;text-align:left;margin:.75rem 0 .25rem;font-size:.75rem;display:block}.quantity-control{justify-content:center;align-items:center;gap:1rem;display:flex}.quantity-value{text-align:center;min-width:2rem;font-size:1.25rem;font-weight:600}.btn-danger{background:var(--danger);color:#fff}.empty-state{text-align:center;color:var(--text-muted);padding:3rem 1rem}@keyframes pulse-text{0%,to{opacity:1}50%{opacity:.45}}.loading-screen{height:100vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;font-size:1rem;animation:1.6s ease-in-out infinite pulse-text;display:flex}.loading-screen:before{content:"🎨";opacity:1;font-size:2.5rem;animation:none}.schemes-page-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.schemes-page-header h1{margin-bottom:0}.custom-scheme-form{background:var(--bg-card);border-radius:12px;margin:.25rem 0;padding:1rem}.custom-scheme-form-header h2{margin-bottom:.75rem}.custom-scheme-empty{color:var(--text-muted);padding:.5rem 0;font-size:.85rem}.custom-scheme-steps{flex-direction:column;gap:.5rem;margin-bottom:.75rem;display:flex}.custom-scheme-step{background:var(--bg);border-radius:8px;align-items:flex-start;gap:.5rem;padding:.6rem;display:flex}.custom-scheme-step-reorder{flex-direction:column;flex-shrink:0;align-items:center;gap:2px;display:flex}.step-num{color:var(--text-muted);font-size:.7rem;line-height:1}.step-reorder-btn{color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;margin:-.5rem -.4rem;padding:.5rem .4rem;font-size:.8rem;line-height:1}.step-reorder-btn:active:not(:disabled){color:var(--text)}.step-reorder-btn:disabled{opacity:.2;cursor:default}.custom-scheme-step-body{flex-direction:column;flex:1;gap:.4rem;min-width:0;display:flex}.step-paint-btn{background:var(--bg-card);color:var(--text);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;border:1px solid #333;border-radius:6px;align-items:center;gap:.5rem;width:100%;min-height:44px;padding:.6rem;display:flex}.step-paint-btn:active{background:var(--bg-input)}.step-paint-name{text-overflow:ellipsis;white-space:nowrap;font-size:.85rem;overflow:hidden}.step-fields{gap:.4rem;display:flex}.step-select,.step-area-input{background:var(--bg-card);color:var(--text);border:1px solid #333;border-radius:6px;flex:1;min-height:44px;padding:.55rem .4rem;font-size:1rem}.step-delete-btn{color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-shrink:0;justify-content:center;align-self:center;align-items:center;min-width:44px;min-height:44px;padding:.6rem;font-size:.9rem;display:inline-flex}.step-delete-btn:active{color:var(--danger)}.custom-scheme-add-btn{width:100%;margin-bottom:1rem}.custom-scheme-form-actions{gap:.5rem;display:flex}.custom-scheme-form-actions .btn{flex:1}.faction-input-wrap{position:relative}.faction-suggestions{background:var(--bg-card);z-index:50;border:1px solid #333;border-radius:8px;max-height:180px;margin-top:2px;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.faction-suggestion-item{width:100%;color:var(--text);text-align:left;cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;min-height:44px;padding:.7rem .75rem;font-size:.9rem;display:block}.faction-suggestion-item:active{background:var(--bg-input)}.paint-picker-overlay{z-index:300;background:#000000b3;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.paint-picker{background:var(--bg-card);border-radius:16px 16px 0 0;flex-direction:column;width:100%;max-width:480px;max-height:70vh;padding:1rem;display:flex}.paint-picker-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.paint-picker-title{font-size:1rem;font-weight:600}.paint-picker-results{-webkit-overflow-scrolling:touch;flex:1;margin-top:.25rem;overflow-y:auto}.paint-picker-row{width:100%;color:var(--text);cursor:pointer;text-align:left;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-bottom:1px solid #1e1e3a;align-items:center;gap:.75rem;min-height:44px;padding:.7rem 0;display:flex}.paint-picker-row:active{background:#ffffff0a}.paint-picker-info{flex-direction:column;min-width:0;display:flex}.paint-picker-name{font-size:.9rem}.paint-picker-meta{color:var(--text-muted);font-size:.75rem}.paint-picker-hint{color:var(--text-muted);text-align:center;padding:.75rem 0;font-size:.85rem}.sort-pills{gap:.4rem;margin-bottom:.75rem;display:flex}.sort-pill{color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap;background:0 0;border:1px solid #333;border-radius:12px;align-items:center;min-height:44px;padding:.55rem .75rem;font-size:.72rem;font-weight:500;display:inline-flex}.sort-pill:active{opacity:.7}.sort-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}
