@import url('https://fonts.googleapis.com/css2?family=Luckiest+Guy&family=Nunito:wght@800;900&display=swap');
*{box-sizing:border-box}body{margin:0;min-height:100vh;color:#fff;font-family:Nunito,Arial,sans-serif;background:radial-gradient(circle at 15% 5%,#31fb71,#09602e 38%,#04160c 100%);overflow-x:hidden}.scanlines{pointer-events:none;position:fixed;inset:0;background:repeating-linear-gradient(0deg,rgba(255,255,255,.04) 0 1px,transparent 1px 5px);mix-blend-mode:soft-light;z-index:20}.topbar{position:sticky;top:0;height:66px;background:rgba(3,20,12,.92);border-bottom:4px solid #ffd91a;display:flex;align-items:center;gap:15px;padding:0 18px;z-index:30;box-shadow:0 8px 0 #540b08}.brand,.title{font-family:'Luckiest Guy',cursive;letter-spacing:1px;text-shadow:3px 4px 0 #8b0b07,5px 6px 0 #1b2029}.brand{font-size:27px;color:#ffd91a}.mini-wallet{margin-left:auto;background:#ffd91a;color:#8b0b07;padding:8px 14px;border-radius:16px;border:3px solid #8b0b07}.hamb{width:48px;height:42px;border:3px solid #ffd91a;border-radius:10px;background:#ff8b18;display:grid;place-items:center;padding:6px;cursor:pointer;box-shadow:0 5px 0 #242b38}.hamb span{display:block;width:25px;height:4px;background:#fff;border-radius:8px;box-shadow:1px 1px 0 #8b0b07}.side{position:fixed;left:0;top:66px;bottom:0;width:285px;background:#102233;border-right:5px solid #ffd91a;z-index:40;transform:translateX(-105%);transition:.25s;padding:18px;box-shadow:10px 0 0 rgba(0,0,0,.25)}.side.open{transform:translateX(0)}.side-title{font-family:'Luckiest Guy';font-size:34px;color:#ffd91a;text-align:center;margin-bottom:15px;text-shadow:3px 3px 0 #8b0b07}.side button{display:block;width:100%;margin:10px 0;padding:14px;border-radius:18px;border:4px solid #242b38;background:linear-gradient(#ffe65a,#ff8d17);color:white;font-family:'Luckiest Guy';font-size:20px;text-shadow:2px 2px 0 #8b0b07;box-shadow:0 6px 0 #151821;cursor:pointer}.overlay{display:none;position:fixed;inset:66px 0 0;background:rgba(0,0,0,.45);z-index:35}.overlay.show{display:block}.app{width:min(1100px,100%);margin:0 auto;padding:24px 15px}.screen{display:none;animation:pop .18s ease}.screen.active{display:block}.title{text-align:center;font-size:clamp(42px,8vw,78px);color:#ffd91a;margin:30px 0}.menu-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,360px));justify-content:center;gap:24px}.game-btn,.back{border:5px solid #2c3341;border-radius:26px;background:linear-gradient(#ffe45b 0%,#ffb422 45%,#ff7e10 46%,#ff9c21 100%);color:#fff;font-family:'Luckiest Guy';font-size:clamp(22px,3vw,38px);padding:18px 24px;text-shadow:3px 3px 0 #9b0804;box-shadow:0 9px 0 #151821, inset 0 0 0 4px rgba(255,255,255,.25);cursor:pointer}.game-btn:active,.back:active{transform:translateY(6px);box-shadow:0 3px 0 #151821}.game-btn.green{background:linear-gradient(#baff4a,#32d442 45%,#08a92b 46%,#2ee45a)}.game-btn.blue{background:linear-gradient(#a9f6ff,#41bff0 45%,#167ee8 46%,#39a8ff)}.game-btn.red{background:linear-gradient(#ff6874,#ec2638 45%,#b10a19 46%,#f64531)}.back{font-size:20px;padding:12px 18px;border-radius:18px}.panel,.game-card{background:#ffd91a;color:#8b0b07;border:7px solid #8b0b07;border-radius:30px;padding:24px;margin:18px auto;width:min(720px,100%);box-shadow:0 9px 0 #fff,0 17px 0 rgba(0,0,0,.28)}input,select{width:100%;padding:16px;margin:8px 0 15px;border-radius:16px;border:4px solid #8b0b07;font-size:20px;font-weight:900;color:#8b0b07;background:#fff}.notice{background:rgba(255,255,255,.58);border-radius:16px;padding:14px;text-align:center;font-size:22px;font-weight:900;margin-top:15px}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stats div{background:#fff3a5;border:4px solid #8b0b07;border-radius:16px;text-align:center;padding:12px}.stats small{display:block}.stats b{font-size:26px}.wheel-wrap{width:min(480px,94vw);height:min(480px,94vw);margin:auto;position:relative}.wheel{position:absolute;inset:7%;border-radius:50%;border:10px solid #fff;box-shadow:0 0 0 12px #d71922,0 0 0 20px #ff4b25,0 15px 25px #0008;background:conic-gradient(#e84e4e 0 25.714deg,#0fbf70 25.714deg 51.428deg,#ffe100 51.428deg 77.142deg,#f28c18 77.142deg 102.856deg,#f6f1df 102.856deg 128.57deg,#2fc48d 128.57deg 154.284deg,#e84e4e 154.284deg 179.998deg,#ffd148 179.998deg 205.712deg,#9620ff 205.712deg 231.426deg,#28b5e8 231.426deg 257.14deg,#e23b8a 257.14deg 282.854deg,#ff3f3f 282.854deg 308.568deg,#ff9d16 308.568deg 334.282deg,#2fc48d 334.282deg 360deg);transition:transform 4s cubic-bezier(.1,.8,.12,1)}.wheel span{position:absolute;left:50%;top:50%;width:96px;margin-left:-48px;margin-top:-18px;text-align:center;font-family:'Luckiest Guy';font-size:18px;color:#fff;text-shadow:2px 2px 0 #8b0b07;transform:rotate(var(--r)) translateY(-165px) rotate(90deg)}.hub{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:100px;height:100px;border-radius:50%;background:radial-gradient(#fff68d,#c76b00);border:8px solid #8b0b07;color:#111;display:grid;place-items:center;font-family:'Luckiest Guy';z-index:3}.pin{position:absolute;left:50%;top:-4px;transform:translateX(-50%);z-index:5;width:0;height:0;border-left:28px solid transparent;border-right:28px solid transparent;border-top:58px solid #fff;filter:drop-shadow(0 4px 0 #8b0b07)}.num-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin:14px 0}.num{width:62px;height:62px;border-radius:14px;border:5px solid #8b0b07;background:#fff;display:grid;place-items:center;font-size:34px;font-weight:900;color:#8b0b07;box-shadow:0 5px 0 #ff8d17}.masked .num{filter:blur(1px)}.label{text-align:center;font-family:'Luckiest Guy';font-size:25px}.pick .num{cursor:pointer;background:#fffbe7}.slot-machine{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:20px auto;width:min(500px,100%)}.reel{height:180px;border-radius:25px;border:7px solid #8b0b07;background:linear-gradient(#fff,#e9e9e9);display:grid;place-items:center;font-size:64px;box-shadow:inset 0 0 25px #7778,0 7px 0 #ff8d17}.reel.spin{animation:shake .12s linear infinite}.modal{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:60;place-items:center}.modal.show{display:grid}.modal-box{width:min(440px,92vw);background:#ffd91a;color:#8b0b07;border:7px solid #8b0b07;border-radius:28px;padding:22px;text-align:center}.digits{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.digits button{height:70px;border-radius:18px;border:4px solid #8b0b07;background:#fff;font-size:34px;font-weight:900;color:#8b0b07}hr{border:0;border-top:5px dashed #8b0b07;margin:20px}@keyframes pop{from{transform:scale(.96);opacity:.5}}@keyframes shake{0%{transform:translateY(-4px)}100%{transform:translateY(4px)}}@media(max-width:760px){.topbar{height:60px}.brand{font-size:20px}.mini-wallet{font-size:13px;padding:6px}.side{top:60px;width:85vw}.overlay{inset:60px 0 0}.app{padding:12px}.menu-grid{grid-template-columns:1fr;gap:15px}.panel,.game-card{padding:16px;border-width:5px;border-radius:22px}.stats{grid-template-columns:repeat(2,1fr)}.wheel-wrap{width:92vw;height:92vw}.wheel span{font-size:13px;transform:rotate(var(--r)) translateY(-31vw) rotate(90deg)}.slot-machine{gap:8px}.reel{height:140px;font-size:48px}.num{width:54px;height:54px;font-size:28px}.game-btn{width:100%;font-size:25px;padding:15px}}
.cost-tag{display:inline-block;background:#fff;color:#8b0b07;border:4px solid #8b0b07;border-radius:18px;padding:10px 16px;font-weight:900;margin:0 auto 15px;box-shadow:0 5px 0 #ff8d17}.wheel.glow{filter:drop-shadow(0 0 24px #fff700)}#fxLayer{position:fixed;inset:0;pointer-events:none;z-index:90;overflow:hidden}#fxLayer i{position:absolute;top:-20px;width:14px;height:22px;background:#ffd91a;border:2px solid #8b0b07;border-radius:4px;animation:fall 1.8s linear forwards}.result-box h2{font-family:'Luckiest Guy';font-size:48px;margin:5px 0 10px;text-shadow:3px 3px 0 #fff}.result-box h2.win{color:#15b83f}.result-box h2.lose{color:#d71922}.result-box p{font-size:23px;font-weight:900}.share-win{font-size:22px;margin-top:14px}.game-card .game-btn+.game-btn{margin-top:14px}@keyframes fall{to{transform:translateY(105vh) rotate(720deg);opacity:.1}}@media(max-width:760px){.share-win{font-size:20px}.result-box h2{font-size:38px}.cost-tag{display:block;text-align:center}}
.round-badge{display:inline-block;background:#fff;color:#8b0b07;border:4px solid #8b0b07;border-radius:18px;padding:10px 16px;font-weight:900;margin:0 auto 15px;box-shadow:0 5px 0 #ff8d17;text-align:center;width:100%}.game-btn.locked{opacity:.65;filter:grayscale(.25);cursor:not-allowed}.moves-list{margin-top:16px;overflow:auto}.moves-table{width:100%;border-collapse:collapse;background:#fff;border:4px solid #8b0b07;border-radius:16px;overflow:hidden}.moves-table th,.moves-table td{padding:10px;border-bottom:2px solid #ffd91a;color:#8b0b07;text-align:left;font-weight:900}.moves-table th{background:#ffb422}.hub{cursor:pointer;user-select:none}.hub:active{transform:translate(-50%,-44%)}
@media(max-width:760px){.moves-table{font-size:13px}.moves-table th,.moves-table td{padding:8px}.round-badge{font-size:15px}}

/* Business payment polish */
.pay-panel{position:relative;overflow:hidden}.pay-panel:before{content:"";position:absolute;inset:-80px -80px auto auto;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.18)}.pay-copy{font-weight:900;line-height:1.45}.paypal-box{margin:14px 0 10px;min-height:48px}.locked{opacity:.55;filter:grayscale(1)}

/* PATCH PRO MAX: notificaciones, mensajes y maquinita */
.msg-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 7px;border-radius:999px;background:#ff164e;color:#fff;font-size:12px;font-weight:1000;box-shadow:0 0 0 3px #fff4;vertical-align:middle;margin-left:6px}.top-notice{position:sticky;top:64px;z-index:30;margin:0 auto;width:min(1040px,calc(100% - 22px));background:linear-gradient(135deg,#fff7cc,#ffd91a);color:#2b1600;border:4px solid #8b0b07;border-radius:18px;padding:12px 14px;display:flex;gap:10px;align-items:center;box-shadow:0 12px 0 #0004}.top-notice b{font-weight:1000}.top-notice span{flex:1}.notice-close{border:0;border-radius:12px;background:#8b0b07;color:#fff;font-weight:1000;padding:9px 12px;cursor:pointer}.messages-list{display:grid;gap:12px}.msg-card{background:#fff;color:#222;border:4px solid #222;border-radius:18px;padding:14px;box-shadow:0 7px 0 #0003}.msg-card.unread{background:#fff8d8;border-color:#ff8a00}.msg-card>div{display:flex;justify-content:space-between;gap:10px;align-items:start}.msg-card small{opacity:.65;font-weight:900}.msg-card p{white-space:pre-wrap;line-height:1.35}.read-pill{display:inline-block;border-radius:99px;background:#16a34a;color:#fff;padding:6px 10px;font-weight:1000}.slot-machine{position:relative;overflow:hidden}.slot-machine:before{content:"";position:absolute;left:0;right:0;top:50%;height:4px;background:#fff8;box-shadow:0 0 20px #fff;z-index:1}.reel{transition:transform .35s ease, filter .35s ease, box-shadow .35s ease}.reel.running{filter:blur(1px) saturate(1.3);animation:slotShake .12s linear infinite}.reel.stopped{animation:reelStop .45s cubic-bezier(.18,.89,.32,1.28);box-shadow:0 0 22px #ffd91a inset,0 0 20px #ffd91a}@keyframes slotShake{0%{transform:translateY(-3px) scale(1.02)}50%{transform:translateY(3px) scale(.98)}100%{transform:translateY(-3px) scale(1.02)}}@keyframes reelStop{0%{transform:translateY(-35px) scale(.9);filter:blur(3px)}70%{transform:translateY(8px) scale(1.1)}100%{transform:translateY(0) scale(1);filter:none}}
@media(max-width:700px){.top-notice{top:58px;display:block}.notice-close{margin-top:8px;width:100%}.msg-card>div{display:block}}
.oauth-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.profile-panel{border:1px solid rgba(255,255,255,.18)}@media(max-width:620px){.oauth-row{grid-template-columns:1fr}}
/* Navegación robusta por ?section= */
.side a{display:block;width:100%;margin:10px 0;padding:14px;border-radius:18px;border:4px solid #242b38;background:linear-gradient(#ffe65a,#ff8d17);color:white;font-family:'Luckiest Guy';font-size:20px;text-shadow:2px 2px 0 #8b0b07;box-shadow:0 6px 0 #151821;cursor:pointer;text-decoration:none;text-align:center}.brand{text-decoration:none}.menu-grid a{text-decoration:none;text-align:center}.mini-links{text-align:center;font-weight:900}.mini-links a{color:#8b0b07}.faq-panel h3{margin:22px 0 6px;font-size:24px}.faq-panel p{font-weight:900;line-height:1.45}

/* PATCH UX SESION + CHAT FLOTANTE */
body.is-guest .app{padding-top:28px}.guest-home{text-align:center}.guest-home p{font-weight:900;font-size:20px;line-height:1.45}.guest-actions{display:grid;grid-template-columns:1fr 1fr;gap:14px}.account-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:start}.chat-float{position:fixed;right:20px;bottom:20px;z-index:120}.chat-bubble{width:72px;height:72px;border-radius:50%;border:5px solid #fff;background:linear-gradient(#41bff0,#167ee8);color:#fff;font-size:30px;box-shadow:0 12px 35px #0007;cursor:pointer;position:relative}.chat-bubble span{position:absolute;right:-4px;top:-4px;background:#ff164e;color:#fff;border-radius:99px;min-width:24px;height:24px;font-size:12px;display:grid;place-items:center}.chat-panel{display:none;position:absolute;right:0;bottom:86px;width:min(380px,92vw);height:520px;background:#fff;border:5px solid #172033;border-radius:26px;overflow:hidden;box-shadow:0 20px 80px #0008;color:#172033}.chat-panel.open{display:grid;grid-template-rows:auto 1fr auto}.chat-head{background:linear-gradient(135deg,#ffb422,#ff7e10);color:#fff;padding:14px 16px;display:flex;justify-content:space-between;align-items:center;font-size:18px;font-weight:1000}.chat-head button{width:auto;border:0;background:#8b0b07;color:#fff;border-radius:12px;padding:5px 10px;font-size:24px;cursor:pointer}.chat-body{padding:14px;overflow:auto;background:#f6f7fb}.chat-msg{max-width:86%;margin:8px 0;padding:10px 12px;border-radius:16px;background:#fff;border:2px solid #dde2ee;box-shadow:0 5px 15px #0001}.chat-msg.user{margin-left:auto;background:#e9f8ff;border-color:#41bff0}.chat-msg.admin{margin-right:auto;background:#fff7d8;border-color:#ffb422}.chat-msg small{display:block;opacity:.65;font-weight:900;margin-bottom:4px}.chat-msg p{margin:0;white-space:pre-wrap;line-height:1.35}.chat-compose{display:grid;grid-template-columns:1fr auto;gap:8px;padding:10px;background:#fff;border-top:2px solid #eef1f6}.chat-compose input{margin:0;border:2px solid #dde2ee;color:#172033;font-size:15px}.chat-compose button{border:0;border-radius:14px;background:#167ee8;color:#fff;font-weight:1000;padding:0 14px;cursor:pointer}@media(max-width:760px){.guest-actions,.account-grid{grid-template-columns:1fr}.chat-float{right:12px;bottom:12px}.chat-bubble{width:64px;height:64px}.chat-panel{height:75vh;bottom:76px}}

/* PATCH CACHE/STABILITY 2026-05: home buttons + chat safe layout */
html,body{min-height:100%;}
.screen{display:none;}
.screen.active{display:block;animation:pop .18s ease both;}
body.is-guest .topbar,body.is-guest .side,body.is-guest .overlay{display:none!important;}
.guest-actions{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;align-items:stretch;margin-top:18px;}
.guest-actions .game-btn{width:100%;min-height:72px;display:flex;align-items:center;justify-content:center;margin:0!important;white-space:normal;text-align:center;}
.menu-grid .game-btn,.oauth-row .game-btn{display:flex;align-items:center;justify-content:center;min-height:64px;margin:0!important;text-align:center;}
.back{cursor:pointer;}
.chat-float{position:fixed!important;right:20px!important;bottom:20px!important;z-index:9999!important;display:block!important;}
.chat-bubble{display:grid!important;place-items:center;line-height:1;}
.chat-panel{position:absolute!important;right:0!important;bottom:86px!important;z-index:10000!important;}
.chat-panel.open{display:grid!important;}
body:not(.is-auth) .chat-float{display:none!important;}
@media(max-width:760px){.guest-actions{grid-template-columns:1fr!important}.guest-actions .game-btn{min-height:64px}.chat-float{right:12px!important;bottom:12px!important}.chat-panel{bottom:76px!important;right:0!important;width:calc(100vw - 24px)!important}}


/* PATCH CACHE + MENU MOVIL PRO */
.side{overflow-y:auto!important;overflow-x:hidden!important;-webkit-overflow-scrolling:touch!important;max-height:calc(100vh - 66px)!important;padding-bottom:110px!important;background:linear-gradient(180deg,#081827,#162d44 55%,#07131f)!important;scrollbar-width:thin;scrollbar-color:#ffd91a #081827;}
.side::-webkit-scrollbar{width:8px}.side::-webkit-scrollbar-track{background:#081827}.side::-webkit-scrollbar-thumb{background:#ffd91a;border-radius:20px}
.side a,.side button{transition:transform .15s ease,filter .15s ease}.side a:hover,.side button:hover{transform:translateX(3px);filter:brightness(1.08)}
.side a.side-play{background:linear-gradient(#ffe65a,#ff8d17)!important;color:#fff!important;text-shadow:2px 2px 0 #8b0b07!important;}
.side a.side-main{background:linear-gradient(#b9fff8,#31c9d8 45%,#1685a5)!important;text-shadow:2px 2px 0 #06485b!important;}
.side a.side-info{background:linear-gradient(#ffffff,#d5ecff 45%,#7aaeff)!important;color:#102233!important;text-shadow:none!important;}
.side a.side-money{background:linear-gradient(#c7ff7c,#29d85c 45%,#079c39)!important;text-shadow:2px 2px 0 #07521f!important;}
.side a.side-data{background:linear-gradient(#b8d7ff,#5a91ff 45%,#2555d7)!important;text-shadow:2px 2px 0 #10287a!important;}
.side a.side-chat{background:linear-gradient(#f2c3ff,#bc55f0 45%,#7f22c9)!important;text-shadow:2px 2px 0 #421069!important;}
.side a.side-account{background:linear-gradient(#ffd6a5,#ff944d 45%,#dd5b18)!important;text-shadow:2px 2px 0 #8b2a00!important;}
.side button.side-logout,#logoutBtn{background:linear-gradient(#ff8b94,#e4293d 45%,#9f0615)!important;text-shadow:2px 2px 0 #58000b!important;}
.guest-actions{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:16px!important;align-items:stretch!important}.guest-actions .game-btn{opacity:1!important;visibility:visible!important;min-height:76px!important}
.chat-float{position:fixed!important;right:18px!important;bottom:18px!important;z-index:2147483000!important;display:block!important;transform:none!important}.chat-panel{position:absolute!important;right:0!important;bottom:76px!important;z-index:2147483001!important}.chat-bubble{width:64px!important;height:64px!important;border-radius:999px!important}
@media(max-width:760px){.side{top:60px!important;max-height:calc(100vh - 60px)!important;width:min(88vw,340px)!important;padding-bottom:130px!important}.side a,.side button{font-size:18px!important;padding:13px!important;margin:8px 0!important}.guest-actions{grid-template-columns:1fr!important}.chat-float{right:12px!important;bottom:12px!important}.chat-panel{width:calc(100vw - 24px)!important;max-width:380px!important;right:0!important}}
