:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}*{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}input,textarea{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.toast-container{position:fixed;bottom:150px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column-reverse;gap:10px;pointer-events:none}.toast{padding:12px 25px;border-radius:8px;color:#fff;font-weight:600;box-shadow:0 5px 15px #0000004d;animation:slideUpToast .3s ease-out;pointer-events:auto;min-width:200px}@keyframes slideUpToast{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.toast-error{background-color:#e74c3c;border-left:5px solid #c0392b}.toast-success{background-color:#27ae60;border-left:5px solid #1e8449}.toast-info{background-color:#2980b9;border-left:5px solid #1f618d}#root{max-width:1400px;margin:0 auto;padding:1rem;text-align:center}.game-container{display:flex;flex-direction:column;align-items:center;gap:15px;font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif;background-color:#2c3e50;padding:20px;border-radius:12px;color:#fff;box-shadow:0 10px 30px #00000080;min-height:90vh}.header{display:flex;justify-content:space-between;width:100%;max-width:1200px;align-items:center;margin-bottom:5px;flex-wrap:wrap;gap:15px}.game-header{padding:10px}.header-left,.header-right{display:flex;align-items:center;gap:10px}.resign-btn{padding:5px 10px!important;font-weight:700}@media(max-width:1000px){.header-left h1{font-size:1.2rem}.game-header{justify-content:space-around}}.score-container{display:flex;gap:15px}.layout-content{display:flex;gap:30px;align-items:flex-start;justify-content:center;width:100%;padding-top:10px}.game-column{display:flex;flex-direction:column;align-items:center;gap:20px}.chat-column{display:flex;flex-direction:column}.board-wrapper{display:flex;justify-content:center;align-items:center;overflow:auto;padding:10px;width:100%}.board-wrapper .board{transform:scale(var(--board-zoom, 1));transform-origin:center top;margin-bottom:calc((var(--board-zoom, 1) - 1) * 600px);transition:transform .2s ease-out}.board{display:flex;flex-direction:column;background-color:#1a252f;padding:8px;border:6px solid #141a21;border-radius:8px;box-shadow:0 5px 15px #0000004d}.board-row{display:flex}.square{width:40px;height:40px;border:1px solid #141a21;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;text-transform:uppercase;position:relative;transition:all .2s ease;background-color:#414141}.chat-container{width:280px;height:630px;background-color:#1a1a1a;border:1px solid #333;border-radius:12px;display:flex;flex-direction:column;padding:15px;margin-top:70px;box-shadow:0 5px 25px #0006}.chat-container h3{margin-top:0;margin-bottom:15px;font-size:1.1rem;color:#f1c40f;font-weight:900;border-bottom:1px solid #333;padding-bottom:8px;text-align:left}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;margin-bottom:15px;text-align:left;font-size:.9rem;background-color:#121212;padding:12px;border-radius:8px;border:1px solid #262626}.chat-msg{padding:10px 14px;border-radius:15px;word-break:break-word;max-width:80%;line-height:1.4;font-size:.85rem}.msg-own{align-self:flex-end;background-color:#27ae60;color:#fff;border-bottom-right-radius:2px}.msg-other{align-self:flex-start;background-color:#333;color:#ecf0f1;border-bottom-left-radius:2px}.chat-input-area{display:flex;gap:8px}.chat-input-area input{flex:1;padding:10px;border-radius:8px;border:1px solid #444;background:#1a1a1a;color:#fff;outline:none;font-size:.9rem}.square:hover:not(:has(.tile)){filter:brightness(1.2);cursor:crosshair}.bonus-label{pointer-events:none;opacity:.9;color:#fff}.square.pending .tile{transform:scale(1.05)}.square.pending.valid .tile,.square.word-part.valid .tile{outline:3px solid #2ecc71;box-shadow:0 0 15px #2ecc7199}.square.pending.invalid .tile,.square.word-part.invalid .tile{outline:3px solid #e74c3c;box-shadow:0 0 15px #e74c3c99}.bonus-TW{background-color:#1d3!important;color:#fff}.bonus-DW{background-color:#799b00!important;color:#fff}.bonus-TL{background-color:#08f!important;color:#fff}.bonus-DL{background-color:#be7d32!important;color:#fff}.bonus-none{background-color:#414141}.tile{width:36px;height:36px;background-color:#c8c8e6;border:1px solid #bdc3c7;border-radius:4px;display:flex;align-items:center;justify-content:center;position:relative;cursor:grab;color:#000;box-shadow:2px 2px 4px #0000004d;transition:transform .15s cubic-bezier(.175,.885,.32,1.275)}.tile.selected{background:linear-gradient(145deg,#d35400,#e67e22);border:2px solid white;transform:translateY(-8px);color:#fff}.tile.joker{background-color:#c8c819;border:1px dashed #7f8c8d}.square .tile.joker{background-color:#c8c819}.tile .letter{font-size:20px;font-weight:800}.tile .points{position:absolute;bottom:1px;right:2px;font-size:8px;font-weight:700}.rack-container{background:linear-gradient(to bottom,#1a252f,#141a21);padding:15px;border-radius:12px;border:4px solid #141a21;width:fit-content;box-shadow:0 4px 10px #0000004d}.rack{display:flex;gap:10px;min-width:350px;min-height:40px;justify-content:center}.message-area{height:40px;margin-bottom:10px;padding:0 20px;border-radius:20px;font-weight:600;display:flex;align-items:center;justify-content:center;min-width:400px}.message-error{background-color:#e74c3c;color:#fff}.message-success{background-color:#27ae60;color:#fff}.message-info{background-color:#ffffff0d;color:#bdc3c7}.score-badge{background:linear-gradient(135deg,#1abc9c,#16a085);padding:8px 20px;border-radius:20px;font-weight:800;opacity:.6;transition:all .3s ease}.score-badge.active{opacity:1;box-shadow:0 0 15px #1abc9c99;transform:scale(1.05)}.own-score{border:2px solid #f1c40f}.own-score.active{box-shadow:0 0 15px #f1c40f99}.controls{display:flex;flex-direction:column;align-items:center;gap:10px}.button-group{display:flex;gap:12px}button{padding:10px 20px;font-size:15px;font-weight:700;cursor:pointer;background-color:#27ae60;color:#fff;border:none;border-radius:6px;transition:all .2s;box-shadow:0 4px #1e8449;text-transform:uppercase}button:hover:not(:disabled){background-color:#2ecc71;transform:translateY(-2px);box-shadow:0 6px #1e8449}button.secondary:hover:not(:disabled){background-color:#3498db;box-shadow:0 6px #1f618d}button.danger:hover:not(:disabled){background-color:#e74c3c;box-shadow:0 6px #962d22}button:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #1e8449}button.secondary:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #1f618d}button.danger:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #962d22}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background-color:#2980b9;box-shadow:0 4px #1f618d}button.danger{background-color:#c0392b;box-shadow:0 4px #962d22}.login-container{min-height:500px;justify-content:center}.login-box{display:flex;flex-direction:column;gap:15px;background:#ffffff0d;padding:30px 50px;border-radius:15px;border:1px solid rgba(255,255,255,.1);width:350px}.login-box h2{margin-top:0;color:#f1c40f}.login-box input{padding:12px;font-size:1rem;border-radius:6px;border:1px solid #1a252f;background:#34495e;color:#fff;outline:none}.password-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.password-input-wrapper input{width:100%}.toggle-password{position:absolute;right:10px;background:none!important;border:none!important;box-shadow:none!important;padding:0!important;cursor:pointer;font-size:1.2rem;margin:0!important;transform:none!important}.lobby-container{width:100%;max-width:1000px;display:flex;flex-direction:column;gap:20px}.lobby-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.lobby-section{background:#ffffff0d;padding:20px;border-radius:12px;border:1px solid rgba(255,255,255,.1);text-align:left}.lobby-section.full-width{grid-column:1 / -1}.lobby-section h3{margin-top:0;color:#f1c40f;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:10px}.search-box{display:flex;gap:10px}.search-box input{flex:1;padding:10px;border-radius:6px;border:none;background:#34495e;color:#fff}.search-results,.invitations-list,.games-list{margin-top:15px;display:flex;flex-direction:column;gap:10px}.search-item,.invite-item,.game-item{display:flex;justify-content:space-between;align-items:center;background:#ffffff08;padding:10px 15px;border-radius:8px;gap:20px}.game-info{display:flex;flex-direction:column}.game-info small{color:#bdc3c7;font-size:.8rem}.game-score{font-size:.9rem;color:#f1c40f;margin:2px 0}.your-turn{color:#2ecc71!important;font-weight:700}.empty-info{color:#7f8c8d;font-style:italic;text-align:center}.user-info{display:flex;align-items:center;gap:15px}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:10000}.joker-modal{background:#2c3e50;padding:30px;border-radius:15px;border:4px solid #f1c40f;max-width:500px;text-align:center;box-shadow:0 10px 40px #00000080}.letter-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin:20px 0}.letter-grid .tile:hover{transform:scale(1.1);background:#f39c12}.square.hint{background-color:#f1c40f!important;box-shadow:inset 0 0 15px #d4ac0d,0 0 20px #f1c40fcc;animation:pulse-hint 1.5s infinite;z-index:5}@keyframes pulse-hint{0%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.7}to{transform:scale(1);opacity:1}}.mobile-chat-toggle{display:none;background-color:#3498db;padding:8px 15px;font-size:14px}@media(max-width:1000px){.game-container{padding:10px;gap:10px}.layout-content{flex-direction:column;align-items:center;gap:15px}.game-column{width:100%;overflow-x:hidden}.board-wrapper{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:10px 0;display:flex;justify-content:flex-start}.board{padding:5px;border-width:4px;min-width:520px}.square{width:32px;height:32px;font-size:8px}.tile{width:30px;height:30px}.tile .letter{font-size:16px}.tile .points{font-size:6px;bottom:1px;right:2px}.rack-container{width:100%;padding:10px 5px;margin-top:5px;overflow-x:auto}.rack{min-width:100%;gap:8px;padding:5px}.button-group{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;padding:0 10px}.button-group button{padding:12px 10px;font-size:13px;height:50px}.message-area{min-width:90%;font-size:.9rem;height:auto;padding:8px 15px;margin-bottom:5px}.mobile-chat-toggle{display:block}.chat-column.mobile-hidden,.game-column.mobile-hidden{display:none}.chat-container{width:100%;margin-top:10px;height:450px}}h1{margin:0;font-size:2.2rem;font-weight:900;background:linear-gradient(to right,#f1c40f,#e67e22);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.chat-toggle-label{display:flex;align-items:center;gap:12px;font-size:.95rem;font-weight:600;color:#ecf0f1;cursor:pointer;padding:5px 10px;border-radius:20px;transition:background .2s;-webkit-user-select:none;user-select:none}.chat-toggle-label:hover{background:#ffffff0d}.chat-toggle-label input{appearance:none;width:34px;height:18px;background:#34495e;border-radius:20px;position:relative;cursor:pointer;transition:background .3s;border:1px solid rgba(255,255,255,.1)}.chat-toggle-label input:checked{background:#27ae60}.chat-toggle-label input:before{content:"";position:absolute;width:14px;height:14px;background:#fff;border-radius:50%;top:1px;left:2px;transition:transform .3s;box-shadow:0 1px 3px #0006}.chat-toggle-label input:checked:before{transform:translate(16px)}.unread-badge{background-color:#e74c3c;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:10px;margin-left:5px;font-weight:700;box-shadow:0 2px 4px #0000004d}.stats-badge{background:#0000004d;padding:5px 12px;border-radius:15px;font-size:.85rem;font-weight:600;color:#f1c40f;border:1px solid rgba(241,196,15,.3);display:inline-block;margin-left:15px}.mobile-game-wrapper,.mobile-lobby-wrapper,.mobile-chat-overlay{display:flex;flex-direction:column;height:100vh;width:100vw;background-color:#1a1a1a;color:#fff;overflow-x:hidden;overflow-y:hidden;position:fixed;top:0;left:0;padding-top:env(safe-area-inset-top)}.mobile-game-wrapper *,.mobile-lobby-wrapper *,.mobile-chat-overlay *{box-sizing:border-box}.mobile-game-wrapper button,.mobile-lobby-wrapper button,.mobile-chat-overlay button{box-shadow:none!important;transform:none!important}.mobile-title-bar{height:88px;background-color:#1a1a1a;display:flex;align-items:center;justify-content:center;position:relative;border-bottom:1px solid #333;box-sizing:border-box}.mobile-title-text{font-size:1.1rem;font-weight:900;letter-spacing:3px;color:#f1c40f;text-transform:uppercase}.mobile-back-btn{position:absolute;left:5px;top:0;height:88px;width:60px;background:none!important;border:none!important;box-shadow:none!important;color:#f1c40f;font-size:2.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10}.mobile-header{height:45px;background-color:#1a1a1a;display:flex;justify-content:space-between;align-items:center;padding:0 10px;border-bottom:1px solid #262626;z-index:10;flex-shrink:0}.mobile-header h1{font-size:1.1rem;margin:0}.mobile-scores{display:flex;gap:6px}.mobile-score-pill{background:#262626;padding:2px 8px;border-radius:8px;font-size:.75rem;font-weight:700;border:1px solid #333}.mobile-score-pill.active{border-color:#f1c40f;background:#3d3300}.mobile-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;background-color:#121212;overflow-y:auto;overflow-x:hidden;position:relative}.mobile-status-bar{width:100%;padding:6px 0;text-align:center;font-size:.8rem;font-weight:700;text-transform:uppercase;flex-shrink:0}.status-my-turn{background-color:#27ae60;color:#fff}.status-opp-turn{background-color:#2980b9;color:#fff}.mobile-board-container{width:100vw;height:auto;display:block;padding:0;box-sizing:border-box;overflow:auto;-webkit-overflow-scrolling:touch;position:relative}.mobile-header-zoom{display:flex;align-items:center;background-color:#262626;border:1px solid #444;border-radius:12px;padding:1px 4px;gap:2px}.mobile-header-zoom .zoom-btn{background:none!important;border:none!important;color:#fff!important;font-size:.95rem!important;padding:2px 6px!important;cursor:pointer;box-shadow:none!important;transform:none!important}.mobile-header-zoom .zoom-label{font-size:.65rem;font-weight:700;color:#f1c40f;min-width:30px;text-align:center}.mobile-controls-area{width:100%;background-color:#1a1a1a;padding:15px 10px;box-sizing:border-box;border-top:1px solid #333;border-bottom:1px solid #333;margin-top:10px}.mobile-button-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px}.mobile-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:6px 2px!important;height:64px!important;font-size:.65rem!important;font-weight:700!important;text-transform:none!important;border-radius:8px!important;gap:4px;box-shadow:none!important;transform:none!important;border:none!important;color:#fff!important}.mobile-action-btn.primary{background-color:#27ae60!important}.mobile-action-btn.secondary{background-color:#2980b9!important}.mobile-action-btn.danger{background-color:#e74c3c!important}.mobile-action-btn:not(.primary):not(.secondary):not(.danger){background-color:#333!important}.mobile-btn-icon{font-size:1.55rem;line-height:1}.mobile-btn-label{font-size:.65rem;font-weight:700}.mobile-rack-area{width:100%;background-color:#262626;padding:15px 0 calc(55px + env(safe-area-inset-bottom)) 0;display:flex;justify-content:center;align-items:center;border-top:1px solid #444}.mobile-rack-wrapper{display:flex;justify-content:center;width:100%}.mobile-game-wrapper .board{min-width:unset;width:calc(100vw * var(--board-zoom, 1));margin:0 auto;padding:0;border-width:1px;border-color:#333}.mobile-game-wrapper .square{width:calc((100vw * var(--board-zoom, 1)) / 15);height:calc((100vw * var(--board-zoom, 1)) / 15);font-size:calc(6px * var(--board-zoom, 1))}.mobile-game-wrapper .tile{width:95%;height:90%;border-radius:2px}.mobile-game-wrapper .tile .letter{font-size:calc(12px * var(--board-zoom, 1))}.mobile-game-wrapper .tile .points{font-size:calc(4px * var(--board-zoom, 1))}.mobile-rack-area .tile{width:42px!important;height:42px!important;font-size:1.2rem}.mobile-rack-area .tile .letter{font-size:22px!important}.mobile-rack-area .tile .points{font-size:8px!important;bottom:2px;right:3px}.mobile-rack-area .rack{min-width:320px;height:50px;display:flex;gap:8px;justify-content:center;align-items:center}.mobile-fab-chat{position:absolute;right:15px;bottom:180px;width:50px;height:50px;border-radius:25px;background-color:#f39c12;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 10px #0000004d;z-index:5;font-size:1.5rem}.mobile-chat-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#1a1a1a;z-index:1000;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-chat-header{padding:15px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #333}.mobile-chat-messages{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:10px}.mobile-chat-input-area{padding:15px calc(15px + env(safe-area-inset-bottom)) 20px 15px;display:flex;gap:10px;background-color:#262626;border-top:1px solid #333}.mobile-chat-input-area input{flex:1;background:#333;border:1px solid #444;padding:12px;border-radius:8px;color:#fff;font-size:1rem}.mobile-chat-overlay{z-index:2000;animation:mobileChatSlideUp .3s ease-out}@keyframes mobileChatSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-chat-header{padding:15px;display:flex;justify-content:space-between;align-items:center;background-color:#262626;border-bottom:1px solid #333}.mobile-chat-header h3{margin:0;font-size:1rem;color:#f1c40f}.mobile-chat-messages{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:12px;background-color:#121212}.mobile-chat-msg{padding:10px 14px;border-radius:15px;max-width:80%;font-size:.9rem;line-height:1.4;word-wrap:break-word}.mobile-msg-own{align-self:flex-end;background-color:#27ae60;color:#fff;border-bottom-right-radius:2px}.mobile-msg-other{align-self:flex-start;background-color:#333;color:#ecf0f1;border-bottom-left-radius:2px}.mobile-chat-input-area{padding:12px 15px calc(12px + env(safe-area-inset-bottom)) 15px;display:flex;gap:10px;background-color:#262626;border-top:1px solid #333}.mobile-chat-input-area input{flex:1;background:#1a1a1a;border:1px solid #444;padding:12px;border-radius:10px;color:#fff;font-size:1rem;outline:none}.mobile-chat-close-btn{background:none;border:none;color:#e74c3c;font-weight:700;font-size:.9rem;padding:5px 10px}.mobile-lobby-wrapper{display:flex;flex-direction:column;height:100vh;width:100vw;background-color:#121212;color:#fff;overflow:hidden;position:fixed;top:0;left:0}.mobile-lobby-content{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:20px;padding-bottom:calc(30px + env(safe-area-inset-bottom))}.mobile-lobby-section{background-color:#1a1a1a;border-radius:12px;border:1px solid #333;padding:15px}.mobile-lobby-section h3{margin:0 0 12px;font-size:.9rem;color:#f1c40f;text-transform:uppercase;letter-spacing:1px}.mobile-list-item{display:flex;justify-content:space-between;align-items:center;background-color:#262626;padding:12px;border-radius:8px;margin-bottom:8px}.mobile-game-card{background:linear-gradient(145deg,#262626,#1e1e1e);border-left:4px solid #333}.mobile-game-card.my-turn{border-left-color:#27ae60;background:linear-gradient(145deg,#1e2e24,#1a1a1a)}.mobile-item-info{display:flex;flex-direction:column;gap:2px}.mobile-item-title{font-weight:700;font-size:1rem}.mobile-item-subtitle{font-size:.75rem;color:#888}.mobile-item-score{font-size:.85rem;color:#f1c40f;font-weight:700}.mobile-lobby-btn{padding:8px 12px;border-radius:6px;font-weight:700;font-size:.8rem;border:none;background-color:#333;color:#fff}.mobile-lobby-btn.primary{background-color:#27ae60}.mobile-lobby-btn.secondary{background-color:#2980b9}.mobile-lobby-btn.danger{background-color:#c0392b}.mobile-search-box{display:flex;gap:8px;margin-bottom:10px}.mobile-search-box input{flex:1;background:#262626;border:1px solid #444;padding:10px;border-radius:8px;color:#fff;font-size:.95rem}.mobile-user-bar{padding:10px 15px;background-color:#1a1a1a;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #333;flex-shrink:0}.mobile-user-bar.centered{justify-content:center;text-align:center}.mobile-user-bar.centered .mobile-item-info{align-items:center}.mobile-user-name{font-weight:900;font-size:1.1rem}.mobile-user-stats{font-size:.7rem;color:#f1c40f;opacity:.8}
