:root{--bg: #0d0f14;--panel: #171a22;--panel-2: #1f2430;--text: #e8eaf0;--muted: #8b93a7;--accent: #b8ff2e;--accent-dark: #7fb515;--danger: #ff5d5d;--radius: 14px}*{box-sizing:border-box}html,body,#root{margin:0;height:100%;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.app{display:flex;flex-direction:column;height:100%;max-width:560px;margin:0 auto}.main{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.tabbar{display:flex;border-top:1px solid #262b38;background:var(--panel);padding-bottom:env(safe-area-inset-bottom)}.tabbar button{flex:1;background:none;border:none;color:var(--muted);font-size:14px;padding:12px 0 10px;cursor:pointer}.tabbar button.active{color:var(--accent)}button.primary{background:var(--accent);color:#10130a;font-weight:700;border:none;border-radius:10px;padding:10px 18px;font-size:15px;cursor:pointer}button.primary.added{background:var(--accent-dark);color:#eaffcb}button.ghost{background:transparent;color:var(--muted);border:1px solid #333a4d;border-radius:10px;padding:6px 12px;cursor:pointer;font-size:13px}.scanner{display:flex;flex-direction:column;height:100%}.viewport{position:relative;background:#000;aspect-ratio:3 / 4;flex-shrink:0;overflow:hidden}.camera{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}.camera-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:radial-gradient(ellipse at center,#1a2030,#0d0f14);padding:24px;text-align:center}.camera-overlay .error{color:var(--danger)}.guide{position:absolute;border:3px solid rgba(255,255,255,.65);border-radius:12px;box-shadow:0 0 0 2000px #00000059;transition:border-color .15s;pointer-events:none}.guide.phase-scanning{border-color:#ffd84d}.guide.phase-unsteady{border-color:#ff9c3f}.guide.phase-locked,.guide.phase-cooldown{border-color:var(--accent)}.guide.phase-not_found{border-color:var(--danger)}.status-pill{position:absolute;top:12px;left:50%;transform:translate(-50%);background:#0d0f14d9;border-radius:999px;padding:8px 16px;font-size:14px;white-space:nowrap}.status-pill.warn{color:#ffb1b1}.shutter{position:absolute;bottom:14px;left:50%;transform:translate(-50%);width:62px;height:62px;border-radius:50%;border:4px solid rgba(255,255,255,.85);background:#0d0f148c;font-size:26px;cursor:pointer}.shutter:disabled{opacity:.5}.result-detail{color:var(--accent);font-size:11px;margin-top:2px}.alternates{display:flex;gap:8px;align-items:center;overflow-x:auto;margin:0 10px 4px;padding-bottom:4px}.alternates-label{color:var(--muted);font-size:12px;white-space:nowrap}.alternate{display:flex;gap:6px;align-items:center;background:var(--panel);border:1px solid #2c3346;border-radius:10px;padding:4px 8px 4px 4px;color:var(--text);cursor:pointer;white-space:nowrap}.alternate img{width:26px;border-radius:3px}.alternate span{display:flex;flex-direction:column;align-items:flex-start;font-size:12px}.alternate small{color:var(--muted);font-size:10px}.hud{position:absolute;bottom:8px;left:8px;font-size:11px;font-family:ui-monospace,monospace;color:#b9ff7a;background:#0000008c;padding:6px 8px;border-radius:8px}.result-sheet{display:flex;gap:12px;align-items:center;background:var(--panel-2);border:1px solid #2c3346;border-radius:var(--radius);margin:10px;padding:10px;animation:slide-up .25s ease-out}@keyframes slide-up{0%{transform:translateY(24px);opacity:0}to{transform:none;opacity:1}}.result-thumb{width:64px;border-radius:6px}.result-info{flex:1;min-width:0}.result-set{color:var(--muted);font-size:11px;letter-spacing:.05em}.result-name{font-weight:700;font-size:17px;margin:2px 0}.result-num{color:var(--muted);font-size:12px}.foil-toggle{font-size:12px;color:var(--muted);display:inline-flex;gap:4px;align-items:center;margin-top:4px}.result-actions{display:flex;flex-direction:column;align-items:center;gap:8px}.stepper{display:inline-flex;align-items:center;gap:8px;background:var(--panel);border-radius:8px;padding:2px 6px}.stepper button{background:none;border:none;color:var(--text);font-size:18px;width:26px;cursor:pointer}.stepper span{min-width:20px;text-align:center;font-size:14px}.recent{padding:4px 10px 16px}.recent-header{display:flex;justify-content:space-between;align-items:center}.recent-header h2{font-size:15px;margin:8px 0}.recent-search{width:100%;margin-bottom:8px}input,select{background:var(--panel);border:1px solid #2c3346;color:var(--text);border-radius:10px;padding:9px 12px;font-size:14px}.recent-list,.collection-list,.card-grid{list-style:none;margin:0;padding:0}.recent-item,.collection-list li{display:flex;gap:10px;align-items:center;background:var(--panel);border:1px solid #232936;border-radius:var(--radius);padding:8px;margin-bottom:8px}.recent-item img,.collection-list img{width:48px;border-radius:5px}.recent-info{flex:1;min-width:0}.recent-set{color:var(--muted);font-size:11px;letter-spacing:.04em}.recent-name{font-weight:600;font-size:15px}.recent-num{color:var(--muted);font-size:12px}.qty-badge{color:var(--accent);font-weight:700;font-size:14px}.browse{padding:10px}.browse-filters{display:flex;gap:8px;margin-bottom:10px}.browse-filters .search-input{flex:1;min-width:0}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}.card-grid li{cursor:pointer}.card-grid img{width:100%;border-radius:8px;display:block}.grid-name{font-size:11px;color:var(--muted);margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:30;padding:16px}.card-detail{background:var(--panel);border-radius:var(--radius);max-width:420px;width:100%;max-height:90vh;overflow-y:auto;position:relative;padding:14px}.card-detail .close{position:absolute;top:10px;right:10px;z-index:1}.detail-img{width:70%;display:block;margin:0 auto 10px;border-radius:10px}.detail-body h2{margin:4px 0}.detail-meta,.detail-subtype{color:var(--muted);font-size:13px;margin:2px 0}.detail-stats{list-style:none;padding:0;margin:8px 0;display:grid;grid-template-columns:1fr 1fr;gap:4px 16px;font-size:13px}.detail-stats li{display:flex;justify-content:space-between}.detail-text{font-size:14px}.detail-flavor{font-style:italic;color:var(--muted);font-size:13px}.detail-qty{display:flex;align-items:center;gap:10px;margin-top:10px;font-size:13px;color:var(--muted);flex-wrap:wrap}.collection{padding:10px}.collection-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.collection-header h2{font-size:16px;margin:4px 0}.collection-actions{display:flex;gap:6px;flex-wrap:wrap}.import-msg{color:var(--accent);font-size:13px}.sets{margin:12px 0}.sets h3{font-size:14px;color:var(--muted);margin:6px 0}.set-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}.set-name{width:40%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.set-bar{flex:1;height:8px;background:var(--panel-2);border-radius:4px;overflow:hidden}.set-bar-fill{height:100%;background:var(--accent)}.set-count{color:var(--muted);min-width:60px;text-align:right}.empty{color:var(--muted);text-align:center;margin-top:32px}
