:root{--navbar-h: 56px;--bg-primary: #eef2ff;--bg-secondary: #ffffff;--bg-card: #ffffff;--text-primary: #1a1a2e;--text-secondary: #555577;--text-muted: #8888aa;--border-color: rgba(0,0,0,.1);--navbar-bg: #ffffff;--navbar-shadow: 0 2px 16px rgba(0,0,0,.08);--table-bg: radial-gradient(ellipse at center, #3d8b5e 0%, #2a5e3f 100%);--card-shadow: 0 4px 18px rgba(0,0,0,.22);--modal-overlay: rgba(0,0,0,.55);--chat-bg: rgba(255,255,255,.95);--input-bg: #f4f6ff;--input-border: #c5cae9}[data-theme=dark]{--bg-primary: #0d0d1a;--bg-secondary: #161629;--bg-card: #1e1e35;--text-primary: #e8e8ff;--text-secondary: #a0a0cc;--text-muted: #6666aa;--border-color: rgba(255,255,255,.1);--navbar-bg: #161629;--navbar-shadow: 0 2px 20px rgba(0,0,0,.5);--table-bg: radial-gradient(ellipse at center, #1a4a32 0%, #0d2818 100%);--card-shadow: 0 4px 24px rgba(0,0,0,.6);--modal-overlay: rgba(0,0,0,.75);--chat-bg: rgba(22,22,41,.97);--input-bg: #1e1e35;--input-border: #3a3a60}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg-primary);color:var(--text-primary);transition:background .3s,color .3s;overflow-x:hidden}#root{display:flex;flex-direction:column;min-height:100vh}button{cursor:pointer;border:none;background:none;font-family:inherit}input{font-family:inherit}ul{list-style:none}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 22px;border-radius:10px;font-size:.95rem;font-weight:600;transition:transform .15s,box-shadow .15s,opacity .15s;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 14px #0003}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff}.btn-secondary{background:linear-gradient(135deg,#1e90ff,#74b9ff);color:#fff}.btn-success{background:linear-gradient(135deg,#00b894,#55efc4);color:#fff}.btn-warning{background:linear-gradient(135deg,#fdcb6e,#f9ca24);color:#333}.btn-danger{background:linear-gradient(135deg,#ff4757,#ff6b81);color:#fff}.btn-danger.btn-sm{padding:4px 10px;font-size:.8rem;border-radius:6px}.btn-ghost{background:transparent;color:var(--text-secondary);border:1.5px solid var(--border-color)}.btn-ghost:hover:not(:disabled){background:var(--bg-secondary)}.btn-ghost-sm{padding:6px 14px;font-size:.85rem;background:var(--bg-secondary);color:var(--text-secondary);border:1.5px solid var(--border-color);border-radius:8px}.btn-draw{padding:11px 28px;font-size:1.05rem;font-weight:800;border-radius:12px;background:linear-gradient(135deg,#f7971e,#ffd200);color:#1a1a2e;box-shadow:0 4px 18px #f7971e8c;letter-spacing:.5px;transition:transform .15s,box-shadow .15s}.btn-draw:hover:not(:disabled){transform:translateY(-3px) scale(1.04);box-shadow:0 8px 28px #f7971eb3}.btn-draw:active:not(:disabled){transform:translateY(0) scale(1)}.btn-draw:disabled{opacity:.45;cursor:not-allowed}.btn-lg{padding:14px 32px;font-size:1.1rem;border-radius:14px}.btn-sm{padding:6px 14px;font-size:.82rem}.navbar{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--navbar-h);display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:var(--navbar-bg);box-shadow:var(--navbar-shadow);transition:background .3s}.navbar-brand{display:flex;align-items:baseline;gap:1px;font-size:1.6rem;font-weight:900;letter-spacing:-1px}.brand-t{color:#ff4757}.brand-a{color:#1e90ff}.brand-k{color:#00b894}.brand-i{color:#fdcb6e}.theme-toggle{font-size:1.4rem;padding:6px;border-radius:50%;transition:transform .3s;background:var(--bg-primary);border:1.5px solid var(--border-color);width:40px;height:40px;display:flex;align-items:center;justify-content:center}.theme-toggle:hover{transform:rotate(20deg) scale(1.1)}.home-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding-top:var(--navbar-h);overflow:hidden;position:relative}.floating-cards{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:0}.floating-card-bg{position:absolute;width:50px;height:75px;border-radius:8px;opacity:.12;animation:floatUp linear infinite;bottom:-100px}@keyframes floatUp{0%{transform:translateY(0) rotate(0);opacity:.12}50%{opacity:.18}to{transform:translateY(-110vh) rotate(360deg);opacity:0}}.home-center{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:32px;padding:20px}.taki-logo{display:flex;align-items:baseline;gap:4px;font-size:5rem;font-weight:900;letter-spacing:-3px;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));flex-direction:column;align-items:center}.logo-t{color:#ff4757;text-shadow:3px 3px 0 #c0392b}.logo-a{color:#1e90ff;text-shadow:3px 3px 0 #1060b0}.logo-k{color:#00b894;text-shadow:3px 3px 0 #008060}.logo-i{color:#fdcb6e;text-shadow:3px 3px 0 #c8a040}.taki-logo{flex-direction:row}.logo-sub{font-size:1rem;font-weight:700;color:var(--text-muted);letter-spacing:4px;margin-left:8px;align-self:flex-end;margin-bottom:8px}.home-buttons{display:flex;flex-direction:column;gap:16px;width:280px}.home-buttons .btn{width:100%}.home-form{background:var(--bg-card);border-radius:18px;padding:28px;width:340px;box-shadow:0 8px 40px #00000026;display:flex;flex-direction:column;gap:16px}.home-form h2{font-size:1.4rem;font-weight:700}.home-form label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;font-weight:600;color:var(--text-secondary)}.home-form input[type=text]{padding:10px 14px;border-radius:10px;border:1.5px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:1rem;outline:none;transition:border-color .2s}.home-form input[type=text]:focus{border-color:#6c5ce7}.home-form input[type=range]{accent-color:#6c5ce7;width:100%;margin-top:4px}.form-row{display:flex;gap:10px;justify-content:space-between}.form-row .btn{flex:1}.error-banner{background:linear-gradient(135deg,#ff4757,#ff6b81);color:#fff;padding:10px 18px;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;max-width:340px;animation:slideIn .3s ease}.error-text{color:#ff4757;font-size:.88rem;margin-top:2px}@keyframes slideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.lobby-page{min-height:100vh;padding-top:calc(var(--navbar-h) + 20px);display:flex;align-items:flex-start;justify-content:center;padding-bottom:40px;position:relative}.lobby-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:url(/taki_bg.png) center center / cover no-repeat;opacity:.25;z-index:0;pointer-events:none}.lobby-page>*{position:relative;z-index:1}.lobby-card{background:var(--bg-card);border-radius:20px;padding:32px;width:100%;max-width:520px;box-shadow:0 8px 40px #0000001f;display:flex;flex-direction:column;gap:22px;margin:0 16px}.join-invite-card{max-width:480px;padding:40px;align-self:center;margin-top:40px}.join-invite-card h2{font-size:1.8rem;font-weight:800;text-align:center}.join-invite-form{display:flex;flex-direction:column;gap:20px}.join-nick-field{display:flex;flex-direction:column;gap:8px}.join-nick-field label{font-size:1rem;font-weight:700;color:var(--text-secondary)}.join-nick-field input{padding:14px 18px;border-radius:12px;border:2px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:1.15rem;outline:none;transition:border-color .2s}.join-nick-field input:focus{border-color:#6c5ce7}.lobby-header{display:flex;align-items:center;justify-content:space-between}.lobby-header h2{font-size:1.5rem;font-weight:800}.room-code-badge{background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;padding:4px 14px;border-radius:20px;font-size:1.1rem;font-weight:700;letter-spacing:3px}.invite-section{display:flex;flex-direction:column;gap:8px}.invite-label{font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}.invite-row{display:flex;gap:8px}.invite-input{flex:1;padding:8px 12px;border-radius:8px;border:1.5px solid var(--input-border);background:var(--input-bg);color:var(--text-secondary);font-size:.82rem;outline:none;overflow:hidden;text-overflow:ellipsis}.player-list-lobby h3{font-size:1rem;font-weight:700;margin-bottom:10px}.player-list-lobby ul{display:flex;flex-direction:column;gap:6px}.lobby-player{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-primary);border-radius:10px;transition:background .2s}.lobby-player.me{background:linear-gradient(135deg,#6c5ce71f,#a29bfe1f);border:1.5px solid rgba(108,92,231,.3)}.player-avatar{font-size:1.2rem}.player-name{flex:1;font-weight:600;font-size:.95rem}.host-badge{font-size:.72rem;font-weight:700;background:linear-gradient(135deg,#fdcb6e,#f9ca24);color:#333;padding:2px 8px;border-radius:6px;letter-spacing:1px}.lobby-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.waiting-text{color:var(--text-muted);font-size:.9rem}.mt-2{margin-top:8px}.game-page{display:grid;grid-template-rows:auto 1fr auto;min-height:100vh;padding-top:var(--navbar-h);background:var(--table-bg);position:relative;overflow:hidden}.game-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:url(/taki_bg.png) center center / cover no-repeat;opacity:.4;z-index:0;pointer-events:none}.opponents-arc{position:relative;width:100%;height:260px;flex-shrink:0;pointer-events:none}.arc-player{pointer-events:all}.game-board{display:flex;align-items:center;justify-content:center;gap:30px;padding:20px;position:relative;flex:1}.deck-pile{position:relative;cursor:pointer}.deck-pile.active .deck-card-back{animation:deck-pulse 1.5s infinite}.deck-card-back{width:80px;height:120px;border-radius:12px;background:linear-gradient(135deg,#2c3e90,#6c5ce7);border:3px solid rgba(255,255,255,.35);box-shadow:var(--card-shadow);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px}.deck-card-back:before{content:"TAKI";font-weight:900;font-size:1rem;color:#fff9;letter-spacing:2px}.deck-count{position:absolute;bottom:-8px;right:-8px;background:#fdcb6e;color:#333;font-size:.75rem;font-weight:800;border-radius:10px;padding:2px 7px;border:2px solid #fff;box-shadow:0 2px 6px #0003}@keyframes deck-pulse{0%,to{box-shadow:var(--card-shadow)}50%{box-shadow:0 0 0 6px #a29bfe66,var(--card-shadow)}}.discard-pile{position:relative;transition:transform .2s}.turn-indicator{position:absolute;top:2px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}.your-turn-badge{background:linear-gradient(135deg,#00b894,#55efc4);color:#fff;padding:5px 16px;border-radius:20px;font-weight:700;font-size:.88rem;animation:pulse-badge 1s infinite;box-shadow:0 2px 12px #00b89480}@keyframes pulse-badge{0%,to{transform:scale(1)}50%{transform:scale(1.06)}}.their-turn-badge{background:#00000059;color:#ffffffd9;padding:5px 16px;border-radius:20px;font-size:.85rem;font-weight:600}.draw-badge{background:linear-gradient(135deg,#ff4757,#ff6b81);color:#fff;padding:4px 12px;border-radius:16px;font-weight:700;font-size:.82rem;animation:pulse-badge .8s infinite}.taki-badge{background:linear-gradient(135deg,#fdcb6e,#f9ca24);color:#333;padding:4px 12px;border-radius:16px;font-weight:700;font-size:.82rem}.direction-indicator{position:absolute;top:14px;right:16px;font-size:1.8rem;color:#fff9}.special-effect-toast{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.8rem;font-weight:900;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.6);pointer-events:none;animation:toastPop 1.8s ease forwards;z-index:50;white-space:nowrap;background:#0006;padding:10px 24px;border-radius:16px}.system-notification-toast{position:absolute;top:10px;left:50%;transform:translate(-50%);font-size:.9rem;font-weight:600;color:#fff;background:#000000a6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:8px 20px;border-radius:20px;z-index:50;pointer-events:none;animation:toastPop 4s ease forwards;white-space:nowrap;border:1px solid rgba(255,255,255,.15)}.error-toast{background:#dc2626d9;border-color:#ff646466;pointer-events:all;cursor:pointer;top:44px}.system-notification-banner{background:#6c5ce726;border:1px solid rgba(108,92,231,.35);border-radius:10px;padding:10px 16px;font-size:.88rem;font-weight:600;color:var(--text-secondary);animation:slideIn .3s ease}@keyframes toastPop{0%{opacity:0;transform:translate(-50%,-50%) scale(.4)}20%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}70%{opacity:1;transform:translate(-50%,-70%) scale(1)}to{opacity:0;transform:translate(-50%,-90%) scale(.9)}}.my-area{padding:12px 16px 20px;display:flex;flex-direction:column;gap:8px;align-items:center}.my-info{display:flex;align-items:center;gap:12px}.action-buttons{display:flex;gap:8px}.card-hand{overflow:visible}.hand-fan{display:flex;align-items:flex-end;justify-content:center;padding:10px 20px 0}.hand-card-wrapper{transition:transform .2s,filter .2s;position:relative}.hand-card-wrapper.hand-playable:hover{transform:translateY(-18px)!important;z-index:50!important}.hand-card-wrapper.hand-played{animation:cardPlayed .4s ease forwards}@keyframes cardPlayed{0%{transform:translateY(0) scale(1);opacity:1}50%{transform:translateY(-60px) scale(.8) rotate(15deg);opacity:.7}to{transform:translateY(-120px) scale(0);opacity:0}}.empty-hand{color:#ffffff80;font-size:.9rem;padding:20px}.taki-card{border-radius:12px;border:3px solid rgba(255,255,255,.45);box-shadow:var(--card-shadow);position:relative;-webkit-user-select:none;user-select:none;transition:transform .2s,box-shadow .2s;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;align-items:stretch}.taki-card.clickable{cursor:pointer}.taki-card.clickable:hover{transform:translateY(-4px);box-shadow:0 8px 28px #00000059}.taki-card.selected{transform:translateY(-12px) scale(1.05);box-shadow:0 12px 36px #00000080}.card-sm{width:46px;height:68px;border-width:2px;border-radius:8px}.card-md{width:72px;height:108px}.card-lg{width:90px;height:136px;border-width:3.5px;border-radius:14px}.card-xl{width:144px;height:216px;border-width:4px;border-radius:18px}.card-red{background:linear-gradient(145deg,#ff4757,#ff6b81 60%,#ff4757)}.card-blue{background:linear-gradient(145deg,#1e90ff,#74b9ff 60%,#1e90ff)}.card-green{background:linear-gradient(145deg,#00b894,#55efc4 60%,#00b894)}.card-yellow{background:linear-gradient(145deg,#fdcb6e,#ffeaa7 60%,#fdcb6e)}.card-wild{background:conic-gradient(#ff4757,#1e90ff,#00b894,#fdcb6e,#ff4757 360deg)}.taki-card.playable{animation:card-glow 1.4s ease-in-out infinite;cursor:pointer}.taki-card.playable:hover{animation:none;transform:translateY(-8px) scale(1.06);box-shadow:0 12px 32px #ffffff80}@keyframes card-glow{0%,to{box-shadow:var(--card-shadow),0 0 #fff6}50%{box-shadow:var(--card-shadow),0 0 0 5px #ffffff4d}}.card-corner{position:absolute;display:flex;flex-direction:column;align-items:center;line-height:1}.card-corner-tl{top:4px;left:5px}.card-corner-br{bottom:4px;right:5px;transform:rotate(180deg)}.corner-value{font-size:.75em;font-weight:900;color:#fffffff2;text-shadow:1px 1px 3px rgba(0,0,0,.4)}.card-sm .corner-value{font-size:.6em}.card-xl .corner-value{font-size:1em}.corner-color{font-size:.55em;color:#ffffffb3}.card-sm .corner-color{display:none}.card-center{flex:1;display:flex;align-items:center;justify-content:center}.card-symbol{font-weight:900;color:#fffffff7;text-shadow:2px 2px 6px rgba(0,0,0,.4);line-height:1}.card-md .card-symbol{font-size:1.5rem}.card-lg .card-symbol{font-size:2rem}.card-xl .card-symbol{font-size:3.2rem}.card-sm .card-symbol{font-size:1rem}.card-xl.face-up.card-type-number .card-center .card-symbol{font-size:7.5rem;line-height:1}.card-lg.face-up.card-type-number .card-center .card-symbol{font-size:4.5rem;line-height:1}.card-md.face-up.card-type-number .card-center .card-symbol{font-size:3rem;line-height:1}.card-sm.face-up.card-type-number .card-center .card-symbol{font-size:1.6rem;line-height:1}.card-type-number .card-symbol{font-size:2rem}.card-special-glow{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 60%);pointer-events:none}.card-xl.face-up.card-type-plus_two .card-center .card-symbol,.card-xl.face-up.card-type-stop .card-center .card-symbol,.card-xl.face-up.card-type-change_direction .card-center .card-symbol{font-size:5.5rem;line-height:1}.card-xl.face-up.card-type-taki .card-center .card-symbol{font-size:2.8rem;line-height:1;letter-spacing:4px}.card-xl.face-up.card-type-king .card-center .card-symbol{font-size:4rem;line-height:1}.card-xl.face-up.card-type-super_taki .card-center .card-symbol{font-size:2.2rem;line-height:1;letter-spacing:2px}.card-lg.face-up.card-type-plus_two .card-center .card-symbol,.card-lg.face-up.card-type-stop .card-center .card-symbol,.card-lg.face-up.card-type-change_direction .card-center .card-symbol{font-size:3.2rem;line-height:1}.card-lg.face-up.card-type-taki .card-center .card-symbol{font-size:1.7rem;line-height:1;letter-spacing:3px}.card-lg.face-up.card-type-king .card-center .card-symbol{font-size:2.5rem;line-height:1}.card-lg.face-up.card-type-super_taki .card-center .card-symbol{font-size:1.4rem;line-height:1;letter-spacing:1px}.card-md.face-up.card-type-plus_two .card-center .card-symbol,.card-md.face-up.card-type-stop .card-center .card-symbol,.card-md.face-up.card-type-change_direction .card-center .card-symbol{font-size:2.5rem;line-height:1}.card-md.face-up.card-type-taki .card-center .card-symbol{font-size:1.3rem;line-height:1;letter-spacing:2px}.card-md.face-up.card-type-king .card-center .card-symbol{font-size:2rem;line-height:1}.card-md.face-up.card-type-super_taki .card-center .card-symbol{font-size:1.1rem;line-height:1;letter-spacing:1px}.card-sm.face-up.card-type-plus_two .card-center .card-symbol,.card-sm.face-up.card-type-stop .card-center .card-symbol,.card-sm.face-up.card-type-change_direction .card-center .card-symbol{font-size:1.5rem;line-height:1}.card-sm.face-up.card-type-taki .card-center .card-symbol{font-size:.75rem;line-height:1;letter-spacing:1px}.card-sm.face-up.card-type-king .card-center .card-symbol{font-size:1.2rem;line-height:1}.card-sm.face-up.card-type-super_taki .card-center .card-symbol{font-size:.65rem;line-height:1}.card-xl .wild-dot{width:16px;height:16px}.card-xl .wild-circles{gap:6px;margin-bottom:6px}.card-lg .wild-dot{width:12px;height:12px}.card-lg .wild-circles{gap:4px;margin-bottom:4px}.card-wild-center{display:flex;flex-direction:column;align-items:center;gap:4px}.wild-circles{display:flex;gap:3px}.wild-dot{width:10px;height:10px;border-radius:50%;border:1.5px solid rgba(255,255,255,.6)}.wild-dot-red{background:#ff4757}.wild-dot-blue{background:#1e90ff}.wild-dot-green{background:#00b894}.wild-dot-yellow{background:#fdcb6e}.card-back{background:linear-gradient(135deg,#2c3e90,#6c5ce7,#2c3e90);border:3px solid rgba(255,255,255,.3);border-radius:12px;overflow:hidden}.card-back.card-sm{border-radius:8px;border-width:2px}.card-back-pattern{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.9rem;color:#ffffff40;letter-spacing:2px;background:repeating-linear-gradient(45deg,transparent,transparent 4px,rgba(255,255,255,.04) 4px,rgba(255,255,255,.04) 8px)}.card-sm .card-back-pattern{font-size:.5rem}.discard-pile.card-played .taki-card{animation:discardSlide .5s cubic-bezier(.25,.46,.45,.94)}@keyframes discardSlide{0%{transform:scale(1.3) rotate(-8deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}.player-info{border-radius:14px;background:#00000040;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:2px solid transparent;transition:border-color .3s,background .3s}.player-info.player-current{border-color:#fdcb6e;background:#0006;animation:player-highlight 1.5s ease infinite}@keyframes player-highlight{0%,to{box-shadow:0 0 #fdcb6e66}50%{box-shadow:0 0 0 8px #fdcb6e33}}.player-info.player-disconnected{opacity:.5}.player-info.player-me{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#6c5ce740;border-color:#a29bfe80;min-width:120px;max-width:200px}.player-avatar-wrap{position:relative;font-size:1.3rem}.current-dot{position:absolute;bottom:-2px;right:-2px;width:9px;height:9px;background:#fdcb6e;border-radius:50%;border:1.5px solid rgba(0,0,0,.3);animation:dotBlink 1s ease infinite}@keyframes dotBlink{0%,to{opacity:1}50%{opacity:0}}.player-details{display:flex;flex-direction:column;flex:1;min-width:0}.player-name-tag{font-size:.82rem;font-weight:700;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-card-count{font-size:.72rem;color:#fff9}.player-info.player-opponent{display:flex;flex-direction:column;align-items:center;gap:7px;padding:10px 14px;min-width:120px}.opponent-header{display:flex;align-items:center;gap:6px;flex-wrap:nowrap}.player-avatar-icon{font-size:1.4rem;line-height:1}.opponent-name{font-size:1rem;font-weight:700;color:#fffffff2;white-space:nowrap;max-width:130px;overflow:hidden;text-overflow:ellipsis}.current-pip{width:8px;height:8px;border-radius:50%;background:#fdcb6e;flex-shrink:0;animation:dotBlink 1s ease infinite}.opponent-card-count{font-size:.85rem;color:#fff9;font-weight:600}.opponent-hand{display:flex;align-items:flex-end}.mini-card{position:relative}.more-cards{font-size:.72rem;color:#fff9;margin-left:6px;font-weight:700;align-self:center}.taki-alert{background:linear-gradient(135deg,#fdcb6e,#f9ca24);color:#333;font-size:.72rem;font-weight:900;padding:2px 6px;border-radius:6px;animation:pulse-badge .7s infinite;letter-spacing:1px}.chat-panel{position:fixed;right:0;top:var(--navbar-h);bottom:0;width:300px;background:var(--chat-bg);box-shadow:-4px 0 20px #0003;display:flex;flex-direction:column;z-index:60;animation:slideFromRight .25s ease}@keyframes slideFromRight{0%{transform:translate(100%)}to{transform:translate(0)}}.chat-header{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:.95rem;border-bottom:1.5px solid var(--border-color);color:var(--text-primary)}.chat-close{font-size:1rem;color:var(--text-muted);padding:4px 6px;border-radius:6px}.chat-close:hover{background:var(--bg-primary)}.chat-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.chat-empty{color:var(--text-muted);font-size:.88rem;text-align:center;margin-top:20px}.chat-msg{display:flex;flex-direction:column;gap:2px}.chat-nick{font-weight:700;font-size:.82rem;color:#6c5ce7}.chat-time{font-size:.72rem;color:var(--text-muted)}.chat-text{font-size:.88rem;color:var(--text-primary);word-break:break-word}.chat-input-row{padding:10px;display:flex;gap:8px;border-top:1.5px solid var(--border-color)}.chat-input{flex:1;padding:8px 12px;border-radius:8px;border:1.5px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);font-size:.88rem;outline:none}.chat-input:focus{border-color:#6c5ce7}.game-corner-controls{position:fixed;right:16px;bottom:148px;z-index:55;display:flex;flex-direction:column;gap:8px;align-items:flex-end}.game-corner-controls .btn{opacity:.9;transition:opacity .2s,transform .15s}.game-corner-controls .btn:hover{opacity:1;transform:scale(1.05)}.confirm-inline{display:flex;align-items:center;gap:6px;background:#0009;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:6px 10px;border-radius:10px;font-size:.85rem;font-weight:600;color:#fff;white-space:nowrap}.chat-toggle-btn{position:fixed;right:16px;bottom:80px;z-index:55;width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#6c5ce7,#a29bfe);color:#fff;font-size:1.4rem;box-shadow:0 4px 16px #6c5ce780;display:flex;align-items:center;justify-content:center;transition:transform .2s}.chat-toggle-btn:hover{transform:scale(1.1)}.chat-toggle-btn.active{background:linear-gradient(135deg,#00b894,#55efc4)}.chat-dot{position:absolute;top:4px;right:4px;width:10px;height:10px;background:#ff4757;border-radius:50%;border:2px solid #fff}.emoji-bar{position:fixed;bottom:16px;left:50%;transform:translate(-50%);display:flex;gap:6px;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 14px;border-radius:30px;z-index:55;border:1.5px solid rgba(255,255,255,.15)}.emoji-btn{font-size:1.4rem;padding:4px;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s}.emoji-btn:hover{transform:scale(1.3);background:#ffffff26}.emoji-reactions-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:70}.floating-emoji{position:absolute;bottom:120px;display:flex;flex-direction:column;align-items:center;gap:3px;animation:floatEmoji 3.5s ease forwards}.floating-emoji-icon{font-size:2.4rem}.floating-emoji-nick{font-size:.72rem;color:#fffc;font-weight:600;background:#0006;padding:1px 6px;border-radius:8px}@keyframes floatEmoji{0%{transform:translateY(0) scale(.5);opacity:0}15%{transform:translateY(-10px) scale(1.1);opacity:1}80%{opacity:1}to{transform:translateY(-180px) scale(.8);opacity:0}}.countdown-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.countdown-number{font-size:18rem;font-weight:900;color:#fff;text-shadow:0 0 60px rgba(255,255,255,.5),0 4px 30px rgba(0,0,0,.6);animation:countdownPop .9s ease-out forwards;line-height:1}@keyframes countdownPop{0%{transform:scale(1.6);opacity:0}20%{transform:scale(1);opacity:1}80%{transform:scale(1);opacity:1}to{transform:scale(.4);opacity:0}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--modal-overlay);display:flex;align-items:center;justify-content:center;z-index:80;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.color-picker-modal{background:var(--bg-card);border-radius:20px;padding:32px;display:flex;flex-direction:column;align-items:center;gap:20px;box-shadow:0 12px 50px #0006;min-width:280px;animation:popIn .25s cubic-bezier(.34,1.56,.64,1)}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.color-picker-modal h3{font-size:1.2rem;font-weight:800;color:var(--text-primary)}.color-options{display:grid;grid-template-columns:1fr 1fr;gap:12px}.color-option{padding:14px 22px;border-radius:12px;font-weight:700;color:#fff;font-size:1rem;transition:transform .15s,box-shadow .15s;text-shadow:1px 1px 4px rgba(0,0,0,.3);border:2px solid rgba(255,255,255,.3)}.color-option:hover{transform:scale(1.07);box-shadow:0 6px 20px #0000004d}.winner-overlay{z-index:90}.winner-modal{background:var(--bg-card);border-radius:24px;padding:40px 48px;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:0 16px 60px #00000080;position:relative;z-index:91;animation:popIn .4s cubic-bezier(.34,1.56,.64,1)}.winner-trophy{font-size:5rem;animation:bounce .8s ease infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-14px)}}.winner-title{font-size:2rem;font-weight:900;color:var(--text-primary)}.winner-sub{font-size:1rem;color:var(--text-secondary)}.winner-actions{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.waiting-for-host{font-size:.88rem;color:var(--text-muted);text-align:center}.confetti-container{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:90;overflow:hidden}.confetti-piece{position:absolute;top:-20px;width:10px;height:14px;border-radius:2px;animation:confettiFall 3s ease-in forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(110vh) rotate(720deg);opacity:0}}.color-red-theme{--table-bg: radial-gradient(ellipse, #5a1a22 0%, #2e0a0f 100%)}.color-blue-theme{--table-bg: radial-gradient(ellipse, #1a3a5a 0%, #0a1e2e 100%)}.color-green-theme{--table-bg: radial-gradient(ellipse, #1a4a32 0%, #0a2418 100%)}.color-yellow-theme{--table-bg: radial-gradient(ellipse, #4a3a1a 0%, #2a1e08 100%)}.color-wild-theme{--table-bg: radial-gradient(ellipse, #2a1a4a 0%, #120a24 100%)}@media (max-width: 600px){.opponents-arc{height:155px}.game-board{gap:12px;padding:6px 10px}.my-area{padding:6px 10px 12px;gap:4px}.chat-panel{width:100%}.taki-logo{font-size:3.5rem}.deck-card-back{width:52px;height:78px}.card-xl{width:72px;height:108px;border-width:2.5px;border-radius:10px}.card-xl .corner-value{font-size:.75em}.card-xl.face-up.card-type-number .card-center .card-symbol{font-size:3.5rem}.card-xl.face-up.card-type-plus_two .card-center .card-symbol,.card-xl.face-up.card-type-stop .card-center .card-symbol,.card-xl.face-up.card-type-change_direction .card-center .card-symbol{font-size:2.4rem}.card-xl.face-up.card-type-taki .card-center .card-symbol{font-size:1.3rem;letter-spacing:2px}.card-xl.face-up.card-type-king .card-center .card-symbol{font-size:2rem}.card-xl.face-up.card-type-super_taki .card-center .card-symbol{font-size:1.1rem;letter-spacing:1px}.card-lg{width:56px;height:84px;border-radius:8px}.card-md{width:46px;height:68px}.hand-fan{padding:4px 8px 0}.hand-card-wrapper{margin-left:-48px!important}.hand-card-wrapper.hand-playable:hover{transform:translateY(-12px)!important}.action-buttons .btn{padding:8px 16px;font-size:.9rem}.your-turn-badge,.their-turn-badge{font-size:.8rem;padding:4px 10px}.emoji-bar{gap:3px;padding:6px 10px}.emoji-btn{width:28px;height:28px;font-size:1rem}}
