:root{color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;height:100%}body{background:#12102a;color:#fff;font-family:Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased}#app{min-height:100dvh}.screen{min-height:100dvh;display:flex}.screen[hidden]{display:none}.import{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:32px 24px;max-width:480px;margin:0 auto;width:100%}.import__title{font-family:Fredoka One,system-ui,sans-serif;font-size:40px;font-weight:400;margin:0}.import__body{width:100%;display:flex;flex-direction:column;align-items:stretch;gap:16px}.import__load{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:160px;padding:24px;border:2px dashed rgba(255,255,255,.25);border-radius:20px;background:#ffffff0a;cursor:pointer;transition:border-color .15s,background .15s}.import__load:hover,.import__load:focus-within{border-color:#ffffff80;background:#ffffff12}.import__load-icon{font-size:40px;line-height:1}.import__load-text{font-family:Fredoka One,system-ui,sans-serif;font-size:24px}.import__file{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.import__hint{margin:0;text-align:center;font-size:14px;color:#ffffff80}.import__error{margin:0;padding:16px;border-radius:14px;background:#dc50501f;border:1px solid rgba(220,80,80,.35);color:#ffd9d9;font-size:15px;line-height:1.4}.preview__count{margin:0;font-size:20px;font-weight:600}.preview__warn{margin:0;font-size:14px;color:#ffe2a8}.preview__best-box{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-radius:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.preview__best{margin:0;font-size:13px;color:#ffffffb3;font-variant-numeric:tabular-nums}.preview__section-label{margin:4px 0 0;font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#ffffff73}.preview__columns{display:flex;align-items:center;gap:8px}.pill{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;padding:10px 14px;border-radius:14px;background:#ffffff12;border:1px solid rgba(255,255,255,.12)}.pill__label{font-size:12px;font-weight:600;color:#ffffff80}.pill__value{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.flip-btn{flex:0 0 auto;width:44px;height:44px;border-radius:12px;border:1px solid rgba(255,255,255,.15);background:#ffffff12;color:#fff;font-size:22px;cursor:pointer;transition:background .15s}.flip-btn:hover{background:#ffffff24}.preview__list{display:flex;flex-direction:column;max-height:180px;overflow-y:auto;border-radius:14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1)}.preview__item{padding:12px 16px}.preview__item+.preview__item{border-top:1px solid rgba(255,255,255,.08)}.preview__target{font-size:16px;font-weight:600}.preview__translation{font-size:14px;color:#fff9}.btn-start{margin-top:8px;min-height:56px;border:none;border-radius:16px;background:#fff;color:#12102a;font-family:Fredoka One,system-ui,sans-serif;font-size:20px;cursor:pointer;transition:transform .1s,box-shadow .15s;box-shadow:0 8px 24px #00000059}.btn-start:active{transform:scale(.98)}.ghost-link{align-self:center;background:none;border:none;color:#ffffff8c;font-size:14px;text-decoration:underline;cursor:pointer;padding:8px}.ghost-link:hover{color:#ffffffd9}.mode-select{display:flex;gap:8px}.mode-select__btn{flex:1 1 0;min-height:48px;border-radius:12px;border:1px solid rgba(255,255,255,.15);background:#ffffff12;color:#fff;font-size:16px;cursor:pointer;transition:background .15s,border-color .15s}.mode-select__btn:hover:not(:disabled){background:#ffffff24}.mode-select__btn--active{background:#fff;border-color:#fff;color:#12102a;font-family:Fredoka One,system-ui,sans-serif}.mode-select__btn:disabled{opacity:.35;cursor:not-allowed}.game{position:relative;width:100%;max-width:768px;margin-inline:auto;display:flex;flex-direction:column;min-height:100dvh;background:#12102a;padding:env(safe-area-inset-top) 0 env(safe-area-inset-bottom)}.bg-layer{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:1;transition:opacity 1.2s ease}.hud,.field{position:relative;z-index:1}.hud{display:flex;align-items:center;justify-content:space-between;height:52px;padding:0 8px;flex:0 0 auto}.hud__pause{position:relative;width:44px;height:44px;border:none;background:none;cursor:pointer;border-radius:10px}.hud__pause:before,.hud__pause:after{content:"";position:absolute;top:50%;width:4px;height:16px;border-radius:2px;background:#fff;transform:translateY(-50%)}.hud__pause:before{left:calc(50% - 5px)}.hud__pause:after{left:calc(50% + 1px)}.hud__pause:hover{background:#ffffff1a}.hud__word{font-size:14px;font-weight:600;color:#ffffff80}.hud__right{display:flex;align-items:center;gap:10px;padding-right:8px}.hud__time{font-size:14px;font-weight:600;color:#ffffffb3;font-variant-numeric:tabular-nums}.hud__score{width:60px;text-align:right;font-size:14px;font-weight:600;font-variant-numeric:tabular-nums}.hud__mult{width:30px;text-align:right;font-size:14px;font-weight:700;color:#ffd479;font-variant-numeric:tabular-nums}.field{position:relative;flex:1 1 auto;overflow:hidden}.field__fade{position:absolute;left:0;right:0;bottom:0;height:120px;pointer-events:none;background:linear-gradient(transparent,#0a081899)}.bottom{position:absolute;left:0;right:0;bottom:0;z-index:2;display:flex;flex-direction:column;padding-top:12px;background:linear-gradient(#0a08181f,#0a08188c)}.slots{flex:0 0 auto;min-height:80px;display:flex;align-items:center;justify-content:center;padding:0 16px}.slots__row{display:flex;align-items:flex-end;gap:24px;animation:slots-in .32s ease}.slots__row--complete{animation:slots-out .36s ease forwards}@keyframes slots-in{0%{transform:translateY(24px);opacity:0}to{transform:none;opacity:1}}@keyframes slots-out{0%{transform:none;opacity:1}to{transform:translateY(-28px);opacity:0}}.slots__group{display:flex;gap:12px}.slots__sep{font-size:28px;line-height:1;color:#fff9;padding-bottom:6px}.slot{width:40px;min-height:44px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px;border-bottom:3px solid rgba(255,255,255,.5);font-family:Fredoka One,system-ui,sans-serif;font-size:28px;color:#fff}.slot:not(.slot--filled){cursor:pointer}.slot--filled{border-bottom-color:#fff}.slot--hint{color:#fff0;transition:color .2s ease}.slot--hint.slot--hint-show{color:#ffffff59}.slot--hint.slot--hint-out{color:#fff0;transition:color .3s ease}.translation{flex:0 0 auto;text-align:center;padding:16px 24px 28px;font-size:18px;color:#ffffffb3}@keyframes fall{0%{transform:translateY(-80px)}to{transform:translateY(var(--fall-end, 100vh))}}.tile{position:absolute;top:0;width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:#ffffffeb;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-family:Fredoka One,system-ui,sans-serif;font-size:36px;color:var(--tile-ink, #2a1d55);box-shadow:0 8px 24px #0006,0 2px 6px #0003;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:manipulation;will-change:transform;animation:fall var(--fall-duration, 4s) linear forwards}.tile--placing{animation:none;transform:none;z-index:10;transition:left .3s ease,top .3s ease}.tile--exiting{opacity:.6;filter:saturate(.5);transition:opacity .25s linear,filter .25s linear}.tile--dropped{opacity:.35;filter:saturate(.2);pointer-events:none;transition:opacity .2s linear,filter .2s linear}@media(min-width:600px){.tile{width:72px;height:72px}}.game.paused .tile{animation-play-state:paused}.game.reduced-motion .tile{animation-timing-function:steps(14,end)}.pause{position:absolute;inset:0;z-index:20;display:flex;align-items:center;justify-content:center;padding:24px;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.pause[hidden]{display:none}.pause__card{width:100%;max-width:320px;display:flex;flex-direction:column;gap:14px;padding:28px 24px;border-radius:20px;background:#ffffff14;border:1px solid rgba(255,255,255,.15)}.pause__title{margin:0 0 8px;text-align:center;font-family:Fredoka One,system-ui,sans-serif;font-weight:400;letter-spacing:.08em}.pause__resume,.pause__quit{min-height:56px;border-radius:14px;font-size:18px;cursor:pointer}.pause__resume{border:none;background:#fff;color:#12102a;font-family:Fredoka One,system-ui,sans-serif}.pause__quit{background:none;border:1px solid rgba(255,255,255,.6);color:#fff}.pause__resume:active,.pause__quit:active{transform:scale(.98)}.toast{position:absolute;left:50%;top:64px;transform:translate(-50%,-8px);z-index:15;padding:10px 18px;border-radius:999px;background:#0000008c;border:1px solid rgba(255,255,255,.15);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);font-size:14px;color:#ffffffd9;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .3s ease,transform .3s ease}.toast--show{opacity:1;transform:translate(-50%)}.end{flex:1;display:flex;justify-content:center;align-items:flex-start;overflow-y:auto;padding:24px 16px calc(24px + env(safe-area-inset-bottom));background:#12102a}.end__card{width:100%;max-width:360px;margin:auto 0;display:flex;flex-direction:column;gap:16px}.end__header{text-align:center;font-size:14px;color:#fff9}.end__calc{display:flex;flex-direction:column;gap:6px;font-variant-numeric:tabular-nums}.end__row{font-size:15px;color:#ffffffbf}.end__row--total{margin-top:6px;padding-top:10px;border-top:1px solid rgba(255,255,255,.15);font-family:Fredoka One,system-ui,sans-serif;font-size:22px;color:#fff}.end__delta{font-size:15px;font-weight:600;color:#ffffffb3}.end__delta--up{color:#7be0a2}.end__delta--down{color:#e89b9b}.end__hints{font-size:13px;color:#ffffff80}.end__history{display:flex;flex-direction:column;gap:4px}.end__history-label{margin-bottom:2px;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.12);font-size:13px;font-weight:600;color:#ffffff80}.end__hrow{display:flex;align-items:center;gap:12px;padding:6px 8px;border-radius:8px;font-size:14px;font-variant-numeric:tabular-nums;color:#fffc}.end__hrow--best{background:#ffffff14;color:#fff}.end__hrow--current{box-shadow:inset 3px 0 #b9a7ff;color:#fff}.end__hdate{flex:0 0 52px;color:#ffffff8c}.end__hscore{flex:1;font-weight:600}.end__htime{flex:0 0 auto;color:#ffffff8c}.end__hreplay{flex:0 0 auto;width:32px;height:32px;border-radius:8px;border:1px solid rgba(255,255,255,.15);background:#ffffff0d;color:#fff;font-size:16px;cursor:pointer}.end__hreplay:hover{background:#ffffff1f}.end__actions{display:flex;flex-direction:column;gap:10px;margin-top:8px}.end__btn{min-height:52px;border-radius:14px;font-size:17px;cursor:pointer;background:none;border:1px solid rgba(255,255,255,.5);color:#fff;font-family:Fredoka One,system-ui,sans-serif}.end__btn--primary{background:#fff;border:none;color:#12102a}.end__btn:active{transform:scale(.98)}.compat-error{min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:16px;padding:32px 24px}.compat-error__title{margin:0;font-family:Fredoka One,system-ui,sans-serif;font-size:26px}.compat-error__body{margin:0;max-width:36ch;line-height:1.5;color:#fffc}.deck-list{display:flex;flex-direction:column;gap:10px}.deck-row{display:flex;align-items:stretch;gap:8px;border-radius:14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);overflow:hidden}.deck-row__select{flex:1;min-width:0;text-align:left;padding:16px;background:none;border:none;color:#fff;font-family:Fredoka One,system-ui,sans-serif;font-size:18px;cursor:pointer;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deck-row__select:hover,.deck-row__select:focus-visible{background:#ffffff12}.deck-row__delete{flex:0 0 auto;width:52px;background:none;border:none;border-left:1px solid rgba(255,255,255,.1);color:#fff;font-size:18px;cursor:pointer;opacity:.7}.deck-row__delete:hover,.deck-row__delete:focus-visible{opacity:1;background:#dc505026}.deck-row--confirm{flex-direction:column;align-items:stretch;gap:12px;padding:16px}.deck-row__confirm-text{margin:0;font-size:15px;line-height:1.4}.deck-row__confirm-scores{display:flex;align-items:center;gap:8px;font-size:14px;color:#fffc;cursor:pointer}.deck-row__confirm-actions{display:flex;align-items:center;gap:12px}.btn-add-deck{min-height:52px;border-radius:14px;border:1px dashed rgba(255,255,255,.3);background:none;color:#fff;font-family:Fredoka One,system-ui,sans-serif;font-size:16px;cursor:pointer}.btn-add-deck:hover,.btn-add-deck:focus-visible{border-color:#fff9;background:#ffffff0d}.btn-danger{min-height:44px;padding:0 18px;border-radius:12px;border:none;background:#d65050;color:#fff;font-family:Fredoka One,system-ui,sans-serif;font-size:15px;cursor:pointer}.btn-danger:active{transform:scale(.98)}.preview__actions{display:flex;flex-direction:column;gap:12px;margin-top:4px}.replace__text{margin:0;font-size:15px;line-height:1.4;color:#ffffffd9}.deck-row__select{display:flex;flex-direction:column;gap:2px}.deck-row__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.deck-row__filename{font-family:Inter,system-ui,sans-serif;font-size:12px;font-weight:400;color:#ffffff73;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview__name{display:flex;flex-direction:column;gap:6px}.preview__name-heading{margin:0;font-family:Fredoka One,system-ui,sans-serif;font-size:24px;font-weight:400}.preview__name-input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#ffffff0f;color:#fff;font-family:Inter,system-ui,sans-serif;font-size:17px}.preview__name-input:focus{outline:none;border-color:#ffffff8c;background:#ffffff17}
