:root{--bg: #0b1020;--surface: #141a33;--text: #e8ecff;--muted: #8890b8;--accent: #22c2ff;--c1: #ef4667;--c2: #22c2ff;--c3: #ffd166;--c4: #5cf083;--c5: #b57bff;--c6: #ff8a3d;--tile-radius: 10%;--gap: 2px}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-feature-settings:"tnum";-webkit-tap-highlight-color:transparent;overscroll-behavior:none;user-select:none;-webkit-user-select:none;touch-action:manipulation}#app{min-height:100dvh;display:flex;flex-direction:column;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}header.topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:12px 16px;gap:8px}.brand{font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:14px;color:var(--muted)}.mode-pill{display:inline-flex;gap:4px;background:var(--surface);padding:4px;border-radius:999px}.mode-pill button{background:transparent;color:var(--muted);border:0;padding:6px 14px;border-radius:999px;font-weight:600;font-size:13px;cursor:pointer}.mode-pill button.active{background:var(--text);color:var(--bg)}.icon-buttons{display:flex;gap:6px;justify-self:end}.menu-btn{background:var(--surface);color:var(--text);border:0;width:36px;height:36px;border-radius:10px;font-size:18px;cursor:pointer}.stats{display:flex;justify-content:space-around;padding:8px 16px 16px}.stat{display:flex;flex-direction:column;align-items:center}.stat .label{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em}.stat .value{font-size:26px;font-weight:700;font-variant-numeric:tabular-nums}main.board-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:8px 12px}.board{display:grid;width:min(100vw - 24px,60vh,480px);aspect-ratio:var(--cols) / var(--rows);grid-template-columns:repeat(var(--cols),1fr);grid-template-rows:repeat(var(--rows),1fr);gap:var(--gap);background:var(--surface);padding:var(--gap);border-radius:14px;box-shadow:0 20px 60px -20px #0009}.tile{border-radius:var(--tile-radius);background:var(--bg);transition:transform .18s cubic-bezier(.2,.9,.3,1.4),opacity .18s ease;position:relative}.tile[data-c="0"]{background:transparent}.tile[data-c="1"]{background:var(--c1)}.tile[data-c="2"]{background:var(--c2)}.tile[data-c="3"]{background:var(--c3)}.tile[data-c="4"]{background:var(--c4)}.tile[data-c="5"]{background:var(--c5)}.tile[data-c="6"]{background:var(--c6)}.tile.hint{box-shadow:inset 0 0 0 3px #ffffff59}.tile.pop{transform:scale(0);opacity:0}.powerup-bar{display:flex;justify-content:center;gap:10px;padding:12px 16px 20px}.powerup{position:relative;background:var(--surface);color:var(--text);border:0;padding:10px 16px;border-radius:12px;font-size:20px;min-width:60px;cursor:pointer;transition:transform .12s ease,background .12s ease}.powerup:disabled{opacity:.35;cursor:default}.powerup.armed{background:var(--accent);color:var(--bg);transform:scale(1.05)}.powerup.locked{opacity:.55;filter:grayscale(.7)}.powerup.locked:after{content:"🔒";position:absolute;bottom:-4px;right:-4px;font-size:12px;background:var(--bg);border-radius:999px;padding:2px 4px}.powerup .count{position:absolute;top:-6px;right:-6px;background:var(--c1);color:#fff;font-size:11px;font-weight:700;border-radius:999px;padding:2px 6px;min-width:18px;text-align:center}.powerup.locked .count{background:var(--surface);color:var(--muted)}.point-burst{position:fixed;transform:translate(-50%,-50%);pointer-events:none;z-index:8;font-weight:800;color:var(--text);text-align:center;text-shadow:0 2px 12px rgba(0,0,0,.7);font-variant-numeric:tabular-nums}.burst-value{font-size:24px;line-height:1}.burst-label{font-size:12px;letter-spacing:.12em;color:var(--accent);text-transform:uppercase;margin-bottom:4px;font-weight:900}.point-burst.tier-0{animation:burst-fly 1.2s cubic-bezier(.3,.7,.2,1) forwards}.point-burst.tier-1{animation:burst-hold-fly 2.4s ease-out forwards}.point-burst.tier-2{animation:burst-hold-fly 2.8s ease-out forwards}.point-burst.tier-3{animation:burst-hold-fly 3.2s ease-out forwards}.point-burst.tier-4{animation:burst-hold-fly 2.8s ease-out forwards}.point-burst.tier-1,.point-burst.tier-2,.point-burst.tier-3{padding:10px 18px;background:#0a0f20bf;border-radius:14px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 30px -6px #0000008c}.point-burst.tier-1 .burst-value{font-size:32px}.point-burst.tier-2{background:#0a0f20cc;box-shadow:0 8px 30px -4px #ffd16640,0 8px 30px -6px #0000008c}.point-burst.tier-2 .burst-value{font-size:40px;color:#ffd166;text-shadow:0 0 18px rgba(255,209,102,.6)}.point-burst.tier-2 .burst-label{color:#ffd166;font-size:15px}.point-burst.tier-3{background:#140a0ad1;box-shadow:0 8px 34px -4px #ff3b3b4d,0 8px 34px -6px #0009}.point-burst.tier-3 .burst-value{font-size:52px;color:#ff3b3b;text-shadow:0 0 22px rgba(255,59,59,.7)}.point-burst.tier-3 .burst-label{color:#ff3b3b;font-size:20px}.point-burst.tier-4{padding:12px 20px;background:linear-gradient(135deg,#22c2ffe6,#b57bffe6);border-radius:14px;box-shadow:0 8px 30px -4px #22c2ff73,0 8px 30px -6px #0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.point-burst.tier-4 .burst-value{font-size:38px;color:#0b1020}.point-burst.tier-4 .burst-label{color:#0b1020;font-size:15px;letter-spacing:.14em}@keyframes burst-fly{0%{transform:translate(-50%,-50%) scale(1);opacity:1}48%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.72);opacity:1}82%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.72);opacity:1}to{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.6);opacity:0}}@keyframes burst-hold-fly{0%{transform:translate(-50%,-50%) scale(.5);opacity:0}5%{transform:translate(-50%,-50%) scale(1.35);opacity:1}12%{transform:translate(-50%,-50%) scale(1);opacity:1}50%{transform:translate(-50%,-50%) scale(1);opacity:1}72%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.7);opacity:1}92%{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.7);opacity:1}to{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.6);opacity:0}}.tile-ghost{position:fixed;z-index:7;border-radius:var(--tile-radius);pointer-events:none;transition:transform .42s cubic-bezier(.5,-.3,.2,1.2),box-shadow .42s ease;box-shadow:0 4px 16px #0000004d}.tile-ghost.moving{box-shadow:0 10px 30px #0000008c}.tile-ghost[data-c="1"]{background:var(--c1)}.tile-ghost[data-c="2"]{background:var(--c2)}.tile-ghost[data-c="3"]{background:var(--c3)}.tile-ghost[data-c="4"]{background:var(--c4)}.tile-ghost[data-c="5"]{background:var(--c5)}.tile-ghost[data-c="6"]{background:var(--c6)}#score.pulse{animation:score-pulse .32s ease}@keyframes score-pulse{0%{transform:scale(1);color:var(--text)}40%{transform:scale(1.25);color:var(--accent)}to{transform:scale(1);color:var(--text)}}.celebrate-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;align-items:center;justify-content:center;z-index:30}.celebrate-card{position:relative;text-align:center;animation:celebrate-card 2.6s ease forwards;opacity:0;z-index:2;padding:22px 28px;background:linear-gradient(135deg,#22c2ff2e,#b57bff2e);border-radius:22px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 18px 60px -12px #0009;max-width:320px}@keyframes celebrate-card{0%{transform:scale(.4);opacity:0}10%{transform:scale(1.15);opacity:1}18%{transform:scale(1)}82%{transform:scale(1);opacity:1}to{transform:scale(.9);opacity:0}}.celebrate-kicker{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.28em;color:var(--accent);margin-bottom:6px}.celebrate-title{font-size:44px;font-weight:900;letter-spacing:.02em;color:var(--text);text-shadow:0 4px 28px rgba(0,0,0,.55);line-height:1.1}.celebrate-desc{margin-top:10px;font-size:14px;color:var(--text);opacity:.9;line-height:1.4}.celebrate-swatches{display:flex;justify-content:center;gap:6px;margin-top:14px}.celebrate-swatch{width:26px;height:26px;border-radius:6px;box-shadow:0 0 10px #0006}.celebrate-particles{position:absolute;left:50%;top:50%;width:0;height:0}.celebrate-particle{position:absolute;left:0;top:0;width:14px;height:14px;border-radius:3px;transform:translate(-50%,-50%);animation:celebrate-shoot 1.6s cubic-bezier(.15,.6,.35,1) forwards;box-shadow:0 0 12px currentColor}@keyframes celebrate-shoot{0%{transform:translate(-50%,-50%) scale(.4) rotate(0);opacity:1}70%{opacity:1}to{transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.1) rotate(360deg);opacity:0}}.toast{position:fixed;left:50%;top:30%;transform:translate(-50%,-50%) scale(.9);background:var(--text);color:var(--bg);padding:10px 18px;border-radius:999px;font-weight:700;pointer-events:none;opacity:0;transition:opacity .22s ease,transform .22s ease;z-index:10}.toast.show{opacity:1;transform:translate(-50%,-50%) scale(1)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20}.modal{background:var(--surface);border-radius:18px;padding:24px;max-width:420px;width:100%}.modal h2{margin:0 0 8px;font-size:22px}.modal p{color:var(--muted);margin:4px 0 16px;line-height:1.5}.modal .score-big{font-size:48px;font-weight:800;text-align:center;margin:12px 0}.speed-bonus{text-align:center;background:#22c2ff24;color:var(--accent);padding:8px 12px;border-radius:10px;font-weight:600;font-size:14px;margin:8px 0 4px;transition:background .25s ease,transform .25s ease}.speed-bonus strong{color:var(--text);font-variant-numeric:tabular-nums}.speed-bonus.awarded{animation:speed-bonus-pop .65s cubic-bezier(.2,.9,.3,1.2);background:#22c2ff52;box-shadow:0 0 24px -4px #22c2ff8c}@keyframes speed-bonus-pop{0%{transform:scale(.94)}35%{transform:scale(1.08)}to{transform:scale(1)}}.score-big{transition:transform .15s ease}.modal .actions{display:flex;gap:8px;margin-top:16px}.modal button{flex:1;background:var(--text);color:var(--bg);border:0;padding:14px;border-radius:12px;font-weight:700;font-size:15px;cursor:pointer}.modal button.ghost{background:transparent;color:var(--text);box-shadow:inset 0 0 0 1px var(--muted)}.theme-cat-toggle{display:flex;gap:4px;background:var(--bg);padding:4px;border-radius:999px;margin:10px auto;width:fit-content}.theme-cat-toggle button{background:transparent;color:var(--muted);border:0;padding:8px 18px;border-radius:999px;font-weight:700;font-size:13px;cursor:pointer}.theme-cat-toggle button.active{background:var(--text);color:var(--bg)}.theme-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:8px}.theme-card{background:var(--bg);border-radius:12px;padding:12px;cursor:pointer;border:2px solid transparent}.theme-card.active{border-color:var(--accent)}.theme-card.locked{opacity:.4;cursor:not-allowed}.theme-card .swatches{display:flex;gap:4px;margin-bottom:8px}.swatch{width:16px;height:16px;border-radius:4px}.theme-card .name{font-weight:700;font-size:13px}.theme-card .hint{font-size:11px;color:var(--muted)}.name-row{display:flex;flex-direction:column;gap:6px;margin:8px 0 4px}.name-row span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.name-row input{background:var(--bg);color:var(--text);border:1px solid var(--surface);padding:12px 14px;font-size:16px;border-radius:10px;font-family:inherit;min-width:0}.name-row input:focus{outline:none;border-color:var(--accent)}.name-edit{display:grid;grid-template-columns:1fr auto;gap:8px}.shuffle-btn{background:var(--bg);color:var(--text);border:1px solid var(--surface);font-size:20px;border-radius:10px;width:48px;cursor:pointer;transition:transform .2s ease,border-color .12s ease}.shuffle-btn:hover{border-color:var(--accent)}.shuffle-btn:active{transform:rotate(180deg)}.section-title{margin:18px 0 4px;font-size:16px;font-weight:700}.subtle{font-size:12px;color:var(--muted);margin:0 0 10px}.leader-hint a{color:var(--accent);text-decoration:none;font-weight:600}.leader-hint a:hover{text-decoration:underline}.period-tabs{display:flex;gap:4px;background:var(--bg);padding:4px;border-radius:999px;margin:12px auto 8px;width:fit-content}.period-tabs button{background:transparent;color:var(--muted);border:0;padding:10px 22px;border-radius:999px;font-weight:700;font-size:14px;cursor:pointer;transition:background .12s ease,color .12s ease}.period-tabs button.active{background:var(--accent);color:var(--bg);box-shadow:0 2px 12px -2px var(--accent)}.period-meta{display:flex;justify-content:space-between;align-items:baseline;padding:0 4px 10px;font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}.period-range{font-weight:700;letter-spacing:.04em;text-transform:uppercase}.period-countdown{opacity:.85}.leader-hint{text-align:center;padding:24px 0;color:var(--muted)}.leader-list{list-style:none;margin:8px 0;padding:0;max-height:50vh;overflow-y:auto}.leader-list li{display:grid;grid-template-columns:36px 1fr auto auto;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;font-variant-numeric:tabular-nums}.leader-list .time{color:var(--muted);font-size:12px;font-weight:600}.leader-list li:nth-child(odd){background:#ffffff08}.leader-list li.me{background:#22c2ff26;box-shadow:inset 0 0 0 1px var(--accent)}.leader-list .rank{color:var(--muted);font-size:13px;font-weight:700;text-align:right}.leader-list li:nth-child(1) .rank{color:#ffd166}.leader-list li:nth-child(2) .rank{color:#c8d0ff}.leader-list li:nth-child(3) .rank{color:#ff8a3d}.leader-list .name{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leader-list .score{font-weight:700;font-size:15px}
