*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0;overflow:hidden;overscroll-behavior:none}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#07080d;color:#e9ecf3;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:none}.app{position:relative;width:100vw;height:calc(100vh - 52px);height:calc(100dvh - 52px);overflow:hidden;background:radial-gradient(1200px 600px at 30% -10%,rgba(99,102,241,.18),transparent 60%),radial-gradient(1000px 600px at 80% 110%,rgba(244,63,94,.15),transparent 60%),linear-gradient(180deg,#0a0c14,#06070b)}.stage{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;animation:screenIn .28s cubic-bezier(.2,.7,.2,1)}@keyframes screenIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.h1{font-size:34px;font-weight:800;letter-spacing:-.02em;line-height:1.05}.h2{font-size:22px;font-weight:700;letter-spacing:-.01em}.h3{font-size:16px;font-weight:600;letter-spacing:-.005em}.lbl-up{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#e9ecf38c}.muted{color:#e9ecf399}.dim{color:#e9ecf366}.mono{font-variant-numeric:tabular-nums}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;font:inherit;font-weight:600;cursor:pointer;border-radius:14px;padding:14px 18px;display:inline-flex;align-items:center;justify-content:center;gap:10px;transition:transform .12s ease,background .15s ease,box-shadow .15s ease;min-height:48px;color:#0a0c14;background:#e9ecf3}.btn:active{transform:scale(.97)}.btn-primary{color:#07080d;background:linear-gradient(180deg,#b9f04a,#74d717);box-shadow:0 6px 24px -8px #aae8468c,inset 0 1px #fff6}.btn-ghost{background:#ffffff0f;color:#e9ecf3;border:1px solid rgba(255,255,255,.08)}.btn-ghost:hover{background:#ffffff1a}.btn-danger{background:#f43f5e29;color:#ff7c8b;border:1px solid rgba(244,63,94,.3)}.btn-icon{width:44px;height:44px;padding:0;border-radius:12px;background:#ffffff0f;color:#e9ecf3;border:1px solid rgba(255,255,255,.08);min-height:unset}.btn-icon:hover{background:#ffffff1a}.btn-block{width:100%}.card{background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:18px;padding:16px}.card-tap{cursor:pointer;transition:background .15s,border-color .15s,transform .12s}.card-tap:active{transform:scale(.98)}.card-tap:hover{background:#ffffff12}.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 8px;flex-shrink:0}.topbar h1{font-size:18px;font-weight:700;margin:0}.safe-top{padding-top:max(14px,env(safe-area-inset-top))}.safe-bot{padding-bottom:max(14px,env(safe-area-inset-bottom))}.scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y;padding:4px 16px 24px}.scroll::-webkit-scrollbar{width:6px}.scroll::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}.game-wrap{position:relative;flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.game-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;display:block;touch-action:none}.hud{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:max(12px,env(safe-area-inset-top)) 14px 8px;pointer-events:none;z-index:5}.hud>*{pointer-events:auto}.scoreboard{display:flex;gap:8px;align-items:center;padding:8px 14px;border-radius:999px;background:#07080d8c;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.08);font-weight:700;font-size:18px;font-variant-numeric:tabular-nums}.scoreboard .vs{color:#ffffff59;font-weight:500;font-size:14px}.scoreboard .me{color:var(--c-me, #b9f04a)}.scoreboard .op{color:var(--c-op, #ff7c8b)}.toast{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:6;font-weight:800;letter-spacing:-.02em}.toast .num{font-size:120px;color:#ffffffeb;text-shadow:0 0 40px rgba(180,220,255,.35);animation:pop .8s ease}.toast .goal{font-size:64px;color:#b9f04a;text-shadow:0 0 40px rgba(180,240,70,.55);animation:goalPop .9s cubic-bezier(.2,.9,.3,1)}@keyframes pop{0%{transform:scale(.6);opacity:0}20%{transform:scale(1.1);opacity:1}80%{transform:scale(1);opacity:1}to{transform:scale(.9);opacity:0}}@keyframes goalPop{0%{transform:scale(.4) rotate(-6deg);opacity:0}30%{transform:scale(1.15) rotate(2deg);opacity:1}to{transform:scale(1) rotate(0);opacity:1}}.modal-back{position:absolute;top:0;right:0;bottom:0;left:0;background:#05060aa6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:20;animation:fade .2s ease;padding:20px}.modal{width:100%;max-width:360px;background:#11141d;border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:22px;animation:modalIn .25s cubic-bezier(.2,.7,.2,1)}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{transform:translateY(20px) scale(.97);opacity:0}to{transform:none;opacity:1}}.pills{display:flex;gap:8px;flex-wrap:wrap}.pill{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:#e9ecf3;border-radius:999px;padding:8px 14px;font:inherit;font-weight:600;font-size:13px;cursor:pointer}.pill[aria-pressed=true]{background:#e9ecf3;color:#07080d;border-color:#e9ecf3}.row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:14px}.row+.row{margin-top:8px}.row .icon-bub{width:40px;height:40px;display:grid;place-items:center;border-radius:12px;background:#ffffff0f;flex-shrink:0}.row .grow{flex:1;min-width:0}.row .ttl{font-weight:600;font-size:15px}.row .sub{font-size:12px;color:#e9ecf38c;margin-top:2px}.bottom-nav{display:flex;gap:4px;padding:6px;margin:0 16px;margin-bottom:max(12px,env(safe-area-inset-bottom));background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:18px;flex-shrink:0}.bottom-nav button{flex:1;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:#e9ecf38c;font:inherit;font-weight:600;font-size:11px;padding:10px 4px;border-radius:12px;display:flex;flex-direction:column;gap:4px;align-items:center;cursor:pointer}.bottom-nav button[aria-pressed=true]{background:#ffffff14;color:#e9ecf3}.bottom-nav .nav-ic{font-size:18px;line-height:1}.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 11px;border-radius:999px;background:#ffc83c1f;color:#ffd766;font-weight:700;font-size:13px;border:1px solid rgba(255,200,60,.25)}.chip-dim{background:#ffffff0f;color:#e9ecf3b3;border-color:#ffffff1a}.tile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.tile{border:1px solid rgba(255,255,255,.07);background:#ffffff08;border-radius:16px;padding:14px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:border-color .15s,transform .12s;position:relative;overflow:hidden}.tile:active{transform:scale(.97)}.tile.equipped{border-color:#b9f04a;box-shadow:0 0 0 2px #b9f04a40}.tile.locked .preview{opacity:.4}.tile .preview{width:72px;height:72px;border-radius:50%;display:grid;place-items:center}.tile .name{font-size:13px;font-weight:600}.tile .lock-bub{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;background:#00000080;display:grid;place-items:center;font-size:12px}.equipped-tag{position:absolute;top:8px;left:8px;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:#b9f04a;color:#07080d;padding:3px 6px;border-radius:6px}.bar{height:6px;background:#ffffff14;border-radius:999px;overflow:hidden}.bar>i{display:block;height:100%;background:linear-gradient(90deg,#74d717,#b9f04a);border-radius:999px;transition:width .4s ease}.switch{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:44px;height:26px;background:#ffffff1a;border:0;border-radius:999px;position:relative;cursor:pointer;transition:background .15s;flex-shrink:0}.switch:after{content:"";position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .18s cubic-bezier(.4,1.4,.5,1)}.switch[aria-checked=true]{background:#74d717}.switch[aria-checked=true]:after{transform:translate(18px)}.range{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:#ffffff1f;border-radius:999px;outline:none}.range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:#fff;border-radius:50%;cursor:pointer;box-shadow:0 2px 6px #0006}.range::-moz-range-thumb{width:18px;height:18px;background:#fff;border:0;border-radius:50%;cursor:pointer}.ach-toast{position:absolute;top:max(14px,env(safe-area-inset-top));left:50%;transform:translate(-50%);background:linear-gradient(180deg,#14161ef2,#0f1118f2);border:1px solid rgba(185,240,74,.35);border-radius:14px;padding:10px 14px;display:flex;align-items:center;gap:10px;z-index:30;animation:achIn .4s cubic-bezier(.2,.9,.3,1),achOut .4s ease 3.6s forwards;box-shadow:0 12px 36px #00000080;max-width:calc(100% - 32px)}@keyframes achIn{0%{transform:translate(-50%,-120%)}to{transform:translate(-50%)}}@keyframes achOut{to{transform:translate(-50%,-120%);opacity:0}}.ach-toast .ic{font-size:22px}.ach-toast .ttl{font-size:13px;font-weight:700}.ach-toast .sub{font-size:11px;color:#e9ecf399}.rotate-prompt{position:absolute;top:0;right:0;bottom:0;left:0;background:#07080d;display:none;align-items:center;justify-content:center;flex-direction:column;gap:12px;z-index:100;text-align:center;padding:24px}.app[data-rotate=force-land] .rotate-prompt{display:flex}.app[data-rotate=force-land] .stage>.screen.game-screen{display:none}.tut-arrow{position:absolute;font-size:28px;pointer-events:none;animation:bob 1.2s ease-in-out infinite}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.no-select{-webkit-user-select:none;user-select:none}.profile-head{display:flex;align-items:center;gap:14px;padding:18px 16px 12px}.avatar{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-weight:800;font-size:22px;background:linear-gradient(135deg,#6366f1,#ec4899);color:#fff;flex-shrink:0}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.stat-cell{background:#ffffff0a;border:1px solid rgba(255,255,255,.06);border-radius:14px;padding:14px}.stat-cell .v{font-size:22px;font-weight:800;letter-spacing:-.01em}.stat-cell .k{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#e9ecf380;margin-top:4px}.dots{display:flex;gap:6px}.dots i{width:10px;height:10px;border-radius:50%;background:#ffffff1f}.dots i.win{background:#b9f04a}.dots i.loss{background:#ff7c8b}.dots i.cur{background:#fff;box-shadow:0 0 0 3px #ffffff2e}.replay-list .row{cursor:pointer}.mode-tile{position:relative;display:flex;flex-direction:column;gap:6px;padding:18px 16px;border-radius:18px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,#ffffff0a,#ffffff05);cursor:pointer;overflow:hidden;min-height:120px;transition:transform .12s,border-color .15s,background .15s}.mode-tile:active{transform:scale(.98)}.mode-tile .glyph{position:absolute;right:10px;bottom:6px;font-size:64px;opacity:.15;line-height:1}.mode-tile .ttl{font-weight:700;font-size:17px}.mode-tile .sub{font-size:12px;color:#e9ecf38c;margin-top:2px}.mode-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.mode-grid>.span2{grid-column:span 2}.tut-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;padding:24px;z-index:40}.tut-card{background:#131722;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:18px;width:100%;max-width:360px}.pu-banner{position:absolute;top:60px;left:50%;transform:translate(-50%);background:#07080db3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);padding:6px 12px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.04em;z-index:5;animation:bannerIn .3s ease}@keyframes bannerIn{0%{opacity:0;transform:translate(-50%,-10px)}to{opacity:1;transform:translate(-50%)}}@media (orientation: landscape) and (max-height: 500px){.scroll{padding:4px 24px 16px}}@media (min-width: 700px){.game-wrap{padding:8px 0}.game-wrap .game-canvas{position:relative!important;inset:auto!important;width:auto!important;height:100%!important;aspect-ratio:9 / 16;max-width:100%}}
