:root{--font-family: "Fredoka", sans-serif;--color-bg-gradient: linear-gradient(135deg, #f5f7fa 0%, #e4e8f0 100%);--color-primary: #6c5ce7;--color-primary-hover: #5b4bc4;--color-primary-light: #ece9fc;--color-secondary: #fd79a8;--color-secondary-hover: #e86393;--color-yellow: #feca57;--color-yellow-dark: #e0a82e;--color-green: #1dd1a1;--color-green-dark: #10ac84;--color-blue: #54a0ff;--color-blue-dark: #2e86de;--color-purple: #a55eea;--color-text: #2d3436;--color-text-light: #636e72;--color-white: #ffffff;--color-gray-light: #f1f2f6;--color-gray-medium: #ced6e0;--color-gray-dark: #747d8c;--color-danger: #ff6b6b;--shadow-sm: 0 4px 6px rgba(0, 0, 0, .05);--shadow-md: 0 10px 20px rgba(108, 92, 231, .12);--shadow-lg: 0 20px 40px rgba(0, 0, 0, .12);--shadow-inset: inset 0 2px 4px rgba(0, 0, 0, .06);--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease;--transition-spring: .4s cubic-bezier(.175, .885, .32, 1.275)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);color:var(--color-text);background:var(--color-bg-gradient);height:100vh;height:100dvh;display:flex;flex-direction:column;overflow:hidden;-webkit-font-smoothing:antialiased}#app-container{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;overflow:hidden}.hidden{display:none!important}.control-panel-footer{display:flex;justify-content:center;gap:15px;margin-top:auto}.icon-btn{background:var(--color-white);border:2px solid var(--color-gray-medium);color:var(--color-text-light);width:44px;height:44px;border-radius:12px;display:flex;justify-content:center;align-items:center;cursor:pointer;box-shadow:var(--shadow-sm);transition:var(--transition-spring)}.icon-btn:hover{transform:translateY(-3px);border-color:var(--color-primary);color:var(--color-primary);box-shadow:var(--shadow-md)}.icon-btn:active{transform:translateY(0)}.game-viewport{flex:1;display:flex;justify-content:center;align-items:center;padding:10px;position:relative;width:100%;height:100%;overflow:hidden}.screen-view{display:none;width:100%;max-width:100%;animation:fade-in .4s ease-out forwards}.screen-view.active{display:flex;flex-direction:column;height:100%;width:100%;justify-content:center}#setup-screen{overflow-y:auto;max-height:100%;padding:20px 0;box-sizing:border-box}.primary-btn{background:linear-gradient(135deg,var(--color-primary) 0%,#5b4bc4 100%);color:var(--color-white);font-family:var(--font-family);font-size:20px;font-weight:600;padding:14px 28px;border:none;border-radius:16px;cursor:pointer;box-shadow:0 6px 12px #6c5ce74d;transition:var(--transition-spring);border-bottom:4px solid #4a3ab0}.primary-btn:hover{transform:translateY(-4px);box-shadow:0 10px 20px #6c5ce766}.primary-btn:active{transform:translateY(-1px);border-bottom-width:2px}.primary-btn.disabled,.primary-btn:disabled{background:var(--color-gray-medium)!important;border-bottom-color:var(--color-gray-dark)!important;color:var(--color-gray-dark);cursor:not-allowed;transform:none!important;box-shadow:none!important}.secondary-btn{background:var(--color-white);border:2px solid var(--color-gray-medium);color:var(--color-text-light);font-family:var(--font-family);font-size:16px;font-weight:600;padding:10px 20px;border-radius:12px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:var(--transition-fast)}.secondary-btn:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.secondary-btn:disabled{opacity:.5;cursor:not-allowed}.welcome-card{background:var(--color-white);border-radius:28px;padding:40px;box-shadow:var(--shadow-lg);text-align:center;border:4px solid var(--color-primary-light);max-width:1200px;margin:auto;width:90%}.title-bounce{font-size:42px;font-weight:800;color:var(--color-primary);margin-bottom:10px}.subtitle{font-size:18px;color:var(--color-text-light);margin-bottom:30px}.section-label{font-size:18px;font-weight:600;color:var(--color-text);margin-bottom:12px;display:block}.player-count-picker{margin-bottom:30px}.player-count-options{display:flex;justify-content:center;gap:12px}.count-btn{background:var(--color-gray-light);border:3px solid transparent;color:var(--color-text-light);font-family:var(--font-family);font-size:18px;font-weight:600;padding:12px 24px;border-radius:16px;cursor:pointer;transition:var(--transition-spring)}.count-btn:hover{transform:scale(1.05)}.count-btn.active{background:var(--color-primary-light);color:var(--color-primary);border-color:var(--color-primary);box-shadow:var(--shadow-md)}.player-configs-container{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;margin-bottom:35px;perspective:1000px}.player-config-card{background:var(--color-white);border-radius:20px;width:260px;box-shadow:var(--shadow-sm);border:3px solid var(--color-gray-medium);overflow:hidden;transition:var(--transition-spring);animation:card-appear .4s cubic-bezier(.175,.885,.32,1.275) forwards}.player-config-card:hover{transform:translateY(-8px) rotate(1deg);box-shadow:var(--shadow-md)}.player-config-card.player-theme-1{border-color:var(--color-primary)}.player-config-card.player-theme-2{border-color:var(--color-secondary)}.player-config-card.player-theme-3{border-color:var(--color-green)}.player-config-card.player-theme-4{border-color:var(--color-yellow)}.card-header{padding:12px;text-align:center;font-weight:700;font-size:18px}.player-indicator{padding:4px 12px;border-radius:8px;color:var(--color-white)}.player-indicator.player-1{background-color:var(--color-primary)}.player-indicator.player-2{background-color:var(--color-secondary)}.player-indicator.player-3{background-color:var(--color-green)}.player-indicator.player-4{background-color:var(--color-yellow-dark)}.card-body{padding:20px;display:flex;flex-direction:column;gap:15px}.input-group{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.input-group label{font-weight:600;font-size:15px}.input-group input,.input-group select{width:100%;padding:10px 14px;border-radius:10px;border:2px solid var(--color-gray-medium);font-family:var(--font-family);font-size:15px;outline:none;transition:var(--transition-fast)}.input-group input:focus,.input-group select:focus{border-color:var(--color-primary)}.avatar-select-group{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.avatar-select-group label{font-weight:600;font-size:15px}.avatar-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;width:100%}.avatar-option{border:2px solid var(--color-gray-light);border-radius:12px;padding:8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:var(--transition-fast);background:var(--color-gray-light)}.avatar-option img{width:44px;height:44px;object-fit:cover;border-radius:50%;border:2px solid var(--color-gray-medium);background:var(--color-white)}.avatar-option span{font-size:12px;font-weight:600;color:var(--color-text-light)}.avatar-option:hover{background:var(--color-white);border-color:var(--color-gray-medium)}.avatar-option.active{background:var(--color-white);border-color:var(--color-primary);box-shadow:0 4px 8px #6c5ce726}.avatar-option.active img{border-color:var(--color-primary);animation:avatar-wiggle .5s ease-in-out}.pulse-glow{animation:pulse-shadow 2s infinite}.game-layout{display:flex;gap:20px;width:100%;height:100%;max-height:100%;justify-content:center;align-items:center}.board-panel{flex:2;align-self:stretch;--board-aspect: calc(var(--grid-cols, 10) / var(--grid-rows, 5));background:var(--color-white);border-radius:28px;padding:10px;box-shadow:var(--shadow-lg);border:5px solid rgba(255,255,255,.8);position:relative;overflow:hidden}.board-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-template-rows:repeat(6,minmax(0,1fr));width:100%;height:100%;position:relative;gap:6px;justify-content:center;align-content:center}.board-tile{border-radius:14px;padding:8px;position:relative;box-shadow:var(--shadow-inset);display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;border-bottom:4px solid rgba(0,0,0,.1);transition:transform .2s}.tile-number{font-size:16px;font-weight:700;color:#00000059}.tile-tag{font-size:13px;font-weight:800;padding:5px 10px;border-radius:8px;align-self:flex-end;color:var(--color-white);box-shadow:var(--shadow-sm);text-transform:uppercase;letter-spacing:.8px}.start-tag{background:var(--color-green)}.win-tag{background:linear-gradient(45deg,var(--color-yellow-dark),var(--color-secondary))}.bridge-tag{background:var(--color-purple)}.slide-tag{background:var(--color-blue-dark)}.tile-pink{background:#ffe3e3}.tile-blue{background:#e3fafc}.tile-mint{background:#e3f9e5}.tile-yellow{background:#fff9db}.tile-purple{background:#f3f0ff}.board-svg-overlay,.board-tokens-container{position:absolute;top:0;left:0;width:100%;height:100%;grid-row:1 / -1;grid-column:1 / -1;pointer-events:none;z-index:10}.board-tokens-container{z-index:20}.player-token{position:absolute;width:48px;height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:translate(-50%,-65%);transition:left .35s cubic-bezier(.25,.8,.25,1.3),top .35s cubic-bezier(.25,.8,.25,1.3);z-index:25}.player-token img{width:40px;height:40px;object-fit:cover;border-radius:50%;border:3px solid var(--color-white);background:var(--color-white);box-shadow:0 4px 8px #00000040}.hop-anim{animation:hop-bounce .35s cubic-bezier(.25,.8,.25,1.3)}.player-token-1 img{border-color:var(--color-primary)}.player-token-2 img{border-color:var(--color-secondary)}.player-token-3 img{border-color:var(--color-green)}.player-token-4 img{border-color:var(--color-yellow)}.control-panel{flex:1;max-width:280px;min-width:250px;display:flex;flex-direction:column;gap:35px;align-self:stretch;background:var(--color-white);border-radius:28px;padding:28px 24px;box-shadow:var(--shadow-lg);border:4px solid var(--color-primary-light)}.sidebar-brand{display:flex;align-items:center;gap:10px;color:var(--color-primary);border-bottom:2px dashed var(--color-primary-light);padding-bottom:12px;justify-content:center}.sidebar-brand .logo-text{font-size:34px;font-weight:800;letter-spacing:.5px;background:linear-gradient(45deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.panel-subtitle{font-size:16px;font-weight:700;color:var(--color-text-light);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px;text-align:center}.active-player-card{padding:24px 0 32px;border-bottom:2px dashed var(--color-gray-light)}.active-player-info{display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center}.active-avatar-wrap{background:var(--color-gray-light);border-radius:50%;width:100px;height:100px;display:flex;justify-content:center;align-items:center;border:4px solid var(--color-primary-light);box-shadow:var(--shadow-md);transition:var(--transition-spring)}.active-avatar-wrap:hover{transform:scale(1.05);border-color:var(--color-primary);box-shadow:var(--shadow-lg)}.active-avatar-wrap img{width:100%;height:100%;border-radius:50%;object-fit:cover}.active-details{display:flex;flex-direction:column;align-items:center;gap:6px}.active-details h2{font-size:28px;font-weight:700}.badge{display:inline-block;font-size:12px;font-weight:700;padding:4px 12px;border-radius:8px;margin-top:4px}.badge-kindergarten{background:var(--color-green-dark);color:var(--color-white)}.badge-first{background:var(--color-primary);color:var(--color-white)}.badge-second{background:var(--color-secondary);color:var(--color-white)}.dice-section{padding:8px 0;display:flex;flex-direction:column;align-items:center;gap:24px;margin-top:auto}.dice-wrapper{perspective:600px;width:80px;height:80px;display:flex;justify-content:center;align-items:center}.die{width:60px;height:60px;position:relative;transform-style:preserve-3d;transition:transform .8s cubic-bezier(.19,1,.22,1)}.die-face{position:absolute;width:60px;height:60px;background:var(--color-white);border:3px solid var(--color-gray-medium);border-radius:12px;display:flex;justify-content:center;align-items:center;box-shadow:inset 0 0 10px #0000001a,var(--shadow-sm);backface-visibility:hidden;-webkit-backface-visibility:hidden}.dot{width:10px;height:10px;background:var(--color-text);border-radius:50%}.dots-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:100%;height:100%;padding:8px}.dots-grid .dot{margin:auto}.die-face.face-1 .dot{background:var(--color-primary);width:14px;height:14px}.die-face.face-2{flex-direction:column;justify-content:space-around;padding:8px}.die-face.face-3{padding:8px;flex-direction:column;justify-content:space-between}.die-face.face-3 .dot:nth-child(1){align-self:flex-start}.die-face.face-3 .dot:nth-child(2){align-self:center}.die-face.face-3 .dot:nth-child(3){align-self:flex-end}.die-face.face-4 .dots-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr)}.die-face.face-5 .dots-grid{grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr)}.die-face.face-5 .dot:nth-child(1){grid-area:1 / 1}.die-face.face-5 .dot:nth-child(2){grid-area:1 / 3}.die-face.face-5 .dot:nth-child(3){grid-area:2 / 2}.die-face.face-5 .dot:nth-child(4){grid-area:3 / 1}.die-face.face-5 .dot:nth-child(5){grid-area:3 / 3}.die-face.face-6 .dots-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(3,1fr)}.face-1{transform:rotateY(0) translateZ(28px)}.face-2{transform:rotateY(90deg) translateZ(28px)}.face-3{transform:rotateY(180deg) translateZ(28px)}.face-4{transform:rotateY(-90deg) translateZ(28px)}.face-5{transform:rotateX(90deg) translateZ(28px)}.face-6{transform:rotateX(-90deg) translateZ(28px)}.die.show-1{transform:rotateX(360deg) rotateY(360deg)}.die.show-2{transform:rotateX(360deg) rotateY(270deg)}.die.show-3{transform:rotateX(360deg) rotateY(180deg)}.die.show-4{transform:rotateX(360deg) rotateY(90deg)}.die.show-5{transform:rotateX(270deg) rotateY(360deg)}.die.show-6{transform:rotateX(90deg) rotateY(360deg)}.die.rolling{animation:dice-spin .8s ease-in-out infinite}.game-log{background:var(--color-white);border-radius:20px;padding:16px 20px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.log-container{height:110px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;padding-right:6px}.log-container::-webkit-scrollbar,.settings-options::-webkit-scrollbar{width:6px}.log-container::-webkit-scrollbar-track,.settings-options::-webkit-scrollbar-track{background:var(--color-gray-light);border-radius:4px}.log-container::-webkit-scrollbar-thumb,.settings-options::-webkit-scrollbar-thumb{background:var(--color-gray-medium);border-radius:4px}.log-entry{font-size:13px;line-height:1.4;padding:6px 10px;border-radius:8px;background:var(--color-gray-light)}.system-msg{border-left:4px solid var(--color-primary)}.roll-msg{border-left:4px solid var(--color-yellow)}.challenge-msg{border-left:4px solid var(--color-purple);font-weight:600}.success-msg{border-left:4px solid var(--color-green);background:#e6fcf5;color:var(--color-green-dark);font-weight:600}.error-msg{border-left:4px solid var(--color-danger);background:#fff5f5;color:var(--color-danger)}.players-standings{background:var(--color-white);border-radius:20px;padding:16px 20px;box-shadow:var(--shadow-sm)}.standings-container{display:flex;flex-direction:column;gap:10px}.standings-entry{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:12px;background:var(--color-gray-light);border:2px solid transparent;transition:var(--transition-fast)}.standings-entry.current-turn-card{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:var(--shadow-sm)}.rank-badge{background:var(--color-gray-dark);color:var(--color-white);font-size:12px;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;justify-content:center;align-items:center}.standings-entry:nth-child(1) .rank-badge{background:var(--color-yellow-dark)}.standings-entry:nth-child(2) .rank-badge{background:var(--color-gray-medium)}.standings-avatar{width:32px;height:32px;object-fit:contain}.player-info-wrap{display:flex;flex-direction:column}.player-title{font-size:14px;font-weight:700}.player-sub{font-size:11px;color:var(--color-text-light)}.winner-card{background:var(--color-white);border-radius:28px;padding:50px 40px;text-align:center;max-width:500px;border:4px solid var(--color-primary-light);margin:auto;box-shadow:var(--shadow-lg)}.trophy-wrap{color:var(--color-yellow);margin-bottom:20px}.trophy-bounce{animation:trophy-wobble 2s infinite ease-in-out}.winner-title{font-size:32px;font-weight:800;color:var(--color-primary);margin-bottom:20px}.winner-details{display:flex;flex-direction:column;align-items:center;gap:15px;margin-bottom:35px}.winner-avatar-pic{width:100px;height:100px;object-fit:cover;border-radius:50%;border:4px solid var(--color-yellow);background:var(--color-white);box-shadow:var(--shadow-md);animation:hero-float 3s infinite ease-in-out}.winner-details h1{font-size:28px;font-weight:700}.winner-details p{font-size:16px;color:var(--color-text-light);max-width:350px;line-height:1.5}.modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;background:#2d343673;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:500;opacity:0;pointer-events:none;transition:opacity .3s ease}.modal-backdrop.active{opacity:1;pointer-events:auto}.modal-card{background:var(--color-white);border-radius:28px;width:90%;max-width:580px;max-height:94vh;max-height:94dvh;box-shadow:var(--shadow-lg);border:4px solid var(--color-primary-light);display:flex;flex-direction:column;overflow-y:auto;transform:scale(.85);transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.modal-backdrop.active .modal-card{transform:scale(1)}.small-modal{max-width:420px}.modal-header{padding:20px 24px;border-bottom:2px solid var(--color-gray-light);display:flex;justify-content:space-between;align-items:center}.challenge-title{display:flex;flex-direction:column;gap:4px}.challenge-badge{font-size:11px;font-weight:700;color:var(--color-white);padding:3px 8px;border-radius:6px;align-self:flex-start;text-transform:uppercase}.bridge-badge{background-color:var(--color-purple)}.slide-badge{background-color:var(--color-blue)}.move-badge{background-color:var(--color-primary)}.modal-header h2{font-size:20px;font-weight:700}.tries-left{background:var(--color-gray-light);padding:6px 12px;border-radius:10px;font-size:13px;font-weight:700}.close-btn{background:none;border:none;font-size:28px;font-weight:300;cursor:pointer;color:var(--color-text-light)}.close-btn:hover{color:var(--color-danger)}.modal-body{padding:24px;display:flex;flex-direction:column;gap:20px}.audio-control-row{display:flex;align-items:center;gap:20px;background:var(--color-gray-light);padding:16px;border-radius:18px}.speak-btn{background:var(--color-primary);border:none;color:var(--color-white);border-radius:16px;padding:12px 18px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:0 4px 8px #6c5ce74d;transition:var(--transition-spring)}.speak-btn:hover{transform:scale(1.06);background:var(--color-primary-hover)}.speak-label{font-family:var(--font-family);font-size:11px;font-weight:700;white-space:nowrap}.pulse-speaking{animation:speak-pulse 1.2s infinite}.clue-container{display:flex;flex-direction:column;gap:2px}.clue-label{font-size:12px;font-weight:700;color:var(--color-text-light);text-transform:uppercase}.clue-text{font-size:15px;font-weight:600;line-height:1.3}.clue-emoji{font-size:20px;margin-top:2px}.wordle-board{--tile-size: 50px;display:grid;column-gap:24px;row-gap:8px;justify-content:center;margin:10px auto}.wordle-tile{width:var(--tile-size);height:var(--tile-size);border:3px solid var(--color-gray-medium);border-radius:12px;font-size:24px;font-weight:800;display:flex;justify-content:center;align-items:center;text-transform:uppercase;background:var(--color-white);-webkit-user-select:none;user-select:none}.wordle-tile.filled{border-color:var(--color-text-light)}.wordle-tile.correct{background:var(--color-green);border-color:var(--color-green);color:var(--color-white)}.wordle-tile.present{background:var(--color-yellow);border-color:var(--color-yellow);color:var(--color-white)}.wordle-tile.absent{background:var(--color-gray-dark);border-color:var(--color-gray-dark);color:var(--color-white)}.keyboard-wrap{display:flex;flex-direction:column;gap:6px;margin-top:10px}.keyboard-row{display:flex;justify-content:center;gap:6px}.key{background:var(--color-gray-light);border:none;font-family:var(--font-family);font-size:16px;font-weight:700;height:44px;flex:1;max-width:44px;border-radius:8px;cursor:pointer;display:flex;justify-content:center;align-items:center;text-transform:uppercase;transition:background-color .2s,transform .1s}.key:active{transform:scale(.95)}.key.action-key{max-width:72px;font-size:11px}.key-correct{background-color:var(--color-green)!important;color:var(--color-white)}.key-present{background-color:var(--color-yellow)!important;color:var(--color-white)}.key-absent{background-color:var(--color-gray-dark)!important;color:var(--color-white)}.key[data-key=enter]{background:linear-gradient(135deg,var(--color-green) 0%,#2ecc71 100%)!important;color:var(--color-white)!important;font-weight:800;text-shadow:0 1px 2px rgba(0,0,0,.15)}.key[data-key=backspace]{background:var(--color-gray-dark)!important;color:var(--color-white)!important}.modal-footer{padding:20px 24px;border-top:2px solid var(--color-gray-light);display:flex;justify-content:space-between;gap:15px}.btn-icon{margin-right:4px}.modal-submit{flex:1;padding:10px 24px!important;font-size:18px!important}.settings-options{display:flex;flex-direction:column;gap:20px;max-height:380px;overflow-y:auto;padding-right:6px}.settings-group{border-bottom:2px solid var(--color-gray-light);padding-bottom:20px}.settings-group:last-child{border-bottom:none}.setting-title{font-weight:700;font-size:15px;color:var(--color-primary);margin-bottom:12px;display:block}.setting-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:10px}.setting-row label{font-size:14px;font-weight:600}.setting-row select,.setting-row input[type=range]{flex:1;max-width:240px;padding:6px;border-radius:8px;border:2px solid var(--color-gray-medium);font-family:var(--font-family);font-size:13px}.toggle-row{justify-content:space-between}.toggle-row input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--color-primary)}.confetti-container{position:fixed;top:0;left:0;width:100vw;height:100vh;height:100dvh;pointer-events:none;z-index:999;overflow:hidden}.confetti-piece{position:absolute;width:12px;height:12px;background:red;top:-12px;border-radius:3px;animation:confetti-fall 3.5s linear infinite}.toast-message{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background:#2d3436f2;color:var(--color-white);padding:12px 24px;border-radius:16px;font-size:15px;font-weight:600;z-index:1000;box-shadow:var(--shadow-lg);pointer-events:none;transition:opacity .5s ease}.toast-message.fade-out{opacity:0}@keyframes fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes logo-bounce{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-5px) rotate(5deg)}}@keyframes card-appear{0%{opacity:0;transform:scale(.8) rotateY(-30deg)}to{opacity:1;transform:scale(1) rotateY(0)}}@keyframes avatar-wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}75%{transform:rotate(8deg)}}@keyframes hop-bounce{0%,to{transform:translate(-50%,-65%) scaleY(1)}50%{transform:translate(-50%,-150%) scaleY(1.1)}}@keyframes dice-spin{0%{transform:rotateX(0) rotateY(0) rotate(0)}to{transform:rotateX(720deg) rotateY(1440deg) rotate(360deg)}}@keyframes trophy-wobble{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.05) rotate(-3deg)}75%{transform:scale(1.05) rotate(3deg)}}@keyframes hero-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes speak-pulse{0%,to{box-shadow:0 0 #6c5ce780}50%{box-shadow:0 0 0 12px #6c5ce700}}.flip-animation{animation:tile-flip .5s ease-out forwards}@keyframes tile-flip{0%{transform:rotateX(0)}45%{transform:rotateX(90deg)}55%{transform:rotateX(90deg)}to{transform:rotateX(0)}}.shake-animation{animation:row-shake .4s ease-in-out}@keyframes row-shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.wrong-answer-shake{animation:wrong-shake .5s ease-in-out;background-color:var(--color-danger)!important;color:var(--color-white)!important;border-color:var(--color-danger)!important}@keyframes wrong-shake{0%,to{transform:rotate(0)}20%{transform:rotate(-5deg)}40%{transform:rotate(5deg)}60%{transform:rotate(-5deg)}80%{transform:rotate(5deg)}}.hint-flash{animation:hint-light 1.2s ease-in-out infinite alternate}@keyframes hint-light{0%{box-shadow:0 0 #6c5ce700;border-color:var(--color-gray-medium)}to{box-shadow:0 0 15px var(--color-primary);border-color:var(--color-primary)}}@keyframes confetti-fall{0%{transform:translateY(-10px) rotate(0);top:-10px}to{transform:translateY(105vh) rotate(720deg);top:105vh}}.slide-up{animation:slide-up-anim .4s ease-out forwards}@keyframes slide-up-anim{0%{bottom:-50px;opacity:0}to{bottom:30px;opacity:1}}@media (max-width: 900px){body,#app-container{height:100vh;height:100dvh;overflow:hidden}.game-viewport{padding:6px}.game-layout{flex-direction:column;align-items:stretch;justify-content:flex-start;height:100%;gap:10px;padding:6px;box-sizing:border-box}.board-panel{--board-aspect: 1.25;width:min(calc((100dvh - 420px) * var(--board-aspect)),calc(100vw - 24px));height:min(calc(100dvh - 420px),calc((100vw - 24px) / var(--board-aspect)));max-width:none;max-height:none;flex:none;margin:0 auto;align-self:center;padding:4px;border-radius:16px}.board-grid{gap:3px}.board-tile{padding:4px;border-radius:8px;border-bottom-width:2px}.tile-number{font-size:11px}.tile-tag{font-size:8px;padding:2px 4px;border-radius:4px;letter-spacing:.2px;max-width:96%;align-self:center;text-align:center;box-sizing:border-box}.player-token{width:32px;height:32px}.player-token img{width:26px;height:26px;border-width:2px}.control-panel{flex:1;width:100%;max-width:none;min-width:0;align-self:stretch;display:flex;flex-direction:column;justify-content:space-between;align-items:stretch;background:var(--color-white);border-width:3px;border-radius:24px;padding:10px 14px;gap:10px;box-sizing:border-box}.control-panel .sidebar-brand{display:none}.control-panel .active-player-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 0;border-bottom:2px dashed var(--color-gray-light);flex:1;justify-content:center}.control-panel .active-player-card .panel-subtitle{display:block;font-size:14px;margin-bottom:4px}.control-panel .active-player-info{flex-direction:column;align-items:center;text-align:center;gap:10px}.control-panel .active-avatar-wrap{width:72px;height:72px;border-width:3px}.control-panel .active-details{align-items:center;gap:2px}.control-panel .active-details h2{font-size:22px;max-width:none;overflow:visible;text-overflow:clip;white-space:normal}.control-panel .active-details .badge{font-size:11px;padding:3px 8px}.control-panel .dice-section{flex-direction:row;justify-content:center;align-items:center;gap:20px;margin-top:0;padding:8px 0}.control-panel .dice-wrapper{width:60px;height:60px;perspective:400px}.control-panel .die{width:50px;height:50px}.control-panel .die-face{width:50px;height:50px;border-width:3px;border-radius:10px}.control-panel .die-face .dot{width:8px;height:8px}.control-panel .die-face.face-1 .dot{width:12px;height:12px}.control-panel #roll-btn{font-size:18px;padding:12px 24px;border-radius:16px;height:48px;flex:1;max-width:200px}.control-panel .control-panel-footer{flex-direction:row;justify-content:center;gap:15px;margin-top:0;border-top:none;padding-top:0}.control-panel .control-panel-footer .icon-btn{width:40px;height:40px}.control-panel .control-panel-footer .icon-btn svg{width:22px;height:22px}#setup-screen{justify-content:flex-start!important;padding:20px 10px}.welcome-card{margin:0 auto;padding:24px 16px}.title-bounce{font-size:32px}.subtitle{font-size:15px;margin-bottom:20px}}@media (max-width: 500px){.player-count-options{flex-wrap:wrap;gap:8px}.count-btn{padding:8px 16px;font-size:14px;border-radius:12px;flex:1;min-width:110px;text-align:center}.game-viewport{padding:4px}.game-layout{padding:4px;gap:8px}.board-panel{--board-aspect: 1;width:min(calc((100dvh - 360px) * var(--board-aspect)),calc(100vw - 16px));height:min(calc(100dvh - 360px),calc((100vw - 16px) / var(--board-aspect)));padding:3px;border-radius:12px}.board-grid{gap:2px}.board-tile{padding:2px;border-radius:6px;border-bottom-width:1px}.tile-number{font-size:9px}.tile-tag{font-size:6.5px;padding:1px 2px;border-radius:3px;letter-spacing:0;max-width:96%;align-self:center;text-align:center;box-sizing:border-box}.player-token{width:24px;height:24px}.player-token img{width:20px;height:20px;border-width:1.5px;box-shadow:0 2px 4px #0003}.control-panel{padding:8px 10px;gap:8px;border-radius:20px}.control-panel .active-player-card{gap:6px;padding:4px 0}.control-panel .active-avatar-wrap{width:60px;height:60px}.control-panel .active-details h2{font-size:18px}.control-panel .active-details .badge{font-size:10px;padding:2px 6px}.control-panel .dice-section{gap:16px;padding:4px 0}.control-panel .dice-wrapper{width:50px;height:50px}.control-panel .die{width:42px;height:42px}.control-panel .die-face{width:42px;height:42px;border-radius:8px}.control-panel #roll-btn{font-size:15px;padding:10px 20px;height:42px}.control-panel .control-panel-footer .icon-btn{width:36px;height:36px}.control-panel .control-panel-footer .icon-btn svg{width:18px;height:18px}.modal-header{padding:10px 14px}.modal-card{width:95%;max-height:98dvh}.modal-body{padding:10px 12px;gap:8px}.audio-control-row{padding:6px 10px;gap:8px;border-radius:12px}.audio-control-row button.speak-btn{flex-direction:row;padding:6px 10px;border-radius:8px;gap:6px}.audio-control-row button.speak-btn svg{width:18px;height:18px}.speak-label{font-size:11px}.clue-container{flex-direction:row;flex-wrap:wrap;align-items:center;gap:4px}.clue-label,.clue-text{font-size:11px}.clue-emoji{font-size:14px}.wordle-board{--tile-size: 38px;column-gap:8px;row-gap:4px;margin:4px auto}.wordle-tile{font-size:18px;border-radius:6px;border-width:1.5px}.keyboard-wrap{gap:4px;margin-top:4px}.keyboard-row{gap:4px}.key{height:48px;font-size:16px;border-radius:8px;flex:1;max-width:none}.key.action-key{font-size:10px;flex:1.5;max-width:none}.modal-footer{display:none!important}}@media (max-width: 950px) and (orientation: landscape){body,#app-container{height:100vh;height:100dvh;overflow:hidden}.game-viewport{padding:4px}.game-layout{flex-direction:row!important;align-items:center;justify-content:center;height:100%;gap:10px;padding:4px;box-sizing:border-box}.board-panel{--board-aspect: 1;width:min(calc(100dvh - 16px),calc(100vw - 200px))!important;height:min(calc(100dvh - 16px),calc(100vw - 200px))!important;max-width:none;max-height:none;flex:none;margin:0;align-self:center;padding:3px;border-radius:12px}.board-grid{gap:2px}.board-tile{padding:2px;border-radius:6px;border-bottom-width:1px}.tile-number{font-size:8px}.tile-tag{font-size:6px;padding:1px 2px;border-radius:3px;max-width:96%;align-self:center;text-align:center;box-sizing:border-box}.player-token{width:20px;height:20px}.player-token img{width:16px;height:16px;border-width:1px}.control-panel{flex:1!important;height:calc(100dvh - 16px)!important;max-width:none!important;min-width:0!important;align-self:center!important;display:flex!important;flex-direction:column!important;justify-content:space-between!important;padding:6px 10px!important;gap:6px!important;border-radius:16px!important}.control-panel .sidebar-brand{padding-bottom:4px;margin-bottom:0}.control-panel .logo-text,.control-panel .logo-icon{font-size:18px}.control-panel .active-player-card{padding:2px 0;gap:4px}.control-panel .active-avatar-wrap{width:44px;height:44px}.control-panel .active-player-name{font-size:14px}.control-panel .dice-section{margin-top:0;gap:8px;padding:4px}.control-panel .die-container{width:36px;height:36px}.control-panel .roll-btn{padding:6px 12px;font-size:12px}.control-panel .settings-toggle-bar{padding-top:4px;gap:8px}#setup-screen{justify-content:center!important;align-items:center!important;padding:10px;overflow-y:auto}#setup-screen .welcome-card{max-width:600px;padding:16px}.modal-header{padding:8px 12px}.modal-header h2{font-size:14px}.tries-left{font-size:11px}.modal-body{padding:8px 10px;gap:6px}.audio-control-row{padding:4px 8px;gap:8px;border-radius:10px}.audio-control-row button.speak-btn{flex-direction:row;padding:4px 8px;border-radius:6px;gap:4px}.audio-control-row button.speak-btn svg{width:16px;height:16px}.speak-label{font-size:10px}.clue-container{flex-direction:row;flex-wrap:wrap;align-items:center;gap:4px}.clue-label,.clue-text{font-size:10px}.clue-emoji{font-size:12px}.wordle-board{--tile-size: 28px;column-gap:6px;row-gap:3px;margin:2px auto}.wordle-tile{width:28px;height:28px;font-size:13px;border-radius:4px;border-width:1px}.keyboard-wrap{gap:2px;margin-top:2px}.keyboard-row{gap:2px}.key{height:26px;font-size:11px;border-radius:4px;max-width:none}.key.action-key{font-size:8px;max-width:none;flex:1.5}.modal-footer{display:none!important}}
