@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Fraunces:ital,opsz,wght@0,9..144,600;0,9..144,700;0,9..144,800;1,9..144,600&display=swap";:root{--bg-base: #faf7f2;--bg-surface: #fffdf9;--bg-surface-raised: #f3efe8;--bg-accent: #e07a3a;--bg-accent-hover: #c9682f;--bg-accent-soft: rgba(224, 122, 58, .1);--text-main: #2c2419;--text-muted: #6b5e4f;--text-soft: #9a8b7a;--border-color: #e8e0d4;--success: #3d9a6b;--success-bg: #edf7f0;--warning: #d4920a;--warning-bg: #fdf6e8;--danger: #c94a4a;--danger-bg: #fdf0f0;--font-display: "Fraunces", Georgia, "Times New Roman", serif;--font-sans: "DM Sans", ui-sans-serif, system-ui, sans-serif;--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--shadow-sm: 0 1px 3px rgba(44, 36, 25, .06);--shadow-md: 0 4px 12px rgba(44, 36, 25, .07);--shadow-lg: 0 10px 24px rgba(44, 36, 25, .09);--shadow-xl: 0 20px 40px rgba(44, 36, 25, .11);--transition: all .22s cubic-bezier(.4, 0, .2, 1);--glass-bg: rgba(255, 253, 249, .82);--glass-border: rgba(232, 224, 212, .6);--glass-blur: blur(14px) saturate(140%);color-scheme:light dark}:root[data-theme=dark]{--bg-base: #141210;--bg-surface: #1e1b17;--bg-surface-raised: #2a2620;--bg-accent: #f0a060;--bg-accent-hover: #e08a45;--bg-accent-soft: rgba(240, 160, 96, .14);--text-main: #f5f0e8;--text-muted: #b8aa98;--text-soft: #857a6c;--border-color: #3a342c;--success: #5cb88a;--success-bg: rgba(92, 184, 138, .12);--warning: #e8b040;--warning-bg: rgba(232, 176, 64, .12);--danger: #e07070;--danger-bg: rgba(224, 112, 112, .12);--glass-bg: rgba(30, 27, 23, .85);--glass-border: rgba(58, 52, 44, .6);--shadow-lg: 0 10px 24px rgba(0, 0, 0, .35);--shadow-xl: 0 24px 48px rgba(0, 0, 0, .45)}.series-theme-dc{--accent: #2563eb;--accent-soft: rgba(37, 99, 235, .1);--accent-strong: #1d4ed8;--theme-glow: 0 0 20px rgba(37, 99, 235, .25);--series-gradient: linear-gradient(135deg, #1e3a8a, #0f172a)}:root[data-theme=dark] .series-theme-dc{--accent: #60a5fa;--accent-soft: rgba(96, 165, 250, .18);--accent-strong: #93c5fd;--theme-glow: 0 0 25px rgba(96, 165, 250, .3)}.series-theme-marvel{--accent: #dc2626;--accent-soft: rgba(220, 38, 38, .1);--accent-strong: #991b1b;--theme-glow: 0 0 20px rgba(220, 38, 38, .25);--series-gradient: linear-gradient(135deg, #7f1d1d, #1e293b)}:root[data-theme=dark] .series-theme-marvel{--accent: #f87171;--accent-soft: rgba(248, 113, 113, .18);--accent-strong: #fca5a5;--theme-glow: 0 0 25px rgba(248, 113, 113, .3)}.series-theme-spongebob{--accent: #d97706;--accent-soft: rgba(217, 119, 6, .1);--accent-strong: #b45309;--theme-glow: 0 0 20px rgba(217, 119, 6, .25);--series-gradient: linear-gradient(135deg, #78350f, #1e293b)}:root[data-theme=dark] .series-theme-spongebob{--accent: #fbbf24;--accent-soft: rgba(251, 191, 36, .18);--accent-strong: #fcd34d;--theme-glow: 0 0 25px rgba(251, 191, 36, .35)}.series-theme-wizard-of-oz{--accent: #059669;--accent-soft: rgba(5, 150, 105, .1);--accent-strong: #047857;--theme-glow: 0 0 20px rgba(5, 150, 105, .25);--series-gradient: linear-gradient(135deg, #064e3b, #0f172a)}:root[data-theme=dark] .series-theme-wizard-of-oz{--accent: #34d399;--accent-soft: rgba(52, 211, 153, .18);--accent-strong: #6ee7b7;--theme-glow: 0 0 25px rgba(52, 211, 153, .3)}.app-shell{--accent: var(--bg-accent);--accent-soft: var(--bg-accent-soft);--accent-strong: var(--bg-accent-hover);--theme-glow: none}*{box-sizing:border-box}body{margin:0;min-width:320px;background-color:var(--bg-base);color:var(--text-main);font-family:var(--font-sans);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(ellipse at 10% 0%,rgba(224,122,58,.09) 0%,transparent 55%),radial-gradient(ellipse at 90% 100%,rgba(212,146,10,.07) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(255,253,249,.5) 0%,transparent 70%);background-attachment:fixed;transition:background-color .3s ease,color .3s ease}h1,h2,h3,.series-toolbar h2,.drawer-heading h2{font-family:var(--font-display);font-weight:700;letter-spacing:-.01em}button,input,select,textarea{font:inherit;color:inherit;border-radius:var(--radius-sm);transition:var(--transition)}button{cursor:pointer;border:1px solid transparent;background:transparent;display:inline-flex;align-items:center;justify-content:center}button:active{transform:scale(.98)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}button:active{transform:none}}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--accent);outline-offset:2px}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-md);border:2px solid var(--bg-base)}::-webkit-scrollbar-thumb:hover{background:var(--text-soft)}.app-shell{width:min(1200px,calc(100% - 32px));margin:0 auto;padding:40px 0 64px}.app-header{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:24px;border-bottom:1px solid var(--border-color);padding-bottom:24px}.overline{margin:0 0 6px;color:var(--bg-accent);font-family:var(--font-display);font-size:.95rem;font-weight:600;font-style:italic;letter-spacing:0;text-transform:none;transition:var(--transition)}h1{margin:0 0 8px;font-size:clamp(2rem,4vw,2.75rem);font-weight:800;line-height:1.12;letter-spacing:-.02em}.header-copy{max-width:600px;margin:0;color:var(--text-muted);font-size:.98rem;line-height:1.5}.sync-pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:99px;padding:8px 16px;background:var(--bg-surface);color:var(--text-muted);font-size:.85rem;font-weight:600;box-shadow:var(--shadow-sm);white-space:nowrap}.sync-pill.online{color:var(--success);border-color:color-mix(in srgb,var(--success) 30%,transparent);background-color:var(--success-bg)}.top-controls{display:flex;justify-content:flex-end;gap:12px;margin-bottom:24px}.preference-toggle{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:8px 16px;background:var(--bg-surface);color:var(--text-muted);font-size:.85rem;font-weight:600;box-shadow:var(--shadow-sm)}.preference-toggle:hover{border-color:var(--text-soft);color:var(--text-main);background:var(--bg-surface-raised)}.preference-toggle[aria-pressed=true]{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong);box-shadow:0 0 10px var(--accent-soft)}.tabs{display:flex;gap:10px;overflow-x:auto;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:6px;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);box-shadow:var(--shadow-md);margin-bottom:28px;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.series-tab{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;min-width:140px;flex:1 0 auto;border:1px solid transparent;border-radius:var(--radius-sm);padding:12px 16px;background:transparent;color:var(--text-muted);text-align:left}.series-tab:hover{background:var(--bg-surface-raised);color:var(--text-main)}.series-tab span{font-size:.95rem;font-weight:700}.series-tab strong{font-size:.78rem;text-transform:none;letter-spacing:0;font-weight:600;color:var(--text-soft)}.series-tab.selected{background:var(--bg-surface);border-color:var(--border-color);color:var(--text-main);box-shadow:var(--shadow-md)}.tabs>button:nth-child(2).selected{--accent: #2563eb}.tabs>button:nth-child(3).selected{--accent: #dc2626}.tabs>button:nth-child(4).selected{--accent: #d97706}.tabs>button:nth-child(5).selected{--accent: #059669}.series-tab.selected span{color:var(--accent)}.page-actions{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:28px}.page-action{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 16px;background:var(--bg-surface);color:var(--text-muted);font-size:.88rem;font-weight:700;box-shadow:var(--shadow-sm)}.page-action:hover{border-color:var(--text-soft);color:var(--text-main);background:var(--bg-surface-raised)}.page-action.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong);box-shadow:0 0 10px var(--accent-soft)}.page-action-back{margin-left:auto}.quick-add-series-list{display:flex;flex-direction:column;gap:24px}.quick-add-series{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;background:var(--bg-surface-raised)}.quick-add-series-dc{border-left:4px solid #2563eb}.quick-add-series-marvel{border-left:4px solid #dc2626}.quick-add-series-spongebob{border-left:4px solid #d97706}.quick-add-series-wizard-of-oz{border-left:4px solid #059669}.quick-add-series-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.quick-add-series-header h3{margin:0 0 4px;font-size:1.1rem;font-weight:800}.quick-add-series-header p{margin:0;font-size:.82rem;color:var(--text-muted)}.quick-add-series-total{flex-shrink:0;padding:6px 12px;border-radius:99px;background:var(--bg-surface);border:1px solid var(--border-color);font-size:.82rem;font-weight:800;color:var(--text-main)}.quick-add-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:10px}.quick-add-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;min-height:72px;padding:10px 8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-surface);text-align:center}.quick-add-card:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}.quick-add-card.owned{border-color:color-mix(in srgb,var(--success) 40%,var(--border-color))}.quick-add-card.duplicate{border-color:var(--warning);background:var(--warning-bg)}.quick-add-card.rare{border-color:color-mix(in srgb,var(--warning) 50%,var(--border-color))}.quick-add-number{font-size:.72rem;font-weight:700;color:var(--text-muted)}.quick-add-card.just-added{border-color:var(--success);background:var(--success-bg);animation:addPop .45s ease}@keyframes addPop{0%{transform:scale(1)}35%{transform:scale(1.08)}to{transform:scale(1)}}.quick-add-card .quick-add-added{font-size:.65rem;font-weight:700;color:var(--success)}.bulk-edit-save-group{display:flex;align-items:center;gap:12px;flex-shrink:0}.bulk-edit-save-group button{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--success);border-radius:var(--radius-sm);padding:10px 16px;background:var(--success);color:#fff;font-size:.88rem;font-weight:800;box-shadow:var(--shadow-sm)}.bulk-edit-save-group button:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.bulk-edit-save-group button:disabled{cursor:not-allowed;opacity:.55}.bulk-edit-status{color:var(--text-muted);font-size:.84rem;font-weight:800;white-space:nowrap}.bulk-edit-status.saving{color:var(--accent)}.bulk-edit-status.saved{color:var(--success)}.bulk-edit-status.error{color:var(--danger)}.bulk-edit-grid{grid-template-columns:repeat(auto-fill,minmax(88px,1fr))}.bulk-edit-card{cursor:text;min-height:96px}.bulk-edit-card:hover,.bulk-edit-card:focus-within{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}.bulk-edit-card.changed{border-color:var(--accent);background:linear-gradient(180deg,var(--bg-surface),var(--accent-soft))}.bulk-edit-card input{width:100%;height:34px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-surface-raised);color:var(--text-main);font-size:1.15rem;font-weight:800;text-align:center}.bulk-edit-card input:focus{border-color:var(--accent);background:var(--bg-surface)}.bulk-edit-name{display:block;width:100%;overflow:hidden;color:var(--text-muted);font-size:.66rem;font-weight:700;line-height:1.15;text-align:center;text-overflow:ellipsis;white-space:nowrap}.set-complete-celebration{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:24px;pointer-events:auto;background:radial-gradient(circle at 50% 38%,color-mix(in srgb,var(--warning) 18%,transparent),transparent 38%),color-mix(in srgb,var(--bg-main) 34%,transparent);-webkit-backdrop-filter:blur(7px) saturate(130%);backdrop-filter:blur(7px) saturate(130%);animation:fadeIn .22s ease-out both}.celebration-card{position:relative;display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:16px;width:min(520px,100%);border:1px solid color-mix(in srgb,var(--success) 45%,var(--border-color));border-radius:var(--radius-md);padding:22px;background:radial-gradient(circle at 92% 12%,color-mix(in srgb,var(--accent) 18%,transparent),transparent 25%),radial-gradient(circle at 18% 16%,color-mix(in srgb,var(--warning) 34%,transparent),transparent 28%),linear-gradient(135deg,var(--bg-surface-raised),var(--success-bg));box-shadow:var(--shadow-xl);overflow:hidden;text-align:left;animation:celebrationCardPop .72s cubic-bezier(.16,1,.3,1)}.celebration-card:after{content:"";position:absolute;inset:-60% auto -60% -30%;width:42%;transform:rotate(16deg);background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);animation:celebrationShine 1.15s .22s ease-out both}.celebration-close{position:absolute;top:14px;right:14px;z-index:2;display:grid;place-items:center;width:36px;height:36px;border:1px solid color-mix(in srgb,var(--success) 26%,var(--border-color));border-radius:99px;background:color-mix(in srgb,var(--bg-surface) 84%,transparent);color:var(--text-muted)}.celebration-close:hover,.celebration-close:focus-visible{border-color:var(--success);color:var(--success)}.celebration-icon{display:grid;place-items:center;width:58px;height:58px;border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--success);box-shadow:var(--shadow-sm);animation:trophyBounce 1s ease both}.celebration-copy{padding-right:36px}.celebration-card .overline{margin-bottom:4px;color:var(--success)}.celebration-card h2{margin:0;font-family:var(--font-display);font-size:clamp(1.25rem,3.6vw,1.75rem);line-height:1.08;color:var(--text-main)}.celebration-card p:last-child{margin:6px 0 0;color:var(--text-muted);font-weight:700}.celebration-prize{grid-column:1 / -1;display:flex;align-items:center;gap:8px;min-height:36px;border:1px dashed color-mix(in srgb,var(--success) 42%,var(--border-color));border-radius:var(--radius-sm);padding:8px 12px;background:color-mix(in srgb,var(--success-bg) 68%,var(--bg-surface));color:var(--success);font-size:.76rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.celebration-prize:before,.celebration-prize:after{content:"";width:9px;height:9px;border-radius:99px;background:var(--warning);box-shadow:15px 0 0 var(--accent),30px 0 0 var(--success)}.celebration-prize:after{margin-left:auto}.celebration-action{grid-column:1 / -1;justify-self:stretch;gap:9px;border:1px solid color-mix(in srgb,var(--success) 42%,transparent);border-radius:var(--radius-sm);padding:12px 16px;background:var(--success);color:#fff;font-weight:900;box-shadow:var(--shadow-sm)}.celebration-action:hover,.celebration-action:focus-visible{background:color-mix(in srgb,var(--success) 84%,black);transform:translateY(-1px)}.celebration-sparkle{position:absolute;top:20px;right:58px;color:var(--warning);animation:sparkleSpin 1.15s ease-in-out infinite}.celebration-burst{position:absolute;inset:0;display:grid;place-items:center;overflow:hidden}.celebration-burst span{--burst-angle: calc(var(--burst-index) * 13deg);position:absolute;width:9px;height:20px;border-radius:4px;background:hsl(calc(var(--burst-index) * 38) 88% 58%);transform:rotate(var(--burst-angle)) translateY(0);animation:confettiBurst 1.65s cubic-bezier(.11,.78,.26,1) both;animation-delay:calc(var(--burst-index) * 18ms)}.undo-toast{position:fixed;right:max(18px,env(safe-area-inset-right));bottom:max(18px,env(safe-area-inset-bottom));z-index:130;display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;width:min(440px,calc(100vw - 36px));border:1px solid var(--border-color);border-radius:var(--radius-md);padding:12px;background:var(--bg-surface);box-shadow:var(--shadow-xl)}.undo-toast strong,.undo-toast span{display:block}.undo-toast strong{color:var(--text-main);font-size:.9rem;line-height:1.2}.undo-toast span{margin-top:2px;color:var(--text-muted);font-size:.8rem;font-weight:700}.undo-toast-action,.undo-toast-close{border:1px solid var(--border-color);background:var(--bg-surface-raised);color:var(--text-main);font-weight:800}.undo-toast-action{gap:7px;padding:9px 12px}.undo-toast-close{width:36px;height:36px;padding:0}.undo-toast-action:hover,.undo-toast-close:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}@keyframes celebrationCardPop{0%{opacity:0;transform:translateY(18px) scale(.82) rotate(-2deg)}55%{opacity:1;transform:translateY(-6px) scale(1.04) rotate(1deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}@keyframes celebrationShine{0%{transform:translate(0) rotate(16deg)}to{transform:translate(420%) rotate(16deg)}}@keyframes trophyBounce{0%{transform:scale(.4) rotate(-12deg)}50%{transform:scale(1.12) rotate(8deg)}72%{transform:scale(.94) rotate(-3deg)}to{transform:scale(1) rotate(0)}}@keyframes sparkleSpin{0%,to{transform:scale(1) rotate(0)}50%{transform:scale(1.22) rotate(16deg)}}@keyframes confettiBurst{0%{opacity:0;transform:rotate(var(--burst-angle)) translateY(0) scale(.4)}14%{opacity:1}to{opacity:0;transform:rotate(var(--burst-angle)) translateY(-44vh) rotate(160deg) scale(1)}}.turn-in-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.turn-in-card{--series-accent: var(--accent);display:flex;flex-direction:column;gap:14px;border:1px solid var(--border-color);border-left:5px solid var(--series-accent);border-radius:var(--radius-md);padding:20px;background:var(--bg-surface-raised);box-shadow:var(--shadow-sm)}.turn-in-card.complete{background:linear-gradient(135deg,var(--bg-surface-raised),var(--success-bg));border-color:color-mix(in srgb,var(--success) 35%,var(--border-color));border-left-color:var(--success)}.turn-in-card-dc{--series-accent: #2563eb}.turn-in-card-marvel{--series-accent: #dc2626}.turn-in-card-spongebob{--series-accent: #d97706}.turn-in-card-wizard-of-oz{--series-accent: #059669}.turn-in-card-header{display:flex;align-items:start;justify-content:space-between;gap:16px}.turn-in-card h3{margin:0;font-size:1.12rem;font-weight:800;color:var(--text-main)}.turn-in-summary,.turn-in-missing{margin:0;color:var(--text-muted);font-size:.88rem;line-height:1.45}.turn-in-missing{color:var(--danger);font-weight:700}.turn-in-card button,.redeem-dialog-actions button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 14px;background:var(--bg-surface);color:var(--text-main);font-weight:800}.turn-in-card button:not(:disabled):hover,.redeem-dialog-actions button:not(:disabled):hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}.turn-in-card.complete button{border-color:var(--success);background:var(--success);color:#fff}.turn-in-card button:disabled,.redeem-dialog-actions button:disabled{cursor:not-allowed;opacity:.55}.redeem-dialog-backdrop{position:fixed;inset:0;z-index:110;display:grid;place-items:center;padding:24px;background:color-mix(in srgb,var(--bg-main) 58%,transparent)}.redeem-dialog{width:min(460px,100%);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:22px;background:var(--bg-surface-raised);box-shadow:var(--shadow-xl)}.redeem-dialog h3{margin:0 0 6px;font-size:1.25rem;font-weight:800}.redeem-dialog p{margin:0 0 16px;color:var(--text-muted)}.rare-choice{display:flex;flex-direction:column;gap:10px;margin:0 0 18px;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:14px}.rare-choice legend{padding:0 6px;font-size:.82rem;font-weight:800;color:var(--text-main)}.rare-choice label{display:flex;align-items:center;gap:10px;color:var(--text-main);font-weight:700}.redeem-dialog-actions{display:flex;justify-content:end;gap:10px}.redeem-dialog-actions button:last-child{border-color:var(--success);background:var(--success);color:#fff}.tools-page .tools-panel{margin-bottom:0;flex-direction:column;align-items:stretch}.tools-page .tools-panel h3{margin:0 0 4px;font-size:1.1rem;font-weight:700}.tools-page .tools-panel p code{font-size:.85em;padding:1px 5px;border-radius:4px;background:var(--bg-surface-raised);border:1px solid var(--border-color)}.error-banner{margin-bottom:24px;border:1px solid var(--danger);border-radius:var(--radius-md);padding:16px 20px;background:var(--danger-bg);color:var(--danger);font-weight:600;font-size:.9rem;line-height:1.5;box-shadow:var(--shadow-sm)}.utility-panel{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:28px;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;background:var(--bg-surface);box-shadow:var(--shadow-md)}.utility-panel h2{margin:0 0 4px;font-size:1.1rem;font-weight:700}.utility-panel p{margin:0;color:var(--text-muted);font-size:.88rem;line-height:1.4}.import-feedback{margin-top:10px!important;border-radius:var(--radius-sm);padding:9px 11px;font-size:.86rem!important;font-weight:800}.import-feedback.success{background:var(--success-bg);color:var(--success)}.import-feedback.error{background:var(--danger-bg);color:var(--danger)}.utility-actions{display:flex;flex-wrap:wrap;gap:10px}.utility-actions button,.import-button{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 18px;background:var(--bg-surface-raised);color:var(--text-main);font-size:.86rem;font-weight:700}.utility-actions button:hover,.import-button:hover{background:var(--bg-surface);border-color:var(--text-soft);box-shadow:var(--shadow-sm)}.import-button input{display:none}.content-panel{border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:32px;background:var(--bg-surface);box-shadow:var(--shadow-lg);position:relative;overflow:hidden;transition:var(--transition)}.series-toolbar{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:28px;border-bottom:1px solid var(--border-color);padding-bottom:24px}.series-toolbar h2{margin:0 0 6px;font-size:1.8rem;font-weight:800;letter-spacing:-.01em}.series-toolbar p{margin:0;color:var(--text-muted);font-size:.95rem}.search-box{display:flex;align-items:center;gap:10px;width:min(340px,100%);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 16px;background:var(--bg-surface-raised);color:var(--text-muted)}.search-box:focus-within{border-color:var(--accent);background:var(--bg-surface);box-shadow:0 0 0 3px var(--accent-soft)}.search-box input{width:100%;border:0;outline:0;background:transparent;color:var(--text-main);font-size:.9rem}.stats-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px}.stat{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 20px;background:var(--bg-surface-raised);display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-sm);transition:var(--transition)}.stat:hover{border-color:color-mix(in srgb,var(--accent) 25%,var(--border-color))}.stat span{font-size:.82rem;font-weight:600;text-transform:none;color:var(--text-muted);letter-spacing:0}.stat strong{font-family:var(--font-display);font-size:1.6rem;font-weight:800;color:var(--text-main)}.dashboard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-bottom:32px}.dashboard-card{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:24px;background:var(--bg-surface-raised);text-align:left;box-shadow:var(--shadow-sm);align-items:start;position:relative;overflow:hidden}.dashboard-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--series-accent, var(--accent));opacity:.85}.dashboard-card:hover{border-color:var(--accent);background:var(--bg-surface);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.dashboard-card h3{margin:0 0 6px;font-size:1.2rem;font-weight:800;color:var(--text-main)}.dashboard-card-dc{--series-accent: #2563eb}.dashboard-card-marvel{--series-accent: #dc2626}.dashboard-card-spongebob{--series-accent: #d97706}.dashboard-card-wizard-of-oz{--series-accent: #059669}.dashboard-card p{margin:0;color:var(--text-muted);font-size:.88rem}.dashboard-card-percent{font-size:1.8rem;font-weight:800;color:var(--accent)}.progress-track{grid-column:1 / -1;overflow:hidden;height:8px;border-radius:99px;background:var(--border-color);margin:4px 0}.progress-track span{display:block;height:100%;border-radius:inherit;background:var(--accent);transition:width .5s ease-out}.dashboard-card-meta{grid-column:1 / -1;display:flex;justify-content:space-between;align-items:center}.dashboard-card-meta small{color:var(--text-muted);font-size:.78rem;font-weight:600}.completion-banner{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:24px;background:linear-gradient(135deg,var(--bg-surface-raised),var(--accent-soft));margin-bottom:28px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-sm);border-left:6px solid var(--accent)}.completion-banner.complete{border-color:var(--border-color);border-left-color:var(--success);background:linear-gradient(135deg,var(--bg-surface-raised),var(--success-bg))}.completion-main-row{display:flex;align-items:center;justify-content:space-between;gap:20px}.completion-main{display:flex;align-items:center;gap:16px}.completion-icon{display:grid;place-items:center;width:48px;height:48px;border-radius:var(--radius-sm);background:var(--bg-surface);color:var(--accent);box-shadow:var(--shadow-sm);flex-shrink:0}.completion-banner.complete .completion-icon{color:var(--success)}.completion-main h3{margin:0 0 4px;font-size:1.15rem;font-weight:800;font-family:var(--font-display)}.completion-main p{margin:0;color:var(--text-muted);font-size:.88rem;line-height:1.4}.set-count{display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:100px;padding:10px;border-radius:var(--radius-sm);background:var(--bg-surface);box-shadow:var(--shadow-sm);text-align:center}.set-count span{font-size:.75rem;font-weight:600;color:var(--text-muted)}.set-count strong{font-size:1.8rem;font-weight:800;color:var(--text-main)}.missing-line{margin:0;padding-top:10px;border-top:1px dashed var(--border-color);font-size:.84rem;color:var(--danger);font-weight:600}.duplicate-opportunity-panel{border-top:1px solid var(--border-color);padding-top:16px;margin-top:4px;display:flex;flex-direction:column;gap:10px}.duplicate-opportunity-header{display:flex;align-items:center;gap:8px;color:var(--warning);font-weight:700;font-size:.9rem;letter-spacing:0}.duplicate-opportunity-panel p{margin:0;font-size:.88rem;color:var(--text-muted);line-height:1.45}.rares-needed-block{display:flex;flex-direction:column;gap:4px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:10px 14px;box-shadow:var(--shadow-sm)}.rares-needed-block span{font-size:.72rem;font-weight:700;color:var(--text-muted);text-transform:uppercase}.rares-needed-block strong{font-size:.95rem;color:var(--accent-strong);font-weight:800}.duplicate-summary{display:flex;align-items:center;justify-content:space-between;gap:20px;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 20px;background:var(--bg-surface-raised);margin-bottom:20px}.duplicate-summary h3{margin:0 0 4px;font-size:.95rem;font-weight:800}.duplicate-summary p{margin:0;font-size:.85rem;color:var(--text-muted)}.duplicate-summary>span{font-weight:800;background:var(--accent-soft);color:var(--accent-strong);padding:6px 12px;border-radius:99px;font-size:.85rem;white-space:nowrap}.quick-add{border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;background:var(--bg-surface-raised);margin-bottom:24px}.quick-add-heading{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.quick-add-heading h3{margin:0 0 4px;font-size:1.05rem;font-weight:800;display:flex;align-items:center;gap:8px;color:var(--accent)}.quick-add-heading p{margin:0;font-size:.85rem;color:var(--text-muted)}.quick-number{display:flex;gap:8px;flex-shrink:0}.quick-number input{width:90px;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:8px 12px;background:var(--bg-surface);text-align:center;font-weight:700}.quick-number button{background:var(--accent);color:#fff;border-radius:var(--radius-sm);padding:8px 16px;font-weight:700;box-shadow:var(--shadow-sm)}.quick-number button:hover{background:var(--bg-accent-hover)}.quick-card-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;scrollbar-width:thin}.quick-card-row button{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 14px;border:1px solid var(--border-color);background:var(--bg-surface);border-radius:var(--radius-sm);min-width:60px}.quick-card-row button:hover{border-color:var(--accent);background:var(--accent-soft);transform:translateY(-1px)}.quick-card-row span{font-size:.72rem;font-weight:700;color:var(--text-muted)}.quick-card-row strong{font-size:1.1rem;font-weight:800;color:var(--text-main)}.list-controls{display:flex;justify-content:space-between;align-items:center;gap:16px;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:8px;background:var(--bg-surface-raised);margin-bottom:24px}.filter-bar{display:flex;gap:6px;flex-wrap:wrap}.filter-bar button{border:1px solid transparent;border-radius:var(--radius-sm);padding:8px 14px;font-size:.85rem;font-weight:700;color:var(--text-muted);background:transparent}.filter-bar button:hover{background:var(--bg-surface);color:var(--text-main)}.filter-bar button.selected{background:var(--bg-surface);border-color:var(--border-color);color:var(--accent-strong);box-shadow:var(--shadow-sm)}.sort-control{display:flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:6px 12px;background:var(--bg-surface);font-size:.85rem;font-weight:700;color:var(--text-muted)}.sort-control select{border:0;background:transparent;color:var(--text-main);font-weight:700;outline:0;cursor:pointer}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.card-tile{border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-surface);overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;height:100%;position:relative;transition:border-color .2s,box-shadow .2s,transform .2s,opacity .2s}.card-tile.unowned{opacity:.6}.card-tile.unowned:hover{opacity:.95;transform:translateY(-2px);box-shadow:var(--shadow-md)}.card-tile.unowned .card-image img{filter:grayscale(80%) contrast(90%)}.card-tile.unowned:hover .card-image img{filter:none}.card-tile.owned{box-shadow:var(--shadow-md)}.card-tile.owned:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.card-tile.duplicate{border-color:var(--accent)}.card-tile.duplicate:after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;border:1.5px solid var(--accent);opacity:.4}.card-tile.rare{border-color:var(--warning);box-shadow:0 4px 10px #f59e0b14}.card-tile.rare.owned{box-shadow:0 10px 20px #f59e0b1f,var(--shadow-md)}.card-tile.rare.owned:hover{box-shadow:0 12px 24px #f59e0b33,var(--shadow-lg);border-color:var(--accent)}#wizard-of-oz-001.rare.owned{border-color:#fbbf24;box-shadow:0 0 15px #fbbf2459}#wizard-of-oz-010.rare.owned{border-color:#ef4444;box-shadow:0 0 15px #ef444459}#spongebob-005.rare.owned{border-color:#34d399;box-shadow:0 0 15px #34d39959}#marvel-007.rare.owned{border-color:#a855f7;box-shadow:0 0 15px #a855f759}.card-tile.dc-hero{background:linear-gradient(180deg,rgba(59,130,246,.03),var(--bg-surface))}.card-tile.dc-villain{background:linear-gradient(180deg,rgba(239,68,68,.03),var(--bg-surface))}.card-image{aspect-ratio:3 / 4;background:var(--bg-surface-raised);border-bottom:1px solid var(--border-color);position:relative;overflow:hidden}.card-image img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.card-tile:hover .card-image img{transform:scale(1.04)}.floating-count-badge{position:absolute;top:10px;right:10px;background:var(--success);color:#fff;font-weight:800;font-size:.85rem;border-radius:99px;width:26px;height:26px;display:grid;place-items:center;box-shadow:0 4px 6px #00000026;z-index:5}.floating-count-badge.is-duplicate{background:var(--warning);animation:mini-pulse 2s infinite}@keyframes mini-pulse{0%{box-shadow:0 0 #f59e0b80}70%{box-shadow:0 0 0 6px #f59e0b00}to{box-shadow:0 0 #f59e0b00}}.card-body{padding:18px;display:flex;flex-direction:column;flex-grow:1}.card-meta{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px;margin-bottom:10px}.card-number{font-size:.72rem;font-weight:800;background:var(--accent-soft);color:var(--accent-strong);padding:3px 8px;border-radius:99px}.count-pill{font-size:.75rem;font-weight:800;background:var(--success);color:#fff;padding:3px 8px;border-radius:99px}.count-pill.is-duplicate{background:var(--warning)}.rarity{font-size:.72rem;font-weight:600;text-transform:capitalize;letter-spacing:0;padding:3px 8px;border-radius:99px;background:var(--bg-surface-raised);color:var(--text-muted)}.rarity.rare{background:var(--warning-bg);color:var(--warning)}.card-body h3{margin:0 0 12px;font-size:1.1rem;font-weight:800;line-height:1.25;color:var(--text-main);flex-grow:1;display:flex;align-items:center}.quantity-row{display:grid;grid-template-columns:36px 1fr 36px;gap:8px;align-items:center;margin-top:auto}.quantity-row button{height:36px;border:1px solid var(--border-color);background:var(--bg-surface-raised);color:var(--text-main);border-radius:var(--radius-sm);display:grid;place-items:center}.quantity-row button:hover{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent)}.quantity-row label{display:flex;flex-direction:column;align-items:center;gap:2px}.quantity-row label span{font-size:.6rem;font-weight:700;text-transform:uppercase;color:var(--text-soft)}.quantity-row input{width:100%;height:32px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-surface-raised);text-align:center;font-weight:800;font-size:1rem}.quantity-row input:focus{border-color:var(--accent);background:var(--bg-surface)}.save-state{margin:8px 0 0;font-size:.78rem;font-weight:600;text-align:center;color:var(--text-soft);min-height:0}.save-state:empty,.save-state.idle{display:none}.save-state.saving{color:var(--accent);display:block}.save-state.saved{color:var(--success);display:block}.save-state.error{color:var(--danger);display:block}.details-button{width:100%;margin-top:8px;padding:10px;background:var(--bg-surface-raised);border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.8rem;font-weight:700;gap:6px;color:var(--text-muted)}.details-button:hover{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent)}.image-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;height:100%;padding:24px;text-align:center;background:linear-gradient(145deg,var(--bg-surface-raised),color-mix(in srgb,var(--border-color) 40%,var(--bg-surface-raised)));color:var(--text-soft)}.image-fallback strong{font-family:var(--font-display);font-size:1rem;color:var(--text-muted)}.quick-add-count{font-size:1.25rem;font-weight:800;color:var(--text-main);line-height:1}.empty-state{border:2px dashed var(--border-color);border-radius:var(--radius-md);padding:40px 24px;text-align:center;color:var(--text-muted);font-size:.95rem;line-height:1.55;margin:20px 0}.empty-state strong{display:block;margin-bottom:6px;font-family:var(--font-display);font-size:1.15rem;color:var(--text-main)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.drawer-backdrop{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:24px;background:#090d1673;-webkit-backdrop-filter:blur(8px) saturate(140%);backdrop-filter:blur(8px) saturate(140%);animation:fadeIn .24s cubic-bezier(.16,1,.3,1)}.detail-drawer{position:relative;width:min(680px,100%);max-height:min(780px,calc(100vh - 48px));border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:28px;background:var(--bg-surface);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:20px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--text-muted) 52%,transparent) transparent;animation:modalPop .28s cubic-bezier(.16,1,.3,1)}.drawer-close{position:absolute;top:20px;right:20px;display:grid;place-items:center;width:36px;height:36px;border:1px solid var(--border-color);border-radius:99px;background:var(--bg-surface-raised);color:var(--text-muted);z-index:10}.drawer-close:hover{background:var(--danger-bg);color:var(--danger);border-color:color-mix(in srgb,var(--danger) 30%,transparent)}.drawer-summary{display:grid;grid-template-columns:minmax(140px,220px) minmax(0,1fr);gap:20px;align-items:start;padding-right:60px}.drawer-summary:not(:has(.drawer-image)){grid-template-columns:1fr}.drawer-image{aspect-ratio:3 / 4;overflow:hidden;border-radius:var(--radius-sm);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);background:var(--bg-surface-raised)}.drawer-image img{width:100%;height:100%;object-fit:cover}.drawer-heading{display:flex;flex-direction:column;gap:8px;min-width:0}.drawer-heading h2{margin:0;font-size:clamp(1.65rem,4vw,2.35rem);font-weight:800;line-height:1.08;overflow-wrap:anywhere}.drawer-quantity{border-top:1px solid var(--border-color);padding-top:20px;margin:0;grid-template-columns:44px minmax(0,1fr) 44px}.drawer-field{display:flex;flex-direction:column;gap:6px}.drawer-field span{font-size:.72rem;font-weight:800;text-transform:uppercase;color:var(--text-muted)}.drawer-field textarea{width:100%;min-height:120px;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:12px;background:var(--bg-surface-raised);color:var(--text-main);resize:vertical;line-height:1.5}.drawer-field textarea:focus{background:var(--bg-surface);border-color:var(--accent);outline:0}.drawer-action{background:var(--accent);color:#fff;padding:12px;border-radius:var(--radius-sm);font-weight:700;box-shadow:var(--shadow-sm);margin-top:8px}.drawer-action:hover{background:var(--bg-accent-hover);box-shadow:var(--shadow-md)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes modalPop{0%{opacity:0;transform:translateY(14px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(max-width:900px){.dashboard-grid{grid-template-columns:1fr;gap:16px}}@media(max-width:780px){.app-shell{width:min(100% - 24px,1200px);padding:24px 0 48px}.app-header{flex-direction:column;align-items:flex-start;gap:16px}.sync-pill{align-self:flex-start}.top-controls{justify-content:stretch}.preference-toggle{flex:1;justify-content:center}.utility-panel{flex-direction:column;align-items:stretch;gap:16px}.utility-actions{justify-content:stretch}.utility-actions button,.import-button{flex:1;justify-content:center}.series-toolbar{flex-direction:column;align-items:stretch;gap:16px}.search-box{width:100%}.list-controls{flex-direction:column;align-items:stretch;gap:12px}.filter-bar{width:100%}.filter-bar button{flex:1}.sort-control{justify-content:space-between}.quick-add-heading{flex-direction:column;align-items:stretch;gap:12px}.quick-number{width:100%}.quick-number input{flex:1}.page-actions{gap:8px}.page-action{flex:1;justify-content:center;min-width:calc(50% - 4px)}.turn-in-grid{grid-template-columns:1fr}.turn-in-card-header{align-items:center}.drawer-backdrop{align-items:end;padding:12px 12px 0}.detail-drawer{width:100%;height:auto;max-height:85vh;border:1px solid var(--border-color);border-bottom:0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -10px 30px #0003;padding:24px 20px 32px;animation:slideInUp .28s cubic-bezier(.16,1,.3,1)}.drawer-summary{grid-template-columns:minmax(90px,120px) 1fr;gap:14px;padding-right:52px}.drawer-close{top:16px;right:16px}}@media(max-width:480px){.drawer-backdrop{padding-inline:8px}.detail-drawer{padding:22px 16px 28px}.drawer-summary{grid-template-columns:minmax(78px,104px) minmax(0,1fr);gap:12px;padding-right:48px}.drawer-heading h2{font-size:1.45rem}.drawer-quantity{grid-template-columns:40px minmax(0,1fr) 40px}.set-complete-celebration{padding:18px}.celebration-card{gap:12px;padding:18px}.celebration-icon{width:50px;height:50px}.celebration-copy{padding-right:32px}.celebration-prize{font-size:.68rem}.celebration-close{top:12px;right:12px}.celebration-sparkle{display:none}.content-panel{padding:20px 16px}.redeem-dialog-backdrop{padding:16px}.redeem-dialog-actions{flex-direction:column-reverse}.redeem-dialog-actions button{width:100%}.card-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.card-tile .card-body{padding:12px}.card-tile .card-body h3{margin-bottom:8px;font-size:.88rem;line-height:1.2}.card-tile .card-meta{margin-bottom:6px}.card-tile .card-number,.card-tile .rarity{font-size:.58rem;padding:2px 6px}.card-tile .quantity-row{grid-template-columns:32px 1fr 32px;gap:6px}.card-tile .quantity-row button{height:32px}.card-tile .quantity-row input{height:28px;font-size:.9rem}.card-tile .details-button{padding:8px;font-size:.72rem}.card-tile .save-state,.card-tile .rare-note{display:none}.stats-strip{grid-template-columns:repeat(2,1fr)}.page-action-back{margin-left:0;width:100%;justify-content:center}.quick-add-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
