:root{color:#fff;background:#14112b;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0;overflow:hidden;touch-action:none}button,input{font:inherit}.auth-shell,.game-shell{min-height:100%;background:radial-gradient(circle at 20% 20%,rgba(0,206,201,.42),transparent 28%),radial-gradient(circle at 80% 30%,rgba(253,121,168,.38),transparent 30%),linear-gradient(135deg,#17133a,#30236d 52%,#101828)}.auth-shell{padding:max(20px,env(safe-area-inset-top)) max(20px,env(safe-area-inset-right)) max(20px,env(safe-area-inset-bottom)) max(20px,env(safe-area-inset-left))}.auth-shell{display:grid;place-items:center}.auth-card{width:min(680px,94vw);max-height:94vh;overflow:auto;border:1px solid rgba(255,255,255,.18);border-radius:28px;padding:clamp(20px,4vw,44px);background:#0f172a9e;box-shadow:0 24px 80px #0000004d;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:24px}.auth-info{display:flex;flex-direction:column;gap:8px}.auth-action{display:flex;flex-direction:column}.eyebrow{margin:0;color:#81ecec;font-weight:800;letter-spacing:.2em;text-transform:uppercase}h1{margin:0 0 8px;font-size:clamp(2rem,6vw,4.6rem);line-height:.92}.auth-form{display:flex;flex-direction:column;gap:16px}.form-grid{display:grid;gap:12px;grid-template-columns:1fr}label{display:grid;gap:6px;color:#ffffffd1;font-weight:700}input{min-height:46px;border:0;border-radius:14px;padding:0 14px;color:#101828;background:#fffffff0}button{min-height:48px;border:0;border-radius:999px;color:#fff;background:linear-gradient(135deg,#00cec9,#6c5ce7);font-weight:900}.link-button{margin-top:12px;width:100%;background:#ffffff24}.form-message,.safety-note{min-height:20px;margin:8px 0 0;color:#ffffffc2}.safety-note{font-size:.88rem;margin:0}@media(max-height:540px)and (orientation:landscape){.auth-shell{padding:max(10px,env(safe-area-inset-top)) max(15px,env(safe-area-inset-right)) max(10px,env(safe-area-inset-bottom)) max(15px,env(safe-area-inset-left))}.auth-card{flex-direction:row;width:min(840px,96vw);max-height:96vh;padding:clamp(14px,3vw,24px);gap:clamp(16px,4vw,36px);align-items:stretch}.auth-info{flex:1 1 42%;justify-content:space-between;gap:8px}.auth-action{flex:1.2 1 58%;justify-content:center}h1{font-size:clamp(1.4rem,4.5vw,2.2rem);margin:4px 0}.auth-form{gap:12px}.form-grid{grid-template-columns:repeat(2,1fr);gap:8px 12px}.auth-form:not(:has(input[name=phone])) .form-grid{grid-template-columns:1fr;gap:8px}label{gap:3px;font-size:.82rem}input{min-height:38px;border-radius:10px;padding:0 10px}button{min-height:40px}.link-button{margin-top:8px;min-height:38px}.safety-note{font-size:.76rem;line-height:1.3;opacity:.85}.form-message{font-size:.8rem;margin:4px 0 0;min-height:16px}}.game-shell{position:fixed;inset:0;width:100vw;height:100dvh;background:#000}.game-stage{position:absolute;inset:0;width:100vw;height:100dvh;overflow:hidden;background:linear-gradient(#74b9ff 0 45%,#55efc4 46% 100%)}.arena{position:absolute;inset:44% 0 0;background:radial-gradient(ellipse at center,#ffeaa7 0 18%,#00b894 19% 100%);transform:perspective(700px) rotateX(62deg);transform-origin:center top}.avatar{--skin: #edf5f8;--skin-mid: #d9e5ea;--skin-shadow: #aebcc2;position:absolute;left:calc(50% - 58px);bottom:20%;width:116px;height:184px;transform-origin:50% 92%;will-change:transform;filter:drop-shadow(0 22px 24px rgba(0,0,0,.22))}.avatar *,.avatar *:before,.avatar *:after{position:absolute;box-sizing:border-box}.avatar-shadow{left:16px;bottom:-10px;width:86px;height:24px;border-radius:50%;background:#10182833;filter:blur(6px)}.avatar-head{z-index:5;left:28px;top:0;width:62px;height:58px;border-radius:20px 20px 18px 18px;background:radial-gradient(circle at 32% 18%,rgba(255,255,255,.95),transparent 28%),linear-gradient(145deg,#f7fdff 0%,var(--skin) 42%,#c6d2d8 100%);box-shadow:inset -7px -9px 12px #5a68703d,inset 7px 8px 12px #ffffffd1}.avatar-eye{top:22px;width:5px;height:12px;border-radius:999px;background:#20242a;box-shadow:0 0 2px #0000004d}.avatar-eye--left{left:23px}.avatar-eye--right{right:21px}.avatar-smile{left:21px;top:34px;width:24px;height:14px;border-bottom:4px solid #20242a;border-radius:0 0 999px 999px;transform:rotate(1deg)}.avatar-body{z-index:3;left:18px;top:54px;width:82px;height:70px;border-radius:30px 30px 16px 16px/26px 26px 14px 14px;background:radial-gradient(circle at 35% 18%,rgba(255,255,255,.86),transparent 30%),linear-gradient(160deg,#f7fdff 0%,var(--skin) 48%,#cad7dd 100%);box-shadow:inset -10px -12px 14px #707e8633,inset 10px 10px 16px #ffffffc7}.avatar-body:after{content:"";left:0;right:0;bottom:0;height:20px;border-radius:0 0 16px 16px;background:linear-gradient(180deg,#deeaef4d,#beccd47a)}.avatar-arm{z-index:2;top:64px;width:28px;height:78px;border-radius:18px;background:radial-gradient(circle at 38% 18%,rgba(255,255,255,.78),transparent 28%),linear-gradient(170deg,#eef7fa 0%,var(--skin-mid) 64%,#b7c5cc 100%);transform-origin:50% 10%}.avatar-arm--left{left:2px;transform:rotate(10deg)}.avatar-arm--right{right:2px;transform:rotate(-10deg)}.avatar-arm span{left:-1px;bottom:-17px;width:30px;height:30px;border-radius:16px 16px 13px 13px;background:linear-gradient(145deg,#f7fdff,#c8d5db);box-shadow:inset -5px -6px 8px #6270782e}.avatar-arm span:before,.avatar-arm span:after{content:"";bottom:1px;width:8px;height:16px;border-radius:999px;background:linear-gradient(#eaf4f7,#c4d1d7)}.avatar-arm span:before{left:4px;transform:rotate(14deg)}.avatar-arm span:after{right:4px;transform:rotate(-14deg)}.avatar-leg{z-index:1;top:116px;width:34px;height:58px;border-radius:12px 12px 18px 18px;background:linear-gradient(160deg,#eaf4f7,#c3d0d7);box-shadow:inset -5px -8px 10px #5d6b732e}.avatar-leg--left{left:24px}.avatar-leg--right{right:24px}.avatar-leg span{left:-3px;bottom:-8px;width:42px;height:22px;border-radius:18px 18px 12px 12px;background:linear-gradient(150deg,#f8fdff,#cdd9df);box-shadow:inset -6px -6px 8px #65737a2e}.avatar.is-moving .avatar-arm--left{animation:arm-left .42s ease-in-out infinite alternate}.avatar.is-moving .avatar-arm--right{animation:arm-right .42s ease-in-out infinite alternate}.avatar.is-moving .avatar-leg--left{animation:leg-left .42s ease-in-out infinite alternate}.avatar.is-moving .avatar-leg--right{animation:leg-right .42s ease-in-out infinite alternate}@keyframes arm-left{0%{transform:rotate(16deg)}to{transform:rotate(-8deg)}}@keyframes arm-right{0%{transform:rotate(-16deg)}to{transform:rotate(8deg)}}@keyframes leg-left{0%{transform:translateY(0)}to{transform:translateY(-5px)}}@keyframes leg-right{0%{transform:translateY(-5px)}to{transform:translateY(0)}}.hud{position:absolute;inset:auto 24px 24px;display:flex;justify-content:space-between;align-items:end;pointer-events:none}.stick,.actions button{pointer-events:auto;border:3px solid rgba(255,255,255,.54);background:#0f172a61;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stick{width:112px;height:112px;border-radius:50%;display:grid;place-items:center}.stick span{width:42px;height:42px;border-radius:50%;background:#ffffffd1}.actions{display:grid;grid-template-columns:repeat(2,64px);gap:12px}.actions button{width:64px;height:64px;font-size:1.4rem}@media(orientation:portrait){#app:before{content:"Girá el dispositivo para jugar en horizontal";position:fixed;inset:0;z-index:10;display:grid;place-items:center;padding:32px;text-align:center;background:#14112b;font-size:1.4rem;font-weight:800}}.player-name{position:absolute;left:50%;bottom:36%;z-index:3;margin:0;padding:4px 10px;border-radius:999px;color:#fff;background:#0f172a80;font-size:.8rem;font-weight:800;transform:translate(-50%)}.stick span{will-change:transform;transition:transform 80ms ease-out}.stick:active,.actions button:active,.actions button.is-pressed{border-color:#fff;background:#6c5ce79e;transform:scale(.96)}.actions button.is-selected{border-color:#a29bfe;background:#6c5ce7d9;box-shadow:0 0 16px #6c5ce7b3;color:#fff;transform:scale(1.02)}.game-stage--3d{background:linear-gradient(#74b9ff 0 42%,#55efc4 43% 100%)}.game-canvas{position:absolute;inset:0;width:100vw;height:100dvh;display:block;outline:none;touch-action:none}.game-stage--3d .player-name{bottom:auto;top:max(18px,env(safe-area-inset-top));z-index:4}.top-bar{position:absolute;top:max(18px,env(safe-area-inset-top));left:50%;z-index:5;display:flex;gap:10px;align-items:center;transform:translate(-50%)}.top-bar .player-name{position:static;transform:none}.settings-button,.settings-close,.voice-toggle-button,.voice-mute-button{min-width:44px;min-height:44px;border:2px solid rgba(255,255,255,.54);border-radius:50%;background:#0f172a7a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:1.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.175,.885,.32,1.275);-webkit-user-select:none;user-select:none}.settings-button:hover,.settings-close:hover,.voice-toggle-button:hover,.voice-mute-button:hover:not(:disabled){transform:scale(1.08);border-color:#ffffffd9;box-shadow:0 4px 15px #ffffff26}.settings-button:active,.settings-close:active,.voice-toggle-button:active,.voice-mute-button:active:not(:disabled){transform:scale(.95)}.voice-toggle-button.is-selected{border-color:#00cec9;background:#00cec959;box-shadow:0 0 16px #00cec980;animation:voice-pulse 2s infinite ease-in-out}.voice-mute-button:disabled{opacity:.38;cursor:not-allowed;transform:none!important}.voice-mute-button.is-pressed{border-color:#d63031;background:#d6303159;box-shadow:0 0 12px #d6303166}@keyframes voice-pulse{0%,to{box-shadow:0 0 12px #00cec966}50%{box-shadow:0 0 20px #00cec9b3}}.settings-panel{position:absolute;top:calc(max(18px,env(safe-area-inset-top)) + 58px);right:max(18px,env(safe-area-inset-right));z-index:6;width:min(420px,calc(100vw - 36px));max-height:calc(100vh - 120px);overflow:auto;border:1px solid rgba(255,255,255,.24);border-radius:22px;padding:14px;color:#fff;background:#0f172ac7;box-shadow:0 24px 80px #00000061;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.settings-panel[hidden]{display:none}.settings-panel header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.character-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.character-option{min-height:40px;border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:8px 10px;color:#ffffffdb;background:#ffffff1a;font-size:.82rem;text-align:left}.character-option.is-selected,.character-option:focus-visible{color:#101828;background:#81ecec;outline:2px solid #ffffff}.coins-display{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;border:2px solid rgba(255,255,255,.4);background:#0f172a7a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 15px #00000026;font-weight:800;font-size:.95rem;color:#ffeaa7;-webkit-user-select:none;user-select:none;cursor:default;transition:all .25s cubic-bezier(.175,.885,.32,1.275)}.coins-display:hover{transform:scale(1.06);border-color:#ffffffb3;box-shadow:0 6px 20px #fdcb6e4d}.coin-icon{font-size:1.15rem;display:inline-block;animation:coin-spin 3s ease-in-out infinite}@keyframes coin-spin{0%,to{transform:rotateY(0)}50%{transform:rotateY(180deg)}}.coin-count{font-variant-numeric:tabular-nums;text-shadow:0 1px 2px rgba(0,0,0,.3)}.coins-display.pulse{animation:pulse-coin .4s ease-out}@keyframes pulse-coin{0%{transform:scale(1);box-shadow:0 0 #fdcb6eb3}50%{transform:scale(1.25);box-shadow:0 0 15px 8px #fdcb6e66}to{transform:scale(1);box-shadow:0 0 #fdcb6e00}}html.game-active,body.game-active{width:100%;height:100%;margin:0;padding:0;overflow:hidden;background:#000;overscroll-behavior:none}body.game-active #app{width:100vw;height:100dvh;margin:0;padding:0}.chat-overlay[hidden]{display:none!important}.chat-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0f172a73;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .25s ease}.chat-box{background:#1e293bbf;border:1px solid rgba(255,255,255,.15);box-shadow:0 20px 25px -5px #00000080,0 10px 10px -5px #0006;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:20px;padding:1.5rem;display:flex;gap:.75rem;align-items:center;width:90%;max-width:500px;transform:translateY(0);animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}.chat-input{flex:1;background:#0f172a99;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:.75rem 1rem;color:#fff;font-family:Outfit,Inter,sans-serif;font-size:1rem;outline:none;transition:all .2s ease}.chat-input:focus{border-color:#fde04799;box-shadow:0 0 0 3px #fde04726;background:#0f172acc}.chat-send{background:linear-gradient(135deg,#fef08a,#facc15);color:#1e1b4b;border:none;font-weight:700;padding:.75rem 1.25rem;border-radius:12px;cursor:pointer;font-family:Outfit,Inter,sans-serif;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #facc1533}.chat-send:hover{transform:translateY(-2px);box-shadow:0 6px 12px -2px #facc1566;filter:brightness(1.05)}.chat-send:active{transform:translateY(0)}.chat-cancel{background:#ffffff1a;border:1px solid rgba(255,255,255,.05);color:#fffc;font-size:1.25rem;width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.chat-cancel:hover{background:#ef444433;border-color:#ef44444d;color:#ef4444}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.chat-feed{position:absolute;top:calc(max(18px,env(safe-area-inset-top)) + 58px);left:max(18px,env(safe-area-inset-left));z-index:5;display:flex;flex-direction:column;gap:6px;width:min(280px,45vw);pointer-events:none}.chat-feed-item{background:#0f172aa6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:6px 12px;font-size:.85rem;line-height:1.3;color:#fffffff2;box-shadow:0 4px 12px #00000026;animation:chat-slide-in .25s cubic-bezier(.175,.885,.32,1.275) forwards;pointer-events:auto;max-width:100%;word-break:break-word}.chat-feed-author{font-weight:800;color:#81ecec;margin-right:4px}.chat-feed-text{color:#fff}@keyframes chat-slide-in{0%{opacity:0;transform:translate(-15px) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes chat-fade-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-8px)}}.kiosk-shop-overlay{position:fixed;top:0;right:0;bottom:0;width:min(440px,92vw);z-index:1000;background:#0f172aa6;backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border-left:1px solid rgba(255,255,255,.15);box-shadow:-15px 0 50px #00000080;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .4s ease;transform:translate(0);opacity:1;display:flex;flex-direction:column}.kiosk-shop-overlay[hidden]{display:none!important;transform:translate(100%);opacity:0;pointer-events:none}.kiosk-shop-box{padding:max(24px,env(safe-area-inset-top) + 12px) max(24px,env(safe-area-inset-right)) max(24px,env(safe-area-inset-bottom)) max(24px,env(safe-area-inset-left));display:flex;flex-direction:column;height:100%;overflow-y:auto}.kiosk-shop-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.kiosk-shop-title{margin:0;font-size:1.6rem;font-weight:900;letter-spacing:-.02em;background:linear-gradient(135deg,#00cec9,#81ecec);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.kiosk-shop-close{background:#ffffff1a;border:1px solid rgba(255,255,255,.05);color:#ffffffd9;font-size:1.5rem;width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s cubic-bezier(.175,.885,.32,1.275)}.kiosk-shop-close:hover{background:#ef444433;border-color:#ef444459;color:#ef4444;transform:rotate(90deg) scale(1.1)}.kiosk-owner-info{display:flex;align-items:center;gap:10px;background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:10px 14px;margin-bottom:24px}.owner-status-indicator{width:10px;height:10px;border-radius:50%;box-shadow:0 0 8px currentColor}.owner-status-indicator.closed{background-color:#ffeaa7;color:#ffeaa7}.owner-status-indicator.active{background-color:#00cec9;color:#00cec9}.owner-status-text{font-size:.9rem;font-weight:700;color:#ffffffd9}.kiosk-products-grid{display:flex;flex-direction:column;gap:16px;margin-bottom:28px}.kiosk-product-card{position:relative;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:18px;display:flex;flex-direction:column;gap:8px;transition:all .3s cubic-bezier(.16,1,.3,1);overflow:hidden}.kiosk-product-card:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#00cec914,#6c5ce714);opacity:0;transition:opacity .3s ease;pointer-events:none}.kiosk-product-card:hover{transform:translateY(-2px);border-color:#00cec94d;box-shadow:0 8px 24px #0003}.kiosk-product-card:hover:before{opacity:1}.product-icon{font-size:2.2rem;margin-bottom:4px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.product-name{font-size:1.15rem;font-weight:800;color:#fff}.product-desc{margin:0;font-size:.88rem;line-height:1.4;color:#ffffffa6}.kiosk-buy-btn{margin-top:6px;min-height:42px;background:linear-gradient(135deg,#00cec9,#0984e3);box-shadow:0 4px 12px #00cec940;font-weight:900;font-size:.95rem;border-radius:999px;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1)}.kiosk-buy-btn:hover{transform:scale(1.02);filter:brightness(1.1);box-shadow:0 6px 18px #00cec966}.kiosk-buy-btn:active{transform:scale(.98)}.kiosk-rent-section{margin-top:auto;border-top:1px solid rgba(255,255,255,.12);padding-top:24px;display:flex;flex-direction:column;gap:12px}.rent-info-text{margin:0;font-size:.85rem;line-height:1.4;color:#ffffff8c;text-align:center}.kiosk-rent-btn{min-height:46px;background:linear-gradient(135deg,#6c5ce7,#a29bfe);box-shadow:0 4px 12px #6c5ce740;font-weight:900;font-size:1rem;border-radius:999px;cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1)}.kiosk-rent-btn:hover{transform:scale(1.02);filter:brightness(1.1);box-shadow:0 6px 18px #6c5ce766}.kiosk-rent-btn:active{transform:scale(.98)}.game-dialog-overlay{position:fixed;inset:0;z-index:99999;background:#0f172a73;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:grid;place-items:center;transition:all .3s cubic-bezier(.16,1,.3,1);animation:modal-fade-in .25s ease-out forwards}.game-dialog-overlay[hidden]{display:none!important;pointer-events:none}.game-dialog-box{width:min(420px,92vw);background:#0f172acc;backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid rgba(255,255,255,.16);border-radius:24px;padding:24px;box-shadow:0 24px 60px #0009;display:flex;flex-direction:column;gap:16px;animation:modal-scale-in .3s cubic-bezier(.175,.885,.32,1.275) forwards}.game-dialog-header{display:flex;align-items:center;gap:12px}.game-dialog-icon{font-size:1.8rem;filter:drop-shadow(0 0 8px currentColor)}.game-dialog-title{margin:0;font-size:1.3rem;font-weight:900;color:#fff;letter-spacing:-.01em}.game-dialog-body{margin:0}.game-dialog-message{margin:0;font-size:.95rem;line-height:1.5;color:#ffffffd9}.game-dialog-footer{display:flex;justify-content:flex-end;margin-top:4px}.game-dialog-btn{min-height:42px;min-width:110px;background:linear-gradient(135deg,#6c5ce7,#81ecec);box-shadow:0 4px 12px #6c5ce74d;color:#fff;border:none;font-weight:900;font-size:.95rem;border-radius:999px;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1)}.game-dialog-btn:hover{transform:scale(1.03);filter:brightness(1.1);box-shadow:0 6px 18px #6c5ce773}.game-dialog-btn:active{transform:scale(.97)}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-scale-in{0%{transform:scale(.9) translateY(15px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}@media(max-width:767px){.kiosk-shop-overlay{width:100%;max-width:100vw;border-left:none;box-shadow:none}.kiosk-shop-box{padding:max(16px,env(safe-area-inset-top) + 8px) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}.kiosk-shop-close{width:44px;height:44px;font-size:1.7rem}}.minigame-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#0a081ceb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left));touch-action:manipulation}.minigame-overlay *{touch-action:manipulation}.minigame-overlay[hidden]{display:none!important}.mg-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border:none;border-radius:12px;font:600 .95rem/1 inherit;cursor:pointer;transition:transform .12s,opacity .12s,box-shadow .12s;-webkit-user-select:none;user-select:none}.mg-btn:active{transform:scale(.96)}.mg-btn--primary{background:linear-gradient(135deg,#6c63ff,#00cec9);color:#fff}.mg-btn--primary:hover{box-shadow:0 0 18px #6c63ff8c}.mg-btn--danger{background:#ff505040;color:#ff6b6b;border:1px solid rgba(255,80,80,.35)}.mg-btn--danger:hover{background:#ff505066}.mg-btn--ghost{background:#ffffff14;color:#ffffffb3;border:1px solid rgba(255,255,255,.12)}.mg-btn--ghost:hover{background:#ffffff24}.mg-message-box{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:380px;width:100%;background:#161234f2;border:1px solid rgba(108,99,255,.3);border-radius:24px;padding:36px 28px;text-align:center;box-shadow:0 32px 80px #00000080}.mg-message-icon{font-size:3rem}.mg-message-text{font-size:1rem;line-height:1.55;color:#ffffffe6}.mg-message-text strong{color:#a29bfe}.mg-message-text small{font-size:.82rem;color:#ffffff8c}.mg-action-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}.mg-panel{width:min(520px,96vw);max-height:85dvh;background:#161234f7;border:1px solid rgba(108,99,255,.28);border-radius:24px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 32px 80px #0000008c}.mg-panel-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;font-size:1.05rem;font-weight:700;border-bottom:1px solid rgba(255,255,255,.07);color:#a29bfe;flex-shrink:0}.mg-panel-body{padding:16px 20px;overflow-y:auto;flex:1}.mg-panel-hint{font-size:.85rem;color:#ffffff80;margin:0 0 14px}.mg-player-list{display:flex;flex-direction:column;gap:10px}.mg-player-row{display:flex;align-items:center;gap:10px;background:#ffffff0a;border:1px solid rgba(255,255,255,.07);border-radius:14px;padding:12px 14px;flex-wrap:wrap}.mg-player-avatar{font-size:1.5rem;flex-shrink:0}.mg-player-name{flex:1;font-weight:700;font-size:.95rem;min-width:80px}.mg-game-select{padding:7px 10px;border-radius:10px;border:1px solid rgba(108,99,255,.35);background:#6c63ff1f;color:#fff;font:inherit;font-size:.85rem;cursor:pointer;flex-shrink:0}.mg-game-select option{background:#1a1640}.mg-game-overlay{display:flex;flex-direction:column;align-items:center;width:100%;max-width:500px;gap:12px}.mg-game-header{text-align:center;display:flex;flex-direction:column;gap:2px}.mg-game-header span{font-size:1.2rem;font-weight:800;color:#a29bfe}.mg-game-header small{font-size:.8rem;color:#ffffff80}.mg-game-container{width:100%;display:flex;justify-content:center}.ttt-game{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.ttt-header{display:flex;flex-direction:column;align-items:center;gap:10px}.ttt-players{display:flex;align-items:center;gap:14px}.ttt-player{display:flex;align-items:center;gap:6px;font-size:.9rem;font-weight:600;color:#ffffff80;padding:6px 14px;border-radius:99px;border:1px solid transparent;transition:all .2s}.ttt-player--active{color:#fff;border-color:#6c63ff73;background:#6c63ff26;box-shadow:0 0 12px #6c63ff4d}.ttt-vs{font-size:.75rem;color:#ffffff4d;font-weight:700}.ttt-mark{font-size:1rem;font-weight:900}.ttt-mark--x{color:#6c63ff}.ttt-mark--o{color:#00cec9}.ttt-turn-label{font-size:.88rem;color:#ffffffa6;margin:0;text-align:center}.ttt-board{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:min(280px,80vw)}.ttt-cell{aspect-ratio:1;border:2px solid rgba(255,255,255,.1);border-radius:16px;background:#ffffff0a;font-size:clamp(1.6rem,8vw,2.4rem);font-weight:900;cursor:default;transition:background .15s,border-color .15s,transform .12s;display:flex;align-items:center;justify-content:center;color:transparent}.ttt-cell--x{color:#6c63ff;border-color:#6c63ff66;background:#6c63ff14}.ttt-cell--o{color:#00cec9;border-color:#00cec966;background:#00cec914}.ttt-cell--playable{cursor:pointer;border-color:#fff3}.ttt-cell--playable:hover{background:#ffffff1a;border-color:#6c63ff80;transform:scale(1.06)}.ttt-cell--playable:active{transform:scale(.96)}.ttt-cancel-btn,.ttt-close-btn{margin-top:4px;padding:10px 24px;border-radius:12px;border:1px solid rgba(255,80,80,.3);background:#ff50501f;color:#ff6b6b;font:600 .9rem/1 inherit;cursor:pointer;transition:background .15s}.ttt-cancel-btn:hover,.ttt-close-btn:hover{background:#ff505040}.ttt-close-btn{border-color:#6c63ff59;background:#6c63ff26;color:#a29bfe}.ttt-close-btn:hover{background:#6c63ff47}.rps-game{display:flex;flex-direction:column;align-items:center;gap:15px;width:100%;max-width:500px;margin:0 auto;padding:10px;box-sizing:border-box}.rps-header{width:100%;text-align:center;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:12px;box-shadow:0 4px 30px #0003;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.rps-players{display:flex;align-items:center;justify-content:center;gap:20px}.rps-player{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 12px;border-radius:12px;background:#ffffff08;border:1px solid transparent;transition:all .3s cubic-bezier(.4,0,.2,1)}.rps-player--active{background:#6c63ff14;border-color:#6c63ff40;box-shadow:0 0 12px #6c63ff26}.rps-wins-badge{font-size:.7rem;background:#ffffff14;padding:2px 8px;border-radius:20px;color:#a29bfe;font-weight:700}.rps-vs{font-size:.75rem;color:#fff3;font-weight:800;letter-spacing:2px}.rps-body{display:flex;flex-direction:column;gap:15px;width:100%}.rps-play-area{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.rps-turn-label{margin:5px 0;font-size:.85rem;font-weight:600;color:#dfe6e9;letter-spacing:.5px}.rps-cards-container{display:flex;justify-content:center;gap:12px;width:100%;margin:4px 0}.rps-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;width:90px;height:115px;background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.rps-card--playable:hover{background:#6c63ff0f;border-color:#6c63ff59;transform:translateY(-4px);box-shadow:0 6px 15px #6c63ff26}.rps-card--playable:active{transform:translateY(-1px) scale(.97)}.rps-card--selected{background:#6c63ff26!important;border-color:#6c63ff99!important;box-shadow:0 0 15px #6c63ff59;transform:translateY(-4px)}.rps-card-emoji{font-size:2rem;filter:drop-shadow(0 4px 6px rgba(0,0,0,.2));transition:transform .2s}.rps-card:hover .rps-card-emoji{transform:scale(1.1)}.rps-card-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#ffffff80}.rps-card--selected .rps-card-label{color:#a29bfe}.rps-status-card{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;max-width:320px;height:115px;background:#ffffff05;border:1px dashed rgba(255,255,255,.1);border-radius:16px;color:#fff6;font-weight:500;font-size:.85rem;gap:8px}.rps-status-icon{font-size:1.8rem;animation:pulseRotate 2.5s infinite ease-in-out}@keyframes pulseRotate{0%{transform:scale(1) rotate(0);opacity:.5}50%{transform:scale(1.1) rotate(180deg);opacity:.9}to{transform:scale(1) rotate(360deg);opacity:.5}}.rps-history{width:100%;display:flex;flex-direction:column;gap:6px;background:#ffffff03;border:1px solid rgba(255,255,255,.03);border-radius:16px;padding:10px;margin-top:4px}.rps-history-title{margin:0;font-size:.7rem;font-weight:700;color:#ffffff4d;text-transform:uppercase;letter-spacing:1px;text-align:center}.rps-history-list{display:flex;flex-direction:column;gap:4px;max-height:80px;overflow-y:auto}.rps-history-row{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;padding:5px 8px;background:#ffffff05;border-radius:8px;border:1px solid rgba(255,255,255,.02);border-left:3px solid rgba(255,255,255,.1);transition:all .2s ease}.rps-history-row:hover{background:#ffffff0a}.rps-history-row--win{border-left-color:#55efc4;background:#55efc40a}.rps-history-row--lose{border-left-color:#ff7675;background:#ff76750a}.rps-history-row--draw{border-left-color:#ffeaa7;background:#ffeaa70a}.rps-history-winner{font-weight:700;color:#55efc4}.rps-history-draw{font-weight:700;color:#ffeaa7}.rps-cancel-btn,.rps-close-btn{margin-top:8px;width:100%;max-width:320px;height:38px;border-radius:12px;border:1px solid rgba(255,80,80,.3);background:#ff50501f;color:#ff6b6b;font:600 .85rem/1 inherit;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.rps-cancel-btn:hover,.rps-close-btn:hover{background:#ff505040}.rps-close-btn{border-color:#6c63ff59;background:#6c63ff26;color:#a29bfe}.rps-close-btn:hover{background:#6c63ff47}.minigame-challenge-btn{font-size:1.2rem;background:linear-gradient(135deg,#6c63ff40,#00cec933);border:1px solid rgba(108,99,255,.4)!important}.minigame-challenge-btn:hover{background:linear-gradient(135deg,#6c63ff73,#00cec959);box-shadow:0 0 14px #6c63ff73}.minigame-overlay{overflow-y:auto;align-items:center}@media(max-height:600px)or (max-width:600px){.minigame-overlay{padding:max(8px,env(safe-area-inset-top)) max(8px,env(safe-area-inset-right)) max(8px,env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left));align-items:center;justify-content:center}.mg-message-box{padding:20px 24px;gap:12px;border-radius:16px;max-width:320px}.mg-message-icon{font-size:2.2rem}.mg-message-text{font-size:.9rem;line-height:1.45}.mg-panel{max-height:94dvh;border-radius:16px}.mg-panel-header{padding:10px 16px}.mg-panel-body{padding:8px 12px}.mg-player-row{padding:8px 10px;border-radius:10px;gap:6px}.mg-player-avatar{font-size:1.25rem}.mg-player-name{font-size:.85rem}.mg-game-select{font-size:.78rem;padding:4px 6px}.mg-game-overlay{gap:6px}.mg-game-header span{font-size:1rem}.mg-game-header small{font-size:.72rem}.ttt-game{gap:8px;width:100%}.ttt-header{gap:4px}.ttt-players{gap:8px}.ttt-player{padding:4px 10px;font-size:.78rem}.ttt-vs{font-size:.68rem}.ttt-board{width:min(200px,48vh);gap:6px}.ttt-cell{border-radius:12px;font-size:clamp(1.2rem,5vh,2rem)}.ttt-cancel-btn,.ttt-close-btn{padding:8px 20px;font-size:.8rem;margin-top:2px;border-radius:10px}.rps-game{gap:8px;width:100%}.rps-body{gap:10px}.rps-play-area{gap:8px}.rps-card{width:75px;height:95px;border-radius:12px}.rps-card-emoji{font-size:1.6rem}.rps-card-label{font-size:.65rem}.rps-status-card{height:95px;font-size:.78rem;padding:8px;border-radius:12px}.rps-status-icon{font-size:1.4rem}.rps-history{padding:8px;border-radius:12px}.rps-history-list{max-height:65px}.rps-cancel-btn,.rps-close-btn{padding:8px 20px;font-size:.8rem;margin-top:2px;border-radius:10px}@media(orientation:landscape){.ttt-game{display:grid;grid-template-columns:1.2fr 1fr;align-items:center;gap:20px;width:100%;max-width:520px}.ttt-header{grid-column:1;grid-row:1;align-items:flex-start;text-align:left;gap:8px}.ttt-players{justify-content:flex-start;gap:8px}.ttt-turn-label{text-align:left;margin:0}.ttt-board{grid-column:2;grid-row:1 / span 2;justify-self:center;width:min(220px,68vh);margin:0}.ttt-cancel-btn,.ttt-close-btn{grid-column:1;grid-row:2;margin-top:0;width:100%;max-width:160px;align-self:flex-start}.rps-game{display:flex;flex-direction:column;gap:6px;width:100%;max-width:540px}.rps-header{padding:6px 10px}.rps-players{justify-content:space-around;gap:10px}.rps-vs{font-size:.7rem}.rps-body{display:grid;grid-template-columns:1.25fr 1fr;gap:12px;width:100%;align-items:stretch}.rps-play-area{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:16px;padding:8px}.rps-turn-label{font-size:.78rem;margin:0 0 4px;text-align:center}.rps-cards-container{margin:0;gap:6px}.rps-card{width:62px;height:80px;border-radius:10px;gap:3px}.rps-card-emoji{font-size:1.3rem}.rps-card-label{font-size:.58rem}.rps-status-card{height:80px;font-size:.72rem;padding:4px;border-radius:10px;max-width:200px}.rps-status-icon{font-size:1.1rem}.rps-actions{width:100%;display:flex;justify-content:center;margin-top:4px}.rps-cancel-btn,.rps-close-btn{margin-top:0;width:100%;max-width:130px;height:30px;font-size:.75rem;border-radius:8px}.rps-history{margin-top:0;padding:8px;display:flex;flex-direction:column;height:100%;box-sizing:border-box;border-radius:14px}.rps-history-title{font-size:.65rem;margin-bottom:4px}.rps-history-list{max-height:100px;flex:1}.rps-history-row{padding:4px 6px;font-size:.7rem}}}.mg-splash{position:absolute;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);animation:mg-splash-fade-in .25s forwards cubic-bezier(.25,1,.5,1)}.mg-splash--win{background:radial-gradient(circle,#ffd70040,#0a081cf5 80%)}.mg-splash--lose{background:radial-gradient(circle,#ff505033,#0a081cf5 80%)}.mg-splash--draw{background:radial-gradient(circle,#6c63ff33,#0a081cf5 80%)}.mg-splash-content{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;animation:mg-splash-pop-in .4s cubic-bezier(.34,1.56,.64,1) both}.mg-splash-emoji{font-size:clamp(4rem,15vw,6rem);line-height:1}.mg-splash--win .mg-splash-emoji{animation:mg-emoji-bounce .8s infinite alternate ease-in-out;text-shadow:0 0 40px rgba(255,215,0,.6)}.mg-splash--lose .mg-splash-emoji{animation:mg-emoji-shake .5s infinite alternate ease-in-out;filter:drop-shadow(0 0 30px rgba(255,80,80,.5))}.mg-splash--draw .mg-splash-emoji{animation:mg-emoji-pulse 1s infinite alternate ease-in-out;filter:drop-shadow(0 0 30px rgba(108,99,255,.5))}.mg-splash-title{font-size:clamp(2rem,8vw,3.2rem);font-weight:900;margin:0;letter-spacing:2px}.mg-splash--win .mg-splash-title{background:linear-gradient(135deg,#ffe066,#f5b041);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 20px rgba(255,215,0,.3)}.mg-splash--lose .mg-splash-title{background:linear-gradient(135deg,#ff8787,#fa5252);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 20px rgba(255,80,80,.3)}.mg-splash--draw .mg-splash-title{background:linear-gradient(135deg,#a29bfe,#74b9ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 20px rgba(108,99,255,.3)}.mg-splash-subtitle{font-size:clamp(.95rem,3.5vw,1.25rem);font-weight:600;color:#fffc;margin:0}@keyframes mg-splash-fade-in{0%{opacity:0}to{opacity:1}}@keyframes mg-splash-pop-in{0%{transform:scale(.7) translateY(30px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}@keyframes mg-emoji-bounce{0%{transform:scale(.9) translateY(0)}to{transform:scale(1.1) translateY(-15px)}}@keyframes mg-emoji-shake{0%{transform:rotate(-8deg) scale(.95)}to{transform:rotate(8deg) scale(1.05)}}@keyframes mg-emoji-pulse{0%{transform:scale(.95)}to{transform:scale(1.1)}}.c4-game{display:flex;flex-direction:column;gap:12px;width:100%;max-width:600px;margin:0 auto}.c4-header{display:flex;flex-direction:column;gap:10px;width:100%}.c4-score-row{display:flex;justify-content:space-between;align-items:center;gap:16px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:10px 16px}.c4-player{display:flex;align-items:center;gap:12px;padding:8px 14px;border-radius:12px;border:1px solid transparent;flex:1;background:#ffffff05;transition:all .25s ease}.c4-player--red{border-color:#ff76751a}.c4-player--yellow{border-color:#ffeaa71a}.c4-player--active.c4-player--red{background:#ff76751f;border-color:#ff767566;box-shadow:0 0 12px #ff767533}.c4-player--active.c4-player--yellow{background:#ffeaa71f;border-color:#ffeaa766;box-shadow:0 0 12px #ffeaa733}.c4-player-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.c4-player--red .c4-player-dot{background:#ff7675;box-shadow:0 0 8px #ff7675}.c4-player--yellow .c4-player-dot{background:#ffeaa7;box-shadow:0 0 8px #ffeaa7}.c4-player-info{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.c4-player-name{font-weight:700;font-size:.9rem;color:#fff}.c4-player-wins{font-size:.75rem;color:#fff9}.c4-vs{font-weight:900;font-size:.8rem;color:#fff6;letter-spacing:1px}.c4-status-badge{text-align:center;padding:6px 12px;border-radius:10px;font-size:.85rem;font-weight:700;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:#fffc}.c4-status-badge--myturn{background:#55efc414;border-color:#55efc440;color:#55efc4}.c4-status-badge--gameover{background:#6c63ff1f;border-color:#6c63ff4d;color:#a29bfe}.c4-body{display:flex;flex-direction:column;gap:16px;width:100%}.c4-play-area{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.c4-columns-header{display:grid;grid-template-columns:repeat(7,1fr);width:min(320px,90vw);gap:6px;justify-items:center}.c4-col-btn{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:4px;opacity:.3;transform:scale(.9);transition:all .2s ease}.c4-col-btn--active{opacity:1;transform:scale(1.1);animation:c4-bounce .6s infinite alternate ease-in-out}.c4-col-btn--active:hover{transform:scale(1.3) translateY(-3px);filter:drop-shadow(0 2px 5px rgba(255,255,255,.3))}@keyframes c4-bounce{0%{transform:scale(1.1) translateY(0)}to{transform:scale(1.1) translateY(-3px)}}.c4-board{display:grid;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(6,1fr);width:min(320px,90vw);aspect-ratio:7 / 6;gap:6px;padding:10px;background:linear-gradient(135deg,#1e293bb3,#0f172acc);border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 32px #0006,inset 0 2px 8px #ffffff0d;border-radius:20px}.c4-cell{position:relative;aspect-ratio:1;border-radius:50%;background:#0a0a12b3;box-shadow:inset 0 2px 6px #000c;display:flex;align-items:center;justify-content:center;overflow:hidden}.c4-token{width:84%;height:84%;border-radius:50%;transform:translateY(-100%);opacity:0;transition:transform .45s cubic-bezier(.25,1,.5,1),opacity .25s}.c4-cell--red .c4-token{transform:translateY(0);opacity:1;background:radial-gradient(circle at 35% 35%,#ff7675,#d63031 70%);box-shadow:0 4px 12px #d6303199,inset 0 2px 4px #ffffff4d}.c4-cell--yellow .c4-token{transform:translateY(0);opacity:1;background:radial-gradient(circle at 35% 35%,#ffeaa7,#fdcb6e 70%);box-shadow:0 4px 12px #fdcb6e99,inset 0 2px 4px #ffffff4d}.c4-actions{display:flex;justify-content:center;width:100%;margin-top:6px}.c4-cancel-btn,.c4-close-btn{width:100%;max-width:240px;height:38px;border-radius:12px;font-size:.85rem}.c4-sidebar{display:flex;flex-direction:column;gap:10px;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:16px;padding:12px;box-sizing:border-box}.c4-sidebar h3{font-size:.85rem;font-weight:800;color:#ffffff80;margin:0;text-transform:uppercase;letter-spacing:.5px}.c4-history-list{display:flex;flex-direction:column;gap:8px;max-height:120px;overflow-y:auto}.c4-history-empty{font-size:.8rem;color:#ffffff59;text-align:center;padding:12px;font-style:italic}.c4-history-item{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;border-radius:10px;font-size:.8rem;border-left:4px solid transparent}.c4-history-item--red{border-left-color:#ff7675;background:#ff76750a;color:#ff7675}.c4-history-item--yellow{border-left-color:#ffeaa7;background:#ffeaa70a;color:#ffeaa7}.c4-history-item--draw{border-left-color:#a29bfe;background:#a29bfe0a;color:#a29bfe}@media(orientation:landscape)and (max-height:600px){.c4-game{display:grid;grid-template-columns:1fr 1.25fr;grid-template-rows:auto 1fr;gap:8px 16px;width:100%;max-width:640px;margin:0 auto;align-items:center}.c4-header{grid-column:1;grid-row:1;display:flex;flex-direction:column;gap:4px;width:100%}.c4-score-row{padding:4px 8px;gap:8px;border-radius:10px}.c4-player{padding:3px 6px;gap:6px;border-radius:8px}.c4-player-dot{width:8px;height:8px}.c4-player-name{font-size:.72rem}.c4-player-wins,.c4-vs{font-size:.65rem}.c4-status-badge{font-size:.72rem;padding:3px 8px;border-radius:8px}.c4-body{display:contents}.c4-sidebar{grid-column:1;grid-row:2;padding:6px 10px;border-radius:12px;box-sizing:border-box;display:flex;flex-direction:column;gap:4px;height:100%;min-height:90px;max-height:130px}.c4-sidebar h3{font-size:.65rem;margin-bottom:2px}.c4-history-list{max-height:80px;flex:1;gap:4px}.c4-history-item{padding:3px 6px;font-size:.68rem;border-radius:6px}.c4-play-area{grid-column:2;grid-row:1 / span 2;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:16px;padding:6px;gap:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}.c4-columns-header{width:min(200px,50vh);gap:4px}.c4-col-btn{font-size:.9rem;padding:0}.c4-board{width:min(200px,50vh);gap:4px;padding:6px;border-radius:14px}.c4-actions{margin-top:2px;width:100%;display:flex;justify-content:center}.c4-cancel-btn,.c4-close-btn{height:28px;font-size:.72rem;border-radius:8px;max-width:120px}}.memo-game{width:100%;max-width:360px;margin:0 auto;display:flex;flex-direction:column;gap:12px;color:#f5f6fa}.memo-header{display:flex;flex-direction:column;gap:8px;align-items:center;width:100%}.memo-score-row{display:flex;align-items:center;justify-content:space-between;width:100%;background:#ffffff08;border:1px solid rgba(255,255,255,.06);padding:8px 16px;border-radius:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.memo-player{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:10px;transition:all .3s ease;background:#ffffff03;border:1px solid transparent}.memo-player--active{background:#a29bfe1a;border-color:#a29bfe4d;box-shadow:0 0 12px #a29bfe33}.memo-player-dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 8px currentColor}.memo-player-dot--red{background-color:#ff7675;color:#ff7675}.memo-player-dot--yellow{background-color:#ffeaa7;color:#ffeaa7}.memo-player-info{display:flex;flex-direction:column;align-items:flex-start}.memo-player-name{font-size:.9rem;font-weight:600;max-width:90px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.memo-player-wins{font-size:.72rem;opacity:.7}.memo-vs{font-size:.8rem;font-weight:700;color:#ffffff4d}.memo-status-badge{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);font-size:.85rem;padding:6px 16px;border-radius:20px;width:100%;text-align:center;box-sizing:border-box;font-weight:600;color:#ffffffe6;transition:all .3s ease}.memo-status-badge--my-turn{background:#2ecc711a;border-color:#2ecc714d;color:#2ecc71;box-shadow:0 0 10px #2ecc7126;animation:memo-pulse 2s infinite ease-in-out}@keyframes memo-pulse{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.memo-body{display:flex;flex-direction:column;gap:12px;width:100%}.memo-play-area{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.memo-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);gap:10px;width:min(280px,75vw);aspect-ratio:1;background:#0003;padding:12px;border-radius:18px;border:1px solid rgba(255,255,255,.05)}.memo-card{perspective:1000px;cursor:pointer;aspect-ratio:1;border-radius:8px}.memo-card-inner{position:relative;width:100%;height:100%;text-align:center;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);transform-style:preserve-3d;border-radius:8px}.memo-card--flipped .memo-card-inner{transform:rotateY(180deg)}.memo-card-back,.memo-card-front{position:absolute;width:100%;height:100%;backface-visibility:hidden;display:flex;align-items:center;justify-content:center;border-radius:8px;font-weight:700}.memo-card-back{background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;font-size:1.2rem;border:1px solid rgba(255,255,255,.15);box-shadow:0 4px 8px #0003}.memo-card-front{background:#ffffff14;border:1px solid rgba(255,255,255,.15);font-size:1.5rem;transform:rotateY(180deg);box-shadow:inset 0 0 10px #ffffff0d}.memo-card--matched .memo-card-front{background:#2ecc7126;border-color:#2ecc7166;color:#2ecc71;opacity:.85}.memo-actions{display:flex;justify-content:center;width:100%}.memo-cancel-btn,.memo-close-btn{width:100%;max-width:200px;height:36px;border-radius:10px;font-size:.85rem;font-weight:600}.memo-sidebar{background:#ffffff05;border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:10px 14px;display:flex;flex-direction:column;gap:8px;max-height:180px}.memo-sidebar h3{font-size:.85rem;font-weight:700;text-transform:uppercase;color:#fff9;letter-spacing:.5px;margin:0}.memo-matched-list{display:flex;flex-wrap:wrap;gap:6px;overflow-y:auto;max-height:140px;align-content:flex-start}.memo-empty-matched{font-size:.75rem;opacity:.5;width:100%;text-align:center;padding:12px 0;font-style:italic}.memo-matched-item{background:#2ecc7114;border:1px solid rgba(46,204,113,.2);color:#2ecc71;font-size:.72rem;padding:4px 8px;border-radius:8px;font-weight:600}@media(orientation:landscape)and (max-height:600px){.memo-game{display:grid;grid-template-columns:1fr 1.25fr;grid-template-rows:auto 1fr;gap:8px 16px;width:100%;max-width:640px;margin:0 auto;align-items:center}.memo-header{grid-column:1;grid-row:1;display:flex;flex-direction:column;gap:4px;width:100%}.memo-score-row{padding:4px 8px;border-radius:10px}.memo-player{padding:3px 6px;gap:6px;border-radius:8px}.memo-player-dot{width:8px;height:8px}.memo-player-name{font-size:.72rem;max-width:65px}.memo-player-wins,.memo-vs{font-size:.65rem}.memo-status-badge{font-size:.72rem;padding:3px 8px;border-radius:8px}.memo-body{display:contents}.memo-sidebar{grid-column:1;grid-row:2;padding:6px 10px;border-radius:12px;box-sizing:border-box;display:flex;flex-direction:column;gap:4px;height:100%;min-height:90px;max-height:130px}.memo-sidebar h3{font-size:.65rem;margin-bottom:2px}.memo-matched-list{max-height:80px;flex:1;gap:4px}.memo-matched-item{padding:3px 6px;font-size:.68rem;border-radius:6px}.memo-play-area{grid-column:2;grid-row:1 / span 2;background:#ffffff05;border:1px solid rgba(255,255,255,.04);border-radius:16px;padding:6px;gap:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}.memo-grid{width:min(200px,50vh);gap:6px;padding:6px;border-radius:14px}.memo-card-back{font-size:.9rem}.memo-card-front{font-size:1.1rem}.memo-actions{width:100%;display:flex;justify-content:center}.memo-cancel-btn,.memo-close-btn{height:28px;font-size:.72rem;border-radius:8px;max-width:120px}}
