body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (min-width:768px){body{align-items:stretch}}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{height:100%;width:100%}.grecaptcha-badge{display:none!important;opacity:0!important;visibility:hidden!important}:root,[data-theme=light]{--bg-primary:#4ecdc4;--bg-secondary:#45b8b0;--bg-tertiary:#3da69f;--bg-card:#5dd9d1;--text-primary:#1a3a3a;--text-secondary:#2d5a5a;--text-tertiary:#3d6a6a;--text-white:#fff;--text-gold:#d4a000;--border-color:#3db9b1;--border-glow:#4ecdc480;--overlay-bg:#4ecdc4f2;--modal-bg:#45b8b0;--button-bg:linear-gradient(180deg,#2d8a85,#247a75);--button-bg-solid:#2d8a85;--button-hover:linear-gradient(180deg,#359590,#2d8a85);--button-hover-solid:#359590;--button-disabled:#7ab5b0;--button-disabled-hover:#8ac5c0;--button-shadow:0 4px 0 #1d6a65;--button-glow:0 0 20px #2d8a8566;--correct-bg:#44bd32;--semi-bg:#f5a623;--incorrect-bg:#7ab5b0;--keyboard-bg:linear-gradient(180deg,#2d8a85,#247a75);--keyboard-bg-solid:#2d8a85;--keyboard-hover:linear-gradient(180deg,#359590,#2d8a85);--keyboard-shadow:0 3px 0 #1d6a65;--share-button-bg:#2d8a85;--gems-bg:#45b8b0;--gems-text:#1a3a3a;--accent-gold:gold;--accent-purple:#9b59b6;--accent-red:#e74c3c;--card-shadow:0 4px 15px #00000026;--glow-turquoise:0 0 15px #2d8a8580}*{box-sizing:border-box;padding:0}*,body{margin:0}body{align-items:center;background-color:#2d8a85;color:#1a3a3a;color:var(--text-primary);display:flex;flex-direction:column;font-family:Clear Sans,Helvetica Neue,Arial,sans-serif;height:100vh;height:100dvh;overflow-x:hidden;overflow-y:hidden;position:relative;width:100vw}.app-background{background-color:#2a7d78;background-image:repeating-linear-gradient(180deg,#ffffff40 0,#ffffff40 3px,#0000 0,#0000 50px),repeating-linear-gradient(90deg,#fff3 0,#fff3 3px,#0000 0,#0000 50px),repeating-linear-gradient(180deg,#0000 0,#0000 47px,#0000004d 0,#0000004d 50px),repeating-linear-gradient(90deg,#0000 0,#0000 47px,#00000040 0,#00000040 50px),repeating-linear-gradient(135deg,#4ecdc426,#4ecdc414 25px,#0000000d 50px),linear-gradient(180deg,#3da69f,#2d8a85 50%,#257a75);background-size:50px 50px,50px 50px,50px 50px,50px 50px,50px 50px,100% 100%;height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}button{border:initial;cursor:pointer;font-family:inherit;outline:none}.home-container{background:#0000;display:flex;flex-direction:column;max-width:600px;min-height:100vh;min-height:100dvh;position:relative;width:100%}@media (max-width:767px){.home-container{display:flex;flex:1 1;flex-direction:column;overflow-x:hidden;overflow-y:auto;padding-bottom:0}}@media (min-width:768px){.home-container{max-width:100%;padding-top:0;width:100%}}.mobile-sidebar{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:2px solid #3db9b1;border:2px solid var(--border-color);border-left:none;border-radius:0 16px 16px 0;box-shadow:4px 0 15px #0000004d,inset 0 1px 0 #ffffff1a;display:flex;flex-direction:column;height:80px;justify-content:center;left:0;padding:8px;position:fixed;top:50%;transform:translateY(-50%);transition:all .3s cubic-bezier(.4,0,.2,1);width:60px;z-index:100}.mobile-sidebar,.mobile-sidebar.expanded{background:linear-gradient(180deg,#2d8a85,#247a75)}.mobile-sidebar.expanded{align-items:flex-start;border:2px solid #3db9b1;border:2px solid var(--border-color);border-left:none;box-shadow:4px 0 20px #0006,inset 0 1px 0 #ffffff1a;height:80vh;justify-content:flex-start;padding:16px;width:220px}@media (min-width:768px){.mobile-sidebar{display:none}}.sidebar-toggle{align-items:center;background:linear-gradient(180deg,#4ecdc4,#3db9b1);border:none;border-radius:12px;box-shadow:0 4px 0 #2a9d97,0 6px 15px #0000004d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:64px;justify-content:center;text-shadow:0 1px 2px #0000004d;transition:all .2s ease;width:44px}@media (max-width:767px){.mobile-sidebar:not(.expanded) .sidebar-toggle{background:linear-gradient(180deg,#4ecdc4,#3db9b1)!important;border:none!important;box-shadow:0 4px 0 #2a9d97,0 6px 15px #0000004d!important}.mobile-sidebar:not(.expanded) .sidebar-toggle:hover{background:linear-gradient(180deg,#5dd9d1,#4ecdc4)!important;border:none!important}}.left-sidebar.expanded .sidebar-toggle{height:40px;margin-bottom:8px;width:100%}.sidebar-toggle:hover{background:linear-gradient(180deg,#5dd9d1,#4ecdc4);box-shadow:0 6px 0 #2a9d97,0 8px 20px #0006;color:#fff;transform:translateY(-2px)}.sidebar-toggle:active{box-shadow:0 2px 0 #2a9d97,0 4px 10px #0000004d;transform:translateY(2px)}.sidebar-content{display:none;flex:1 1;flex-direction:column;gap:12px;overflow-x:hidden;overflow-y:auto;width:100%}.left-sidebar.expanded .sidebar-content{display:flex}.sidebar-button{align-items:center;background:linear-gradient(180deg,#1e5a55,#1e5a55 50%,#164a45 0,#164a45);border:2px solid #4ecdc480;border-radius:14px;box-shadow:0 5px 0 #0f3532,0 7px 15px #00000059;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:700;gap:12px;min-height:60px;overflow:hidden;padding:12px 16px;position:relative;text-shadow:0 2px 4px #0000004d;transition:all .15s ease;width:100%}.sidebar-button:before{background:linear-gradient(180deg,#ffffff1f,#fff0);border-radius:12px 12px 0 0;content:"";height:50%;left:0;pointer-events:none;position:absolute;right:0;top:0}.sidebar-button:hover{background:linear-gradient(180deg,#237a74,#237a74 50%,#1c6a64 0,#1c6a64);border-color:#4ecdc4b3;box-shadow:0 8px 0 #0f3532,0 10px 25px #0006;color:#fff;transform:translateY(-3px)}.sidebar-button:active{box-shadow:0 2px 0 #0f3532,0 4px 8px #0003;transform:translateY(3px)}.sidebar-icon{align-items:center;background:#0000;border:none;border-radius:0;display:flex;flex-shrink:0;height:40px;justify-content:center;min-height:40px;min-width:40px;transition:all .2s ease;width:40px}.sidebar-button:hover .sidebar-icon{background:#0000;border:none}.sidebar-icon svg{color:inherit;height:32px;width:32px}.sidebar-icon img{height:32px;object-fit:contain;width:32px}.sidebar-label{opacity:0;overflow:hidden;transition:opacity .3s ease,width .3s ease;white-space:nowrap;width:0}.left-sidebar.expanded .sidebar-label{opacity:1;width:auto}.desktop-nav-bar{display:none}@media (min-width:768px){.desktop-nav-bar{display:block;flex-shrink:0}.desktop-nav-content{align-items:center;display:flex;flex-direction:row;gap:12px;justify-content:flex-start}.desktop-nav-bar .sidebar-button{flex:0 0 auto;min-height:50px;padding:12px 20px;transform:none;width:auto}.desktop-nav-bar .sidebar-button:hover{transform:translateY(-2px)}.desktop-nav-bar .sidebar-label{opacity:1;width:auto}}.mobile-bottom-nav{align-items:center;background:linear-gradient(180deg,#2d8a85,#2d8a85 50%,#247a75 0,#247a75);border-top:2px solid #4ecdc4;bottom:0;box-shadow:0 -4px 0 #1d5a55,0 -6px 20px #0000004d;display:flex;height:70px;justify-content:space-around;left:0;padding-bottom:env(safe-area-inset-bottom);position:fixed;right:0;z-index:1000}@media (min-width:768px){.mobile-bottom-nav{display:none}}.nav-slider-indicator{background:linear-gradient(180deg,#ffffff40,#ffffff40 50%,#ffffff26 0,#ffffff26);border:2px solid #ffffff4d;border-radius:12px;bottom:8px;box-shadow:0 3px 0 #00000026,inset 0 1px 0 #ffffff4d;pointer-events:none;position:absolute;top:8px;transition:left .3s cubic-bezier(.4,0,.2,1);width:calc(20% - 12px);z-index:0}.nav-slider-indicator:before{background:linear-gradient(180deg,#fff3,#ffffff0d);border-radius:10px 10px 0 0;content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.bottom-nav-tab{-webkit-tap-highlight-color:transparent;align-items:center;background:#0000;border:none;color:#fff9;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:2px;justify-content:center;padding:8px 4px;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1);z-index:1}.bottom-nav-tab:active{transform:scale(.95)}.bottom-nav-tab.active{color:#fff}.tab-icon-wrapper{align-items:center;display:flex;height:32px;justify-content:center;transition:all .25s cubic-bezier(.4,0,.2,1);width:32px}.bottom-nav-tab.active .tab-icon-wrapper{height:36px;transform:translateY(-2px);width:36px}.tab-icon{filter:brightness(.8);height:100%;object-fit:contain;transition:all .25s ease;width:100%}.tab-icon-svg{align-items:center;display:flex;justify-content:center}.tab-icon-svg svg{height:100%;width:100%}.bottom-nav-tab.active .tab-icon{filter:brightness(1) drop-shadow(0 2px 4px rgba(0,0,0,.3))}.tab-label{font-size:10px;font-weight:600;letter-spacing:.5px;max-height:0;opacity:0;overflow:hidden;text-shadow:0 1px 2px #0000004d;text-transform:uppercase;transition:all .25s cubic-bezier(.4,0,.2,1)}.bottom-nav-tab.active .tab-label{max-height:20px;opacity:1}.bottom-nav-tab.active:before{display:none}.mobile-pages-wrapper{bottom:70px;left:0;overflow:hidden;padding-bottom:env(safe-area-inset-bottom);position:fixed;right:0;top:0;z-index:1}@media (min-width:768px){.mobile-pages-wrapper{display:none}}.mobile-pages-track{display:flex;height:100%;transition:transform .35s cubic-bezier(.4,0,.2,1);width:500%}.mobile-pages-track[data-active=shop]{transform:translateX(0)}.mobile-pages-track[data-active=customize]{transform:translateX(-20%)}.mobile-pages-track[data-active=play]{transform:translateX(-40%)}.mobile-pages-track[data-active=leaderboard]{transform:translateX(-60%)}.mobile-pages-track[data-active=chat]{transform:translateX(-80%)}.mobile-page{background:#4ecdc4;background:var(--bg-primary);flex:0 0 20%;overflow-x:hidden}.mobile-page[data-tab=customize],.mobile-page[data-tab=leaderboard],.mobile-page[data-tab=shop]{background:linear-gradient(180deg,#4ecdc4,#3da69f)}.mobile-page-content{min-height:100%;padding:60px 16px 20px}.mobile-page-header{margin-bottom:20px;text-align:center}.mobile-page-header h2{color:#fff;font-size:24px;font-weight:700;margin:0 0 8px;text-shadow:0 2px 4px #0000004d}.mobile-page-header p{color:#fffc;font-size:14px;margin:0}.shop-page-content{display:flex;flex-direction:column;gap:16px}.shop-section{background:#ffffff1a;border:1px solid #fff3;border-radius:16px;padding:16px}.shop-section-title{align-items:center;color:#fff;display:flex;font-size:16px;font-weight:700;gap:8px;margin:0 0 12px}.shop-coming-soon{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.shop-coming-soon-icon{height:64px;margin-bottom:16px;opacity:.7;width:64px}.shop-coming-soon-text{color:#ffffffb3;font-size:18px;font-weight:600}.duellex-plus-card{background:linear-gradient(180deg,gold,gold 50%,#e6b800 0,#e6b800);border:3px solid #b8860b;border-radius:16px;box-shadow:0 6px 0 #9a7209,0 8px 15px #0000004d,inset 0 2px 0 #fff6;cursor:pointer;overflow:hidden;padding:20px;position:relative;transition:all .15s ease}.duellex-plus-card:before{animation:shine-sweep 3s ease-in-out infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;pointer-events:none;position:absolute;top:0;width:50%}@keyframes shine-sweep{0%{left:-100%}50%,to{left:150%}}.duellex-plus-card:after{background:linear-gradient(180deg,#ffffff40,#ffffff0d);border-radius:13px 13px 0 0;content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.duellex-plus-card:active{box-shadow:0 2px 0 #9a7209,0 4px 8px #0003,inset 0 2px 0 #fff6;transform:translateY(4px)}.duellex-plus-header{align-items:center;display:flex;gap:12px;margin-bottom:12px;position:relative;z-index:1}.duellex-plus-icon{align-items:center;background:linear-gradient(180deg,#fff8dc,#ffe4b5);border:2px solid #b8860b;border-radius:12px;box-shadow:0 3px 0 #8b6914,inset 0 1px 0 #ffffff80;display:flex;height:48px;justify-content:center;width:48px}.duellex-plus-title{color:#2c2416;font-size:24px;font-weight:800;position:relative;text-shadow:0 1px 0 #ffffff80;z-index:1}.duellex-plus-benefits{color:#5a4a2a;font-size:14px;line-height:1.5;position:relative;z-index:1}.gem-shop-section{border-top:2px solid #3db9b1;border-top:2px solid var(--border-color);margin-top:20px;padding-top:20px}.gem-shop-title{align-items:center;color:#1a3a3a;color:var(--text-primary);display:flex;font-size:18px;font-weight:700;margin-bottom:16px}.gem-shop-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.gem-pack-card{background:linear-gradient(180deg,#4a5568,#4a5568 50%,#3d4654 0,#3d4654);border:2px solid #5a6578;border-radius:12px;box-shadow:0 4px 0 #2d3748,0 6px 10px #0000004d,inset 0 1px 0 #ffffff1a;cursor:pointer;overflow:hidden;padding:12px 8px;position:relative;text-align:center;transition:all .15s ease}.gem-pack-card:after{background:linear-gradient(180deg,#ffffff1a,#0000);border-radius:10px 10px 0 0;content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.gem-pack-card:active{box-shadow:0 1px 0 #2d3748,0 2px 5px #0003,inset 0 1px 0 #ffffff1a;transform:translateY(3px)}.gem-pack-card.popular{background:linear-gradient(180deg,#7c3aed,#7c3aed 50%,#6d28d9 0,#6d28d9);border-color:#8b5cf6;box-shadow:0 4px 0 #5b21b6,0 6px 10px #7c3aed66,inset 0 1px 0 #fff3}.gem-pack-card.best-value{background:linear-gradient(180deg,#f59e0b,#f59e0b 50%,#d97706 0,#d97706);border-color:#fbbf24;box-shadow:0 4px 0 #b45309,0 6px 10px #f59e0b66,inset 0 1px 0 #ffffff4d}.gem-pack-badge{border-radius:0 0 6px 6px;font-size:8px;font-weight:800;left:50%;letter-spacing:.5px;padding:2px 6px;position:absolute;text-transform:uppercase;top:-2px;transform:translateX(-50%);z-index:2}.gem-pack-badge.popular-badge{background:#a855f7;color:#fff}.gem-pack-badge.best-badge{background:#fbbf24;color:#78350f}.gem-pack-icon{font-size:24px;margin-bottom:4px;position:relative;z-index:1}.gem-pack-amount{color:#fff;font-size:16px;font-weight:800;position:relative;text-shadow:0 1px 2px #0000004d;z-index:1}.gem-pack-bonus{color:#4ade80;font-size:10px;font-weight:600;margin-top:2px;position:relative;z-index:1}.gem-pack-price{background:#0000004d;border-radius:6px;color:#ffffffe6;font-size:12px;font-weight:700;margin-top:6px;padding:4px 8px;position:relative;z-index:1}.customize-page-content{display:flex;flex-direction:column;gap:16px}.customize-animation-btn{align-items:center;background:linear-gradient(180deg,#3a3a4a,#3a3a4a 50%,#2e2e3a 0,#2e2e3a);border:2px solid #4a4a5a;border-radius:12px;box-shadow:0 4px 0 #1a1a25,0 6px 10px #0000004d;color:#1a3a3a;color:var(--text-primary);cursor:pointer;display:flex;font-size:15px;font-weight:700;justify-content:space-between;overflow:hidden;padding:14px 16px;position:relative;text-align:left;transition:all .15s ease}.customize-animation-btn:before{background:linear-gradient(180deg,#ffffff1a,#ffffff05);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.customize-animation-btn:not(.locked):hover{box-shadow:0 2px 0 #1a1a25,0 4px 6px #0003;transform:translateY(2px)}.customize-animation-btn:not(.locked):active{box-shadow:0 0 0 #1a1a25,0 2px 4px #0003;transform:translateY(4px)}.customize-animation-btn.active{background:linear-gradient(180deg,#5cbf60,#5cbf60 50%,#45a049 0,#45a049);border-color:#3d8c40;box-shadow:0 4px 0 #2d682f,0 6px 10px #0000004d;color:#fff}.customize-animation-btn.locked{background:linear-gradient(180deg,#2a2a35,#2a2a35 50%,#222230 0,#222230);border-color:#3a3a4a;box-shadow:0 4px 0 #15151d,0 6px 10px #0000004d;color:#2d5a5a;color:var(--text-secondary);cursor:not-allowed;opacity:.7}.customize-animation-btn .checkmark{font-size:18px;font-weight:700}.leaderboard-page-content{display:flex;flex-direction:column;gap:12px}.play-page-content{display:flex;flex-direction:column;gap:16px}.events-button-play{align-items:center;background:linear-gradient(135deg,#9b59b6,#8e44ad);border:2px solid #a855f7;border-radius:12px;box-shadow:0 4px 0 #7c3aed,0 5px 15px #8b5cf64d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:700;gap:10px;justify-content:center;letter-spacing:.5px;padding:14px 20px;text-transform:uppercase;transition:all .2s ease;width:100%}.events-button-play:active{box-shadow:0 2px 0 #7c3aed,0 3px 8px #8b5cf633;transform:translateY(2px)}.events-button-play img{height:24px;width:24px}.mobile-pages-container{bottom:70px;left:0;overflow:hidden;position:fixed;right:0;top:60px;z-index:50}.mobile-pages-slider{display:flex;height:100%;transition:transform .35s ease;width:500%}.mobile-page{-webkit-overflow-scrolling:touch;background:linear-gradient(180deg,#4ecdc4,#3da69f);flex-shrink:0;height:100%;overflow-y:auto;width:20%}.mobile-play-page{pointer-events:none;visibility:hidden}.mobile-pages-slider[data-active-tab=shop]{transform:translateX(0)}.mobile-pages-slider[data-active-tab=customize]{transform:translateX(-20%)}.mobile-pages-slider[data-active-tab=play]{transform:translateX(-40%)}.mobile-pages-slider[data-active-tab=chat]{transform:translateX(-60%)}.mobile-pages-slider[data-active-tab=leaderboard]{transform:translateX(-80%)}.mobile-pages-container:has(.mobile-pages-slider[data-active-tab=play]){pointer-events:none}.mobile-play-content[data-active-tab=chat],.mobile-play-content[data-active-tab=customize],.mobile-play-content[data-active-tab=leaderboard],.mobile-play-content[data-active-tab=shop]{pointer-events:none}.mobile-play-content[data-active-tab=play]{pointer-events:auto}.mobile-play-content{-webkit-overflow-scrolling:touch;background:#0000!important;bottom:70px!important;left:0!important;overflow-y:auto!important;padding:12px 12px 20px!important;position:fixed!important;top:60px!important;transition:transform .35s ease!important;width:100%!important;z-index:55!important}.mobile-play-content .user-profile-section{flex-wrap:wrap!important;margin-bottom:8px!important;margin-top:16px!important;padding:12px 14px!important}.mobile-play-content .profile-avatar-placeholder{font-size:16px!important;height:40px!important;width:40px!important}.mobile-play-content .profile-name{font-size:14px!important}.mobile-play-content .rank-display-container{margin-bottom:8px!important;padding:10px!important}.mobile-play-content .season-pass-button{margin-bottom:8px!important;min-height:auto!important;padding:10px 16px!important}.mobile-play-content .puzzle-buttons-row{margin-bottom:8px!important}.mobile-play-content .puzzle-button{height:100px!important;min-height:100px!important}.mobile-play-content .puzzle-button-image{height:50px!important;width:50px!important}.mobile-play-content .puzzle-button-text{font-size:12px!important}.mobile-play-content .events-button-play{margin-bottom:8px!important;padding:10px 16px!important}.mobile-play-content .create-game-buttons-mobile{gap:8px!important;margin-bottom:8px!important;margin-top:8px!important}.mobile-play-content .create-game-buttons-mobile .create-game-button{box-shadow:0 3px 0 #1d6a65,0 4px 10px #00000040!important;font-size:14px!important;padding:12px 16px!important}.mobile-play-content .create-game-buttons-mobile .bot-button{box-shadow:0 3px 0 #c5d9d7,0 4px 10px #00000026!important}.mobile-play-content[data-active-tab=shop]{transform:translateX(200%)}.mobile-play-content[data-active-tab=customize]{transform:translateX(100%)}.mobile-play-content[data-active-tab=play]{transform:translateX(0)}.mobile-play-content[data-active-tab=chat]{transform:translateX(-100%)}.mobile-play-content[data-active-tab=leaderboard]{transform:translateX(-200%)}.mobile-page-content{margin:0 auto;max-width:500px;padding:80px 20px 40px}.customize-section{background:linear-gradient(180deg,#3a3a4a,#3a3a4a 50%,#32323f 0,#32323f);border:2px solid #4a4a5a;border-radius:14px;box-shadow:0 5px 0 #25252f,0 7px 15px #00000059;margin-bottom:16px;overflow:hidden;padding:18px;position:relative}.customize-section:before{background:linear-gradient(180deg,#ffffff14,#ffffff05);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.customize-section-title{color:#fff;font-size:17px;font-weight:700;margin:0 0 12px;position:relative;text-shadow:0 1px 2px #0000004d;z-index:1}.customize-coming-soon{align-items:center;background:linear-gradient(180deg,#0000001a,#0003);border-radius:10px;display:flex;flex-direction:column;justify-content:center;padding:30px 20px;position:relative;text-align:center;z-index:1}.customize-coming-soon-icon{height:48px;margin-bottom:12px;opacity:.7;width:48px}.customize-coming-soon-text{color:#ffffffb3;font-size:14px;font-weight:600}.leaderboard-section{background:#ffffff1a;border:1px solid #fff3;border-radius:16px;padding:16px}.leaderboard-coming-soon{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.leaderboard-coming-soon-icon{height:64px;margin-bottom:16px;opacity:.7;width:64px}.leaderboard-coming-soon-text{color:#ffffffb3;font-size:18px;font-weight:600}.top-nav{align-items:center;background:linear-gradient(180deg,#2d8a85,#2d8a85 50%,#247a75 0,#247a75);border-bottom:2px solid #4ecdc4;box-shadow:0 4px 0 #1d5a55,0 6px 15px #0000004d;display:grid;flex-shrink:0;grid-template-columns:1fr auto 1fr;max-width:600px;padding:12px 20px;position:relative;width:100%;z-index:100}@media (min-width:768px){.fullscreen-button{display:none}}.nav-left{align-items:center;display:flex;flex:1 1;gap:12px;justify-content:center}@media (max-width:767px){.nav-left{justify-content:flex-start;padding-left:8px}}.nav-center{align-items:center;display:flex;justify-content:center}.nav-logo-container{display:inline-block;position:relative}.nav-logo{background:#0000;display:block;height:48px;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;object-fit:contain;width:auto}.nav-logo[src*=DuellexLogo]{filter:contrast(1.1);mix-blend-mode:multiply}.nav-logo-beta{background:linear-gradient(180deg,#ff6b6b,#ff6b6b 50%,#e55555 0,#e55555);border:1px solid #f88;border-radius:6px;bottom:-2px;box-shadow:0 2px 0 #c44444,0 3px 6px #0000004d;color:#fff;font-size:9px;font-weight:700;letter-spacing:.5px;line-height:1;padding:3px 6px;position:absolute;right:-8px;white-space:nowrap}.nav-right{justify-content:flex-end}.gems-display,.nav-right{align-items:center;display:flex;gap:8px}.gems-display{background:linear-gradient(180deg,#1d5a55,#1d5a55 50%,#164a45 0,#164a45);border:2px solid #4ecdc4;border-radius:12px;box-shadow:0 4px 0 #0d3a35,0 6px 12px #0000004d;color:#fff;cursor:pointer;font-size:15px;font-weight:700;overflow:hidden;padding:8px 16px;position:relative;text-shadow:0 1px 2px #00000080;transition:all .15s ease}.gems-display:before{background:linear-gradient(180deg,#ffffff26,#ffffff05);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.gems-display:hover{box-shadow:0 2px 0 #0d3a35,0 4px 8px #0003;transform:translateY(2px)}.gems-display:active{box-shadow:0 0 0 #0d3a35,0 2px 4px #0003;transform:translateY(4px)}.gems-icon{cursor:pointer;display:block;flex-shrink:0;height:20px;object-fit:contain;width:20px}.purchase-overlay{align-items:center;background:#000000bf;bottom:0;display:none;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:3000}.purchase-overlay.show{display:flex}.purchase-content{background:#45b8b0;background:var(--modal-bg);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:16px;max-height:90vh;max-width:90%;min-width:320px;overflow-y:auto;padding:24px;position:relative}.purchase-close{align-items:center;background:#0000;border:none;border-radius:50%;color:#1a3a3a;color:var(--text-primary);cursor:pointer;display:flex;font-size:28px;height:36px;justify-content:center;position:absolute;right:12px;top:12px;transition:background .2s;width:36px}.purchase-close:hover{background:#3da69f;background:var(--bg-tertiary)}.purchase-title{color:#1a3a3a;color:var(--text-primary);font-size:24px;font-weight:600;letter-spacing:-.5px;margin:0 0 20px;text-align:center}.purchase-options{display:flex;flex-direction:column;gap:12px}.purchase-option{align-items:center;background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:16px;transition:all .2s ease}.purchase-option:hover{background:#3da69f;background:var(--bg-tertiary);border-color:#3db9b1;border-color:var(--border-color);transform:translateY(-2px)}.purchase-option-left{display:flex;flex:1 1;flex-direction:column;gap:4px}.purchase-option-title{align-items:center;color:#1a3a3a;color:var(--text-primary);display:flex;font-size:16px;font-weight:600;gap:8px}.purchase-option-bonus{color:linear-gradient(180deg,#2d8a85,#247a75);color:var(--button-bg);font-size:12px;font-weight:500}.purchase-option-right{align-items:flex-end;display:flex;flex-direction:column;gap:4px}.purchase-option-amount{color:#1a3a3a;color:var(--text-primary);font-size:20px;font-weight:600}.purchase-option-price{color:#2d5a5a;color:var(--text-secondary);font-size:14px}.fullscreen-button{align-items:center;background:linear-gradient(180deg,#1d5a55,#1d5a55 50%,#164a45 0,#164a45);border:2px solid #4ecdc4;border-radius:10px;box-shadow:0 3px 0 #0d3a35,0 4px 8px #0000004d;color:#fff;cursor:pointer;display:flex;justify-content:center;overflow:hidden;padding:8px;position:relative;transition:all .15s ease}.fullscreen-button:before{background:linear-gradient(180deg,#ffffff26,#ffffff05);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.fullscreen-button:hover{box-shadow:0 1px 0 #0d3a35,0 2px 4px #0003;transform:translateY(2px)}.fullscreen-button:active{box-shadow:0 0 0 #0d3a35,0 1px 2px #0003;transform:translateY(3px)}.fullscreen-button svg{height:20px;position:relative;width:20px;z-index:1}@media (min-width:768px){.desktop-only{display:flex}.mobile-only{display:none}.home-container{padding-left:0}.home-container,.top-nav{margin:0;max-width:100%;width:100%}.top-nav{background:#4ecdc4;background:var(--bg-primary);padding:12px 0}.top-nav>*{margin:0 auto;max-width:1200px;padding:0 20px}.desktop-nav-bar{background:#45b8b0;background:var(--bg-secondary);margin:0;max-width:100%;padding:12px 0;width:100%}.desktop-nav-content{margin:0 auto;max-width:1200px;padding:0 20px}.rooms-content-wrapper{transition:transform .3s cubic-bezier(.4,0,.2,1);width:100%}@media (max-width:767px){.rooms-content-wrapper{align-items:stretch;display:flex;flex:1 1 auto;flex-direction:column;justify-content:center;margin:0;min-height:auto;padding:0 0 180px;width:100%}.main-content-column{align-self:stretch;display:flex;flex:1 1 auto;flex-direction:column;justify-content:flex-start;margin-bottom:0;min-height:0;padding-bottom:20px;padding-top:20px;width:100%}}@media (min-width:768px){.rooms-content-wrapper{align-items:flex-start;display:flex;flex-direction:row;gap:24px;margin:0 auto;max-width:1600px;min-height:calc(100vh - 200px);padding:20px 20px 32px}.main-content-column{align-items:center;align-self:flex-start;display:flex;flex:1 1;flex-direction:column;justify-content:flex-start;margin:0 auto;max-height:calc(100vh - 80px);max-width:900px;min-height:0;overflow-x:hidden;overflow-y:auto;padding:0 8px 40px}}.character-display{box-sizing:border-box;font-family:inherit}.character-drawer-backdrop{animation:fadeIn .3s cubic-bezier(.4,0,.2,1);background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:199}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.character-display.mobile-drawer{background:#45b8b0!important;background:var(--bg-secondary)!important;border-left:1px solid #3db9b1!important;border-left:1px solid var(--border-color)!important;bottom:auto!important;box-shadow:-2px 0 8px #0003!important;display:block!important;height:100vh!important;height:100dvh!important;left:auto!important;margin:0!important;max-width:320px!important;overflow-y:auto!important;padding:20px!important;position:fixed!important;right:-100%!important;top:0!important;transition:right .3s cubic-bezier(.4,0,.2,1)!important;width:85%!important;z-index:200!important}.character-display.mobile-drawer.open{right:0!important}.character-display.mobile-drawer .character-display-header{align-items:center!important;border-bottom:2px solid #3db9b1!important;border-bottom:2px solid var(--border-color)!important;display:flex!important;justify-content:space-between!important;margin-bottom:20px!important;padding-bottom:16px!important}.character-display.mobile-drawer .character-content{display:flex!important;flex-direction:column!important;gap:24px!important}.character-display.mobile-drawer .character-visual{align-items:center!important;background:#4ecdc4!important;background:var(--bg-primary)!important;border:1px solid #3db9b1!important;border:1px solid var(--border-color)!important;border-radius:12px!important;box-shadow:0 2px 4px #0000000d!important;display:flex!important;justify-content:center!important;padding:20px!important}.character-display.mobile-drawer .character-equipment{display:flex!important;flex-direction:column!important;gap:10px!important}.character-display.mobile-drawer .equipment-item{align-items:center!important;background:#4ecdc4!important;background:var(--bg-primary)!important;border:1px solid #3db9b1!important;border:1px solid var(--border-color)!important;border-radius:8px!important;display:flex!important;font-size:14px!important;justify-content:space-between!important;padding:12px 16px!important}.character-display.desktop-sidebar{align-self:center;background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;display:block;flex-shrink:0;max-width:280px;padding:20px;width:280px}.character-display-header{align-items:center;border-bottom:2px solid #3db9b1;border-bottom:2px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.character-display-header h3{color:#1a3a3a;color:var(--text-primary);font-size:20px;font-weight:700;letter-spacing:-.3px;margin:0}@media (max-width:767px){.character-display-header{margin-bottom:16px;padding-bottom:12px}.character-display-header h3{font-size:18px}}.character-close-button{align-items:center;background:none;border:none;border-radius:4px;color:#2d5a5a;color:var(--text-secondary);cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;padding:0;transition:background .2s;width:32px}.character-close-button:hover{background:#3da69f;background:var(--bg-tertiary)}.character-content{display:flex;flex-direction:column;gap:24px}@media (max-width:767px){.character-content{gap:16px}}.character-visual{align-items:center;background:#4ecdc4;background:var(--bg-primary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 4px #0000000d;display:flex;justify-content:center;padding:20px}@media (max-width:767px){.character-visual{padding:16px}}.character-avatar{align-items:center;display:flex;justify-content:center;width:100%}.character-avatar svg{height:auto;max-width:100%}@media (max-width:767px){.character-avatar svg{height:133px;width:100px}}.character-equipment{display:flex;flex-direction:column;gap:10px}@media (max-width:767px){.character-equipment{gap:8px}}.equipment-item{align-items:center;background:#4ecdc4;background:var(--bg-primary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:8px;display:flex;font-size:14px;justify-content:space-between;padding:12px 16px;transition:all .2s ease}@media (max-width:767px){.equipment-item{font-size:13px;padding:10px 12px}}.equipment-item:hover{background:#3da69f;background:var(--bg-tertiary);transform:translateX(2px)}.equipment-label{color:#2d5a5a;color:var(--text-secondary);font-size:13px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.equipment-value{color:#1a3a3a;color:var(--text-primary);font-size:14px;font-weight:600}.character-drawer-toggle{align-items:center;background:linear-gradient(180deg,#2d8a85,#247a75);background:var(--button-bg);border:none;border-radius:50%;box-shadow:0 2px 8px #0003;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:fixed;right:16px;top:50%;transform:translateY(-50%);transition:transform .3s ease,background .2s;width:48px;z-index:50}.character-drawer-toggle:hover{background:linear-gradient(180deg,#359590,#2d8a85);background:var(--button-hover);transform:translateY(-50%) scale(1.1)}.character-drawer-toggle:active{transform:translateY(-50%) scale(.95)}.rooms-and-create-wrapper.shifted-left,.rooms-content-wrapper.shifted-left{transform:translateX(-85%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.rooms-and-create-wrapper{flex-direction:column;overflow:hidden;transition:transform .3s cubic-bezier(.4,0,.2,1)}.rooms-and-create-wrapper,.rooms-container{display:flex;flex:1 1;min-height:0;width:100%}.rooms-container{flex-direction:column;margin:0 auto;max-width:600px;overflow-y:auto;padding:0 16px}@media (min-width:768px){.rooms-container{display:flex;flex:1 1;flex-direction:column;margin:0;max-width:600px;min-height:0;overflow-y:auto;padding:0;width:100%}}.create-game-buttons{background:#0000;border:none;display:flex;flex-direction:column;gap:12px;margin:12px 16px;max-width:600px;padding:0;width:calc(100% - 32px)}@media (min-width:768px){.create-game-buttons{align-self:center;background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;flex:0 0 auto;flex-direction:row;justify-content:center;margin:0;min-width:320px;padding:20px;position:-webkit-sticky;position:sticky;top:50%;transform:translateY(-50%);width:auto}}.game-container,.game-header{margin:0 auto;max-width:1200px;padding-left:80px}}.menu-button{background:linear-gradient(180deg,#1d5a55,#1d5a55 50%,#164a45 0,#164a45);border:2px solid #4ecdc4;border-radius:10px;box-shadow:0 3px 0 #0d3a35,0 4px 8px #0000004d;cursor:pointer;display:flex;flex-direction:column;gap:4px;overflow:hidden;padding:10px;position:relative;transition:all .15s ease}.menu-button:before{background:linear-gradient(180deg,#ffffff26,#ffffff05);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.menu-button:hover{box-shadow:0 1px 0 #0d3a35,0 2px 4px #0003;transform:translateY(2px)}.menu-button:active{box-shadow:0 0 0 #0d3a35,0 1px 2px #0003;transform:translateY(3px)}.menu-button span{background:#fff;border-radius:2px;height:3px;position:relative;transition:all .3s;width:22px;z-index:1}.screen-title-container{align-items:center;display:grid;grid-template-columns:1fr auto 1fr;margin:16px auto 20px;max-width:600px;padding:0 16px;width:100%}@media (min-width:768px){.screen-title-container{margin:0 auto 24px;padding:0}}.screen-title{color:#1a3a3a;color:var(--text-primary);font-size:32px;font-weight:600;grid-column:2;justify-self:center;letter-spacing:-.5px;text-align:center}.online-counter{align-items:center;background:#6b7280;border-radius:20px;color:#fff;display:flex;font-size:14px;font-weight:500;gap:8px;grid-column:3;justify-self:end;padding:6px 12px}.online-dot{display:inline-block;height:16px;position:relative;width:16px}.online-dot:after,.online-dot:before{border:2px solid #fff;border-radius:50%;content:"";left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.online-dot:before{animation:rotateGlobe 2s linear infinite;border-right-color:#0000;border-top-color:#0000;height:12px;width:12px}.online-dot:after{animation:rotateGlobe 1.5s linear infinite reverse;border-bottom-color:#0000;border-left-color:#0000;height:8px;width:8px}@keyframes rotateGlobe{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}.online-count{white-space:nowrap}.guest-username-container{display:flex;justify-content:center;margin-bottom:16px;max-width:600px;padding:0 16px;width:100%}@media (min-width:768px){.guest-username-container{margin:0 auto 24px;padding:0}}.guest-username-input-wrapper{align-items:center;display:flex;max-width:400px;position:relative;width:100%}@media (min-width:768px){.guest-username-input-wrapper{flex:1 1;max-width:500px;min-width:300px}}.guest-username-input{background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:8px;color:#1a3a3a;color:var(--text-primary);font-family:inherit;font-size:16px;font-weight:400;outline:none;padding:12px 48px 12px 16px;transition:all .2s ease;width:100%}.guest-username-input::placeholder{color:#2d5a5a;color:var(--text-secondary)}.guest-username-input:focus{background:#3da69f;background:var(--bg-tertiary);border-color:linear-gradient(180deg,#2d8a85,#247a75);border-color:var(--button-bg);box-shadow:0 0 0 3px #007bff1a}.guest-username-confirm{align-items:center;background:linear-gradient(180deg,#2d8a85,#247a75);background:var(--button-bg);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:32px;justify-content:center;padding:0;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:all .2s ease;width:32px}.guest-username-confirm:hover:not(:disabled){background:linear-gradient(180deg,#359590,#2d8a85);background:var(--button-hover);transform:translateY(-50%) scale(1.05)}.guest-username-confirm:active:not(:disabled){transform:translateY(-50%) scale(.95)}.guest-username-confirm:disabled{cursor:not-allowed;opacity:.4}.rooms-container{flex:1 1;min-height:0;padding:0 16px}.levels-path-container,.rooms-container{margin:0 auto;max-width:600px;overflow-y:auto;width:100%}.levels-path-container{height:calc(100vh - 320px);min-height:400px;overflow-x:hidden;padding:20px;position:relative;scroll-behavior:smooth}@media (max-width:767px){.levels-path-container{height:calc(100vh - 380px);min-height:300px;padding-bottom:40px}}@media (min-width:768px){.levels-path-container{height:calc(80vh - 280px);max-height:calc(80vh - 280px)}}.levels-path-container:after{content:"";display:block;height:1px}.levels-path{align-items:center;display:flex;flex-direction:column;justify-content:flex-end;min-height:7200px;padding-bottom:20px;position:relative;width:100%}.level-section{border-radius:12px;margin:0 20px}.level-section-title{font-family:inherit;letter-spacing:1px}.level-node{align-items:center;background:linear-gradient(135deg,#7ec8a3,#5a9a7a);border:3px solid #2c2416;border-radius:50%;box-shadow:0 4px 8px #0003;cursor:pointer;display:flex;height:80px;justify-content:center;position:absolute;transition:all .3s ease;width:80px;z-index:1}.level-node:hover{background:linear-gradient(135deg,#8fd9b4,#6ab390);box-shadow:0 6px 12px #0000004d;transform:scale(1.15)}.level-node:active{transform:scale(1.05)}.level-number{color:#fff;font-size:24px;font-weight:700;text-shadow:1px 1px 2px #0000004d}.level-path-svg{overflow:visible}@media (min-width:768px){.levels-path-container{height:calc(100vh - 150px);max-width:600px}}.loading-message,.no-rooms-message{align-items:center;color:#2d5a5a;color:var(--text-secondary);display:flex;font-size:16px;justify-content:center;padding:32px 16px;text-align:center;width:100%}@media (min-width:768px){.loading-message,.no-rooms-message{align-items:center;display:flex;justify-content:center;padding:32px 0;text-align:center;width:100%}}.room-entry{align-items:center;background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:8px;padding:16px 20px;position:relative;transition:all .2s ease}.room-entry:hover{background:#3da69f;background:var(--bg-tertiary);border-color:#3db9b1;border-color:var(--border-color);transform:translateY(-1px)}.room-entry:active{transform:scale(.98)}.room-entry.unavailable{cursor:not-allowed;opacity:.6}.room-left{flex:1 1}.username{color:#1a3a3a;color:var(--text-primary);font-size:16px;font-weight:500;letter-spacing:-.2px}.room-right{align-items:center;display:flex}.battle-button{background:linear-gradient(180deg,#2d8a85,#247a75);background:var(--button-bg);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;letter-spacing:.3px;padding:10px 24px;transition:all .2s ease}.battle-button:hover:not(:disabled){background:linear-gradient(180deg,#359590,#2d8a85);background:var(--button-hover);transform:translateY(-1px)}.battle-button:active:not(:disabled){transform:scale(.95)}.battle-button.unavailable,.battle-button:disabled{background:#7ab5b0;background:var(--button-disabled);color:#2d5a5a;color:var(--text-secondary);cursor:not-allowed;opacity:.6}.room-separator{background:linear-gradient(90deg,#0000 0,#3db9b1 20%,#3db9b1 80%,#0000);background:linear-gradient(to right,#0000 0,var(--border-color) 20%,var(--border-color) 80%,#0000 100%);border-radius:2px;bottom:0;height:2px;left:16px;position:absolute;right:16px}.create-game-button{background:linear-gradient(180deg,#2d8a85,#247a75);background:var(--button-bg);border:none;border-radius:12px;color:#fff;font-size:16px;font-weight:600;letter-spacing:.3px;padding:14px 24px;transition:all .2s ease;width:100%}.create-game-button.bot-button{background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);color:#1a3a3a;color:var(--text-primary)}.create-game-button.bot-button:hover{background:#3da69f;background:var(--bg-tertiary);transform:translateY(-1px)}.create-game-button:hover{background:linear-gradient(180deg,#359590,#2d8a85);background:var(--button-hover);transform:translateY(-1px)}.create-game-button:active{transform:translateY(0)}.menu-overlay{align-items:center;background:#000000bf;bottom:0;display:none;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.menu-overlay.show{display:flex}.menu-content{background:#45b8b0;background:var(--modal-bg);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;max-height:80vh;max-width:90%;min-width:280px;padding:24px;position:relative}.menu-close{align-items:center;background:#0000;border-radius:50%;color:#1a3a3a;color:var(--text-primary);display:flex;font-size:32px;height:36px;justify-content:center;position:absolute;right:12px;top:12px;transition:background .2s;width:36px}.menu-close:hover{background:#3da69f;background:var(--bg-tertiary)}.menu-content h2{color:#1a3a3a;color:var(--text-primary);margin-bottom:20px}.menu-list{list-style:none}.menu-list li{margin-bottom:12px}.menu-list a{background:linear-gradient(180deg,#2d8a85,#247a75);border-radius:10px;box-shadow:0 3px 0 #1d6a65,0 4px 10px #0003;color:#fff;display:block;font-size:18px;font-weight:600;padding:12px 16px;text-decoration:none;text-shadow:0 1px 2px #0000004d;transition:all .15s ease}.menu-list a:hover{background:linear-gradient(180deg,#359590,#2d8a85);box-shadow:0 5px 0 #1d6a65,0 6px 15px #0000004d;transform:translateY(-2px)}.menu-list-button{background:linear-gradient(180deg,#2d8a85,#247a75);border:none;border-radius:10px;box-shadow:0 3px 0 #1d6a65,0 4px 10px #0003;color:#fff;cursor:pointer;display:block;font-family:inherit;font-size:18px;font-weight:600;padding:12px 16px;text-align:left;text-decoration:none;text-shadow:0 1px 2px #0000004d;transition:all .15s ease;width:100%}.menu-list-button:hover{background:linear-gradient(180deg,#359590,#2d8a85);box-shadow:0 5px 0 #1d6a65,0 6px 15px #0000004d;transform:translateY(-2px)}.menu-list-button:active{box-shadow:0 2px 0 #1d6a65,0 3px 8px #0003;transform:translateY(1px)}.game-container{background:#0000;display:flex;flex-direction:column;height:100vh;height:100dvh;margin:0 auto;max-width:600px;overflow:visible;position:relative;width:100%;z-index:1}@media (min-width:768px){.game-container{height:auto;max-width:800px;min-height:100vh}.keyboard-wrapper{margin-top:8px}.game-container>.emote-container{left:20px;margin-top:8px;min-height:80px;opacity:1;position:absolute;top:360px;transform:none;visibility:visible;z-index:5}.player-section{align-items:center;flex:1 1;justify-content:center;padding:24px}}@media (max-width:767px){.game-container{justify-content:flex-end}.player-section{border-radius:0;margin:0}.game-container:not([data-solo=true]) .player-section{justify-content:flex-end;overflow-y:visible;padding:12px 12px max(12px,env(safe-area-inset-bottom,12px))}.game-container[data-solo=true] .player-section{padding:12px 12px 200px}.words{margin-bottom:8px}.keyboard-wrapper{margin-bottom:0;margin-top:0}.game-container:not([data-solo=true]) .emote-container{margin-bottom:0;margin-top:8px;padding-bottom:max(8px,env(safe-area-inset-bottom,8px))}}.mobile-game-top-bar{display:none}@media (max-width:767px){.mobile-game-top-bar{align-items:flex-start;box-sizing:border-box;display:flex;flex-direction:row;flex-shrink:0;gap:8px;justify-content:space-between;padding:8px;width:100%}}@media (min-width:768px){.mobile-game-top-bar{display:contents}}.game-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#4ecdc4;background:var(--bg-primary);border-bottom:1px solid #3db9b1;border-bottom:1px solid var(--border-color);flex-shrink:0;justify-content:space-between;padding:12px 20px;z-index:10}.game-header,.game-header-left{align-items:center;display:flex}.game-header-left{gap:12px}.game-header .gems-icon{display:block;flex-shrink:0;height:20px;object-fit:contain;width:20px}.back-button{background:#0000;border-radius:4px;color:#1a3a3a;color:var(--text-primary);font-size:24px;padding:4px 8px;transition:background .2s}.back-button:hover{background:#3da69f;background:var(--bg-tertiary)}.game-header-right{align-items:center;display:flex;gap:12px}.minimap-backdrop{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:99}.opponent-minimap{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;cursor:pointer;left:12px;padding:10px;position:absolute;top:76px;transition:all .4s cubic-bezier(.4,0,.2,1);width:120px;z-index:5}@media (min-width:768px){.opponent-minimap{left:20px}}@media (max-width:767px){.opponent-minimap:not(.expanded){flex-shrink:0;left:auto;padding:6px;position:relative;top:auto;width:80px}.opponent-minimap:not(.expanded) .minimap-words .letter{height:10px;min-height:10px;min-width:10px;width:10px}.opponent-minimap:not(.expanded) .minimap-header{margin-bottom:4px;padding-bottom:4px}.opponent-minimap:not(.expanded) .minimap-header .opponent-name{font-size:9px}}.opponent-minimap.expanded{box-shadow:0 8px 32px #0000004d;cursor:default;left:50%;max-height:80vh;max-width:90vw;overflow-y:auto;padding:24px;top:50%;transform:translate(-50%,-50%);width:400px;z-index:100}.opponent-minimap.expanded .minimap-words .letter{height:48px;min-height:48px;min-width:48px;width:48px}.opponent-minimap.expanded .minimap-header{align-items:center;flex-direction:row;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.opponent-minimap.expanded .minimap-header .opponent-name{font-size:22px;font-weight:700}.minimap-header{border-bottom:1px solid #3db9b1;border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:4px;margin-bottom:6px;padding-bottom:6px;position:relative}.minimap-header .opponent-name{color:#1a3a3a;color:var(--text-primary);flex:1 1;font-size:11px;font-weight:600;text-align:center}.minimap-close-button{align-items:center;background:#0000;border:none;border-radius:4px;color:#1a3a3a;color:var(--text-primary);cursor:pointer;display:flex;flex-shrink:0;font-size:28px;height:32px;justify-content:center;line-height:1;padding:0;transition:background .2s,color .2s;width:32px}.minimap-close-button:hover{background:#3da69f;background:var(--bg-tertiary);color:#1a3a3a;color:var(--text-primary)}.minimap-content{display:flex;flex-direction:column;min-height:0;position:relative;width:100%}.opponent-emote-display{animation:emotePop .5s ease-out;font-size:64px;left:50%;pointer-events:none;position:absolute;text-shadow:0 0 20px #00000080;top:50%;transform:translate(-50%,-50%);z-index:100}@keyframes emotePop{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.minimap-view-opponent-text{color:#2d5a5a;color:var(--text-secondary);cursor:pointer;font-size:10px;font-weight:600;margin-top:auto;padding-top:8px;text-align:center;transition:color .2s ease;-webkit-user-select:none;user-select:none}.minimap-view-opponent-text:hover{color:#1a3a3a;color:var(--text-primary)}.top-points-container{display:flex;flex-direction:column;gap:8px;position:absolute;right:12px;top:76px;z-index:5}@media (min-width:768px){.top-points-container{right:20px}}@media (max-width:767px){.top-points-container{align-items:flex-end;flex-direction:column!important;flex-shrink:0;gap:4px;padding:0;position:relative!important;right:auto!important;top:auto!important}}.player-points-display{align-items:flex-end;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;gap:4px;padding:10px 14px}.player-points-display .points-label{color:#2d5a5a;color:var(--text-secondary);font-size:9px;letter-spacing:.5px;text-transform:uppercase}.player-points-display .points-value{color:linear-gradient(180deg,#2d8a85,#247a75);color:var(--button-bg);font-size:16px;font-weight:700}.opponent-points-display-top{align-items:flex-end;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;display:flex;flex-direction:column;gap:4px;padding:10px 14px}.opponent-points-label{color:#2d5a5a;color:var(--text-secondary);font-size:9px;letter-spacing:.5px;text-transform:uppercase}.opponent-points-value{color:linear-gradient(180deg,#2d8a85,#247a75);color:var(--button-bg);font-size:16px;font-weight:700}.minimap-words{align-items:center;flex-direction:column}.minimap-words,.minimap-words .word{display:flex;gap:2px}.minimap-words .letter{background:#ffffff26;border:1px solid #2d7a75;font-size:0;height:16px;margin:0;min-height:16px;min-width:16px;width:16px}.minimap-words .letter span{display:none}.minimap-words .letter.correct,.minimap-words .letter.incorrect,.minimap-words .letter.semi{opacity:1}.player-section{background:#0000;display:flex;flex:1 1;flex-direction:column;justify-content:flex-end;min-height:0;overflow-y:auto;padding:16px 16px 200px;position:relative;z-index:1}.desktop-game-content{display:none}@media (min-width:768px){.desktop-game-content{background:linear-gradient(180deg,#4ecdc4d9,#4ecdc4d9 50%,#38a39bd9 0,#38a39bd9);border:3px solid #6ee0d899;border-radius:20px;box-shadow:0 6px 0 #1e5a55cc,0 8px 20px #0006,inset 0 1px 0 #ffffff26;display:flex;flex-direction:column;padding:24px 32px;position:relative}.desktop-game-content:before{background:linear-gradient(180deg,#ffffff26,#fff0);border-radius:17px 17px 0 0;content:"";height:50%;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.player-section{align-items:center;justify-content:center;padding:24px}}.player-label{color:#2d5a5a;color:var(--text-secondary);flex-shrink:0;font-size:12px;letter-spacing:1px;margin-bottom:8px;text-align:center;text-transform:uppercase}.words{-webkit-tap-highlight-color:transparent;align-items:center;cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;gap:4px;justify-content:flex-start;margin-bottom:16px;-webkit-user-select:none;user-select:none}.words .letter,.words .word{pointer-events:none}.words .letter{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}.keyboard-wrapper{flex-shrink:0;margin-top:0;position:relative}@media (max-width:767px){.mobile-game-container{-webkit-tap-highlight-color:transparent;background:linear-gradient(180deg,#4ecdc4e6,#4ecdc4e6 50%,#38a39be6 0,#38a39be6);border:3px solid #6ee0d899;border-radius:16px;box-shadow:0 5px 0 #1e5a55cc,0 7px 16px #0006;cursor:pointer;display:flex;flex-direction:column;gap:12px;overflow:hidden;padding:12px;position:relative;-webkit-user-select:none;user-select:none}.mobile-game-container:before{background:linear-gradient(180deg,#ffffff26,#fff0);border-radius:13px 13px 0 0;content:"";height:50%;left:0;pointer-events:none;position:absolute;right:0;top:0;z-index:0}.mobile-game-container .words{margin-bottom:0;pointer-events:none}.mobile-game-container .keyboard-wrapper{margin-top:0;pointer-events:auto!important}.mobile-game-container .keyboard{pointer-events:none}.mobile-game-container .keyboard-button{cursor:pointer;pointer-events:auto!important}.mobile-game-container .end-actions{pointer-events:none}.mobile-game-container #playagain{pointer-events:auto}}.word{display:flex;gap:4px}.letter{align-items:center;background:linear-gradient(180deg,#4ecdc4,#4ecdc4 50%,#3db9b1 0,#3db9b1);border:2px solid #ffffff4d;border-radius:10px;box-shadow:0 3px 0 #2a9d97,0 4px 8px #0000004d;box-sizing:border-box;color:#fff;display:flex;flex-shrink:0;font-size:1.6rem;font-weight:700;height:50px;justify-content:center;min-height:50px;min-width:50px;overflow:hidden;position:relative;text-shadow:0 1px 2px #0000004d;transform-origin:center;-webkit-user-select:none;user-select:none;width:50px}.letter:before{background:linear-gradient(180deg,#ffffff26,#fff0);border-radius:8px 8px 0 0;content:"";height:50%;left:0;pointer-events:none;position:absolute;right:0;top:0}.letter>span{align-items:center;display:flex;font-size:inherit;height:100%;justify-content:center;width:100%}.letter:empty{background:linear-gradient(180deg,#4ecdc466,#4ecdc466 50%,#3db9b166 0,#3db9b166);border:2px solid #fff3;box-shadow:0 3px 0 #2a9d9780,0 4px 8px #0003}.letter.typing,.letter:not(:empty):not(.correct):not(.semi):not(.incorrect):not(.typing){background:linear-gradient(180deg,#4ecdc4,#4ecdc4 50%,#3db9b1 0,#3db9b1);border:2px solid #ffffff4d}.letter.correct{background:linear-gradient(180deg,#44bd32,#44bd32 50%,#3aa329 0,#3aa329)!important;box-shadow:0 3px 0 #2d8a22,0 4px 8px #0000004d!important}.letter.correct,.letter.semi{border:2px solid #ffffff4d!important;color:#fff!important}.letter.semi{background:linear-gradient(180deg,#f5a623,#f5a623 50%,#e09612 0,#e09612)!important;box-shadow:0 3px 0 #c4850f,0 4px 8px #0000004d!important}.letter.incorrect{background:linear-gradient(180deg,#4a5d6e,#4a5d6e 50%,#3d4f5e 0,#3d4f5e)!important;border:2px solid #fff3!important;box-shadow:0 3px 0 #2d3d4a,0 4px 8px #0000004d!important;color:#fff!important}.letter[data-letter-status=correct]{background:linear-gradient(180deg,#44bd32,#44bd32 50%,#3aa329 0,#3aa329)!important;border:2px solid #ffffff4d!important;box-shadow:0 3px 0 #2d8a22,0 4px 8px #0000004d!important;color:#fff!important}.letter[data-letter-status=semi]{background:linear-gradient(180deg,#f5a623,#f5a623 50%,#e09612 0,#e09612)!important;border:2px solid #ffffff4d!important;box-shadow:0 3px 0 #c4850f,0 4px 8px #0000004d!important;color:#fff!important}.letter[data-letter-status=incorrect]{background:linear-gradient(180deg,#4a5d6e,#4a5d6e 50%,#3d4f5e 0,#3d4f5e)!important;border:2px solid #fff3!important;box-shadow:0 3px 0 #2d3d4a,0 4px 8px #0000004d!important;color:#fff!important}.letter.correct,.letter.incorrect,.letter.semi{animation-fill-mode:forwards!important}.word.attempted .letter.correct,.word.attempted .letter[data-letter-status=correct]{background:linear-gradient(180deg,#44bd32,#44bd32 50%,#3aa329 0,#3aa329)!important;border:2px solid #ffffff4d!important;box-shadow:0 3px 0 #2d8a22,0 4px 8px #0000004d!important;color:#fff!important}.word.attempted .letter.semi,.word.attempted .letter[data-letter-status=semi]{background:linear-gradient(180deg,#f5a623,#f5a623 50%,#e09612 0,#e09612)!important;border:2px solid #ffffff4d!important;box-shadow:0 3px 0 #c4850f,0 4px 8px #0000004d!important;color:#fff!important}.word.attempted .letter.incorrect,.word.attempted .letter[data-letter-status=incorrect]{background:linear-gradient(180deg,#4a5d6e,#4a5d6e 50%,#3d4f5e 0,#3d4f5e)!important;border:2px solid #fff3!important;box-shadow:0 3px 0 #2d3d4a,0 4px 8px #0000004d!important;color:#fff!important}.word.attempted .letter:not(.correct):not(.semi):not(.incorrect):not([data-letter-status]){background:linear-gradient(180deg,#1e5a5599,#1e5a5599 50%,#164a4599 0,#164a4599);border:2px solid #fff3}.keyboard{box-sizing:border-box;flex-direction:column;margin-bottom:4px;padding:0 4px;transition:opacity .2s ease-in-out;width:100%}.keyboard,.keyboard-row{align-items:center;display:flex;justify-content:center;max-width:100%}.keyboard-row{flex-wrap:nowrap}.keyboard-button{-webkit-tap-highlight-color:transparent;background:linear-gradient(180deg,#4ecdc4,#4ecdc4 50%,#3db9b1 0,#3db9b1);border:2px solid #fff3;border-radius:10px;box-shadow:0 4px 0 #2a9d97,0 5px 10px #0000004d;color:#fff;cursor:pointer;flex:0 0 auto;font-family:inherit;font-size:13px;font-weight:700;height:44px;margin:3px;overflow:hidden;position:relative;text-shadow:0 1px 2px #0000004d;text-transform:uppercase;touch-action:manipulation;transition:all .12s ease;-webkit-user-select:none;user-select:none;width:32px}.keyboard-button:before{background:linear-gradient(180deg,#ffffff40,#fff0);border-radius:8px 8px 0 0;content:"";height:50%;left:0;pointer-events:none;position:absolute;right:0;top:0}.keyboard-button.bottom-row,.keyboard-button.middle-row{width:32px}.keyboard-button.larger{font-size:11px;padding:0 10px;width:auto}.keyboard-button.enter{background:linear-gradient(180deg,#44bd32,#44bd32 50%,#3aa329 0,#3aa329);box-shadow:0 4px 0 #2d8a22,0 5px 10px #0000004d;min-width:55px;padding:0 12px;width:auto}.keyboard-button:hover{background:linear-gradient(180deg,#5dd9d1,#4ecdc4);box-shadow:0 6px 0 #2a9d97,0 7px 15px #0006;transform:translateY(-2px)}.keyboard-button:active{background:linear-gradient(180deg,#3db9b1,#2a9d97);box-shadow:0 2px 0 #2a9d97,0 3px 5px #0003;transform:translateY(2px)}.keyboard-button.correct{background:linear-gradient(180deg,#44bd32,#44bd32 50%,#3aa329 0,#3aa329)!important;box-shadow:0 4px 0 #2d8a22,0 5px 10px #0000004d!important;color:#fff}.keyboard-button.semi{background:linear-gradient(180deg,#f5a623,#f5a623 50%,#e09612 0,#e09612);box-shadow:0 4px 0 #c4850f,0 5px 10px #0000004d;color:#fff}.keyboard-button.incorrect{background:linear-gradient(180deg,#4a5d6e,#4a5d6e 50%,#3d4f5e 0,#3d4f5e);box-shadow:0 4px 0 #2d3d4a,0 5px 10px #0000004d;color:#8a9baa}.keyboard.disabled{opacity:.5;pointer-events:none}.keyboard.disabled .keyboard-button{cursor:not-allowed;opacity:.5}.end-actions,.game-over .keyboard{opacity:0;pointer-events:none}.end-actions{grid-column-gap:16px;grid-row-gap:2px;display:grid;grid-auto-flow:column;grid-template-columns:auto auto;grid-template-rows:auto auto;left:50%;position:absolute;text-align:center;top:8px;transform:translateX(-50%)}.game-over .end-actions{opacity:1;pointer-events:inherit;transition:opacity .2s ease-in}.end-actions>span:first-of-type{font-size:28px;font-weight:700}.end-actions>span:last-of-type{font-size:12px}.emote-container{align-items:center;display:flex;flex-direction:column;gap:12px;margin-top:16px;min-height:80px;padding:12px;position:relative}.emote-buttons{flex-wrap:wrap;gap:8px}.emote-button,.emote-buttons{display:flex;justify-content:center}.emote-button{-webkit-tap-highlight-color:transparent;align-items:center;background:#45b8b0;background:var(--bg-secondary);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;font-size:24px;height:48px;padding:0;transition:all .2s ease;user-select:none;-webkit-user-select:none;width:48px}.emote-button:hover{background:#3da69f;background:var(--bg-tertiary);border-color:#3db9b1;border-color:var(--border-color);transform:scale(1.1)}.emote-button:active{transform:scale(.95)}.player-emote-display{animation:emotePop .5s ease-out;font-size:48px;left:50%;pointer-events:none;position:absolute;text-shadow:0 0 20px #00000080;top:50%;transform:translate(-50%,-50%);z-index:10}button#playagain{background:#4d5;border-radius:6px;color:#fff;font-weight:bolder;grid-row:span 2;padding:12px 24px;text-transform:uppercase;white-space:pre-wrap}.toast{align-items:center;animation:toast-birth .3s cubic-bezier(.34,1.56,.64,1) forwards;background:#45b8b0;background:var(--bg-secondary);border:2px solid #3db9b1;border:2px solid var(--border-color);border-radius:12px;box-shadow:0 4px 12px #00000026;color:#1a3a3a;color:var(--text-primary);display:flex;font-size:16px;font-weight:600;justify-content:center;left:50%;max-width:320px;min-width:200px;padding:16px 24px;pointer-events:none;position:fixed;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:1000}@keyframes letter-shake{0%,to{transform:translateX(0) rotate(0)}10%{transform:translateX(-2px) rotate(-1deg)}20%{transform:translateX(2px) rotate(1deg)}30%{transform:translateX(-2px) rotate(-1deg)}40%{transform:translateX(2px) rotate(1deg)}50%{transform:translateX(-1px) rotate(-.5deg)}60%{transform:translateX(1px) rotate(.5deg)}70%{transform:translateX(-1px) rotate(-.5deg)}80%{transform:translateX(1px) rotate(.5deg)}90%{transform:translateX(0) rotate(0)}}@keyframes letter-pop{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes green-glow{0%{box-shadow:0 0 0 #79b85100;filter:brightness(1)}50%{box-shadow:0 0 20px #79b851cc,0 0 30px #79b85199;filter:brightness(1.3)}to{box-shadow:0 0 0 #79b85100;filter:brightness(1)}}.word.attempted .letter.correct{animation:green-glow .8s ease-out}.letter.correct.animating{animation:letter-shake-margin .6s ease-in-out,green-glow .8s ease-out;animation-fill-mode:both}.letter.semi.animating-yellow{animation:yellow-shake-updown .5s ease-in-out,yellow-glow .8s ease-out;animation-fill-mode:both}@keyframes letter-shake-margin{0%,to{margin-left:0;margin-top:0}10%{margin-left:-2px;margin-top:-1px}20%{margin-left:2px;margin-top:1px}30%{margin-left:-2px;margin-top:-1px}40%{margin-left:2px;margin-top:1px}50%{margin-left:-1px;margin-top:-.5px}60%{margin-left:1px;margin-top:.5px}70%{margin-left:-1px;margin-top:-.5px}80%{margin-left:1px;margin-top:.5px}90%{margin-left:0;margin-top:0}}@keyframes yellow-shake-updown{0%,to{margin-top:0}25%{margin-top:-2px}50%{margin-top:0}75%{margin-top:2px}}@keyframes yellow-glow{0%{box-shadow:0 0 0 #f3c23700;filter:brightness(1)}50%{box-shadow:0 0 15px #f3c237b3,0 0 25px #f3c23780;filter:brightness(1.2)}to{box-shadow:0 0 0 #f3c23700;filter:brightness(1)}}@keyframes green-letter-pulse{0%,to{box-shadow:0 0 20px #79b85199,0 0 40px #79b85166;filter:brightness(1.2) drop-shadow(0 0 10px rgba(121,184,81,.5))}50%{box-shadow:0 0 30px #79b851b3,0 0 60px #79b85180;filter:brightness(1.3) drop-shadow(0 0 15px rgba(121,184,81,.6))}}.green-letter-glow{animation:green-letter-pulse 1s ease-in-out infinite}.minimap-words .letter.correct{animation:letter-pop .5s cubic-bezier(.34,1.56,.64,1),green-glow .8s ease-out}.minimap-words .letter.correct.animating{animation:letter-pop .5s cubic-bezier(.34,1.56,.64,1),letter-shake .6s ease-in-out .3s,green-glow .8s ease-out}@keyframes toast-birth{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}80%{opacity:1;transform:translate(-50%,-50%) scale(1.05)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes slideInRight{0%{opacity:0;transform:translateY(-50%) translateX(-20px)}to{opacity:1;transform:translateY(-50%) translateX(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}.modal{align-items:center;background:linear-gradient(180deg,#2d8a85,#247a75);border:3px solid #4ecdc4;border-radius:20px;box-shadow:0 8px 30px #00000080,0 0 30px #4ecdc433,inset 0 1px 0 #ffffff1a;display:flex;flex-direction:column;justify-content:center;left:50%;max-width:90%;min-width:320px;opacity:0;padding:32px 48px;pointer-events:none;position:fixed;top:50%;transform:translate(-50%,-50%);transition:opacity .3s ease-in-out,transform .3s ease-in-out;z-index:2500}.modal.show{opacity:1;pointer-events:inherit;transform:translate(-50%,-50%) scale(1)}.modal-close{align-items:center;background:#0000;border-radius:50%;color:#2d5a5a;color:var(--text-secondary);cursor:pointer;display:flex;font-size:28px;height:36px;justify-content:center;line-height:1;position:absolute;right:16px;top:16px;transition:background .2s;width:36px}.modal-close:hover{background:#3da69f;background:var(--bg-tertiary)}.modal-title{color:#1a3a3a;color:var(--text-primary);font-size:28px;font-weight:700;margin:0 0 16px;text-align:center}.modal-content{align-items:center;color:#2d5a5a;color:var(--text-secondary);display:flex;flex-direction:column;font-size:16px;gap:12px;justify-content:center;line-height:1.5;text-align:center}.modal_finish .word span{background:linear-gradient(180deg,#359590,#2d8a85);border:2px solid #4ecdc4;border-radius:8px;box-shadow:0 3px 0 #1d6a65,0 4px 10px #0000004d;color:#fff;display:inline-block;font-size:18px;padding:10px 15px;text-transform:uppercase;vertical-align:top}.modal-actions{align-items:center;display:flex;gap:12px;justify-content:center;margin-top:20px;width:100%}.backdrop{background:#000;bottom:0;left:0;opacity:0;pointer-events:none;position:fixed;right:0;top:0;transition:opacity .2s ease-in-out;z-index:2000}.backdrop.show{opacity:.75;pointer-events:inherit}.waiting-overlay{align-items:center;background:#000000bf;bottom:0;display:none;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:3000}.waiting-overlay.show{display:flex}.waiting-content{background:#45b8b0;background:var(--modal-bg);border:1px solid #3db9b1;border:1px solid var(--border-color);border-radius:12px;max-width:90%;min-width:300px;padding:32px;text-align:center}.waiting-content h2{color:#1a3a3a;color:var(--text-primary);font-size:24px;margin-bottom:16px}.waiting-content p{color:#2d5a5a;color:var(--text-secondary);font-size:16px;margin-bottom:24px}.waiting-buttons{display:flex;gap:12px;justify-content:center}.waiting-button{border:none;border-radius:12px;cursor:pointer;font-size:16px;font-weight:700;padding:14px 28px;text-shadow:0 1px 2px #0000004d;transition:all .15s ease}.waiting-button.primary{background:linear-gradient(180deg,#4ecdc4,#3db9b1);box-shadow:0 4px 0 #2a9d97,0 5px 15px #0000004d;color:#fff}.waiting-button.primary:hover{background:linear-gradient(180deg,#5dd9d1,#4ecdc4);box-shadow:0 6px 0 #2a9d97,0 7px 20px #0006;transform:translateY(-2px)}.waiting-button.primary:active{box-shadow:0 2px 0 #2a9d97,0 3px 8px #0000004d;transform:translateY(2px)}.waiting-button.secondary{background:linear-gradient(180deg,#359590,#2d8a85);border:2px solid #3db9b1;border:2px solid var(--border-color);box-shadow:0 4px 0 #1d6a65,0 5px 15px #0000004d;color:#1a3a3a;color:var(--text-primary)}.waiting-button.secondary:hover{background:linear-gradient(180deg,#4ecdc4,#3db9b1);box-shadow:0 6px 0 #1d6a65,0 7px 20px #0006;transform:translateY(-2px)}.waiting-button.secondary:active{box-shadow:0 2px 0 #1d6a65,0 3px 8px #0000004d;transform:translateY(2px)}.mobile-grid-overlay{background:#4ecdc4;background:var(--bg-primary);bottom:0;display:none;left:0;opacity:0;overflow:hidden;padding-bottom:env(safe-area-inset-bottom);position:fixed;right:0;top:0;touch-action:none;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease;z-index:2000}body.mobile-overlay-open{height:100%;overflow:hidden;position:fixed;width:100%}.mobile-grid-overlay.show{display:flex;flex-direction:column;opacity:1;transform:translateY(0)}.mobile-grid-overlay.show.closing{opacity:0;transform:translateY(20px)}.mobile-grid-content{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:0;height:100%;justify-content:space-between;min-height:0;overflow:hidden;padding:0 0 max(16px,env(safe-area-inset-bottom,16px));position:relative;touch-action:none;transition:opacity .3s ease,transform .3s ease}.mobile-grid-overlay.show .mobile-grid-content{opacity:1;transform:translateY(0)}.mobile-grid-overlay.show.closing .mobile-grid-content{opacity:.8;transform:translateY(10px)}.mobile-overlay-timer .turn-timer{display:flex;position:static;transform:none}.mobile-timer{flex-shrink:0;justify-content:center;padding:8px 0;pointer-events:none}.mobile-grid-words,.mobile-timer{align-items:center;display:flex;flex-direction:column;gap:4px;width:100%}.mobile-grid-words .word{display:flex;gap:4px}.mobile-grid-words .letter{font-size:1.8rem;height:56px;min-height:56px;min-width:56px;width:56px}.mobile-overlay-keyboard{max-width:100%!important;width:100%!important}.mobile-overlay-keyboard .keyboard{display:flex;flex-direction:column;gap:6px;max-width:100%;padding:0 4px;width:100%}.mobile-overlay-keyboard .keyboard-row{align-items:center;display:flex;flex-wrap:nowrap;gap:4px;justify-content:center;width:100%}.mobile-overlay-keyboard .keyboard-button{border-radius:8px;flex:1 1;font-size:16px;font-weight:600;height:48px;margin:0;max-width:none;min-width:0;padding:0}.mobile-overlay-keyboard .keyboard-button.larger{flex:1.5 1;font-size:12px;min-width:0;padding:0 4px}.mobile-overlay-keyboard .keyboard-button.enter{flex:2 1;font-size:14px;min-width:0;padding:0 8px}.mobile-overlay-keyboard .keyboard-button.wide-backspace{flex:3 1;min-width:0}.mobile-overlay-keyboard .keyboard-button.bottom-row,.mobile-overlay-keyboard .keyboard-button.middle-row{flex:1 1;min-width:0;width:auto}.mobile-grid-buttons{display:flex;gap:12px;justify-content:center;width:100%}.mobile-grid-close,.mobile-grid-enter{background:linear-gradient(180deg,#2d8a85,#247a75);background:var(--button-bg);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;max-width:150px;padding:10px 24px;transition:all .2s ease}.mobile-grid-close:hover,.mobile-grid-enter:hover{background:linear-gradient(180deg,#359590,#2d8a85);background:var(--button-hover);transform:translateY(-1px)}.mobile-grid-close:active,.mobile-grid-enter:active{transform:translateY(0)}.mobile-grid-enter{background:linear-gradient(180deg,#2d8a85,#247a75);background:var(--button-bg)}.mobile-grid-enter:disabled{cursor:not-allowed;opacity:.5}@media (min-width:768px){.mobile-grid-overlay{display:none!important}}.puzzle-buttons-row{align-items:center;display:flex;flex-direction:row;gap:8px;justify-content:center;margin:16px auto 20px;max-width:600px;min-height:150px;padding:0 16px;position:relative;width:100%}@media (max-width:767px){.puzzle-buttons-row{margin:16px auto;padding:0 8px}}.puzzle-carousel-arrow{align-items:center;background:#45b8b0;background:var(--bg-secondary);border:2px solid #3db9b1;border:2px solid var(--border-color);border-radius:12px;color:#1a3a3a;color:var(--text-primary);cursor:pointer;display:flex;flex-shrink:0;font-size:48px;font-weight:700;height:150px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:50px}.puzzle-carousel-arrow:hover{background:#3da69f;background:var(--bg-tertiary);transform:scale(1.05)}.puzzle-carousel-arrow:active{transform:scale(.95)}.puzzle-carousel-arrow-left{border-bottom-right-radius:0;border-right:none;border-top-right-radius:0}.puzzle-carousel-arrow-right{border-bottom-left-radius:0;border-left:none;border-top-left-radius:0}.puzzle-carousel-container{align-items:center;display:flex;flex:1 1;height:100%;min-height:150px;min-width:0;overflow:hidden;position:relative}.puzzle-carousel-track{align-items:center;display:flex;flex-direction:row;gap:12px;justify-content:center;transition:transform .3s ease}.puzzle-carousel-track .puzzle-button{flex:0 0 150px;height:150px;max-width:150px;min-width:150px;width:150px}.puzzle-button{align-items:center;aspect-ratio:1;background:linear-gradient(180deg,#2a2a3a,#2a2a3a 50%,#222230 0,#222230);border:3px solid #3a3a4a;border-radius:14px;box-shadow:0 5px 0 #1a1a25,0 7px 15px #00000059;box-sizing:border-box;color:#fff;cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:16px;font-weight:600;gap:10px;height:150px;justify-content:center;max-width:150px;min-width:0;min-width:150px;overflow:hidden;padding:16px;position:relative;transition:transform .15s ease,box-shadow .15s ease;width:150px}.puzzle-button.daily-puzzle{overflow:visible}.puzzle-button:before{background:linear-gradient(180deg,#ffffff1a,#ffffff05);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.puzzle-button-text{font-size:14px;font-weight:700;letter-spacing:1px;line-height:1.2;position:relative;text-align:center;text-shadow:0 2px 4px #0000004d;text-transform:uppercase;z-index:2}.puzzle-button-image{flex-shrink:0;height:auto;max-width:80px;object-fit:contain;position:relative;width:100%;z-index:2}.puzzle-button.daily-puzzle{background:linear-gradient(180deg,#4ecdc4,#4ecdc4 50%,#3db9b1 0,#3db9b1);border-color:#2a9d97;box-shadow:0 5px 0 #1f7a75,0 7px 15px #00000059;color:#fff}.puzzle-button.challenge-puzzle{background:linear-gradient(180deg,#5a5a6a,#5a5a6a 50%,#4a4a5a 0,#4a4a5a);border-color:#6a6a7a;box-shadow:0 5px 0 #3a3a4a,0 7px 15px #00000059;color:#fff}.puzzle-button:hover{box-shadow:0 8px 0 #1a1a25,0 12px 20px #0006;transform:translateY(-3px)}.puzzle-button:active{box-shadow:0 2px 0 #1a1a25,0 4px 8px #0000004d;transform:translateY(3px)}.puzzle-button.daily-puzzle:hover{box-shadow:0 8px 0 #1f7a75,0 12px 20px #0006}.puzzle-button.daily-puzzle:active{box-shadow:0 2px 0 #1f7a75,0 4px 8px #0000004d}.puzzle-button.challenge-puzzle:hover{box-shadow:0 8px 0 #3a3a4a,0 12px 20px #0006}.puzzle-button.puzzle-tower-puzzle{background:linear-gradient(180deg,#e6955c,#e6955c 50%,#d4844a 0,#d4844a);border-color:#c27339;box-shadow:0 5px 0 #a86230,0 7px 15px #00000059;color:#fff;overflow:visible;position:relative}.puzzle-button.puzzle-tower-puzzle:hover{box-shadow:0 8px 0 #a86230,0 12px 20px #0006}.puzzle-button.puzzle-tower-puzzle:active{box-shadow:0 2px 0 #a86230,0 4px 8px #0000004d}.new-notification-badge{animation:bounce 2s infinite;background:linear-gradient(180deg,#ff4757,#ff4757 50%,#e63946 0,#e63946);border:2px solid #fff;border-radius:10px;box-shadow:0 3px 0 #c0392b,0 4px 8px #0000004d;color:#fff;font-size:10px;font-weight:700;padding:5px 10px;position:absolute;right:-10px;top:-10px;z-index:100}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}60%{transform:translateY(-3px)}}.puzzle-button.draws-puzzle{background:linear-gradient(180deg,#8b5cf6,#8b5cf6 50%,#7c3aed 0,#7c3aed);border-color:#6d28d9;box-shadow:0 5px 0 #5b21b6,0 7px 15px #00000059;color:#fff;overflow:visible;position:relative}.puzzle-button.draws-puzzle:hover{box-shadow:0 8px 0 #5b21b6,0 12px 20px #0006}.puzzle-button.draws-puzzle:active{box-shadow:0 2px 0 #5b21b6,0 4px 8px #0000004d}.puzzle-button.draws-puzzle:before{animation:none;background:linear-gradient(180deg,#ffffff26,#ffffff05);border-radius:12px 12px 0 0;content:"";height:50%;left:0;opacity:1;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.puzzle-button.draws-puzzle:after{display:none}.draws-sparkle-1,.draws-sparkle-2,.draws-sparkle-3{animation:sparkle 3s infinite;font-size:16px;opacity:0;pointer-events:none;position:absolute}.draws-sparkle-1{animation-delay:.5s;right:15%;top:30%}.draws-sparkle-2{animation-delay:1s;bottom:15%;left:20%}.draws-sparkle-3{animation-delay:2s;right:30%;top:15%}@keyframes sparkle{0%,to{opacity:0;transform:scale(0) rotate(0deg)}50%{opacity:1;transform:scale(1) rotate(180deg)}}.puzzle-button-icon{align-items:center;display:flex;justify-content:center;line-height:1}@media (max-width:767px){.puzzle-carousel-arrow{font-size:36px;height:120px;width:40px}.puzzle-carousel-track .puzzle-button{flex:0 0 120px}.puzzle-button,.puzzle-carousel-track .puzzle-button{height:120px;max-width:120px;min-width:120px;width:120px}.puzzle-button{gap:8px;padding:12px}.puzzle-button-text{font-size:11px}.puzzle-button-image{max-width:70px}.puzzle-button-icon{font-size:36px!important}}@media (min-width:768px){.main-content-column .puzzle-buttons-row{margin:20px auto 40px;max-width:600px;padding:0}.puzzle-carousel-arrow{min-height:150px}}.puzzle-buttons-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin:16px auto 20px;max-width:320px;padding:0 16px;width:100%}.puzzle-buttons-grid .puzzle-button{aspect-ratio:1;height:auto;max-width:none;min-width:0;width:100%}@media (max-width:767px){.puzzle-buttons-grid{gap:10px;max-width:280px;padding:0 8px}.puzzle-buttons-grid .puzzle-button{gap:6px;padding:10px}.puzzle-buttons-grid .puzzle-button-text{font-size:10px}.puzzle-buttons-grid .puzzle-button-icon{font-size:32px!important}.puzzle-buttons-grid .puzzle-button-image{max-width:60px}}@media (min-width:768px){.puzzle-buttons-grid{margin:20px auto 30px;max-width:340px;padding:0}}.rank-display-container{align-items:center;background:linear-gradient(180deg,#3a3a4a,#3a3a4a 50%,#32323f 0,#32323f);border:3px solid #4a4a5a;border-radius:16px;box-shadow:0 6px 0 #2a2a35,0 8px 20px #00000059;display:flex;flex-direction:row;gap:24px;justify-content:center;margin:20px auto 0;max-width:500px;opacity:1!important;overflow:hidden;padding:24px;position:relative;visibility:visible!important;width:100%}.rank-display-container:before{background:linear-gradient(180deg,#ffffff1a,#ffffff08);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.season-pass-button{align-items:center;background:linear-gradient(180deg,#4ecdc4,#4ecdc4 50%,#3db9b1 0,#3db9b1);border:3px solid #2a9d97;border-radius:14px;box-shadow:0 5px 0 #1f7a75,0 7px 15px #00000059;cursor:pointer;display:flex;gap:12px;justify-content:center;margin:20px auto;max-width:500px;overflow:hidden;padding:18px 24px;position:relative;text-align:center;transition:transform .15s ease,box-shadow .15s ease;width:100%}.season-pass-crown{height:180px;left:40%;object-fit:contain;opacity:.25;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);width:180px;z-index:0}.season-pass-text{color:#fff;font-size:18px;font-weight:800;letter-spacing:1px;position:relative;text-shadow:0 2px 4px #0000004d;text-transform:uppercase;z-index:1}.season-pass-button:before{background:linear-gradient(180deg,#ffffff40,#ffffff14);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.season-pass-button:hover{box-shadow:0 8px 0 #1f7a75,0 12px 20px #0006;transform:translateY(-3px)}.season-pass-button:active{box-shadow:0 2px 0 #1f7a75,0 4px 8px #0000004d;transform:translateY(3px)}@keyframes shimmer{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}@media (min-width:768px){.season-pass-button{max-width:600px}.main-content-column .season-pass-button{margin:20px auto;max-width:600px}}@media (max-width:767px){.rank-display-container{margin:16px auto 0;padding:20px}.season-pass-button{margin:20px 16px!important;max-width:calc(100% - 32px)!important;padding:16px 20px!important;width:calc(100% - 32px)!important}.season-pass-text{font-size:16px;letter-spacing:.8px}.season-pass-crown{height:150px;left:35%;width:150px}}@media (min-width:768px){.main-content-column .rank-display-container{margin:20px auto 0;max-width:600px;padding:24px 0;width:100%}}.rank-display{border:3px solid #3db9b1;border:3px solid var(--border-color);border-radius:20px;box-shadow:0 8px 24px #0000004d;flex:1 1;flex-direction:row;gap:16px;max-width:100%;opacity:1;visibility:visible}.rank-badge,.rank-display{align-items:center;background:#45b8b0;background:var(--bg-secondary);display:flex;padding:20px 24px}.rank-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid #ffffff4d;border-radius:16px;box-shadow:0 6px 16px #00000040;flex-direction:column;gap:10px;justify-content:center;min-width:180px}.rank-emoji{font-size:64px;line-height:1}.rank-name{color:#fff;font-size:20px;font-weight:700;letter-spacing:1.5px;text-shadow:0 2px 4px #0000004d;text-transform:uppercase}.rank-stats{align-items:stretch;background:#0000;border:none;border-radius:0;flex-direction:column;gap:16px;padding:0}.rank-stat,.rank-stats{display:flex;width:100%}.rank-stat{align-items:center;flex-direction:row;gap:12px}.rank-stat-content{display:flex;flex:1 1;flex-direction:column;gap:4px}.rank-stat-progress{align-items:center;display:flex;flex:1 1;gap:8px}.level-progress-bar{background:linear-gradient(180deg,#3a3a4a,#3a3a4a 50%,#2e2e3a 0,#2e2e3a);border:2px solid #4a4a5a;border-radius:10px;box-shadow:0 3px 0 #1e1e28,inset 0 2px 4px #0006;flex:1 1;height:16px;overflow:hidden;position:relative}.level-progress-fill{background:linear-gradient(180deg,gold,gold 50%,#e6b800 0,#e6b800);border-radius:8px;box-shadow:0 0 12px #ffd70099,inset 0 1px 0 #fff6;height:100%;position:relative;transition:width .3s ease}.level-progress-fill:before{background:linear-gradient(180deg,#ffffff4d,#ffffff1a);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.elo-progress-bar{background:linear-gradient(180deg,#247a75,#1d6a65);border:2px solid #3db9b1;border-radius:8px;box-shadow:inset 0 2px 4px #0000004d;flex:1 1;height:14px;overflow:hidden;position:relative}.elo-progress-fill{background:linear-gradient(180deg,#4ecdc4,#3db9b1);border-radius:6px;box-shadow:0 0 10px #4ecdc480;height:100%;transition:width .3s ease}.stat-label{color:#2d5a5a;color:var(--text-secondary);font-size:14px}.stat-value{color:#1a3a3a;color:var(--text-primary);font-size:32px}@keyframes checkmarkDraw{0%{stroke-dashoffset:24}to{stroke-dashoffset:0}}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.user-profile-section{align-items:center;background:linear-gradient(180deg,#3a3a4a,#3a3a4a 50%,#32323f 0,#32323f);border:3px solid #4a4a5a;border-radius:16px;box-shadow:0 6px 0 #2a2a35,0 8px 20px #00000059;display:flex;gap:16px;margin:0 auto 20px;max-width:600px;overflow:hidden;padding:16px;position:relative;width:100%}.user-profile-section:before{background:linear-gradient(180deg,#ffffff1a,#ffffff08);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.profile-avatar{flex-shrink:0;position:relative;z-index:1}.profile-avatar-placeholder{align-items:center;background:linear-gradient(180deg,#4ecdc4,#4ecdc4 50%,#3db9b1 0,#3db9b1);border:3px solid #2a9d97;border-radius:12px;box-shadow:0 4px 0 #1f7a75,0 6px 12px #0000004d;color:#fff;display:flex;font-size:24px;font-weight:800;height:60px;justify-content:center;text-shadow:0 2px 4px #0000004d;width:60px}@media (min-width:768px){.user-profile-section{min-height:100px;padding:24px}.profile-avatar-placeholder{border-radius:14px;font-size:32px;height:80px;width:80px}.profile-name{font-size:22px}}.profile-info{display:flex;flex:1 1;flex-direction:column;gap:4px;position:relative;z-index:1}.profile-name{color:#fff;font-size:18px;font-weight:700;text-shadow:0 1px 3px #0000004d}.profile-user-id{align-items:center;color:#2d5a5a;color:var(--text-secondary);display:flex;font-size:12px;gap:8px}.user-id-text{font-family:monospace}.copy-user-id-btn{align-items:center;background:none;border:none;border-radius:4px;color:#2d5a5a;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:4px;transition:all .2s ease}.copy-user-id-btn:hover{background:#3da69f;background:var(--bg-tertiary);color:#1a3a3a;color:var(--text-primary)}.profile-online-counter{align-items:center;color:#2d5a5a;color:var(--text-secondary);display:flex;font-size:12px;gap:6px;position:absolute;right:12px;top:12px}.profile-online-counter .online-dot{animation:pulse-dot 2s infinite;background:#4caf50;border-radius:50%;height:8px;width:8px}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.profile-online-counter .online-count{font-weight:600}.profile-actions{display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;margin-left:auto;width:50%}.profile-login-btn,.profile-signup-btn{border:2px solid #2a9d97;border-radius:10px;cursor:pointer;font-size:14px;font-weight:700;overflow:hidden;padding:10px 20px;position:relative;text-shadow:0 1px 2px #0000004d;transition:transform .15s ease,box-shadow .15s ease}.profile-login-btn{background:linear-gradient(180deg,#4ecdc4,#4ecdc4 50%,#3db9b1 0,#3db9b1);box-shadow:0 4px 0 #1f7a75,0 6px 12px #0000004d;color:#fff;flex:1 1}.profile-login-btn:before,.profile-signup-btn:before{background:linear-gradient(180deg,#ffffff40,#ffffff14);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.profile-login-btn:hover{box-shadow:0 6px 0 #1f7a75,0 8px 16px #0006;transform:translateY(-2px)}.profile-login-btn:active{box-shadow:0 1px 0 #1f7a75,0 2px 5px #0000004d;transform:translateY(3px)}.profile-signup-btn{background:linear-gradient(180deg,#5cbf60,#5cbf60 50%,#45a049 0,#45a049);border-color:#2d682f;box-shadow:0 4px 0 #1b5e20,0 6px 12px #0000004d;color:#fff}.profile-signup-btn:hover{box-shadow:0 6px 0 #1b5e20,0 8px 16px #0006;transform:translateY(-2px)}.profile-signup-btn:active{box-shadow:0 1px 0 #1b5e20,0 2px 5px #0000004d;transform:translateY(3px)}.profile-logout-btn{background:linear-gradient(180deg,#5a5a6a,#5a5a6a 50%,#4a4a5a 0,#4a4a5a);border:2px solid #4a4a5a;border-radius:10px;box-shadow:0 4px 0 #3a3a4a,0 6px 12px #0000004d;color:#fff;cursor:pointer;font-size:14px;font-weight:700;overflow:hidden;padding:10px 20px;position:relative;text-shadow:0 1px 2px #0000004d;transition:transform .15s ease,box-shadow .15s ease}.profile-logout-btn:before{background:linear-gradient(180deg,#ffffff26,#ffffff0d);content:"";height:50%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.profile-logout-btn:hover{background:linear-gradient(180deg,#f44336,#f44336 50%,#e53935 0,#e53935);border-color:#c62828;box-shadow:0 6px 0 #b71c1c,0 8px 16px #0006;transform:translateY(-2px)}.profile-logout-btn:active{box-shadow:0 1px 0 #b71c1c,0 2px 5px #0000004d;transform:translateY(3px)}@media (max-width:767px){.user-profile-section{align-items:flex-start;border-radius:12px;box-sizing:border-box;flex-wrap:wrap;gap:10px;margin:0;max-width:none;padding:12px 16px;width:100%}.profile-online-counter{font-size:11px;right:8px;top:8px}.user-profile-section>.profile-login-btn,.user-profile-section>.profile-logout-btn{flex-basis:100%!important;margin:8px auto 0!important;position:static!important;width:calc(100% - 24px)!important}.profile-avatar-placeholder{font-size:20px;height:50px;width:50px}.profile-name{font-size:16px}.profile-info{flex:1 1 auto;max-width:calc(100% - 70px);min-width:0}.profile-user-id{flex-wrap:wrap}.user-id-text{font-size:11px;word-break:break-all}.profile-actions{flex-direction:row;gap:8px;margin-left:auto;margin-top:8px;width:50%}.profile-login-btn{flex:1 1;font-size:13px;padding:10px 12px;white-space:nowrap}}.turn-timer{align-items:center;display:flex;flex-direction:column;gap:4px;justify-content:center;left:50%;padding:0;pointer-events:none;position:absolute;top:60px;transform:translateX(-50%);z-index:10}@media (max-width:767px){.turn-timer{flex:1 1;padding:0;position:static;transform:none}}@media (min-width:768px){.turn-timer{display:none}}.minimap-timer{align-items:center;display:flex;flex-direction:column;gap:4px;justify-content:center;margin-top:8px;pointer-events:none}.minimap-timer-hidden{display:none}@media (max-width:767px){.minimap-timer{display:none}}.minimap-timer .timer-container{height:50px;width:50px}.minimap-timer .timer-circle{border-width:2px;font-size:14px;height:50px;width:50px}.minimap-timer .timer-progress{height:50px;width:50px}.minimap-timer .timer-progress:before{mask:radial-gradient(circle,#0000 22px,#000 23px);-webkit-mask:radial-gradient(circle,#0000 22px,#000 23px)}.minimap-timer .timer-label{font-size:10px}@media (min-width:768px){.minimap-timer .turn-timer{display:flex;left:auto;padding:0;position:static;top:auto;transform:none}}.points-orb{border-radius:50%;height:12px;pointer-events:none;position:fixed;transition:left .8s ease-out,top .8s ease-out,transform .8s ease-out,opacity .8s ease-out;width:12px;will-change:left,top,transform,opacity;z-index:2000}.points-orb.correct{background:#44bd32;background:var(--correct-bg);box-shadow:0 0 8px #44bd32;box-shadow:0 0 8px var(--correct-bg)}.points-orb.semi{background:#f5a623;background:var(--semi-bg);box-shadow:0 0 8px #f5a623;box-shadow:0 0 8px var(--semi-bg)}.points-orb.incorrect{background:#7ab5b0;background:var(--incorrect-bg);box-shadow:0 0 8px #7ab5b0;box-shadow:0 0 8px var(--incorrect-bg)}.timer-container{height:60px;position:relative;width:60px}.timer-circle{align-items:center;border:3px solid #3db9b1;border:3px solid var(--border-color);border-radius:50%;color:#1a3a3a;color:var(--text-primary);display:flex;font-size:18px;font-weight:700;justify-content:center;position:relative;z-index:2}.timer-circle,.timer-progress{background:#45b8b0;background:var(--bg-secondary);height:60px;width:60px}.timer-progress{--progress-deg:0deg;z-index:0}.timer-progress,.timer-progress:before{border-radius:50%;left:0;position:absolute;top:0}.timer-progress:before{background:conic-gradient(from 0deg,#f44 0deg,#f44 0deg,#0000 0deg 1turn);background:conic-gradient(from 0deg,#f44 0deg,#f44 var(--progress-deg,0deg),#0000 var(--progress-deg,0deg) 1turn);content:"";height:100%;mask:radial-gradient(circle,#0000 26px,#000 28px);-webkit-mask:radial-gradient(circle,#0000 26px,#000 28px);transition:background 1s linear;width:100%}.timer-label{color:#1a3a3a;color:var(--text-primary);display:block;font-size:12px;font-weight:700;letter-spacing:1px;opacity:1;text-transform:uppercase;visibility:visible}.player-turn .timer-circle{box-shadow:0 0 10px #ff44444d}.waiting-turn .timer-circle{opacity:.6}@media (min-width:768px){.top-nav{padding:16px 24px}.screen-title{font-size:48px;margin:32px 0}.room-entry{padding:20px}.username{font-size:20px}.create-game-button{font-size:20px;padding:20px 32px}.game-header{padding:16px 24px}.opponent-section,.player-section{justify-content:center;padding:24px}.letter{font-size:2rem;height:64px;width:64px}.keyboard-button{color:#fff;font-size:16px;height:56px;width:44px}.keyboard-button.bottom-row,.keyboard-button.middle-row{width:44px}.keyboard-button.larger{width:auto}.keyboard-button.enter{min-width:90px;padding:0 20px;width:auto}.modal{padding:30px 80px 50px}}@media (max-width:480px){.rank-display-container{gap:16px;margin:20px auto;max-width:100%;padding:16px}.rank-display{gap:12px;max-width:100%;padding:16px}.rank-badge{flex-shrink:0;min-width:auto;padding:12px 16px}.rank-emoji{font-size:32px}.rank-name{font-size:12px}.rank-stats{gap:16px}.rank-stat{gap:4px}.stat-label{font-size:11px}.stat-value{font-size:18px}.opponent-minimap{left:8px;padding:6px;top:68px;width:100px}.opponent-minimap.expanded{padding:20px;width:320px}.opponent-minimap.expanded .minimap-words .letter{height:36px;min-height:36px;min-width:36px;width:36px}.top-points-container{gap:6px;right:8px;top:68px}.opponent-points-display-top,.player-points-display{padding:6px 10px}.opponent-points-value,.player-points-display .points-value{font-size:14px}.minimap-words .letter{height:14px;min-height:14px;min-width:14px;width:14px}.game-container:not([data-solo=true]) .player-section{align-items:center;border-radius:14px;justify-content:flex-end;margin:6px;overflow-y:visible;padding:10px 8px max(10px,env(safe-area-inset-bottom,10px))}.game-container[data-solo=true] .player-section{border-radius:14px;margin:6px;padding:10px 8px 150px}.game-container{display:flex;flex-direction:column;justify-content:flex-end}.words{margin-bottom:8px;order:1}.keyboard-wrapper{margin-bottom:0;margin-top:0;order:2}.game-container:not([data-solo=true]) .emote-container{margin-bottom:0;margin-top:8px;order:3;padding-bottom:max(8px,env(safe-area-inset-bottom,8px))}.letter{font-size:1.4rem;height:44px;min-height:44px;min-width:44px;width:44px}.keyboard-button{font-size:11px;height:36px;margin:2px;width:28px}.keyboard-button.bottom-row,.keyboard-button.middle-row{width:28px}.keyboard-button.larger{width:auto}.keyboard-button.enter{font-size:10px;min-width:45px;padding:0 8px;width:auto}.timer-circle,.timer-container{height:50px;width:50px}.timer-circle{border-width:2px;font-size:16px}.timer-progress{height:50px;width:50px}.timer-progress:before{mask:radial-gradient(circle,#0000 22px,#000 23px);-webkit-mask:radial-gradient(circle,#0000 22px,#000 23px)}}@media (max-width:360px){.opponent-minimap{left:6px;padding:5px;top:48px;width:90px}.opponent-minimap.expanded{padding:18px;width:280px}.opponent-minimap.expanded .minimap-words .letter{height:32px;min-height:32px;min-width:32px;width:32px}.top-points-container{gap:4px;right:6px;top:64px}.opponent-points-display-top,.player-points-display{padding:5px 8px}.opponent-points-value,.player-points-display .points-value{font-size:12px}.minimap-words .letter{height:12px;min-height:12px;min-width:12px;width:12px}}.chat-messages-desktop::-webkit-scrollbar,.chat-messages-mobile::-webkit-scrollbar{width:8px}.chat-messages-desktop::-webkit-scrollbar-track,.chat-messages-mobile::-webkit-scrollbar-track{background:#b5a68633;border-radius:4px}.chat-messages-desktop::-webkit-scrollbar-thumb,.chat-messages-mobile::-webkit-scrollbar-thumb{background:#5a4f3f80;border-radius:4px;-webkit-transition:background .2s;transition:background .2s}.chat-messages-desktop::-webkit-scrollbar-thumb:hover,.chat-messages-mobile::-webkit-scrollbar-thumb:hover{background:#5a4f3fb3}.chat-messages-desktop,.chat-messages-mobile{scrollbar-color:#5a4f3f80 #b5a68633;scrollbar-width:thin}@media (min-width:768px){.main-content-column::-webkit-scrollbar{width:8px}.main-content-column::-webkit-scrollbar-track{background:#b5a68633;border-radius:4px}.main-content-column::-webkit-scrollbar-thumb{background:#5a4f3f80;border-radius:4px;-webkit-transition:background .2s;transition:background .2s}.main-content-column::-webkit-scrollbar-thumb:hover{background:#5a4f3fb3}.main-content-column{scrollbar-color:#5a4f3f80 #b5a68633;scrollbar-width:thin}}@keyframes pulse{0%,to{box-shadow:0 0 0 0 #538d4e66;transform:scale(1)}50%{box-shadow:0 0 0 8px #538d4e00;transform:scale(1.02)}}@keyframes yourTurnPopover{0%{opacity:0;transform:translateY(-100%)}5%{opacity:1;transform:translateY(0)}90%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(0)}}@keyframes yourTurnPopoverDesktop{0%{opacity:0;transform:translate(-50%,-150%)}5%{opacity:1;transform:translate(-50%,-50%)}90%{opacity:1;transform:translate(-50%,-50%)}to{opacity:0;transform:translate(-50%,-50%)}}@keyframes duellex-glow{0%,to{box-shadow:0 0 4px #ffd7004d,0 0 8px #ffd70033}50%{box-shadow:0 0 6px #ffd70066,0 0 12px #ffd7004d}}@keyframes admin-glow{0%,to{box-shadow:0 0 4px #4ecdc44d,0 0 8px #4ecdc433}50%{box-shadow:0 0 6px #4ecdc466,0 0 12px #4ecdc44d}}input[type=range]{-webkit-appearance:none;appearance:none;background:#0000;cursor:pointer}input[type=range]::-webkit-slider-runnable-track{background:inherit;border-radius:6px;height:12px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:linear-gradient(180deg,#fff,#fff 50%,#e8e8e8 0,#e8e8e8);border:3px solid #4ecdc4;border-radius:50%;box-shadow:0 3px 0 #0003,0 4px 8px #00000026;cursor:pointer;height:24px;margin-top:-6px;position:relative;width:24px;z-index:2}input[type=range]::-webkit-slider-thumb:active{box-shadow:0 2px 0 #0003,0 3px 6px #0003;transform:scale(1.1)}input[type=range]::-moz-range-track{background:inherit;border-radius:6px;height:12px}input[type=range]::-moz-range-thumb{background:linear-gradient(180deg,#fff,#fff 50%,#e8e8e8 0,#e8e8e8);border:3px solid #4ecdc4;border-radius:50%;box-shadow:0 3px 0 #0003,0 4px 8px #00000026;cursor:pointer;height:24px;width:24px}input[type=range]:focus{outline:none}input[type=range]:focus::-webkit-slider-thumb{box-shadow:0 3px 0 #0003,0 4px 8px #00000026,0 0 0 3px #4ecdc44d}.landing-container{align-items:center;background-color:#2d8a85;box-sizing:border-box;display:flex;justify-content:center;min-height:100vh;min-height:100dvh;overflow:hidden;padding:20px;position:relative;width:100%}.landing-container:before{animation:landingDiamondSlide 20s linear infinite;background:linear-gradient(45deg,#0000 48%,#4ecdc466 49%,#4ecdc480 50%,#4ecdc466 51%,#0000 52%),linear-gradient(-45deg,#0000 48%,#4ecdc466 49%,#4ecdc480 50%,#4ecdc466 51%,#0000 52%),radial-gradient(circle at 50% 50%,#4ecdc426 0,#0000 40%),linear-gradient(180deg,#3da69f,#2d8a85 50%,#247a75);background-position:0 0,0 0,0 0,0 0;background-size:40px 40px,40px 40px,40px 40px,100% 100%;content:"";filter:blur(1px);height:200%;left:-50%;pointer-events:none;position:absolute;top:-50%;width:200%;z-index:0}@keyframes landingDiamondSlide{0%{transform:translate(0)}to{transform:translate(40px,40px)}}.landing-content{align-items:center;display:flex;flex-direction:column;gap:28px;max-width:500px;text-align:center;width:100%}.landing-logo-container{align-items:center;display:flex;filter:drop-shadow(0 4px 20px rgba(0,0,0,.2));justify-content:center;margin-bottom:8px}.landing-logo{background:#0000;height:120px;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;max-width:90%;object-fit:contain;width:auto}.landing-logo[src*=DuellexLogo]{filter:brightness(1.1) drop-shadow(0 0 20px rgba(0,0,0,.2));mix-blend-mode:normal}.landing-title{color:#1a3a3a;font-size:36px;font-weight:800;letter-spacing:-.5px;margin:0;text-shadow:0 2px 10px #ffffff4d}.landing-description{color:#1a3a3a;font-size:17px;line-height:1.6;margin:0;max-width:400px}.landing-banner{align-items:center;background:linear-gradient(180deg,#45b8b0,#3da69f);border:3px solid #2d8a85;border-radius:20px;box-shadow:0 8px 30px #00000026,inset 0 1px 0 #fff3;display:flex;flex-direction:column;gap:24px;padding:36px 28px;width:100%}.landing-banner-text{color:#1a3a3a;font-size:17px;font-weight:600;margin:0}.landing-buttons{display:flex;flex-direction:column;gap:16px;max-width:320px;width:100%}.landing-button{border:none;border-radius:14px;cursor:pointer;font-family:inherit;font-size:18px;font-weight:700;letter-spacing:.5px;padding:18px 28px;text-shadow:0 2px 3px #0000004d;text-transform:uppercase;transition:all .15s ease;width:100%}.landing-button-primary{background:linear-gradient(180deg,#2d8a85,#247a75);box-shadow:0 5px 0 #1d6a65,0 6px 20px #0000004d,0 0 25px #2d8a854d;color:#fff}.landing-button-primary:hover{background:linear-gradient(180deg,#359590,#2d8a85);box-shadow:0 8px 0 #1d6a65,0 10px 30px #0006,0 0 35px #2d8a8566;transform:translateY(-3px)}.landing-button-primary:active{box-shadow:0 2px 0 #1d6a65,0 4px 10px #0000004d;transform:translateY(2px)}.landing-button-secondary{background:linear-gradient(180deg,#fff,#e8f5f4);border:2px solid #3db9b1;box-shadow:0 5px 0 #c5d9d7,0 6px 20px #0003;color:#1a3a3a}.landing-button-secondary:hover{background:linear-gradient(180deg,azure,#fff);box-shadow:0 8px 0 #c5d9d7,0 10px 30px #0000004d;transform:translateY(-3px)}.landing-button-secondary:active{box-shadow:0 2px 0 #c5d9d7,0 4px 10px #0003;transform:translateY(2px)}@media (max-width:767px){.landing-container{padding:16px}.landing-content{gap:24px}.landing-logo{height:100px}.landing-title{font-size:30px}.landing-description{font-size:15px}.landing-banner{gap:20px;padding:28px 22px}.landing-banner-text{font-size:15px}.landing-button{font-size:16px;padding:16px 22px}}@media (max-width:480px){.landing-logo{height:80px}.landing-title{font-size:26px}.landing-description{font-size:14px}.landing-banner{border-radius:16px;padding:24px 18px}.landing-button{border-radius:12px;font-size:15px;padding:14px 20px}}.puzzle-tower-game{bottom:0;font-family:Clear Sans,Helvetica Neue,Arial,sans-serif;left:0;overflow:hidden;position:fixed;right:0;top:0}.tower-sky{z-index:0}.sky-gradient,.tower-sky{bottom:0;left:0;position:absolute;right:0;top:0}.sky-gradient{background:linear-gradient(180deg,#5ba3d9,#7bbfea 30%,#a8d8f0 60%,#c8e8f8)}.clouds-layer{height:60%;left:0;overflow:hidden;pointer-events:none;position:absolute;right:0;top:0}.cloud{border-radius:50px;filter:blur(1px)}.cloud,.cloud:after,.cloud:before{background:#ffffffe6;position:absolute}.cloud:after,.cloud:before{border-radius:50%;content:""}.cloud-1{animation:cloudFloat 40s linear infinite;height:40px;left:-15%;top:8%;width:120px}.cloud-1:before{height:50px;left:20px;top:-20px;width:50px}.cloud-1:after{height:45px;left:50px;top:-15px;width:60px}.cloud-2{animation:cloudFloat 50s linear infinite;animation-delay:-15s;height:35px;left:20%;top:15%;width:100px}.cloud-2:before{height:45px;left:15px;top:-18px;width:45px}.cloud-2:after{height:40px;left:45px;top:-12px;width:55px}.cloud-3{animation:cloudFloat 45s linear infinite;animation-delay:-30s;height:45px;left:55%;top:5%;width:130px}.cloud-3:before{height:55px;left:25px;top:-22px;width:55px}.cloud-3:after{height:50px;left:60px;top:-18px;width:70px}.cloud-4{animation:cloudFloat 55s linear infinite;animation-delay:-10s;height:30px;left:75%;top:22%;width:90px}.cloud-4:before{height:40px;left:12px;top:-15px;width:40px}.cloud-4:after{height:35px;left:38px;top:-10px;width:50px}.cloud-5{animation:cloudFloat 48s linear infinite;animation-delay:-25s;height:28px;left:35%;top:30%;width:80px}.cloud-5:before{height:38px;left:10px;top:-14px;width:35px}.cloud-5:after{height:32px;left:35px;top:-10px;width:45px}.cloud-6{animation:cloudFloat 52s linear infinite;animation-delay:-5s;height:38px;left:90%;top:12%;width:110px}.cloud-6:before{height:48px;left:18px;top:-18px;width:48px}.cloud-6:after{height:42px;left:52px;top:-14px;width:58px}@keyframes cloudFloat{0%{transform:translateX(0)}to{transform:translateX(calc(-100vw - 150px))}}.tower-hud{align-items:center;display:flex;gap:10px;justify-content:flex-start;left:12px;pointer-events:none;position:fixed;right:60px;top:12px;z-index:100}.hud-item{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:linear-gradient(180deg,#4ecdc440,#4ecdc426);border:2px solid #4ecdc466;border-radius:12px;box-shadow:0 4px 0 #00000026,0 6px 12px #0003;padding:8px 16px;pointer-events:auto;text-align:center}.hud-label{color:#fffc;font-size:9px;letter-spacing:1px;margin-bottom:2px;text-shadow:0 1px 2px #0000004d;text-transform:uppercase}.hud-label,.hud-value{display:block;font-weight:700}.hud-value{color:#fff;font-size:22px;text-shadow:0 2px 4px #0000004d}.hud-stability{min-width:100px}.stability-bar{display:flex;gap:3px;justify-content:center;margin-top:4px}.stability-segment{border-radius:3px;box-shadow:0 2px 0 #0003;height:6px;transition:all .3s ease;width:16px}.stability-segment.stable{background:linear-gradient(180deg,#4ecdc4,#3db9b1)}.stability-segment.cracked{background:linear-gradient(180deg,#e74c3c,#c0392b)}.tower-wrapper{-ms-overflow-style:none;align-items:center;bottom:220px;display:flex;flex-direction:column;left:50%;max-height:calc(100vh - 320px);overflow-x:visible;overflow-y:auto;position:absolute;scrollbar-width:none;transform:translateX(-50%);z-index:10}.tower-wrapper::-webkit-scrollbar{display:none}.tower-structure{min-width:300px;position:relative}.tower-roof,.tower-structure{align-items:center;display:flex;flex-direction:column}.tower-roof{margin-bottom:-2px;width:100%;z-index:5}.roof-peak{border-bottom:40px solid #5a4a3a;border-left:156px solid #0000;border-right:156px solid #0000;filter:drop-shadow(0 -2px 4px rgba(0,0,0,.3));height:0;position:relative;width:0}.roof-peak:after{background:linear-gradient(180deg,#6a5a4a,#4a3a2a);bottom:-40px;content:"";height:8px;left:-150px;position:absolute;right:-150px}.tower-floor{align-items:center;background:linear-gradient(90deg,#4a5a6a,#5a6a7a 5%,#6a7a8a 50%,#5a6a7a 95%,#4a5a6a);border-left:6px solid #3a4a5a;border-right:6px solid #3a4a5a;display:flex;justify-content:center;min-width:300px;padding:4px 12px;position:relative;transition:all .2s ease;z-index:2}.tower-floor.current-floor{background:linear-gradient(90deg,#5a6a7a,#6a7a8a 5%,#7a8a9a 50%,#6a7a8a 95%,#5a6a7a);border-left-color:#4ecdc4;border-right-color:#4ecdc4}.tower-floor.success-flash{animation:successFlash .5s ease}@keyframes successFlash{0%,to{background:linear-gradient(90deg,#5a6a7a,#7a8a9a 50%,#5a6a7a)}50%{background:linear-gradient(90deg,#3db9b1,#4ecdc4 50%,#3db9b1)}}.tower-floor.invalid-shake{animation:invalidShake .5s ease;border-left-color:#e74c3c;border-right-color:#e74c3c}@keyframes invalidShake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-6px)}20%,40%,60%,80%{transform:translateX(6px)}}.tower-floor.correct-floor{background:linear-gradient(90deg,#3a5a5a,#4a6a6a 5%,#4ecdc4 50%,#4a6a6a 95%,#3a5a5a);opacity:.85}.tower-floor.wrong-floor{background:linear-gradient(90deg,#5a4a4a,#6a5a5a 5%,#7a6a6a 50%,#6a5a5a 95%,#5a4a4a);opacity:.7}.floor-label{background:#00000080;border-radius:4px;color:#fffc;font-size:10px;font-weight:700;left:-45px;padding:3px 6px;position:absolute;white-space:nowrap}.floor-windows{align-items:center;display:flex;gap:4px;justify-content:center;padding:4px 0;position:relative;width:100%;z-index:2}.completed-floors{display:flex;flex-direction:column}.tower-window{align-items:center;background:#1a2530;border:2px solid #3a4a5a;border-radius:4px;display:flex;height:48px;justify-content:center;overflow:hidden;position:relative;transition:all .15s ease;width:48px}.tower-window:before{background:linear-gradient(135deg,#ffffff4d,#0000);border-radius:2px;content:"";height:8px;left:2px;position:absolute;top:2px;width:12px}.tower-window.empty{background:linear-gradient(135deg,#6496b433,#5082a01a)}.tower-window.typing{background:#4ecdc426;border-color:#4ecdc4;box-shadow:0 0 8px #4ecdc480}.tower-window.typing.has-letter{animation:letterPop .15s ease;background:linear-gradient(135deg,#4ecdc44d,#4ecdc433)}.tower-window.built{animation:windowBuild .2s ease}@keyframes letterPop{0%{transform:scale(.9)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes windowBuild{0%{opacity:.5;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.tower-window.correct{background:linear-gradient(135deg,#4ecdc4,#3db9b1);border-color:#3db9b1}.tower-window.semi{background:linear-gradient(135deg,#f0c419,#d4a817);border-color:#d4a817}.tower-window.incorrect{background:linear-gradient(135deg,#5a6a7a,#4a5a6a);border-color:#4a5a6a}.window-inner{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.window-letter{color:#fff;font-size:22px;font-weight:700;text-shadow:0 1px 2px #0006;text-transform:uppercase}.cracks-overlay{bottom:60px;left:6px;overflow:hidden;pointer-events:none;position:absolute;right:6px;top:40px;z-index:0}.cracks-svg{height:100%;left:0;position:absolute;top:0;width:100%}.crack-line{fill:none;stroke:#1e140acc;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;animation:crackDraw .5s ease forwards}.crack-line.horizontal{stroke-width:4}.crack-line.danger{stroke:#b43232e6;stroke-width:5;animation:crackDraw .5s ease forwards,crackPulse 1s ease infinite}@keyframes crackDraw{0%{stroke-dashoffset:400;opacity:0}50%{opacity:1}to{stroke-dashoffset:0;opacity:1}}@keyframes crackPulse{0%,to{stroke:#b43232b3;filter:none}50%{stroke:#dc3c3c;filter:drop-shadow(0 0 4px rgba(220,60,60,.6))}}.tower-structure.collapse-animation{animation:buildingCollapse 2.5s ease-in forwards}@keyframes buildingCollapse{0%{transform:translateY(0) rotate(0deg)}10%{transform:translateY(0) rotate(-2deg)}20%{transform:translateY(0) rotate(3deg)}30%{transform:translateY(10px) rotate(-4deg)}50%{opacity:1;transform:translateY(30px) rotate(6deg)}70%{opacity:.7;transform:translateY(80px) rotate(-10deg)}to{opacity:0;transform:translateY(200px) rotate(20deg)}}.puzzle-tower-game.collapsing .tower-sky{animation:skyDarken 2s ease forwards}@keyframes skyDarken{0%{filter:brightness(1)}to{filter:brightness(.4) saturate(.5)}}.tower-foundation{align-items:center;background:linear-gradient(180deg,#5a6a7a,#4a5a6a 50%,#3a4a5a);border-bottom:4px solid #2a3a4a;border-left:6px solid #3a4a5a;border-right:6px solid #3a4a5a;display:flex;flex-direction:column;justify-content:flex-end;min-height:60px;position:relative;width:300px}.foundation-body{background:linear-gradient(180deg,#4a5a6a,#3a4a5a);height:20px;width:100%}.foundation-door{background:linear-gradient(180deg,#4a3a2a,#3a2a1a);border:3px solid #2a1a0a;border-bottom:none;border-radius:6px 6px 0 0;height:48px;margin-bottom:-1px;position:relative;width:40px}.door-handle{background:#a89a8a;border-radius:50%;box-shadow:inset 0 1px 2px #0000004d;height:5px;position:absolute;right:8px;top:50%;width:5px}.tower-ground{background:linear-gradient(180deg,#4a7a4a,#3a6a3a);border-top:3px solid #5a8a5a;height:20px;margin-top:-1px;width:400px}.tower-keyboard-wrapper{background:#0000;bottom:0;display:flex;justify-content:center;left:0;padding:12px 8px calc(12px + env(safe-area-inset-bottom));position:fixed;right:0;z-index:100}.tower-keyboard-inner{display:flex;flex-direction:column;gap:8px;max-width:500px;width:100%}.tower-keyboard-wrapper .keyboard{display:flex;flex-direction:column;gap:6px;max-width:100%;padding:0 4px;width:100%}.tower-keyboard-wrapper .keyboard-row{align-items:center;display:flex;flex-wrap:nowrap;gap:4px;justify-content:center;width:100%}.tower-keyboard-wrapper .keyboard-button{background:#3a3a3cf2;border:none;border-radius:8px;box-shadow:0 2px 4px #0000004d;color:#fff;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;height:48px;margin:0;max-width:none;min-width:0;padding:0;transition:all .1s ease}.tower-keyboard-wrapper .keyboard-button:active{transform:scale(.95)}.tower-keyboard-wrapper .keyboard-button.larger{flex:1.5 1}.tower-keyboard-wrapper .keyboard-button.enter{display:none}.tower-keyboard-wrapper .keyboard-button.correct{background:#4ecdc4}.tower-keyboard-wrapper .keyboard-button.semi{background:#f0c419}.tower-keyboard-wrapper .keyboard-button.incorrect{background:#5a6a7af2;opacity:.6}.tower-enter-btn{background:linear-gradient(180deg,#4ecdc4,#3db9b1);border:none;border-radius:10px;box-shadow:0 4px 0 #2d9a92,0 6px 12px #0000004d;color:#fff;cursor:pointer;font-size:18px;font-weight:700;height:50px;letter-spacing:2px;transition:all .15s ease;width:100%}.tower-enter-btn:active{box-shadow:0 2px 0 #2d9a92,0 4px 8px #0000004d;transform:translateY(2px)}.tower-enter-btn:disabled{background:linear-gradient(180deg,#5a6a7a,#4a5a6a);box-shadow:0 4px 0 #3a4a5a,0 6px 12px #0000004d;cursor:not-allowed;opacity:.7}.tower-exit-btn{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:linear-gradient(180deg,#4ecdc44d,#4ecdc433);border:2px solid #4ecdc480;border-radius:12px;box-shadow:0 4px 0 #00000026,0 6px 12px #0003;color:#fff;cursor:pointer;display:flex;font-size:20px;font-weight:700;height:42px;justify-content:center;position:fixed;right:12px;text-shadow:0 1px 2px #0000004d;top:12px;transition:all .15s ease;width:42px;z-index:150}.tower-exit-btn:hover{background:linear-gradient(180deg,#4ecdc466,#4ecdc44d);box-shadow:0 6px 0 #00000026,0 8px 16px #00000040;transform:translateY(-2px)}.tower-exit-btn:active{box-shadow:0 2px 0 #00000026,0 4px 8px #0003;transform:translateY(2px)}.tower-game-over{align-items:center;animation:fadeIn .5s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:200}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-over-content{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);background:linear-gradient(180deg,#4ecdc440,#4ecdc426);border:3px solid #4ecdc480;border-radius:20px;box-shadow:0 8px 0 #00000026,0 12px 40px #0000004d;max-width:90%;padding:32px;text-align:center;width:360px}.game-over-title{color:#e74c3c;font-size:26px;font-weight:800;margin:0 0 20px;text-shadow:0 2px 4px #00000080}.game-over-stats{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.stat{background:linear-gradient(180deg,#ffffff26,#ffffff14);border:2px solid #fff3;border-radius:12px;box-shadow:0 3px 0 #0000001a;padding:12px 18px}.stat-label{color:#ffffffb3;display:block;font-size:10px;letter-spacing:1px;margin-bottom:6px;text-shadow:0 1px 2px #0000004d;text-transform:uppercase}.stat-value{color:#4ecdc4;display:block;font-size:28px;font-weight:700;text-shadow:0 2px 4px #0000004d}.stat-value.correct-word{color:#f5a623;font-size:32px;letter-spacing:4px;text-shadow:0 2px 4px #0000004d}.game-over-buttons{display:flex;gap:12px;justify-content:center}.tower-btn{border:2px solid #0000;border-radius:12px;cursor:pointer;font-size:14px;font-weight:700;letter-spacing:1px;overflow:hidden;padding:14px 28px;position:relative;text-transform:uppercase;transition:all .15s ease}.retry-btn{background:linear-gradient(180deg,#4ecdc4,#4ecdc4 50%,#3db9b1 0,#3db9b1);border-color:#6ee0d880;box-shadow:0 4px 0 #2a9d97,0 6px 12px #0003;color:#fff;text-shadow:0 1px 2px #0000004d}.retry-btn:hover{box-shadow:0 6px 0 #2a9d97,0 8px 16px #00000040;transform:translateY(-2px)}.retry-btn:active{box-shadow:0 2px 0 #2a9d97,0 4px 8px #0003;transform:translateY(2px)}.exit-btn{background:linear-gradient(180deg,#fff3,#fff3 50%,#ffffff1f 0,#ffffff1f);border-color:#ffffff4d;box-shadow:0 4px 0 #00000026,0 6px 12px #0003;color:#fff;text-shadow:0 1px 2px #0000004d}.exit-btn:hover{box-shadow:0 6px 0 #00000026,0 8px 16px #00000040;transform:translateY(-2px)}.exit-btn:active{box-shadow:0 2px 0 #00000026,0 4px 8px #0003;transform:translateY(2px)}.tower-intro-overlay{align-items:center;animation:introFade 2.5s ease forwards;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:150}@keyframes introFade{0%{opacity:1}80%{opacity:1}to{opacity:0;pointer-events:none}}.intro-text{animation:introTextPop .5s ease;background:linear-gradient(180deg,#4ecdc433,#4ecdc41a);border:3px solid #4ecdc466;border-radius:20px;box-shadow:0 8px 0 #00000026,0 12px 40px #0000004d;color:#fff;padding:32px 48px;text-align:center}.intro-text h2{color:#4ecdc4;font-size:36px;font-weight:800;margin:0 0 16px;text-shadow:0 4px 8px #00000080}.intro-text p{color:#ffffffe6;font-size:16px;margin:8px 0;text-shadow:0 1px 2px #0000004d}.intro-warning{background:#e74c3c33;border:1px solid #e74c3c4d;border-radius:8px;color:#e74c3c!important;display:inline-block;font-weight:700;margin-top:16px!important;padding:8px 16px}@keyframes introTextPop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media (max-width:400px){.tower-window{height:42px;width:42px}.window-letter{font-size:18px}.tower-floor{padding:3px 8px}.tower-floor,.tower-structure{min-width:260px}.tower-foundation{width:260px}.tower-ground{width:340px}.hud-item{padding:6px 10px}.hud-value{font-size:18px}.stability-segment{height:5px;width:12px}.tower-wrapper{bottom:200px;max-height:calc(100vh - 280px)}.floor-label{font-size:9px;left:-35px;padding:2px 4px}.tower-keyboard-wrapper .keyboard-button{font-size:14px;height:44px}.tower-enter-btn{font-size:16px;height:44px}.roof-peak{border-bottom-width:32px;border-left-width:133px;border-right-width:133px}.roof-peak:after{height:6px;left:-127px;right:-127px}.water-layer{bottom:150px}}.building-cottage,.building-cottage .tower-floor,.building-cottage .tower-structure{min-width:200px}.building-cottage .tower-foundation{width:200px}.building-cottage .tower-ground{width:280px}.building-cottage .roof-peak{border-left-width:106px;border-right-width:106px}.building-cottage .roof-peak:after{left:-100px;right:-100px}.floor-cottage{background:linear-gradient(90deg,#8b7355,#a08060 5%,#b8956a 50%,#a08060 95%,#8b7355);border-left:6px solid #6b5344;border-right:6px solid #6b5344;justify-content:center}.floor-cottage.current-floor{background:linear-gradient(90deg,#9b8365,#b09070 5%,#c8a57a 50%,#b09070 95%,#9b8365);border-left-color:#4ecdc4;border-right-color:#4ecdc4}.window-cottage{background:linear-gradient(135deg,#1a2530,#0d1520);border:3px solid #5b4334;border-radius:6px 6px 0 0}.window-cottage:before{background:linear-gradient(135deg,#fff6,#0000)}.roof-cottage .roof-peak{border-bottom:50px solid #8b4513;border-left:156px solid #0000;border-right:156px solid #0000;filter:drop-shadow(0 -2px 4px rgba(0,0,0,.3))}.roof-cottage .roof-peak:after{background:linear-gradient(180deg,sienna,#8b4513);bottom:-50px;content:"";height:10px;left:-150px;position:absolute;right:-150px}.roof-chimney{background:linear-gradient(90deg,#8b4513,sienna 50%,#8b4513);border:2px solid #6b3310;border-radius:2px 2px 0 0;bottom:20px;height:35px;position:absolute;right:-60px;width:24px;z-index:1}.chimney-smoke{animation:smokeRise 2s ease-out infinite;background:#c8c8c899;border-radius:50%;height:12px;left:50%;position:absolute;top:-15px;transform:translateX(-50%);width:12px}@keyframes smokeRise{0%{opacity:.6;transform:translateX(-50%) translateY(0) scale(1)}to{opacity:0;transform:translateX(-50%) translateY(-30px) scale(2)}}.foundation-cottage{background:linear-gradient(180deg,#6b5344,#5b4334 50%,#4b3324);border-left:6px solid #4b3324;border-right:6px solid #4b3324}.foundation-cottage .foundation-door{background:linear-gradient(180deg,#5b4334,#4b3324);border:3px solid #3b2314;border-radius:8px 8px 0 0}.ground-cottage{background:linear-gradient(180deg,#228b22,#1a7a1a);border-top:4px solid #32cd32}.foundation-windows{bottom:15px;display:flex;gap:80px;left:50%;position:absolute;transform:translateX(-50%)}.foundation-window{background:linear-gradient(135deg,#87ceeb,#5ba3d9)!important;border:2px solid #fff!important;border-radius:3px;height:35px;width:30px}.foundation-body,.foundation-door,.foundation-window,.tower-foundation,.tower-foundation *{color:inherit}.building-brick,.building-brick .tower-floor,.building-brick .tower-structure{min-width:270px}.building-brick .tower-foundation{width:270px}.building-brick .tower-ground{width:350px}.building-brick .roof-peak{border-left-width:141px;border-right-width:141px}.building-brick .roof-peak:after{left:-135px;right:-135px}.floor-brick{background:repeating-linear-gradient(90deg,#c4a484,#c4a484 48px,#a68b6a 0,#a68b6a 50px),linear-gradient(180deg,#d4b494,#c4a484 50%,#b49474);background-blend-mode:overlay;border-left:6px solid #8b7355;border-right:6px solid #8b7355;justify-content:center}.floor-brick.current-floor{background:repeating-linear-gradient(90deg,#d4b494,#d4b494 48px,#b69b7a 0,#b69b7a 50px),linear-gradient(180deg,#e4c4a4,#d4b494 50%,#c4a484);background-blend-mode:overlay;border-left-color:#4ecdc4;border-right-color:#4ecdc4}.window-brick{background:linear-gradient(135deg,#1a2530,#0d1520);border:4px solid #ddd;border-radius:2px;box-shadow:0 3px 0 #0003}.window-brick:before{background:linear-gradient(135deg,#ffffff4d,#0000)}.roof-brick .roof-peak{border-bottom:35px solid #4a4a4a;border-left:175px solid #0000;border-right:175px solid #0000;filter:drop-shadow(0 -2px 4px rgba(0,0,0,.4))}.roof-brick .roof-peak:after{background:linear-gradient(180deg,#5a5a5a,#3a3a3a);bottom:-35px;content:"";height:6px;left:-169px;position:absolute;right:-169px}.foundation-brick{background:linear-gradient(180deg,#a68b6a,#8b7355 50%,#6b5344);border-left:6px solid #6b5344;border-right:6px solid #6b5344}.foundation-brick .foundation-door{background:linear-gradient(180deg,#2a2a2a,#1a1a1a);border:3px solid #4a4a4a;border-radius:4px 4px 0 0;height:58px;width:55px}.foundation-brick .foundation-windows{gap:140px}.foundation-brick .foundation-window{background:linear-gradient(135deg,#ffdc64cc,#ffc83299);border:3px solid #ddd;height:40px;width:35px}.ground-brick{background:linear-gradient(180deg,#4a4a4a,#3a3a3a);border-top:4px solid #5a5a5a}.building-skyscraper,.building-skyscraper .tower-floor,.building-skyscraper .tower-structure{min-width:320px}.building-skyscraper .tower-foundation{width:320px}.building-skyscraper .tower-ground{width:400px}.building-skyscraper .roof-peak{border-left-width:166px;border-right-width:166px}.building-skyscraper .roof-peak:after{left:-160px;right:-160px}.floor-skyscraper{background:linear-gradient(90deg,#4a6080,#5a7090 5%,#6a80a0 50%,#5a7090 95%,#4a6080);border-left:8px solid #3a5070;border-right:8px solid #3a5070;justify-content:center}.floor-skyscraper.current-floor{background:linear-gradient(90deg,#5a7090,#6a80a0 5%,#7a90b0 50%,#6a80a0 95%,#5a7090);border-left-color:#4ecdc4;border-right-color:#4ecdc4}.window-skyscraper{background:linear-gradient(180deg,#87ceebe6,#5ba3d9cc 50%,#4ecdc499);border:2px solid #fffc;border-radius:2px;box-shadow:0 0 10px #4ecdc44d,inset 0 0 20px #fff3;height:52px;width:52px}.window-skyscraper:before{background:linear-gradient(135deg,#fff9,#0000 50%);height:10px;width:15px}.window-skyscraper:after{background:linear-gradient(135deg,#ffffff4d,#0000 30%,#0000 70%,#ffffff1a);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.roof-skyscraper .roof-peak{border-bottom:25px solid #3a5070;border-left:185px solid #0000;border-right:185px solid #0000;filter:drop-shadow(0 -2px 4px rgba(0,0,0,.4))}.roof-skyscraper .roof-peak:after{background:linear-gradient(180deg,#4a6080,#3a5070);bottom:-25px;content:"";height:5px;left:-180px;position:absolute;right:-180px}.roof-skyscraper:before{background:linear-gradient(180deg,#aaa,#888);border-radius:2px;height:40px;top:-60px;width:4px}.roof-skyscraper:after,.roof-skyscraper:before{content:"";left:50%;position:absolute;transform:translateX(-50%)}.roof-skyscraper:after{animation:antennaLight 1.5s ease-in-out infinite;background:#f33;border-radius:50%;box-shadow:0 0 10px #f33,0 0 20px #f33;height:8px;top:-65px;width:8px}@keyframes antennaLight{0%,to{opacity:1}50%{opacity:.3}}.foundation-skyscraper{background:linear-gradient(180deg,#3a5070,#2a4060 50%,#1a3050);border-left:8px solid #1a3050;border-right:8px solid #1a3050;min-height:70px}.foundation-skyscraper .foundation-body{background:linear-gradient(180deg,#3a5070,#2a4060);height:25px}.foundation-skyscraper .foundation-door{background:linear-gradient(180deg,#87ceeb99,#5ba3d980);border:3px solid #fff9;border-radius:2px 2px 0 0;height:60px;width:70px}.foundation-skyscraper .foundation-windows{bottom:20px;gap:180px}.foundation-skyscraper .foundation-window{background:linear-gradient(180deg,#87ceebcc,#5ba3d9b3);border:2px solid #fff9;height:45px;width:40px}.ground-skyscraper{background:linear-gradient(180deg,#4a4a4a,#3a3a3a);border-top:4px solid #5a5a5a}.island-container,.island-mound{align-items:center;display:flex;flex-direction:column;position:relative}.island-mound{width:100%}.island-base{background:linear-gradient(180deg,#deb887,#d2a679 30%,#c4956a 60%,#b8845c)!important;border-radius:0 0 170px 170px/0 0 45px 45px;height:45px;margin-top:-8px;position:relative;width:340px;z-index:1}.island-base,.island-container,.island-container *,.island-mound,.island-palm,.island-rock,.island-rocks{color:inherit}.island-base:before{background:radial-gradient(circle at 20% 30%,#ffffff4d 0,#0000 8%),radial-gradient(circle at 60% 50%,#fff3 0,#0000 6%),radial-gradient(circle at 80% 20%,#ffffff40 0,#0000 7%),radial-gradient(circle at 40% 70%,#ffffff26 0,#0000 5%);border-radius:inherit;bottom:0;content:"";left:0;position:absolute;right:0;top:0}.island-rocks{bottom:8px;display:flex;gap:8px;left:25px;position:absolute}.island-rock{background:linear-gradient(180deg,#8b8878,#6b6858);border-radius:50% 50% 45% 45%;height:10px;width:12px}.island-rock:nth-child(2){height:7px;margin-top:3px;width:8px}.island-palm{bottom:35px;position:absolute;right:30px;z-index:2}.palm-trunk{background:linear-gradient(90deg,#8b6914,#a67c00 50%,#8b6914);border-radius:4px;height:35px;transform:rotate(5deg);transform-origin:bottom center;width:8px}.palm-leaves{left:50%;position:absolute;top:-20px;transform:translateX(-50%)}.palm-leaf{background:linear-gradient(90deg,#228b22,#32cd32 50%,#228b22);border-radius:50% 50% 0 0/100% 100% 0 0;height:12px;position:absolute;transform-origin:bottom center;width:30px}.palm-leaf:first-child{transform:rotate(-60deg) translateY(-5px)}.palm-leaf:nth-child(2){transform:rotate(-30deg) translateY(-5px)}.palm-leaf:nth-child(3){transform:rotate(0deg) translateY(-8px)}.palm-leaf:nth-child(4){transform:rotate(30deg) translateY(-5px)}.palm-leaf:nth-child(5){transform:rotate(60deg) translateY(-5px)}.water-layer{bottom:170px;height:calc(100vh - 270px);left:0;overflow:visible;pointer-events:none;position:absolute;right:0;z-index:5}.water-layer .water-body{background:linear-gradient(180deg,#1e90ffb3,#0077becc 30%,#00508ce6);bottom:0;left:0;min-height:0;position:absolute;right:0;transition:height 1s ease}.water-layer:before{background:linear-gradient(180deg,#00508ce6,#003c78f2);bottom:0;content:"";height:50px;left:0;position:absolute;right:0}.water-container{display:none}.water-body{background:linear-gradient(180deg,#1e90ffb3,#0077becc 30%,#00508ce6);bottom:0;height:50px;transition:height 1s ease}.water-body,.water-body:before{left:0;position:absolute;right:0}.water-body:before{background:linear-gradient(180deg,#fff6,#87cefa4d);content:"";height:8px;top:0}.water-waves{height:20px;left:-20px;overflow:hidden;position:absolute;right:-20px;top:-10px}.wave{animation:waveMove 3s linear infinite;background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120'%3E%3Cpath fill='rgba(30, 144, 255, 0.6)' d='M0 60c150 60 350-60 600 0s450-60 600 0v60H0Z'/%3E%3C/svg%3E");background-size:600px 20px;height:100%;position:absolute;width:200%}.wave:nth-child(2){animation-delay:-1.5s;animation-duration:4s;opacity:.5;top:3px}.wave:nth-child(3){animation-delay:-2s;animation-duration:5s;opacity:.3;top:6px}@keyframes waveMove{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.water-body.rising{animation:waterPulse 2s ease-in-out infinite}@keyframes waterPulse{0%,to{background:linear-gradient(180deg,#1e90ffb3,#0077becc 30%,#00508ce6)}50%{background:linear-gradient(180deg,#46aaffcc,#1e90ffd9 30%,#0064b4f2)}}.water-body.danger{animation:waterDanger .8s ease-in-out infinite}@keyframes waterDanger{0%,to{background:linear-gradient(180deg,#dc5050b3,#b43232cc 30%,#8c1e1ee6)}50%{background:linear-gradient(180deg,#ff6464cc,#dc4646d9 30%,#b43232f2)}}.hud-water{min-width:80px}.water-level-bar{background:#0000004d;border:2px solid #ffffff4d;border-radius:4px;height:24px;overflow:hidden;position:relative;width:60px}.water-level-fill{background:linear-gradient(180deg,#4ecdc4,#2ea39d);bottom:0;left:0;position:absolute;right:0;transition:height .5s ease}.water-level-fill.warning{background:linear-gradient(180deg,#f0c419,#d4a817)}.water-level-fill.danger{animation:dangerPulse .5s ease-in-out infinite;background:linear-gradient(180deg,#e74c3c,#c0392b)}@keyframes dangerPulse{0%,to{opacity:1}50%{opacity:.7}}.building-cottage .island-base{width:340px}.building-brick .island-base{width:420px}.building-skyscraper .island-base{width:480px}.building-cottage .water-container{width:500px}.building-brick .water-container{width:600px}.building-skyscraper .water-container{width:680px}.water-flood{animation:waterFlood 2s ease-in forwards}@keyframes waterFlood{0%{height:50px;height:var(--current-height,50px)}to{height:500px}}