:root{--bg: #04130c;--bg-2: #071f14;--panel: #0b271a;--panel-2: #0e3322;--line: #1b4a33;--turf: #18e07a;--turf-deep: #0f9d54;--ink: #eafff4;--ink-dim: #8fc4a9;--ink-faint: #4f8068;--need: #29543c;--danger: #ff6b6b;--foil-1: #ffe79a;--foil-2: #f6c453;--foil-3: #fff6d6;--foil-4: #e0a82e;--safe-t: env(safe-area-inset-top, 0px);--safe-b: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Archivo,system-ui,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overscroll-behavior-y:none}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background:radial-gradient(120% 80% at 50% -10%,rgba(24,224,122,.18),transparent 60%),repeating-linear-gradient(180deg,var(--bg) 0,var(--bg) 64px,var(--bg-2) 64px,var(--bg-2) 128px)}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}button{font-family:inherit;cursor:pointer}.foil-text{background:linear-gradient(100deg,var(--foil-1),var(--foil-2),var(--foil-3),var(--foil-4));background-size:220% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:shimmer 5s linear infinite}@keyframes shimmer{to{background-position:220% center}}.boot{height:100%;display:grid;place-content:center;gap:18px;justify-items:center;color:var(--ink-dim);letter-spacing:.04em}.boot-orb{width:46px;height:46px;border-radius:50%;border:3px solid var(--line);border-top-color:var(--turf);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth{min-height:100%;display:grid;place-items:center;padding:calc(24px + var(--safe-t)) 18px calc(24px + var(--safe-b));position:relative}.auth-glow{position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(24,224,122,.22),transparent 65%);filter:blur(20px);top:-120px}.auth-card{position:relative;width:100%;max-width:420px;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:26px;padding:30px 26px 26px;box-shadow:0 40px 90px -40px #000000e6,inset 0 1px #ffffff0d}.brand{text-align:center;margin-bottom:22px}.brand-kicker{font-size:11px;letter-spacing:.34em;color:var(--turf);font-weight:700}.brand-title{font-family:Anton,sans-serif;font-size:clamp(38px,12vw,54px);line-height:.92;letter-spacing:.01em;margin:8px 0 12px}.brand-sub{color:var(--ink-dim);font-size:14px;line-height:1.5}.seg{display:grid;grid-template-columns:1fr 1fr;background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:4px;margin-bottom:20px}.seg button{border:0;background:transparent;color:var(--ink-dim);padding:11px;border-radius:10px;font-weight:700;font-size:14px;transition:.2s}.seg .seg-on{background:linear-gradient(180deg,var(--turf),var(--turf-deep));color:#04130c;box-shadow:0 6px 18px -6px var(--turf-deep)}.auth-form{display:grid;gap:14px}.field{display:grid;gap:6px}.field span{font-size:12px;letter-spacing:.06em;color:var(--ink-faint);text-transform:uppercase;font-weight:700}.field input{background:var(--bg);border:1px solid var(--line);color:var(--ink);padding:13px 14px;border-radius:12px;font-size:16px;outline:none;transition:.2s}.field input:focus{border-color:var(--turf);box-shadow:0 0 0 3px #18e07a26}.btn-primary{margin-top:6px;border:0;border-radius:13px;padding:15px;font-size:15px;font-weight:800;letter-spacing:.02em;color:#04130c;background:linear-gradient(180deg,var(--turf),var(--turf-deep));box-shadow:0 10px 26px -10px var(--turf-deep);transition:transform .1s}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.6}.error{background:#ff6b6b1f;border:1px solid rgba(255,107,107,.4);color:#ffc4c4;padding:10px 12px;border-radius:10px;font-size:13px}.auth-foot{text-align:center;margin-top:18px;color:var(--ink-dim);font-size:14px}.linklike{background:none;border:0;color:var(--turf);font-weight:700;font-size:14px;padding:0}.vault{padding-bottom:calc(40px + var(--safe-b))}.topbar{position:sticky;top:0;z-index:30;padding-top:var(--safe-t);background:#04130cd1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}.topbar-inner{max-width:1000px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:12px 16px}.topbar-brand{font-family:Anton,sans-serif;font-size:21px;letter-spacing:.01em}.topbar-user{display:flex;align-items:center;gap:12px}.who{color:var(--ink-dim);font-size:14px;font-weight:600}.logout{background:var(--panel);border:1px solid var(--line);color:var(--ink-dim);padding:7px 12px;border-radius:10px;font-size:13px;font-weight:600}.hero{max-width:1000px;margin:0 auto;padding:24px 16px 8px;display:flex;flex-wrap:wrap;gap:22px;align-items:center}.progress-wrap{display:flex;align-items:center;gap:18px}.ring{flex-shrink:0;filter:drop-shadow(0 6px 16px rgba(0,0,0,.4))}.ring-track{fill:none;stroke:var(--line);stroke-width:10}.ring-fill{fill:none;stroke:url(#foil);stroke-width:10;stroke-linecap:round;transition:stroke-dasharray .7s cubic-bezier(.16,1,.3,1)}.ring-text{fill:var(--ink);font-family:Anton,sans-serif;font-size:26px;text-anchor:middle}.big-count{font-family:Anton,sans-serif;font-size:46px;line-height:1}.big-count .of{font-size:20px;color:var(--ink-faint);margin-left:6px}.hero-label{color:var(--ink-dim);font-size:13px;letter-spacing:.08em;text-transform:uppercase;margin-top:4px}.stat-strip{display:flex;gap:10px;margin-left:auto}.stat{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:12px 16px;min-width:78px;text-align:center}.stat-value{font-family:Anton,sans-serif;font-size:26px;line-height:1}.stat-label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:4px}.stat-need .stat-value{color:#ffd089}.stat-doubles .stat-value{color:#8fd6ff}.stat-have .stat-value{color:var(--turf)}.controls{max-width:1000px;margin:0 auto;padding:14px 16px 6px;position:sticky;top:calc(var(--safe-t) + 53px);z-index:20;background:linear-gradient(180deg,var(--bg) 60%,transparent)}.search{width:100%;background:var(--panel);border:1px solid var(--line);color:var(--ink);padding:12px 14px;border-radius:12px;font-size:16px;outline:none}.search:focus{border-color:var(--turf)}.filters{display:flex;gap:8px;margin-top:10px;overflow-x:auto;padding-bottom:2px}.chip{flex-shrink:0;background:var(--panel);border:1px solid var(--line);color:var(--ink-dim);padding:8px 16px;border-radius:999px;font-weight:700;font-size:13px;transition:.15s}.chip-on{background:linear-gradient(180deg,var(--turf),var(--turf-deep));color:#04130c;border-color:transparent}.sections{max-width:1000px;margin:0 auto;padding:6px 16px}.album-section{margin-top:22px}.section-head{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px dashed var(--line)}.section-flag{font-size:26px}.section-head h2{font-family:Anton,sans-serif;font-size:20px;letter-spacing:.02em;text-transform:uppercase;font-weight:400}.section-grp{font-size:11px;font-weight:700;color:var(--turf);background:#18e07a1a;border:1px solid rgba(24,224,122,.3);padding:3px 8px;border-radius:6px;letter-spacing:.05em}.section-count{margin-left:auto;font-size:13px;color:var(--ink-faint);font-weight:700}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:10px}.tile-wrap{display:flex;flex-direction:column;gap:5px;margin:0;min-width:0}.tile-name{font-size:10px;line-height:1.2;text-align:center;color:var(--ink-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tile{position:relative;aspect-ratio:3 / 4;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent;transition:transform .12s ease;overflow:hidden}.tile:active{transform:scale(.94)}.tile-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block;pointer-events:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.tile-need .tile-img{filter:grayscale(1) brightness(.6) contrast(.9);opacity:.45}.tile-owned .tile-img{filter:none;opacity:1}.tile-need{background:repeating-linear-gradient(45deg,transparent,transparent 7px,rgba(255,255,255,.02) 7px,rgba(255,255,255,.02) 8px),var(--bg-2);border:1.5px dashed var(--need);color:var(--ink-faint)}.tile-owned{border:1px solid rgba(255,231,154,.5);color:#2a1c00;background:linear-gradient(135deg,var(--foil-1),var(--foil-2) 40%,var(--foil-3) 55%,var(--foil-4));background-size:200% 200%;box-shadow:0 8px 20px -10px #f6c45399,inset 0 1px #fff9;animation:pop .32s cubic-bezier(.18,1.4,.4,1)}.tile-owned:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.75) 48%,transparent 62%);background-size:250% 250%;animation:foilsweep 4.5s ease-in-out infinite;mix-blend-mode:overlay;pointer-events:none}@keyframes pop{0%{transform:scale(.6) rotate(-6deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}@keyframes foilsweep{0%,to{background-position:0% 0%}50%{background-position:100% 100%}}.tile-foil.tile-need{border-style:solid;border-color:#f6c45366;background:linear-gradient(135deg,#f6c4530f,#ffffff05),var(--bg-2)}.tile-num{position:absolute;top:4px;left:4px;font-family:Anton,sans-serif;font-size:13px;line-height:1;color:#fff;background:#04130cb8;padding:2px 5px;border-radius:6px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.tile-owned .tile-num{background:#2a1c00c7;color:var(--foil-1)}.tile-flag{font-size:30px;line-height:1}.tile-owned .tile-flag{filter:drop-shadow(0 1px 1px rgba(0,0,0,.25))}.tile-glyph{font-size:24px;opacity:.75}.tile-owned .tile-glyph{opacity:1}.tile-silhouette{width:34px;height:34px;border-radius:50% 50% 45% 45%;background:currentColor;opacity:.18}.tile-owned .tile-silhouette{opacity:.32;background:#2a1c00}.tile-check{position:absolute;bottom:5px;right:6px;font-size:13px;font-weight:900;color:var(--turf-deep)}.tile-doubles{position:absolute;top:4px;right:4px;background:#04130c;color:var(--foil-2);border:1px solid var(--foil-4);border-radius:8px;font-size:11px;font-weight:800;padding:2px 6px;line-height:1.1}.tile-add{position:absolute;bottom:4px;left:5px;width:22px;height:22px;border-radius:7px;border:1px solid rgba(58,39,0,.4);background:#ffffff59;color:#2a1c00;font-size:16px;font-weight:800;line-height:1;display:grid;place-items:center}.empty{text-align:center;color:var(--ink-faint);padding:50px 0;font-size:15px}.footer-note{text-align:center;color:var(--ink-faint);font-size:13px;line-height:1.6;margin:36px auto 0;max-width:460px}.footer-note b{color:var(--ink-dim)}.fab{position:fixed;right:18px;bottom:calc(20px + var(--safe-b));z-index:40;width:62px;height:62px;border-radius:20px;border:1px solid rgba(255,231,154,.6);font-size:28px;color:#2a1c00;background:linear-gradient(135deg,var(--foil-1),var(--foil-2) 45%,var(--foil-3) 60%,var(--foil-4));box-shadow:0 14px 30px -10px #f6c453b3,inset 0 1px #fff9;transition:transform .12s}.fab:active{transform:scale(.92)}.fab-swap{bottom:calc(94px + var(--safe-b));font-size:30px;color:#04130c;background:linear-gradient(135deg,#5cf0a3,var(--turf) 50%,var(--turf-deep));border:1px solid rgba(24,224,122,.6);box-shadow:0 14px 30px -10px var(--turf-deep),inset 0 1px #fff6}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#020a06b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;animation:fade .2s ease}@keyframes fade{0%{opacity:0}}.sheet{width:100%;max-width:560px;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-bottom:0;border-radius:26px 26px 0 0;padding:14px 20px calc(20px + var(--safe-b));box-shadow:0 -30px 80px -30px #000000e6;animation:slideup .28s cubic-bezier(.16,1,.3,1)}@keyframes slideup{0%{transform:translateY(100%)}}.sheet-grip{width:42px;height:5px;border-radius:999px;background:var(--line);margin:0 auto 14px}.sheet-title{font-family:Anton,sans-serif;font-size:24px;text-transform:uppercase;font-weight:400}.sheet-sub{color:var(--ink-dim);font-size:13px;line-height:1.5;margin:6px 0 14px}.sheet-sub b{color:var(--turf)}.qa-input{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--ink);border-radius:14px;padding:14px;font-size:18px;font-family:Anton,monospace;letter-spacing:.08em;text-transform:uppercase;outline:none;resize:none}.qa-input:focus{border-color:var(--turf);box-shadow:0 0 0 3px #18e07a26}.qa-stats{display:flex;gap:14px;margin:12px 2px 8px;font-size:13px;font-weight:700}.qa-ok{color:var(--turf)}.qa-bad{color:#ffd089}.qa-chips{display:flex;flex-wrap:wrap;gap:7px;max-height:140px;overflow-y:auto;padding:2px}.qa-chip{font-size:13px;font-weight:800;letter-spacing:.03em;padding:5px 10px;border-radius:9px;border:1px solid}.qa-chip-ok{color:#2a1c00;background:linear-gradient(135deg,var(--foil-1),var(--foil-3));border-color:var(--foil-4)}.qa-chip-bad{color:#ffc4c4;background:#ff6b6b1a;border-color:#ff6b6b73}.qa-x{margin-left:4px;opacity:.7}.sheet-actions{display:flex;gap:10px;margin-top:18px}.sheet-actions .btn-primary{flex:1;margin-top:0}.btn-ghost{background:var(--panel);border:1px solid var(--line);color:var(--ink-dim);border-radius:13px;padding:15px 20px;font-weight:700;font-size:15px}.swapbtn{background:#18e07a1f;border:1px solid rgba(24,224,122,.4);color:var(--turf);padding:7px 12px;border-radius:10px;font-size:13px;font-weight:800;letter-spacing:.02em}.iconbtn{background:var(--panel);border:1px solid var(--line);color:var(--ink-dim);width:36px;height:34px;border-radius:10px;font-size:16px;line-height:1;display:grid;place-items:center}.toast-undo{background:#04130c40;border:1px solid rgba(4,19,12,.4);color:#04130c;font-weight:800;font-size:13px;padding:4px 12px;border-radius:9px;margin-left:4px}.hist-list{margin-top:12px;display:flex;flex-direction:column;gap:8px;max-height:60vh;overflow-y:auto}.hist-row{display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:10px 12px}.hist-time{font-size:12px;color:var(--ink-faint);font-variant-numeric:tabular-nums;flex-shrink:0}.hist-label{font-size:14px;font-weight:600;flex:1;min-width:0}.hist-undone{opacity:.5}.hist-undone .hist-label{text-decoration:line-through}.hist-tag{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-faint);flex-shrink:0}.sheet-tall{max-height:88vh;overflow-y:auto}.seg-sm button{padding:9px;font-size:13px}.swap-body{margin-top:14px}.list-block{background:var(--bg);border:1px solid var(--line);border-radius:16px;padding:14px;margin-bottom:14px}.list-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.list-title{font-family:Anton,sans-serif;font-size:17px;text-transform:uppercase}.list-hint{color:var(--ink-faint);font-size:12px;margin-top:2px}.list-btns{display:flex;gap:6px;flex-shrink:0}.btn-mini{padding:7px 12px;font-size:12px;border-radius:9px}.code-box{margin-top:10px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--ink-dim);word-spacing:4px;line-height:1.7;max-height:110px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.code-empty{color:var(--ink-faint);font-weight:500;letter-spacing:0}.swap-result-head{display:flex;align-items:center;justify-content:space-between;margin:14px 2px 8px;font-size:14px;color:var(--ink-dim)}.swap-result-head b{color:var(--turf);font-size:16px}.link-copy{background:none;border:0;color:var(--turf);font-weight:800;font-size:13px}.swap-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.scroll-grid{max-height:46vh;overflow-y:auto;margin-top:10px;padding:4px 4px 2px;background:var(--bg);border:1px solid var(--line);border-radius:14px;-webkit-overflow-scrolling:touch}.mini-badge{position:absolute;top:4px;right:4px;font-size:10px;font-weight:800;letter-spacing:.02em;padding:2px 5px;border-radius:7px;background:#04130cc7;color:var(--foil-2);border:1px solid var(--foil-4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.tile-need .mini-badge{color:var(--ink-dim);border-color:var(--line);background:#04130cd9}.muted{color:var(--ink-faint)}.copy-flash{position:fixed;left:50%;bottom:30px;transform:translate(-50%);z-index:60;background:var(--turf);color:#04130c;font-weight:800;font-size:13px;padding:10px 16px;border-radius:12px;animation:toastin .25s ease}.detail-top{display:flex;gap:16px;align-items:center;margin:16px 0 20px}.detail-card{position:relative;width:116px;flex-shrink:0;aspect-ratio:3 / 4;border-radius:14px;overflow:hidden}.detail-card .tile-img{filter:none!important;opacity:1!important}.detail-meta{min-width:0}.detail-code{font-family:Anton,sans-serif;font-size:26px;letter-spacing:.02em;display:flex;align-items:center;gap:8px}.detail-code span{font-size:22px}.detail-name{font-size:17px;font-weight:700;margin-top:2px;line-height:1.25}.detail-team{color:var(--ink-dim);font-size:13px;margin-top:4px}.detail-status{margin-top:10px;display:inline-block;font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:5px 10px;border-radius:8px;color:var(--ink-faint);background:var(--bg);border:1px solid var(--line)}.detail-status.on{color:var(--turf);border-color:#18e07a66;background:#18e07a1a}.stepper{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--bg);border:1px solid var(--line);border-radius:18px;padding:10px}.step-btn{width:60px;height:60px;flex-shrink:0;border-radius:14px;border:1px solid var(--line);background:var(--panel-2);color:var(--ink);font-size:34px;font-weight:700;line-height:1;display:grid;place-items:center;transition:transform .1s}.step-btn:active{transform:scale(.9)}.step-btn:disabled{opacity:.35}.step-val{text-align:center;line-height:1.1}.step-val b{font-family:Anton,sans-serif;font-size:38px;display:block}.step-val span{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}.detail-actions{display:flex;gap:10px;margin-top:16px}.toast{position:fixed;left:50%;transform:translate(-50%);bottom:calc(96px + var(--safe-b));z-index:45;background:linear-gradient(180deg,var(--turf),var(--turf-deep));color:#04130c;font-weight:800;font-size:14px;padding:12px 18px;border-radius:14px;box-shadow:0 14px 30px -10px #0009;animation:toastin .3s cubic-bezier(.16,1,.3,1);max-width:92vw;display:flex;align-items:center;gap:8px}@keyframes toastin{0%{transform:translate(-50%,20px);opacity:0}}@media(max-width:560px){.hero{gap:16px}.stat-strip{width:100%;margin-left:0}.stat{flex:1;min-width:0}.big-count{font-size:40px}.grid{grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px}}
