:root{color-scheme:dark;--bg: #0c0c0f;--bg-elev: #141418;--bg-chip: rgba(255, 255, 255, .08);--fg: #f5f5f7;--muted: #9a9aa3;--accent: #ffd84b;--accent-ink: #1c1c1e;--keep: #3dd68c;--reject: #ff5c5c;--border: rgba(255, 255, 255, .08);--danger: #ff8585;--safe-top: env(safe-area-inset-top, 0px);--safe-bot: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:15px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;overscroll-behavior:none;touch-action:manipulation}button{font:inherit;border:0;background:transparent;color:inherit;cursor:pointer;padding:0}img{max-width:100%;display:block}.app{display:flex;flex-direction:column;min-height:100vh;padding-bottom:calc(168px + var(--safe-bot))}.topbar{position:sticky;top:0;z-index:5;background:linear-gradient(180deg,#0c0c0ffa,#0c0c0fd9);backdrop-filter:saturate(180%) blur(18px);-webkit-backdrop-filter:saturate(180%) blur(18px);border-bottom:1px solid var(--border);padding:calc(10px + var(--safe-top)) 16px 8px}.topbar-row{display:flex;align-items:center;gap:12px}.title{font-size:17px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.round-badge{font-size:11px;font-weight:600;padding:4px 8px;border-radius:999px;background:var(--bg-chip);color:var(--muted);letter-spacing:.02em;text-transform:uppercase}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px}.stat{background:var(--bg-elev);border:1px solid var(--border);border-radius:12px;padding:8px 10px;text-align:left}.stat-accent{background:#ffd84b1a;border-color:#ffd84b38}.stat-value{font-size:20px;font-weight:700;letter-spacing:-.015em;line-height:1.05}.stat-label{font-size:11px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stat-hint{opacity:.7}.filter{display:flex;gap:6px;margin-top:10px}.pill{flex:1;padding:7px 10px;border-radius:999px;background:var(--bg-chip);color:var(--fg);font-size:13px;font-weight:500;transition:background .12s ease}.pill-active{background:var(--fg);color:var(--bg);font-weight:600}.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px;padding:4px}@media (min-width: 560px){.grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 860px){.grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 1200px){.grid{grid-template-columns:repeat(5,1fr)}}.card{position:relative;aspect-ratio:4 / 3;overflow:hidden;background:#111;border-radius:10px;transition:transform .08s ease,box-shadow .12s ease,opacity .12s ease;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.card img{width:100%;height:100%;object-fit:cover;pointer-events:none}.card-reject img{opacity:.42;filter:grayscale(.45)}.card-reject{outline:2px solid var(--reject);outline-offset:-2px}.card-keep{outline:2px solid transparent}.card:active{transform:scale(.985)}.card-overlay{position:absolute;left:6px;bottom:6px;display:flex;gap:4px}.chip{font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.chip-keep{background:#3dd68c2e;color:#a9f0c8}.chip-reject{background:#ff5c5c33;color:#ffc1c1}.empty{padding:48px 20px;text-align:center;color:var(--muted)}.lightbox{position:fixed;inset:0;background:#000000eb;z-index:20;display:flex;align-items:center;justify-content:center}.lb-stage{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px}.lb-img{max-width:100%;max-height:calc(100vh - 180px);object-fit:contain;border-radius:8px}.lb-close{position:absolute;top:calc(10px + var(--safe-top));right:10px;width:40px;height:40px;border-radius:20px;background:#ffffff1f;font-size:22px;line-height:1}.lb-caption{color:var(--muted);font-size:13px;margin-top:12px;display:flex;gap:10px;align-items:center}.lb-fname{max-width:60vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-count{color:var(--fg);opacity:.7}.lb-actions{display:flex;align-items:center;gap:10px;margin-top:14px;padding-bottom:var(--safe-bot)}.lb-arrow{width:44px;height:44px;border-radius:22px;background:#ffffff1a;font-size:24px;line-height:1}.lb-arrow:disabled{opacity:.35}.lb-toggle{padding:12px 22px;border-radius:24px;font-weight:600;font-size:15px;min-width:160px}.lb-toggle.is-keep{background:var(--reject);color:#fff}.lb-toggle.is-reject{background:var(--keep);color:#03140b}.bottombar{position:fixed;left:0;right:0;bottom:0;z-index:10;background:linear-gradient(180deg,#0c0c0f99,#0c0c0ff7);backdrop-filter:saturate(180%) blur(18px);-webkit-backdrop-filter:saturate(180%) blur(18px);border-top:1px solid var(--border);padding:10px 14px calc(10px + var(--safe-bot));display:flex;flex-direction:column;gap:8px}.name-input{width:100%;padding:10px 14px;border-radius:12px;background:var(--bg-elev);border:1px solid var(--border);color:var(--fg);font-size:14px}.name-input:focus{outline:2px solid rgba(255,216,75,.32);border-color:#ffd84b8c}.submit-btn{width:100%;padding:14px;border-radius:14px;background:var(--accent);color:var(--accent-ink);font-size:15px;font-weight:700;letter-spacing:-.005em;box-shadow:0 6px 20px #ffd84b38}.submit-btn:active{transform:translateY(1px)}.submit-btn:disabled{opacity:.6;box-shadow:none}.save-hint{color:var(--muted);font-size:12px;text-align:center}.error-inline{color:var(--danger);font-size:12px;text-align:center}.splash{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px;text-align:center}.logo{font-size:56px}.splash-msg{max-width:340px;color:var(--muted);font-size:15px;line-height:1.45}.submitted{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px 20px calc(40px + var(--safe-bot));gap:10px}.submitted .logo{width:72px;height:72px;border-radius:36px;background:var(--keep);color:#03140b;font-size:36px;line-height:72px;margin-bottom:8px}.submitted h1{font-size:24px;font-weight:700;margin:4px 0 0;letter-spacing:-.015em}.submitted p{max-width:420px;color:var(--fg)}.submitted .muted{color:var(--muted);font-size:13px}.summary{display:flex;gap:18px;margin:16px 0 8px;color:var(--muted)}.summary b{color:var(--fg);font-size:18px;margin-right:4px}.secondary-btn{margin-top:14px;padding:10px 18px;border-radius:999px;background:var(--bg-chip);color:var(--fg);font-size:14px;font-weight:600}
