:root{--pink-bg:#fce4ec;--rose:#f06292;--gold:#ffe082;--wine:#880e4f;--sky:#b3e5fc;--glass:#ffffff8a;--shadow-soft:0 18px 48px #880e4f24;--shadow-inset:inset 0 1px 0 #ffffff9e, inset 0 -1px 0 #880e4f0d;color:var(--wine);background:var(--pink-bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:var(--pink-bg);min-width:320px;min-height:100%}body{background:linear-gradient(180deg, #ffffff6b, #fce4ec00 36%), linear-gradient(135deg, #b3e5fc57, #ffe0822e 48%, #f0629224), var(--pink-bg);min-width:320px;min-height:100svh;margin:0}body,button,input{font-family:inherit}button:focus-visible,input:focus-visible{outline-offset:3px;outline:3px solid #b3e5fceb}img,svg{display:block}#root{min-height:100svh}.admin-shell{color:#172026;background:#eef3f7;grid-template-columns:280px minmax(0,1fr);min-height:100svh;display:grid}.admin-sidebar{background:#fff;border-right:1px solid #d8e1e8;grid-template-rows:auto auto 1fr auto;gap:18px;min-height:100svh;padding:18px;display:grid}.admin-brand{align-items:center;gap:10px;font-weight:900;display:flex}.admin-key-form,.admin-stack{gap:12px;display:grid}.admin-key-form label,.admin-field{gap:6px;display:grid}.admin-key-form span,.admin-field span,.admin-check{color:#51616d;font-size:13px;font-weight:800}.admin-key-form input,.admin-field input,.admin-field select,.admin-field textarea{color:#172026;width:100%;min-height:40px;font:inherit;background:#fff;border:1px solid #cfdbe3;border-radius:8px;padding:9px 10px}.admin-field textarea{resize:vertical}.admin-key-form button,.admin-actions button,.user-filters button,.admin-icon-button,.row-actions button,.entity-list button{color:#fff;min-height:40px;font:inherit;cursor:pointer;background:#1f6feb;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:900;display:inline-flex}.admin-icon-button{color:#172026;background:#fff;border:1px solid #d8e1e8;width:44px}.admin-icon-button:disabled{cursor:default;opacity:.52}.admin-nav{align-content:start;gap:8px;display:grid}.admin-nav button{color:#42515c;min-height:42px;font:inherit;cursor:pointer;background:0 0;border:0;border-radius:8px;align-items:center;gap:10px;padding:0 12px;font-weight:850;display:flex}.admin-nav button.is-active{color:#0b3d91;background:#e8f1ff}.hub-state{border-radius:8px;align-items:center;gap:8px;min-height:38px;padding:0 10px;font-size:13px;font-weight:900;display:flex}.hub-state--connected{color:#146c2e;background:#e6f6eb}.hub-state--idle,.hub-state--offline{color:#8a4b00;background:#fff3df}.admin-main{align-content:start;gap:16px;min-width:0;padding:22px;display:grid}.admin-header{justify-content:space-between;align-items:center;gap:16px;display:flex}.admin-kicker{color:#657683;font-size:13px;font-weight:900}.admin-header h1{color:#172026;align-items:center;gap:10px;margin:4px 0 0;font-size:28px;line-height:1.1;display:flex}.admin-notice{border-radius:8px;align-items:center;min-height:42px;padding:0 14px;font-weight:900;display:flex}.admin-notice--ok{color:#146c2e;background:#e6f6eb}.admin-notice--warn{color:#8a4b00;background:#fff3df}.admin-notice--error{color:#a12222;background:#ffe9e9}.admin-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;display:grid}.admin-span-2{grid-column:span 3}.metric,.admin-panel{background:#fff;border:1px solid #d8e1e8;border-radius:8px;box-shadow:0 10px 28px #1720260f}.metric{align-content:center;gap:8px;min-height:92px;padding:14px;display:grid}.metric span{color:#657683;font-size:13px;font-weight:900}.metric strong{font-size:30px;line-height:1}.admin-panel{padding:16px}.admin-panel h2{margin:0 0 14px;font-size:18px}.admin-split{grid-template-columns:minmax(0,1.2fr) minmax(280px,.8fr);gap:14px;display:grid}.admin-form-grid,.user-filters{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.user-filters{grid-template-columns:repeat(6,minmax(0,1fr));align-items:end}.admin-check{align-items:center;gap:9px;min-height:40px;display:flex}.admin-check input{width:18px;height:18px}.admin-actions{justify-content:flex-end;gap:10px;display:flex}.admin-actions button:disabled,.text-card-actions button:disabled,.text-editor-toolbar button:disabled{cursor:default;opacity:.52}.admin-defs{gap:10px;margin:0;display:grid}.admin-defs div{justify-content:space-between;gap:12px;display:flex}.admin-defs dt{color:#657683;font-weight:800}.admin-defs dd{margin:0;font-weight:900}.live-feed,.entity-list,.admin-table{gap:8px;display:grid}.live-row{background:#f5f8fb;border-radius:8px;grid-template-columns:74px 150px minmax(0,1fr);align-items:center;gap:10px;min-height:44px;padding:8px 10px;display:grid}.live-row code{text-overflow:ellipsis;white-space:nowrap;color:#51616d;min-width:0;overflow:hidden}.entity-list button{color:#172026;background:#f5f8fb;justify-content:space-between;width:100%;padding:0 12px}.announcement-preview{background:#f5f8fb;border:1px solid #d8e1e8;border-radius:8px;gap:10px;padding:14px;display:grid}.announcement-preview img{object-fit:cover;border-radius:8px;width:100%;max-height:220px}.announcement-preview p{color:#42515c}.announcement-preview span{color:#fff;background:#1f6feb;border-radius:8px;align-items:center;gap:6px;width:fit-content;padding:8px 10px;font-weight:900;display:inline-flex}.message-builder{grid-template-columns:minmax(220px,.7fr) minmax(0,1fr);align-items:start;gap:12px;display:grid}.image-picker{gap:10px;display:grid}.image-picker>span{color:#51616d;font-size:13px;font-weight:800}.image-drop{color:#657683;background:#f5f8fb;border:1px dashed #aebfca;border-radius:8px;place-items:center;min-height:180px;display:grid;overflow:hidden}.image-drop img{object-fit:cover;width:100%;height:100%;max-height:260px}.upload-button{color:#fff;cursor:pointer;background:#1f6feb;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:40px;font-weight:900;display:inline-flex}.upload-button input{display:none}.telegram-preview{background:#dcebf7;border:1px solid #d8e1e8;border-radius:8px;padding:14px;display:grid}.telegram-bubble{color:#172026;background:#fff;border-radius:8px;justify-self:start;gap:10px;width:min(100%,420px);padding:10px;display:grid;box-shadow:0 8px 18px #17202614}.telegram-bubble img{object-fit:cover;border-radius:8px;width:100%;max-height:240px}.telegram-bubble p{color:#172026;white-space:pre-wrap;margin:0;line-height:1.45}.telegram-bubble span{color:#1f6feb;background:#edf5ff;border-radius:8px;justify-content:center;align-items:center;gap:7px;min-height:36px;font-weight:900;display:inline-flex}.text-editor-layout{grid-template-columns:minmax(0,1fr) 340px;align-items:start;gap:14px;display:grid}.text-editor-main,.text-card-list{gap:12px;display:grid}.text-page-tabs{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;display:grid}.text-page-tabs button,.text-editor-toolbar button,.text-card-actions button{color:#42515c;min-height:38px;font:inherit;cursor:pointer;background:#fff;border:1px solid #d8e1e8;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:900;display:inline-flex}.text-page-tabs button{flex-direction:column;align-items:flex-start;padding:8px}.text-page-tabs button.is-active{color:#0b3d91;background:#e8f1ff;border-color:#9ec1ff}.text-page-tabs small{color:#657683;font-size:12px}.text-editor-toolbar{background:#fff;border:1px solid #d8e1e8;border-radius:8px;grid-template-columns:minmax(120px,.7fr) minmax(140px,1fr) auto;align-items:center;gap:10px;min-height:54px;padding:10px 12px;display:grid;box-shadow:0 10px 28px #1720260d}.text-editor-toolbar span{color:#657683;font-size:13px;font-weight:800}.text-editor-toolbar button{color:#fff;background:#1f6feb;border-color:#1f6feb}.text-card{background:#fff;border:1px solid #d8e1e8;border-left-width:4px;border-radius:8px;gap:12px;padding:14px;display:grid;box-shadow:0 10px 28px #1720260d}.text-card.is-dirty{background:#fffdfa;border-left-color:#d08a00}.text-card header,.text-card footer{justify-content:space-between;gap:12px;display:flex}.text-card header{align-items:flex-start}.text-card header div{gap:5px;min-width:0;display:grid}.text-card code{color:#657683;text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.text-card header span{color:#315062;background:#edf3f8;border-radius:8px;flex:none;padding:5px 8px;font-size:12px;font-weight:900}.text-card footer{align-items:center}.text-card footer small{color:#657683}.text-card-actions{gap:8px;display:flex}.text-card-actions button:last-child{color:#fff;background:#1f6feb;border-color:#1f6feb}.text-preview{background:#fff;border:1px solid #d8e1e8;border-radius:8px;gap:12px;padding:16px;display:grid;position:sticky;top:22px;box-shadow:0 10px 28px #1720260f}.text-preview h2{margin:0;font-size:18px}.preview-phone{color:#172026;background:#f5f8fb;border:1px solid #cfdbe3;border-radius:8px;align-content:start;gap:12px;min-height:420px;padding:18px;display:grid}.preview-phone--center{align-content:center}.preview-modal,.preview-score,.preview-stats,.preview-message,.preview-article,.preview-toggle,.preview-row,.preview-nav{background:#fff;border:1px solid #d8e1e8;border-radius:8px}.preview-modal{text-align:center;justify-items:center;gap:12px;padding:18px;display:grid}.preview-modal p,.preview-article p{color:#42515c;margin:0;line-height:1.45}.preview-modal button,.preview-buttons button{color:#fff;min-height:38px;font:inherit;background:#1f6feb;border:0;border-radius:8px;font-weight:900}.preview-score{justify-content:space-between;padding:12px;display:flex}.preview-stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:10px;display:grid}.preview-stats span{background:#edf3f8;border-radius:8px;align-items:center;min-height:34px;padding:0 9px;font-size:13px;font-weight:800;display:flex}.preview-message{margin:0;padding:12px;font-weight:900}.preview-buttons{grid-template-columns:1fr 1fr;gap:8px;display:grid}.preview-buttons button:nth-child(2){color:#172026;background:#e6f6eb}.preview-phone h3{margin:0;font-size:24px}.preview-article{gap:8px;padding:12px;display:grid}.preview-row,.preview-toggle,.preview-nav{justify-content:space-between;align-items:center;gap:10px;min-height:42px;padding:0 12px;display:flex}.preview-row em{color:#0b3d91;font-style:normal;font-weight:900}.preview-toggle{display:grid}.preview-toggle span{color:#657683;font-size:13px;font-weight:800}.preview-nav{justify-content:space-around;margin-top:auto;font-size:12px;font-weight:900}.admin-user-row{background:#f5f8fb;border-radius:8px;grid-template-columns:minmax(180px,1.5fr) 70px 90px 90px 70px 70px minmax(110px,.9fr) 92px;align-items:center;gap:10px;min-height:54px;padding:8px 10px;display:grid}.admin-table-head{color:#657683;text-transform:uppercase;background:#edf3f8;font-size:12px;font-weight:900}.admin-user-row small{color:#657683;margin-top:3px;display:block}.risk{color:#a12222;font-weight:900}.row-actions{gap:6px;display:flex}.row-actions button{color:#172026;background:#fff;border:1px solid #d8e1e8;width:38px;min-height:34px}.muted{color:#657683}@media (width<=1100px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{grid-template-rows:auto;min-height:auto}.admin-nav{grid-template-columns:repeat(3,minmax(0,1fr))}.admin-grid,.admin-split,.text-editor-layout,.message-builder,.admin-form-grid,.user-filters,.text-page-tabs,.text-editor-toolbar{grid-template-columns:1fr}.text-preview{position:static}.admin-span-2{grid-column:auto}.admin-user-row,.live-row{grid-template-columns:1fr}}.app-shell{width:min(100%,1180px);min-height:100svh;color:var(--wine);grid-template-rows:auto 1fr auto;margin:0 auto;display:grid}.topbar{max-height:88px;padding:max(14px, env(safe-area-inset-top)) 18px 10px;justify-content:space-between;align-items:center;gap:16px;transition:max-height .22s,opacity .18s,padding .22s,transform .22s;display:flex;overflow:hidden}.app-shell.is-game-active .topbar{opacity:0;pointer-events:none;max-height:0;padding-top:0;padding-bottom:0;transform:translateY(-8px)}button{font:inherit;border:0}.brand-button,.icon-button,.primary-button,.secondary-button,.top-play-button,.bottom-nav button{cursor:pointer;border-radius:8px;min-height:44px;transition:transform .18s,box-shadow .18s,background .18s}.brand-button:active,.icon-button:active,.primary-button:active,.secondary-button:active,.top-play-button:active,.bottom-nav button:active{transform:translateY(1px)scale(.99)}.icon-button:disabled,.primary-button:disabled,.secondary-button:disabled,.top-play-button:disabled{cursor:default;opacity:.54;transform:none}.brand-button{min-height:54px;color:var(--wine);background:0 0;justify-content:center;align-items:center;padding:0;font-weight:900;display:inline-flex}.brand-logo{object-fit:contain;filter:drop-shadow(0 8px 14px #880e4f24);pointer-events:none;width:auto;height:clamp(46px,5vw,60px)}.topbar-actions{justify-content:flex-end;align-items:center;gap:8px;min-width:0;display:flex}.top-play-button{color:#fff;background:var(--rose);white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-width:138px;height:44px;padding:0 16px;font-size:15px;font-weight:950;display:none;box-shadow:0 10px 24px #f0629257}.top-play-button:hover,.primary-button:hover{box-shadow:0 14px 28px #f0629266}.app-main{min-height:0;padding:8px 18px 12px}.game-layout{grid-template-columns:minmax(300px,1fr) 300px;align-items:start;gap:16px;display:grid}.side-rail{grid-area:1/2;min-width:0;height:clamp(560px,100svh - 160px,650px);padding-bottom:clamp(220px,24vw,292px);position:relative}.board-zone{grid-area:1/1}.board-zone,.session-panel,.screen-panel{background:var(--glass);box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid #880e4f1f;border-radius:8px}.board-zone{padding:clamp(10px,1.8vw,16px)}.board-zone.is-idle{overflow:hidden}.idle-mascot-stage{aspect-ratio:16/9;pointer-events:none;background:#ffffff52;border-radius:8px;width:min(100%,620px);max-width:100%;margin:0 auto;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #880e4f14,inset 0 24px 50px #ffffff85}.idle-background{z-index:0;object-fit:cover;pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.idle-mascot{z-index:1;object-fit:contain;filter:drop-shadow(0 26px 34px #880e4f3d);-webkit-user-select:none;user-select:none;width:min(78%,430px);max-height:116%;animation:4.2s ease-in-out infinite idle-cat-float;position:absolute;top:54%;left:50%;transform:translate(-50%,-50%)}.screen-title{justify-content:flex-end;align-items:center;gap:14px;margin-bottom:14px;display:flex}h1,h2,p{margin:0}h1{font-size:clamp(26px,4vw,40px);font-weight:950;line-height:1.05}h2{font-size:18px;line-height:1.2}.icon-button{width:44px;color:var(--wine);box-shadow:var(--shadow-inset);background:#ffffffa3;place-items:center;display:inline-grid}.board{--board-width:min(78vw, 560px, calc((100svh - 140px) * .75));width:var(--board-width);aspect-ratio:3/4;touch-action:none;-webkit-user-select:none;user-select:none;background:linear-gradient(145deg,#ffffff6b,#b3e5fc57),#ffffff52;border-radius:8px;grid-template-rows:repeat(8,minmax(0,1fr));grid-template-columns:repeat(6,minmax(0,1fr));gap:clamp(5px,1.2vw,9px);max-width:100%;margin:0 auto;padding:clamp(8px,2vw,12px);display:grid;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #880e4f14,inset 0 24px 50px #ffffff85}.board:before{content:"";z-index:0;border-radius:inherit;pointer-events:none;background:radial-gradient(circle at 24% 18%,#ffffff80,#0000 28%),linear-gradient(135deg,#ffe08224,#0000 42%,#b3e5fc2e);position:absolute;inset:0}.board.is-resolving .tile:not(.is-matched):not(.is-dragging){filter:saturate(.9)brightness(1.02)}.tile{--drag-x:0px;--drag-y:0px;--hint-x:0px;--hint-y:0px;z-index:1;color:#fffffff5;background:linear-gradient(145deg, var(--tile-glow), var(--tile-color) 62%, #880e4f38);cursor:grab;touch-action:none;width:100%;min-width:0;height:100%;min-height:0;transform:translate3d(var(--drag-x), var(--drag-y), 0);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border-radius:8px;place-items:center;transition:transform .12s,box-shadow .16s,opacity .16s,filter .16s;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 1px 1px #ffffffd1,inset 0 -9px 18px #880e4f29,0 8px 16px #880e4f24}.tile:before{content:"";pointer-events:none;background:linear-gradient(145deg,#ffffff70,#0000 28%),linear-gradient(315deg,#fff3,#0000 34%);border:1px solid #ffffff94;border-radius:8px;position:absolute;inset:7%}.tile:after{content:"";filter:blur(5px);background:#ffffff3d;border-radius:999px;height:12%;position:absolute;inset:auto 18% 12%}.tile:disabled{cursor:default;opacity:.78}.tile:active{transform:translate3d(var(--drag-x), var(--drag-y), 0)}.tile.is-dragging{z-index:4;cursor:grabbing;transform:translate3d(var(--drag-x), var(--drag-y), 0);transition:none;box-shadow:inset 0 1px 1px #ffffffdb,inset 0 -9px 18px #880e4f1f,0 18px 28px #880e4f3d}.tile.is-selected{outline:3px solid var(--gold);outline-offset:2px;box-shadow:inset 0 1px 1px #ffffffd1,0 0 0 5px #ffe08261,0 14px 24px #880e4f2e}.tile.is-hinted{z-index:3;will-change:transform;transition:box-shadow .16s,opacity .16s,filter .16s;animation:1.6s ease-in-out infinite hint-nudge}.tile.is-matched{z-index:5;pointer-events:none;animation:.36s forwards glass-pop}.tile.is-matched:before{border-color:#ffffffe6;animation:.36s forwards glass-ring}.tile.is-matched:after{filter:blur(3px);background:radial-gradient(circle,#fffffff2,#ffe08273 42%,#0000 70%);border-radius:50%;height:auto;animation:.36s forwards glass-spark;inset:16%}.tile.is-new{animation:.24s ease-out both tile-enter}.tile-icon{z-index:1;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 2px 3px #880e4f38);width:92%;height:92%;position:relative}.tile.is-matched .tile-icon{animation:.32s forwards icon-pop}.tile--spark,.tile--drop{color:#880e4fc2}.session-panel{z-index:2;gap:14px;padding:16px;display:grid;position:relative}.panel-actions{grid-template-columns:1fr;gap:10px;display:grid}.side-mascot{inset-inline:4px;z-index:1;pointer-events:none;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 24px 34px #880e4f33);width:min(100%,292px);margin:0 auto;animation:4.8s ease-in-out infinite mascot-float;position:absolute;bottom:0}.meter-block{gap:9px;display:grid}.meter-title{justify-content:space-between;align-items:center;gap:12px;font-weight:900;display:flex}.meter{height:12px;box-shadow:var(--shadow-inset);background:#ffffffa3;border-radius:999px;overflow:hidden}.meter span{border-radius:inherit;background:linear-gradient(90deg, var(--rose), var(--gold), var(--sky));height:100%;transition:width .22s;display:block}.stat-grid,.settings-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.stat-item,.settings-grid div{min-height:72px;color:var(--wine);box-shadow:var(--shadow-inset);background:#ffffff85;border-radius:8px;align-content:center;gap:6px;padding:12px;display:grid}.stat-item span,.settings-grid span,.toggle-row small{color:#880e4fa8;font-size:13px;font-weight:800}.stat-item strong,.settings-grid strong{font-size:24px;line-height:1}.message-strip{min-height:46px;color:var(--wine);text-align:center;background:#b3e5fc6b;border-radius:8px;place-items:center;padding:10px 12px;font-weight:900;display:grid}.score-burst{z-index:8;color:var(--wine);text-shadow:0 2px #ffffffeb,0 0 18px #ffe082e6,0 14px 24px #880e4f38;pointer-events:none;font-size:clamp(34px,8vw,62px);font-weight:950;line-height:1;animation:.88s ease-out both score-float;position:absolute;top:46%;left:50%}.primary-button{color:#fff;background:var(--rose);justify-content:center;align-items:center;gap:9px;width:100%;padding:0 16px;font-weight:950;display:inline-flex;box-shadow:0 12px 24px #f0629257}.secondary-button{width:100%;color:var(--wine);box-shadow:var(--shadow-inset);background:#fff9;justify-content:center;align-items:center;gap:9px;padding:0 16px;font-weight:950;display:inline-flex}.primary-button--gold{color:var(--wine);background:var(--gold);box-shadow:0 12px 24px #ffe0825c}.screen-panel{min-height:min(650px,100svh - 155px);padding:20px}.leaderboard{gap:10px;display:grid}.empty-state{color:#880e4fb8;text-align:center;box-shadow:var(--shadow-inset);background:#ffffff85;border-radius:8px;margin:0;padding:14px;font-weight:850}.leader-row{min-height:56px;box-shadow:var(--shadow-inset);background:#ffffff8f;border-radius:8px;grid-template-columns:42px 1fr auto;align-items:center;gap:12px;padding:10px 14px;display:grid}.leader-row.is-current{background:#ffe0828c}.leader-rank{background:#f0629226;border-radius:8px;place-items:center;width:34px;height:34px;font-weight:950;display:grid}.leader-name{align-items:center;gap:7px;min-width:0;font-weight:900;display:inline-flex}.faq-panel{align-content:start;gap:12px;display:grid}.faq-panel article{box-shadow:var(--shadow-inset);background:#ffffff8a;border-radius:8px;padding:16px}.faq-panel article p{color:#880e4fb8;margin-top:8px}.settings-panel{align-content:start;gap:14px;display:grid}.toggle-row{min-height:70px;box-shadow:var(--shadow-inset);background:#ffffff8f;border-radius:8px;justify-content:space-between;align-items:center;gap:14px;padding:12px 14px;display:flex}.toggle-row span{gap:4px;display:grid}.toggle-row input{appearance:none;width:54px;height:32px;box-shadow:var(--shadow-inset);cursor:pointer;background:#880e4f2e;border-radius:999px;flex:none;padding:3px}.toggle-row input:before{content:"";background:#fff;border-radius:50%;width:26px;height:26px;transition:transform .18s;display:block;box-shadow:0 4px 10px #880e4f33}.toggle-row input:checked{background:var(--rose)}.toggle-row input:checked:before{transform:translate(22px)}.bottom-nav{box-sizing:border-box;width:100%;padding:10px 18px max(10px, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fce4ecd1;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;transition:opacity .18s,transform .18s;display:grid;position:sticky;bottom:0}.bottom-nav.is-hidden{pointer-events:none;opacity:0;transform:translateY(100%)}.bottom-nav button{color:#880e4fb3;width:100%;min-width:0;box-shadow:var(--shadow-inset);background:#ffffff80;place-items:center;gap:3px;font-size:12px;font-weight:900;display:grid}.bottom-nav button.is-active{color:#fff;background:var(--rose);box-shadow:0 10px 22px #f0629247}.modal-backdrop{z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#880e4f47;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{width:min(100%,360px);color:var(--wine);text-align:center;background:#ffffffe0;border-radius:8px;gap:14px;padding:22px;display:grid;box-shadow:0 24px 60px #880e4f47}.modal svg{color:var(--rose);margin:0 auto}.modal p{color:#880e4fb8}.announcement-modal{width:min(100%,440px)}.announcement-modal img{object-fit:cover;width:100%;max-height:min(280px,44svh);box-shadow:var(--shadow-inset);border-radius:8px}.announcement-modal .secondary-button{min-height:42px}@keyframes hint-nudge{0%,30%,to{transform:translate3d(var(--drag-x), var(--drag-y), 0)}52%,64%{transform:translate3d(calc(var(--drag-x) + var(--hint-x)), calc(var(--drag-y) + var(--hint-y)), 0)}}@keyframes glass-pop{0%{opacity:1;filter:brightness()saturate();transform:translate3d(var(--drag-x), var(--drag-y), 0) scale(1)}38%{opacity:1;filter:brightness(1.24)saturate(1.25);transform:translate3d(var(--drag-x), var(--drag-y), 0) scale(1.13)}to{opacity:0;filter:brightness(1.5)saturate(.7)blur(2px);transform:translate3d(var(--drag-x), var(--drag-y), 0) scale(.34) rotate(10deg)}}@keyframes glass-ring{0%{opacity:.75;transform:scale(1)}to{opacity:0;transform:scale(1.55)}}@keyframes glass-spark{0%{opacity:0;transform:scale(.45)}35%{opacity:1;transform:scale(1.2)}to{opacity:0;transform:scale(2.1)}}@keyframes icon-pop{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.65)rotate(-8deg)}}@keyframes tile-enter{0%{opacity:.38;filter:brightness(1.08)}to{opacity:1;filter:brightness()}}@keyframes score-float{0%{opacity:0;transform:translate(-50%,16px)scale(.78)}18%{opacity:1;transform:translate(-50%)scale(1.05)}to{opacity:0;transform:translate(-50%,-44px)scale(1)}}@keyframes mascot-float{0%,to{transform:translate(0,0)}50%{transform:translateY(-8px)}}@keyframes idle-cat-float{0%,to{transform:translate(-50%,-50%)rotate(-2deg)scale(.98)}50%{transform:translate(-50%,-56%)rotate(2deg)scale(1.02)}}@media (width<=900px){.game-layout{grid-template-columns:1fr}.side-rail{align-content:start;gap:16px;height:auto;padding-bottom:0;display:grid;position:static}.session-panel{grid-template-columns:1fr 1fr;align-items:stretch}.meter-block,.stat-grid,.message-strip,.panel-actions,.session-panel .primary-button{grid-column:span 2}.side-mascot{z-index:auto;width:min(230px,72vw);margin:0 auto;position:static}}@media (width<=640px){.app-shell{padding-bottom:calc(78px + env(safe-area-inset-bottom))}.app-shell.is-game-active{padding-bottom:0}.topbar{padding:max(8px, env(safe-area-inset-top)) 12px 6px;flex-direction:row;align-items:center;gap:10px}.brand-button{align-self:flex-start;min-height:38px}.brand-logo{height:38px}.topbar-actions{flex:1;justify-content:flex-end}.top-play-button{min-width:132px;height:42px;min-height:42px;padding-inline:14px;font-size:14px;display:inline-flex}.app-main{padding:4px 12px 8px}.app-shell.is-game-active .app-main{padding-top:2px}.game-layout{flex-direction:column;align-items:stretch;gap:8px;display:flex}.board-zone{order:1;grid-area:auto}.side-rail{order:2;grid-area:auto;width:100%}.board-zone,.session-panel,.screen-panel{padding:6px}.board{--board-width:min(100%, calc((100svh - 218px) * .75));gap:4px;padding:6px}.idle-mascot-stage{width:100%;min-height:178px}.idle-mascot{width:min(86%,320px)}.app-shell.is-game-active .board{--board-width:min(100%, calc((100svh - 104px) * .75))}.session-panel{box-sizing:border-box;gap:8px;width:100%}.panel-actions{display:none}.meter-block{gap:6px}.meter-title{font-size:15px}.meter{height:9px}.stat-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px;width:100%}.stat-item{text-align:center;gap:4px;min-width:0;min-height:48px;padding:7px 4px}.stat-item span{font-size:10px}.stat-item strong{font-size:17px}.message-strip{min-height:34px;padding:7px 9px;font-size:13px}.side-mascot{display:none}.bottom-nav{z-index:9;width:100vw;padding:8px 12px max(8px, env(safe-area-inset-bottom));border-radius:0;gap:7px;position:fixed;left:0;right:0}.bottom-nav button span{font-size:11px}}
