*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#0f0f1e,#1a1a2e);min-height:100vh}.app{min-height:100vh;padding:20px}.home-screen{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f1e,#1a1a2e);min-height:100vh;padding:20px}.home-container{background:#fff;border-radius:20px;box-shadow:0 30px 80px #0006;padding:50px 40px;max-width:600px;width:100%;display:flex;flex-direction:column;gap:40px}.home-header{text-align:center}.home-header h1{font-size:4.5em;font-weight:900;letter-spacing:-2px;background:linear-gradient(135deg,#00d9ff,#ff006e,#ffbe0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px}.home-header p{font-size:1.3em;color:#2c3e50;font-weight:600;letter-spacing:1px;margin-bottom:25px}.home-content{display:flex;flex-direction:column;gap:30px}.home-card{background:linear-gradient(135deg,#f8f9fa,#ecf0f1);padding:30px;border-radius:16px;border:2px solid #00D9FF;text-align:center;display:flex;flex-direction:column;gap:15px}.home-card h2{font-size:1.8em;color:#2c3e50;font-weight:700}.home-card p{font-size:1em;color:#555;line-height:1.5}.home-btn{padding:16px 32px;border:none;border-radius:10px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);width:100%;min-height:48px}.create-btn{background:linear-gradient(135deg,#ffbe0b,#ff006e);color:#fff;box-shadow:0 6px 15px #ffbe0b66}.create-btn:hover{transform:translateY(-4px);box-shadow:0 12px 30px #ffbe0b99}.join-btn{background:linear-gradient(135deg,#00d9ff,#00a8cc);color:#fff;box-shadow:0 6px 15px #00d9ff66}.join-btn:hover{transform:translateY(-4px);box-shadow:0 12px 30px #00d9ff99}.home-divider{text-align:center;font-size:1.2em;color:#999;font-weight:600;letter-spacing:2px;margin:10px 0}.home-footer{text-align:center;color:#666;font-size:1em;line-height:1.6;padding-top:20px;border-top:2px solid #eee}.invite-header{display:none}.invite-buttons-group{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}.invite-btn-footer,.join-game-btn-footer{flex:1;min-width:140px;padding:12px 18px;border:none;border-radius:8px;font-size:.95em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1)}.invite-btn-footer{background:linear-gradient(135deg,#00d9ff,#00a8cc);color:#fff;box-shadow:0 6px 15px #00d9ff66}.invite-btn-footer:hover{transform:translateY(-3px);box-shadow:0 8px 20px #00d9ff99}.join-game-btn-footer{background:linear-gradient(135deg,#6c757d,#495057);color:#fff;box-shadow:0 6px 15px #6c757d66}.join-game-btn-footer:hover{transform:translateY(-3px);box-shadow:0 8px 20px #6c757d99}.current-room-info-footer{color:#2c3e50;font-weight:700;padding:12px 15px;background:#e8f4f8;border-radius:8px;border-left:4px solid #00D9FF;font-size:.95em;text-align:center;margin-top:15px}.invite-btn-header,.join-game-btn-header{display:none}.join-screen{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f1e,#1a1a2e);min-height:100vh}.join-container{background:#fff;border-radius:20px;box-shadow:0 30px 80px #0006;padding:50px;max-width:700px;width:100%}.join-title{text-align:center;margin-bottom:40px}.join-title h1{font-size:3em;font-weight:900;background:linear-gradient(135deg,#00d9ff,#ff006e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px}.join-title p{font-size:1.2em;color:#2c3e50;font-weight:600}.join-content{display:grid;grid-template-columns:1fr 1fr;gap:30px}.join-form{display:flex;flex-direction:column;gap:20px}.join-error-banner{background:#fff0f0;border:1.5px solid #ff4d4d;border-radius:8px;padding:10px 14px;color:#c0000c;font-size:.92em;font-weight:600}.join-warn-banner{background:#fff8e1;border-color:#f59f00;color:#7a5500}.form-group{display:flex;flex-direction:column;gap:10px}.form-group label{font-weight:700;color:#2c3e50;font-size:1em}.form-group input{padding:12px 15px;border:3px solid #00D9FF;border-radius:8px;font-size:1em;transition:all .3s;background:#fff;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-user-select:text;user-select:text}.form-group input:focus{outline:none;border-color:#ff006e;box-shadow:0 0 0 4px #ff006e1a;transform:translateY(-2px)}.join-btn{padding:14px 20px;background:linear-gradient(135deg,#ffbe0b,#ff006e);color:#fff;border:none;border-radius:8px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 15px #ffbe0b66;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-user-select:none;user-select:none}.join-btn:hover{transform:translateY(-4px);box-shadow:0 10px 25px #ffbe0b99}.join-info{background:linear-gradient(135deg,#f8f9fa,#ecf0f1);padding:25px;border-radius:12px;border-left:6px solid #00D9FF}.join-info h3{color:#2c3e50;margin-bottom:15px;font-size:1.2em}.join-info ol{color:#333;font-size:.95em;line-height:1.8;margin-left:20px}.join-info li{margin-bottom:8px;font-weight:500}.back-to-main-btn{margin-top:25px;padding:12px 24px;background:linear-gradient(135deg,#6c757d,#495057);color:#fff;border:none;border-radius:8px;font-size:1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 15px #6c757d66;align-self:center}.back-to-main-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #6c757d99;background:linear-gradient(135deg,#5a6268,#3e4a53)}.back-to-main-btn:active{transform:translateY(-1px)}.setup-screen{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f1e,#1a1a2e);min-height:100vh}.setup-container{background:#fff;border-radius:20px;box-shadow:0 30px 80px #0006;padding:50px;max-width:900px;width:100%}.setup-title-section{text-align:center;margin-bottom:50px}.setup-title-section h1{font-size:4.5em;font-weight:900;letter-spacing:-2px;background:linear-gradient(135deg,#00d9ff,#ff006e,#ffbe0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px}.setup-title-section p{font-size:1.3em;color:#2c3e50;font-weight:600;letter-spacing:1px;margin-bottom:25px}.card-display-row{display:flex;justify-content:center;gap:15px;margin-bottom:40px}.playing-card{width:80px;height:120px;background:#fff;border:3px solid #2c3e50;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1.8em;font-weight:700;box-shadow:0 8px 20px #0003;animation:float 3s ease-in-out infinite}.playing-card:nth-child(1){animation-delay:0s}.playing-card:nth-child(2){animation-delay:.2s}.playing-card:nth-child(3){animation-delay:.4s}.playing-card:nth-child(4){animation-delay:.6s}.playing-card:nth-child(5){animation-delay:.8s}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.setup-content{display:grid;grid-template-columns:1fr 1fr;gap:40px}@keyframes ruleSlideIn{0%{opacity:0;transform:translate(-18px)}to{opacity:1;transform:translate(0)}}@keyframes iconPop{0%{transform:scale(1)}50%{transform:scale(1.25) rotate(-8deg)}to{transform:scale(1)}}.rules{padding:20px;background:linear-gradient(145deg,#f8faff,#f3f0ff);border-radius:18px;border:1.5px solid #e2e8f8;box-shadow:0 2px 12px #5050b412}.rules-header{margin-bottom:14px}.rules-badge{display:inline-block;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;font-size:.78em;font-weight:800;letter-spacing:1.2px;text-transform:uppercase;padding:4px 14px;border-radius:20px;box-shadow:0 2px 8px #6366f159}.rules-grid{display:flex;flex-direction:column;gap:8px}.rule-card{display:flex;align-items:center;gap:14px;padding:11px 14px;border-radius:13px;border:1.5px solid transparent;cursor:default;opacity:0;animation:ruleSlideIn .38s ease-out forwards;transition:transform .2s ease,box-shadow .2s ease}.rule-card:nth-child(1){animation-delay:.05s}.rule-card:nth-child(2){animation-delay:.13s}.rule-card:nth-child(3){animation-delay:.21s}.rule-card:nth-child(4){animation-delay:.29s}.rule-card:nth-child(5){animation-delay:.37s}.rule-card:hover{transform:translate(5px) scale(1.015);box-shadow:0 6px 20px #0000001a}.rule-card:hover .rule-emoji{animation:iconPop .4s ease}.rule-icon-wrap{position:relative;flex-shrink:0;width:46px;height:46px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#ffffffa6;box-shadow:0 2px 6px #00000014}.rule-step{position:absolute;top:-6px;right:-6px;width:16px;height:16px;border-radius:50%;background:#00000073;color:#fff;font-size:.6em;font-weight:800;display:flex;align-items:center;justify-content:center;line-height:1}.rule-emoji{font-size:1.5em;display:block;transition:transform .2s}.rule-body{display:flex;flex-direction:column;gap:4px;flex:1}.rule-title{font-size:.82em;font-weight:800;text-transform:uppercase;letter-spacing:.7px}.rule-desc{font-size:.88em;line-height:1.45;display:flex;flex-wrap:wrap;gap:5px;align-items:center;color:inherit}.rule-pill{display:inline-block;border-radius:20px;padding:2px 10px;font-size:.85em;font-weight:700;white-space:nowrap}.pill-1v1,.pill-2v2{background:#ffffffbf;border:1px solid rgba(0,0,0,.12)}.rule-note{display:block;width:100%;font-size:.82em;font-style:italic;opacity:.75;margin-top:1px}.rule-goal{background:linear-gradient(135deg,#e8f5e9,#d0f0d0);border-color:#66bb6a}.rule-goal .rule-title{color:#2e7d32}.rule-goal .rule-desc{color:#388e3c}.rule-goal .rule-icon-wrap{background:#66bb6a2e}.rule-goal .rule-step{background:#2e7d32}.rule-players{background:linear-gradient(135deg,#e3f2fd,#c8e6fa);border-color:#42a5f5}.rule-players .rule-title{color:#0d47a1}.rule-players .rule-desc{color:#1565c0}.rule-players .rule-icon-wrap{background:#42a5f52e}.rule-players .rule-step{background:#0d47a1}.rule-wild{background:linear-gradient(135deg,#fff8e1,#ffecb0);border-color:#ffc107}.rule-wild .rule-title{color:#e65100}.rule-wild .rule-desc{color:#bf360c}.rule-wild .rule-icon-wrap{background:#ffc10733}.rule-wild .rule-step{background:#e65100}.rule-single-j{background:linear-gradient(135deg,#fce4ec,#f9c8d8);border-color:#e91e63}.rule-single-j .rule-title{color:#880e4f}.rule-single-j .rule-desc{color:#ad1457}.rule-single-j .rule-icon-wrap{background:#e91e6326}.rule-single-j .rule-step{background:#880e4f}.rule-double-j{background:linear-gradient(135deg,#ede7f6,#d8caf0);border-color:#7e57c2}.rule-double-j .rule-title{color:#4527a0}.rule-double-j .rule-desc{color:#512da8}.rule-double-j .rule-icon-wrap{background:#7e57c226}.rule-double-j .rule-step{background:#4527a0}.sequences-selector{margin-top:25px;padding:20px;background:linear-gradient(135deg,#e8f4f8,#f0e6ff);border-radius:12px;border:2px solid #00D9FF}.sequences-selector h3{color:#2c3e50;margin:0 0 15px;font-size:1.2em;font-weight:700}.selector-buttons{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap}.sequence-btn{padding:12px 20px;background:#fff;color:#2c3e50;border:3px solid #00D9FF;border-radius:8px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 10px #00d9ff33;min-width:50px;text-align:center}.sequence-btn:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00d9ff66;background:#f0f8ff}.sequence-btn.active{background:linear-gradient(135deg,#00d9ff,#ff006e);color:#fff;border-color:#ffbe0b;box-shadow:0 8px 20px #ffbe0b80;transform:scale(1.1);font-weight:900}.selector-info{color:#2c3e50;font-size:.95em;margin:0;font-weight:600}.setup-divider{display:flex;align-items:center;gap:12px;margin:4px 0}.setup-divider:before,.setup-divider:after{content:"";flex:1;height:1px;background:#ccc}.setup-divider span{color:#888;font-size:.9em;font-weight:600;letter-spacing:1px}.join-section{display:flex;flex-direction:column;gap:12px}.join-section label{font-weight:700;color:#2c3e50;font-size:1.1em}.join-section input{padding:12px 16px;border:2px solid #ddd;border-radius:8px;font-size:1em;outline:none;transition:border-color .2s;text-transform:uppercase;letter-spacing:2px}.join-section input:focus{border-color:#00d9ff}.join-section .join-btn{padding:14px;background:linear-gradient(135deg,#00d9ff,#09b);color:#fff;border:none;border-radius:10px;font-size:1.05em;font-weight:700;cursor:pointer;transition:all .2s}.join-section .join-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #00d9ff66}.join-section .join-btn:disabled{opacity:.5;cursor:not-allowed}.setup-form{display:flex;flex-direction:column;gap:25px;justify-content:center}.setup-form label{font-weight:700;color:#2c3e50;font-size:1.1em;display:block;margin-bottom:15px}.player-input-group{display:flex;gap:10px;margin-bottom:20px}.player-input-group input{flex:1;padding:14px 16px;border:3px solid #00D9FF;border-radius:10px;font-size:1.05em;transition:all .3s;font-weight:500;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-user-select:text;user-select:text;background:#fff}.player-input-group input:focus{outline:none;border-color:#ff006e;box-shadow:0 0 0 4px #ff006e1a;transform:translateY(-2px)}.player-input-group button{padding:14px 20px;background:linear-gradient(135deg,#00d9ff,#ff006e);color:#fff;border:none;border-radius:10px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 15px #00d9ff66;min-width:100px;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-user-select:none;user-select:none}.player-input-group button:hover{transform:translateY(-4px);box-shadow:0 10px 25px #ff006e80}.player-input-group button:active{transform:translateY(-2px)}.players-display{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.player-badge-container{display:flex;align-items:center;gap:5px;animation:slideInLeft .3s ease-out}.player-badge{padding:12px 18px;border-radius:20px;color:#fff;font-weight:700;font-size:1em;box-shadow:0 6px 15px #0003}.remove-player-btn{background:#f44;color:#fff;border:none;border-radius:50%;width:28px;height:28px;padding:0;font-size:1.2em;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 4px 10px #ff44444d;font-weight:700}.remove-player-btn:hover{background:red;transform:scale(1.15);box-shadow:0 6px 15px #ff000080}.remove-player-btn:active{transform:scale(.95)}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.start-btn{padding:16px;background:linear-gradient(135deg,#ffbe0b,#ff006e);color:#fff;border:none;border-radius:10px;font-size:1.2em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 8px 20px #ffbe0b66}.start-btn:hover:not(:disabled){transform:translateY(-4px);box-shadow:0 12px 30px #ffbe0b99}.start-btn:disabled{opacity:.5;cursor:not-allowed}.create-btns{display:flex;flex-direction:column;gap:10px}.ai-btn{padding:14px;background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;border:none;border-radius:10px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 18px #7c3aed59}.ai-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 26px #7c3aed8c}.ai-btn:disabled{opacity:.5;cursor:not-allowed}.conn-warning{text-align:center;color:#e65100;font-size:.85em;margin:0;animation:pulse 1.5s ease-in-out infinite}.toast-popup{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:#1a1a2e;color:#fff;padding:12px 24px;border-radius:30px;font-size:.95em;font-weight:600;box-shadow:0 8px 30px #0006;z-index:9999;pointer-events:none;animation:toastIn .2s ease,toastOut .3s ease 1.9s forwards;white-space:nowrap}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1}to{opacity:0;transform:translate(-50%) translateY(8px)}}.conn-banner{display:flex;align-items:center;gap:10px;background:#fff3e0;border:2px solid #ff9800;border-radius:10px;padding:10px 16px;color:#e65100;font-weight:700;font-size:.92em}.conn-dot{width:10px;height:10px;border-radius:50%;background:#ff9800;flex-shrink:0;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.teams-screen{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f1e,#1a1a2e)}.teams-container{background:#fff;border-radius:20px;box-shadow:0 30px 80px #0000004d;padding:50px;max-width:900px;width:100%}.teams-container h1{text-align:center;font-size:3em;background:linear-gradient(135deg,#00d9ff,#ff006e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:40px;font-weight:700}.teams-content{display:flex;flex-direction:column;gap:30px}.teams-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}.team-section{background:linear-gradient(135deg,#f8f9fa,#ecf0f1);padding:30px;border-radius:16px;border:3px solid #00D9FF;display:flex;flex-direction:column;gap:20px}.team-section h2{color:#2c3e50;font-size:1.5em;margin:0;text-align:center;font-weight:700;border-bottom:3px solid #00D9FF;padding-bottom:15px}.team-members{display:flex;flex-direction:column;gap:10px;min-height:60px;justify-content:center}.team-member{padding:12px 16px;border-radius:10px;color:#fff;font-weight:700;font-size:1.05em;text-align:center;box-shadow:0 6px 15px #00000026;animation:popIn .4s cubic-bezier(.34,1.56,.64,1)}@keyframes popIn{0%{opacity:0;transform:scale(.7)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.team-players{display:flex;flex-direction:column;gap:8px}.add-to-team-btn{padding:10px 16px;background:#fff;border:3px solid;border-radius:8px;font-weight:700;font-size:.95em;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);color:#333}.add-to-team-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #00d9ff4d;background:linear-gradient(135deg,#f8f9fa,#ecf0f1)}.confirm-teams-btn{padding:16px;background:linear-gradient(135deg,#ffbe0b,#ff006e);color:#fff;border:none;border-radius:10px;font-size:1.2em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 8px 20px #ffbe0b66;align-self:center;min-width:300px}.confirm-teams-btn:hover{transform:translateY(-4px);box-shadow:0 12px 30px #ffbe0b99}.confirm-teams-btn:active{transform:translateY(-2px)}.back-btn{padding:14px 24px;background:linear-gradient(135deg,#6c757d,#495057);color:#fff;border:none;border-radius:10px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 15px #6c757d66;align-self:center;min-width:200px}.back-btn:hover{transform:translateY(-4px);box-shadow:0 10px 25px #6c757d99;background:linear-gradient(135deg,#5a6268,#3e4a53)}.back-btn:active{transform:translateY(-2px)}.game-screen{background:linear-gradient(135deg,#1a1a2e,#0f0f1e);height:100vh;display:flex;flex-direction:column;overflow:hidden}.game-header{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:8px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 12px #2c3e504d;flex-shrink:0}.game-header h1{font-size:1.4em;margin:0}.current-turn{font-size:1em;font-weight:700;color:#ffbe0b;text-shadow:0 2px 8px rgba(255,190,11,.6);animation:pulse 2s ease-in-out infinite}.header-info{display:flex;gap:30px;align-items:center}.quit-btn{padding:5px 12px;background:linear-gradient(135deg,#f44,red);color:#fff;border:none;border-radius:6px;font-size:.85em;font-weight:700;cursor:pointer;transition:all .2s ease}.quit-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #f009;background:linear-gradient(135deg,red,#c00)}.quit-btn:active{transform:translateY(-1px)}.hints-btn{padding:5px 10px;background:#ffffff26;color:#fff;border:1.5px solid rgba(255,255,255,.3);border-radius:6px;font-size:.82em;font-weight:700;cursor:pointer;transition:all .2s ease}.hints-btn:hover{background:#ffffff40}.hints-btn.hints-on{background:#00e06440;border-color:#00e064;color:#a0ffcc}.timer{font-size:.95em;font-weight:700;background:#fff3;padding:4px 12px;border-radius:8px}.timer.warning{background:#ff6b6b;animation:pulse .5s infinite;box-shadow:0 4px 15px #ff6b6b80}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.status{font-size:.85em;font-weight:700;padding:4px 10px;border-radius:12px;background:#fff3}.status.connected{background:#51cf66;box-shadow:0 4px 15px #51cf6666}.status.disconnected{background:#ff6b6b;box-shadow:0 4px 15px #ff6b6b66}.game-content{display:grid;grid-template-columns:1fr 220px;gap:8px;padding:6px 10px 10px;flex:1;min-height:0;overflow:hidden}.board-section{display:flex;flex-direction:column;min-height:0;flex:1}.game-board{display:grid;grid-template-columns:repeat(10,1fr);grid-template-rows:repeat(10,1fr);gap:3px;background:#8a9eaa;padding:5px;border-radius:10px;flex:1;min-height:0;overflow:hidden;box-shadow:0 6px 24px #00000080}.board-cell{background:#fff;border-radius:3px;border:1px solid #d0d0d0;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;transition:filter .1s ease;-webkit-user-select:none;user-select:none;min-width:0;min-height:0;box-shadow:0 1px 2px #0000002e;gap:1px}.board-cell:hover:not(.corner-wild):not(.has-chip){filter:brightness(.92)}.board-cell.corner-wild{background:linear-gradient(135deg,#0d1e2e,#1a3a50);border-color:#00d9ff;border-width:2px;cursor:default}.board-cell.has-chip{cursor:default}.card-rank-top,.card-suit-top,.card-corner-suits,.corner-row,.chip,.chip-ghost,.valid-glow{pointer-events:none}.card-rank-top{font-size:clamp(7px,1.7vw,15px);font-weight:900;line-height:1;font-family:Georgia,serif;z-index:1;text-align:center}.card-suit-top{font-size:clamp(6px,1.4vw,13px);line-height:1;z-index:1;text-align:center}.card-corner-suits{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;pointer-events:none;z-index:1}.corner-row{display:flex;gap:clamp(2px,.5vw,5px);font-size:clamp(6px,1.5vw,13px);line-height:1;font-weight:700}.chip{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:3px;z-index:3;opacity:.85;animation:chipDrop .2s ease-out}@keyframes chipDrop{0%{opacity:0;transform:scale(.8)}to{opacity:.85;transform:scale(1)}}.chip-ghost{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:4;font-size:clamp(7px,1.5vw,13px);font-weight:900;opacity:.55;letter-spacing:-.5px;font-family:Georgia,serif;text-shadow:0 0 4px rgba(255,255,255,.9);white-space:nowrap}.board-cell.valid-move{outline:2px solid #00e064;outline-offset:-2px;background:#f0fff6!important}.valid-glow{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:3px;background:#00d9682e;z-index:2;animation:validPulse .9s ease-in-out infinite}@keyframes validPulse{0%,to{border-color:#00d96880;background:#00d96814}50%{border-color:#00d968;background:#00d9682e}}.board-cell.in-seq:after{content:"";position:absolute;background:#ffd700b3;z-index:4;pointer-events:none}.board-cell.in-seq.sequence-horizontal:after{width:100%;height:4px;top:50%;left:0;transform:translateY(-50%)}.board-cell.in-seq.sequence-vertical:after{width:4px;height:100%;left:50%;top:0;transform:translate(-50%)}.board-cell.in-seq.sequence-diagonal:after{width:140%;height:4px;top:50%;left:-20%;transform:rotate(45deg)}.sidebar{display:flex;flex-direction:column;gap:8px;overflow-y:auto;width:100%;min-height:0}.section{background:linear-gradient(135deg,#f8f9fa,#ecf0f1);padding:10px 12px;border-radius:10px;border:1.5px solid #e0e0e0;width:100%;flex-shrink:0}.section h3{color:#2c3e50;margin:0 0 8px;font-size:.9em;font-weight:700;border-bottom:2px solid #00D9FF;padding-bottom:6px}.player-section{background:linear-gradient(135deg,#2c3e50,#34495e);border:none}.player-section h3{color:#fff;border-color:#fff6}.current-player{padding:20px;border-radius:12px;color:#fff;text-align:center;box-shadow:0 8px 20px #0003}.player-name{font-size:1.5em;font-weight:700;margin-bottom:8px}.sequences{font-size:1.1em;opacity:.95}.hand-count{font-size:1em;opacity:.9;margin-top:8px}.score-list{display:flex;flex-direction:column;gap:8px}.score-item{display:flex;align-items:center;gap:10px;padding:12px;background:linear-gradient(135deg,#f8f9fa,#ecf0f1);border-radius:8px;border:2px solid #e0e0e0;transition:all .2s;font-weight:600}.score-item.active{background:linear-gradient(135deg,#ffbe0b,#ff006e);border-color:#00d9ff;box-shadow:0 6px 15px #ffbe0b4d;transform:scale(1.05);color:#fff}.score-value{margin-left:auto;background:#00000014;padding:4px 12px;border-radius:6px;font-weight:700}.hand-display{background:#fff;border-radius:10px;padding:12px;min-height:60px}.cards-list{display:flex;flex-wrap:wrap;gap:6px;padding:4px 0}.hand-card{position:relative;width:46px;height:64px;background:#fff;border-radius:5px;border:1.5px solid #bbb;box-shadow:0 2px 6px #0000002e;cursor:pointer;transition:transform .12s,box-shadow .12s;-webkit-user-select:none;user-select:none;flex-shrink:0}.hand-card:hover{transform:translateY(-5px);box-shadow:0 8px 18px #00000047}.hand-card-selected{border:2px solid #00D9FF;box-shadow:0 0 0 3px #00d9ff73,0 6px 16px #00000038;transform:translateY(-7px)}.hand-card-dim{opacity:.5;cursor:default}.hand-card-dim:hover{transform:none;box-shadow:0 2px 6px #0000002e}.hand-tl{position:absolute;top:4px;left:5px;display:flex;flex-direction:column;align-items:center;line-height:1;pointer-events:none}.hand-rank{font-size:11px;font-weight:900;font-family:Georgia,serif}.hand-suit-sm{font-size:9px;line-height:1}.hand-pip{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:20px;line-height:1;pointer-events:none}.hand-br{position:absolute;bottom:4px;right:5px;display:flex;flex-direction:column;align-items:center;transform:rotate(180deg);line-height:1;pointer-events:none}.no-cards{color:#999;text-align:center;padding:20px;font-style:italic}.hand-card-jack{width:52px;height:74px}.jack-portrait-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:4px;z-index:0;pointer-events:none}.jack-corner{background:#ffffffe0;border-radius:2px;padding:1px 2px;z-index:2!important}.jack-eye-badge{position:absolute;bottom:3px;left:50%;transform:translate(-50%);font-size:7px;font-weight:800;white-space:nowrap;padding:1px 4px;border-radius:3px;z-index:3;pointer-events:none;letter-spacing:.3px}.badge-single{background:#dc0000d9;color:#fff}.badge-double{background:#0064c8d9;color:#fff}.side-ad{position:fixed;top:50%;transform:translateY(-50%);width:160px;min-height:600px;z-index:10}.side-ad-left{left:8px}.side-ad-right{right:8px}.game-ad-banner{width:100%;min-height:60px;max-height:90px;background:#0000004d;flex-shrink:0;overflow:hidden}@media (max-width: 1300px){.side-ad{display:none}}.messages-section{background:#fff}.msg-list{background:linear-gradient(135deg,#f8f9fa,#ecf0f1);border-radius:10px;padding:12px;max-height:120px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.msg{color:#555;font-size:.9em;background:#fff;border-radius:6px;border-left:3px solid #00D9FF;padding:6px 6px 6px 10px}.sidebar::-webkit-scrollbar,.msg-list::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track,.msg-list::-webkit-scrollbar-track{background:#f0f0f0;border-radius:10px}.sidebar::-webkit-scrollbar-thumb,.msg-list::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#00d9ff,#ff006e);border-radius:10px}.finish-screen{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f1e,#1a1a2e);min-height:100vh}.finish-container{background:#fff;border-radius:20px;box-shadow:0 30px 80px #0006;padding:0;max-width:480px;width:100%;overflow:hidden;display:flex;flex-direction:column;gap:0}.finish-winner-banner{padding:36px 30px 28px;text-align:center;color:#fff}.finish-trophy{font-size:3em;margin-bottom:6px}.finish-winner-name{font-size:2.4em;font-weight:900;letter-spacing:-1px;text-shadow:0 2px 8px rgba(0,0,0,.25)}.finish-winner-label{font-size:1.1em;font-weight:700;letter-spacing:4px;opacity:.85;margin-top:4px}.finish-you-label{margin-top:10px;font-size:.95em;opacity:.75;font-style:italic}.final-scores{padding:20px 28px;border-bottom:1px solid #eee}.final-scores h3{color:#444;margin-bottom:12px;font-size:1em;font-weight:700;text-transform:uppercase;letter-spacing:1px}.final-score-item{display:flex;align-items:center;gap:10px;padding:8px 0;color:#333;font-weight:600;border-bottom:1px solid #f0f0f0}.final-score-item:last-child{border-bottom:none}.final-score-item.winner-row{color:#111;font-weight:800}.score-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.score-name{flex:1}.score-val{font-variant-numeric:tabular-nums;color:#666}.winner-row .score-val{color:#111}.view-board-btn{margin:16px 28px 0;padding:12px;background:#f0f8ff;border:2px solid #00D9FF;border-radius:10px;color:#006fa8;font-size:1em;font-weight:700;cursor:pointer;transition:background .2s;width:calc(100% - 56px)}.view-board-btn:hover{background:#d8f4ff}.finish-actions{display:flex;gap:12px;padding:16px 28px 28px}.final-board-overlay{width:100%;height:100vh;display:flex;flex-direction:column;background:#1a1a2e}.final-board-header{display:flex;align-items:flex-start;justify-content:space-between;padding:12px 20px;background:#ffffff14;color:#fff;flex-shrink:0;gap:16px}.final-board-header h2{font-size:1em;font-weight:700;margin-bottom:4px}.close-board-btn{background:#ffffff26;border:none;color:#fff;padding:8px 14px;border-radius:8px;cursor:pointer;font-weight:700;font-size:.9em}.close-board-btn:hover{background:#ffffff40}.final-board-view{flex:1;min-height:0}.seq-ring{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:3px;border:3px solid var(--seq-color);box-shadow:0 0 10px var(--seq-color),inset 0 0 6px color-mix(in srgb,var(--seq-color) 40%,transparent);z-index:6;pointer-events:none;animation:seqPulse 1.4s ease-in-out infinite}@keyframes seqPulse{0%,to{opacity:1}50%{opacity:.55}}.final-seq-cell{z-index:1}.seq-legend{display:flex;gap:14px;margin-top:4px;flex-wrap:wrap}.seq-legend-item{display:flex;align-items:center;gap:6px;color:#ffffffd9;font-size:.82em;font-weight:600}.seq-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.play-again-btn{flex:1;padding:13px;background:linear-gradient(135deg,#00d9ff,#ffbe0b);color:#fff;border:none;border-radius:10px;font-size:1em;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px #00d9ff59}.play-again-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #00d9ff8c}.restart-btn{flex:1;padding:13px;background:linear-gradient(135deg,#6c757d,#495057);color:#fff;border:none;border-radius:10px;font-size:1em;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #6c757d4d}.restart-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #6c757d80;background:linear-gradient(135deg,#5a6268,#3e4a53)}.invite-btn{padding:14px 24px;background:linear-gradient(135deg,#00d9ff,#00a8cc);color:#fff;border:none;border-radius:10px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 15px #00d9ff66;margin-top:10px}.invite-btn:hover{transform:translateY(-4px);box-shadow:0 10px 25px #00d9ff99;background:linear-gradient(135deg,#00b8ff,#09b)}.invite-btn:active{transform:translateY(-2px)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:20px;padding:40px;max-width:500px;width:90%;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideUp .4s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-content h2{font-size:2em;color:#2c3e50;margin-bottom:20px;font-weight:700}.modal-content p{color:#555;font-size:1.05em;margin-bottom:20px;font-weight:500}.modal-close{position:absolute;top:15px;right:15px;background:#f44;border:none;border-radius:50%;width:35px;height:35px;font-size:1.5em;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s;padding:0}.modal-close:hover{background:red;transform:scale(1.1)}.room-code-display{background:linear-gradient(135deg,#f0f0f0,#e8e8e8);border:3px solid #00D9FF;border-radius:12px;padding:25px;margin-bottom:25px;display:flex;flex-direction:column;align-items:center;gap:15px}.room-code-text{font-size:2.5em;font-weight:900;letter-spacing:4px;color:#ff006e;font-family:Courier New,monospace;text-shadow:0 2px 8px rgba(255,0,110,.3)}.invite-link-display{background:linear-gradient(135deg,#f0f0f0,#e8e8e8);border:3px solid #00D9FF;border-radius:12px;padding:15px;margin-bottom:25px;display:flex;flex-direction:column;gap:12px}.invite-input{padding:12px 15px;border:2px solid #00D9FF;border-radius:8px;font-size:.9em;font-family:Courier New,monospace;color:#333;background:#fff;word-break:break-all;resize:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-user-select:text;user-select:text}.copy-btn{padding:12px 20px;background:linear-gradient(135deg,#ffbe0b,#ff006e);color:#fff;border:none;border-radius:8px;font-size:1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 15px #ffbe0b66;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-user-select:none;user-select:none}.copy-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #ffbe0b99}.copy-btn:active{transform:translateY(-1px)}.divider{text-align:center;font-weight:700;color:#999;margin:20px 0;font-size:1.2em}.modal-close-btn{width:100%;padding:14px;background:linear-gradient(135deg,#6c757d,#495057);color:#fff;border:none;border-radius:8px;font-size:1.1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 15px #6c757d66}.modal-close-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #6c757d99;background:linear-gradient(135deg,#5a6268,#3e4a53)}.modal-close-btn:active{transform:translateY(-1px)}.lobby-screen{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0f1e,#1a1a2e);min-height:100vh;padding:20px}.lobby-container{background:#fff;border-radius:20px;box-shadow:0 30px 80px #0006;padding:40px;max-width:600px;width:100%;display:flex;flex-direction:column;gap:30px}.lobby-header{text-align:center;display:flex;flex-direction:column;gap:15px}.lobby-header h1{font-size:3.5em;font-weight:900;background:linear-gradient(135deg,#00d9ff,#ff006e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0}.lobby-header h2{font-size:1.8em;color:#2c3e50;margin:0;font-weight:600}.room-code{font-family:Courier New,monospace;background:#f0f0f0;padding:5px 10px;border-radius:8px;color:#ff006e;font-weight:700;font-size:1.3em}.lobby-header p{color:#666;font-size:1.1em;margin:0}.host-name-section{background:linear-gradient(135deg,#fff0f5,#f0f7ff);padding:20px;border-radius:12px;border:2px solid #FF006E;display:flex;flex-direction:column;gap:12px}.host-name-section h3{margin:0;color:#2c3e50;font-size:1.1em;font-weight:700}.host-name-input-group{display:flex;gap:10px;flex-wrap:wrap}.host-name-input{flex:1;min-width:200px;padding:12px 15px;border:2px solid #FF006E;border-radius:8px;font-size:1em;color:#333;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-user-select:text;user-select:text;background:#fff;transition:all .3s}.host-name-input:focus{outline:none;border-color:#00d9ff;box-shadow:0 0 0 3px #00d9ff1a}.set-name-btn{padding:12px 20px;background:linear-gradient(135deg,#ff006e,#ff4b7d);color:#fff;border:none;border-radius:8px;font-size:1em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 6px 15px #ff006e66;min-width:100px;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-user-select:none;user-select:none}.set-name-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #ff006e99}.set-name-btn:active{transform:translateY(-1px)}.invite-link-section h3{margin:0;color:#2c3e50;font-size:1.2em;font-weight:700}.invite-link-display{display:flex;gap:10px;flex-wrap:wrap}.invite-input{flex:1;min-width:250px;padding:12px 15px;border:2px solid #00D9FF;border-radius:8px;font-family:Courier New,monospace;font-size:.9em;color:#333;background:#fff;transition:all .3s}.invite-input:focus{outline:none;border-color:#ff006e;box-shadow:0 0 0 3px #ff006e1a}.copy-btn{background:linear-gradient(135deg,#00d9ff,#00a8cc);color:#fff;padding:12px 24px;border:none;border-radius:10px;font-size:1em;font-weight:700;cursor:pointer;transition:all .3s ease;align-self:center}.copy-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #00d9ff66}.lobby-content{display:flex;flex-direction:column;gap:25px}.lobby-content h3{font-size:1.4em;color:#2c3e50;margin:0;padding-bottom:10px;border-bottom:2px solid #00D9FF}.player-list{display:flex;flex-direction:column;gap:12px;min-height:100px;max-height:200px;overflow-y:auto;padding:15px;background:#f8f9fa;border-radius:12px;border:2px solid #e0e0e0}.player-item{padding:15px 20px;border-radius:10px;color:#fff;font-weight:700;font-size:1.1em;text-align:center;box-shadow:0 4px 12px #0003;transition:all .3s ease}.player-item:hover{transform:translate(5px);box-shadow:0 6px 16px #0000004d}.empty-message{text-align:center;color:#999;font-style:italic;padding:20px 0;margin:0}.lobby-actions{display:flex;flex-direction:column;gap:12px}.lobby-actions .start-btn{background:linear-gradient(135deg,#00d9ff,#ff006e);color:#fff;padding:18px 30px;border:none;border-radius:12px;font-size:1.2em;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 8px 20px #00d9ff4d}.lobby-actions .start-btn:not(:disabled):hover{transform:translateY(-4px);box-shadow:0 12px 30px #00d9ff80}.lobby-actions .start-btn:disabled{opacity:.5;cursor:not-allowed}.add-ai-btn{padding:12px 24px;background:linear-gradient(135deg,#6f42c1,#8e44ad);color:#fff;border:none;border-radius:10px;font-size:1em;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #6f42c166}.add-ai-btn:hover{transform:translateY(-3px);box-shadow:0 8px 25px #6f42c199}.add-ai-btn.remove-ai{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 4px 15px #e74c3c66}.add-ai-btn.remove-ai:hover{box-shadow:0 8px 25px #e74c3c99}.lobby-actions .back-btn{background:linear-gradient(135deg,#6c757d,#495057);color:#fff;padding:12px 24px;border:none;border-radius:10px;font-size:1em;font-weight:700;cursor:pointer;transition:all .3s ease}.lobby-actions .back-btn:hover{transform:translateY(-3px);box-shadow:0 8px 20px #0000004d}.lobby-info{background:#f0f7ff;padding:20px;border-radius:12px;border-left:4px solid #00D9FF}.lobby-info h4{margin:0 0 12px;color:#2c3e50;font-size:1.1em}.lobby-info ul{margin:0;padding-left:20px;list-style-type:none}.lobby-info li{margin-bottom:8px;color:#555;line-height:1.6}.lobby-info li:before{content:"✓ ";color:#00d9ff;font-weight:700;margin-right:8px}@media (max-width: 1200px){.game-content,.setup-content,.teams-grid{grid-template-columns:1fr}}@media (max-width: 900px){.game-content{grid-template-columns:1fr;gap:20px;padding:20px}.game-board{max-height:60vh}.home-container{padding:40px 30px}.home-card{padding:25px;border-radius:12px;gap:12px}.home-card h2{font-size:1.4em;margin-bottom:5px}.home-card p{font-size:.95em}.home-btn{padding:14px 24px;font-size:1em}.setup-screen{min-height:auto;padding:10px 0;display:flex;align-items:flex-start;justify-content:center}.setup-container{padding:20px;border-radius:15px;width:100%;max-width:100%;margin:10px auto}.setup-title-section{margin-bottom:30px;text-align:center}.setup-title-section h1{font-size:2.4em;margin-bottom:8px;letter-spacing:0}.setup-title-section p{font-size:1em;margin-bottom:15px;line-height:1.4}.card-display-row{gap:6px;margin-bottom:20px;flex-wrap:wrap;justify-content:center}.playing-card{width:50px;height:75px;font-size:1em;border-radius:8px;border-width:2px}.setup-content{display:flex;flex-direction:column;gap:20px;grid-template-columns:unset}.rules{padding:15px;border-left-width:4px;border-radius:10px}.rules h2{font-size:1.2em;margin-bottom:12px}.rules ul{gap:8px}.rules li{font-size:.9em;line-height:1.5}.sequences-selector{padding:15px;margin-top:15px}.sequences-selector h3{font-size:1.1em;margin-bottom:10px}.selector-buttons{gap:8px}.sequence-btn{padding:10px 16px;font-size:1em;min-width:45px}.join-screen{min-height:auto;padding:10px 0}.join-container{padding:20px;border-radius:15px;width:100%;max-width:100%;margin:10px auto}.join-title h1{font-size:2.2em;margin-bottom:10px}.join-title p{font-size:1em}.join-content{grid-template-columns:1fr;gap:20px}.lobby-screen{padding:10px;min-height:auto;display:flex;align-items:flex-start}.lobby-container{padding:20px;border-radius:15px;width:100%;max-width:100%;margin:10px auto;gap:20px}.lobby-header h1{font-size:2.5em;margin-bottom:8px}.lobby-header h2{font-size:1.3em;margin-bottom:10px}.lobby-header p{font-size:1em}.room-code{font-size:1.1em;padding:4px 8px}.copy-btn{width:100%;padding:12px;font-size:.95em}.host-name-section{padding:15px;border-radius:10px;gap:10px}.host-name-input-group{flex-direction:column;gap:8px}.host-name-input{min-width:unset;width:100%;padding:12px;font-size:1em}.set-name-btn{width:100%;padding:12px;font-size:.95em;min-width:unset}.invite-link-section h3{font-size:1.1em;margin-bottom:8px}.invite-link-display{flex-direction:column;gap:8px}.invite-input{min-width:unset;width:100%;padding:12px;font-size:.9em}.lobby-content{gap:15px}.player-list{gap:8px}.player-item{padding:12px;font-size:1em}.lobby-actions{flex-direction:column;gap:10px}.lobby-actions .start-btn,.lobby-actions .back-btn{width:100%;padding:12px;font-size:.95em}.teams-screen{min-height:auto;padding:10px 0;display:flex;align-items:flex-start}.teams-container{padding:20px;width:100%;max-width:100%;margin:10px auto}.teams-container h1{font-size:2.2em;margin-bottom:25px}.teams-grid{grid-template-columns:1fr;gap:20px}.team-section{padding:20px;border:2px solid #00D9FF}.team-section h2{font-size:1.2em;margin-bottom:12px;padding-bottom:10px}.confirm-teams-btn{min-width:200px;padding:14px;font-size:1em;width:100%}.game-board{gap:4px;padding:10px;border-radius:15px;aspect-ratio:auto;max-height:80vh}.board-cell{border:2px solid #2c3e50;border-radius:6px;font-size:.95em;min-height:36px;min-width:36px}.game-content{display:flex;flex-direction:column;grid-template-columns:unset;gap:15px;padding:15px}.board-section{width:100%;order:1}.board-section h2{font-size:1.3em;margin-bottom:10px}.side-panel,.sidebar{width:100%;order:2;max-width:100%;max-height:none}.game-header{flex-direction:column;gap:10px;font-size:.85em;flex-wrap:wrap}.room-code-display{padding:8px 10px;font-size:.95em;word-break:break-word}.status{font-size:1em;padding:8px 12px}.invite-btn-footer,.join-game-btn-footer,.setup-btn,.play-btn,.start-btn{padding:12px 16px;font-size:.95em;min-width:100px;width:auto}.invite-buttons-group{gap:10px;flex-wrap:wrap;justify-content:stretch}.invite-btn-footer,.join-game-btn-footer{flex:1;min-width:100px}input[type=text],input[type=password]{padding:12px;font-size:16px!important;border-radius:6px;width:100%;max-width:100%}.player-info{font-size:.95em;padding:12px}.score-item{padding:10px;font-size:.95em}.hand-section{max-height:none;width:100%}.hand-cards,.cards-list{gap:6px;flex-wrap:wrap;justify-content:flex-start}.hand-card{width:42px;height:58px}.messages-section,.msg-list{max-height:100px;font-size:.85em;padding:8px}.msg{font-size:.85em;padding:6px 8px;margin-bottom:4px}.join-info{font-size:.95em}.join-info li{margin-bottom:6px}.current-room-info-footer{padding:10px 12px;font-size:.9em;margin-top:10px}button{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.back-to-main-btn,.setup-btn,.play-btn,.invite-btn-footer,.join-game-btn-footer,.add-to-team-btn,.confirm-teams-btn,.sequence-btn{min-height:44px;min-width:44px}.player-list{max-height:200px;overflow-y:auto}}@media (max-width: 480px){.app{padding:8px;min-height:100vh}body{font-size:13px}.setup-screen,.join-screen,.teams-screen{min-height:auto;padding:8px 0}.setup-container,.join-container,.teams-container{padding:15px;border-radius:12px;width:100%;max-width:100%;margin:8px auto;box-shadow:0 15px 40px #0000004d}.setup-title-section h1,.join-title h1,.teams-container h1{font-size:2em;letter-spacing:-.5px;margin-bottom:8px}.setup-title-section p,.join-title p{font-size:.95em;margin-bottom:12px}.card-display-row{gap:4px;margin-bottom:15px}.playing-card{width:45px;height:68px;font-size:.9em;border-width:2px;border-radius:6px}.setup-content,.join-content,.teams-content{display:flex;flex-direction:column;gap:15px}.rules{padding:12px;border-left-width:3px;border-radius:8px}.rules h2,.team-section h2{font-size:1.1em;margin-bottom:10px}.rules li,.join-info li{font-size:.9em;line-height:1.4;margin-bottom:6px}.sequences-selector{padding:12px;margin-top:12px}.sequences-selector h3{font-size:1em;margin-bottom:8px}.selector-buttons{gap:6px;flex-wrap:wrap}.sequence-btn{padding:8px 12px;font-size:.9em;min-width:40px}.game-content{display:flex;flex-direction:column;padding:10px;gap:12px}.board-section{width:100%}.board-section h2{font-size:1.2em;margin-bottom:8px}.game-board{gap:2px;padding:6px;max-height:70vh;border-radius:12px}.board-cell{border:1.5px solid #2c3e50;font-size:.8em;min-height:28px;min-width:28px;border-radius:5px}.board-cell.corner-wild{border-width:2px}.game-header{gap:8px;font-size:.8em;flex-wrap:wrap;padding:8px}.room-code-display{padding:6px 8px;font-size:.85em;word-break:break-word}.status{font-size:.9em;padding:6px 10px}.timer{font-size:.85em}input[type=text],input[type=password],input[type=number]{font-size:16px!important;padding:12px 10px;width:100%;max-width:100%;border-radius:6px}.setup-btn,.play-btn,.invite-btn-footer,.join-game-btn-footer,.start-btn,.add-to-team-btn,.confirm-teams-btn,.sequence-btn{padding:12px 14px;font-size:.95em;min-height:44px;min-width:44px}.invite-buttons-group{gap:8px;margin-top:12px;flex-wrap:wrap}.confirm-teams-btn{width:100%;min-width:unset}.teams-grid{grid-template-columns:1fr;gap:15px}.team-section{padding:15px;border-width:2px}.player-info{font-size:.9em;padding:10px}.player-name{font-size:1.3em;margin-bottom:6px}.sequences,.hand-count{font-size:.95em}.score-list{gap:6px}.score-item{padding:8px 10px;font-size:.9em;gap:8px}.score-item.active{transform:scale(1.02)}.hand-section{max-height:none;width:100%}.hand-cards,.cards-list{gap:5px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding-bottom:8px}.hand-card{width:38px;height:54px}.messages-section{width:100%}.msg-list{max-height:80px;gap:4px;padding:8px}.msg{font-size:.8em;padding:5px 8px;margin-bottom:2px}.side-panel,.sidebar{width:100%;max-width:100%;max-height:auto;order:2}.back-to-main-btn{padding:12px 16px;font-size:.95em;width:auto;margin-top:12px}input[type=text],input[type=password]{font-size:16px!important}.room-code-display,.player-name,.team-member{overflow-wrap:break-word;word-break:break-word}.player-list,.hand-cards,.cards-list{overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.join-info{font-size:.9em;line-height:1.5}.join-info li{margin-bottom:5px}.current-room-info-footer{padding:10px;font-size:.85em;margin-top:8px}}@media (max-width: 768px){.game-screen{height:100dvh;height:100vh;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;background:linear-gradient(160deg,#0f0c29,#302b63,#24243e)}.game-screen .game-header{flex-direction:row;flex-wrap:nowrap;align-items:center;justify-content:space-between;gap:6px;padding:8px 12px;flex-shrink:0;background:linear-gradient(90deg,#1a1a3e,#2c2c5e);border-bottom:2px solid rgba(0,217,255,.3)}.game-screen .game-header h1{font-size:1.1em;margin:0;color:#00d9ff;letter-spacing:1px}.game-screen .current-turn{font-size:.82em;text-align:center;flex:1}.game-screen .header-info{gap:6px;flex-shrink:0}.game-screen .quit-btn{padding:5px 10px;font-size:.78em;border-radius:8px}.game-screen .timer{font-size:.82em;font-weight:700}.game-screen .game-content{display:flex;flex-direction:column;padding:8px;gap:10px;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.game-screen .board-section{width:100%;flex:none}.game-screen .board-section>h2{display:none}.game-screen .game-board{display:grid;grid-template-columns:repeat(10,1fr);grid-template-rows:repeat(10,1fr);width:calc(100vw - 16px);aspect-ratio:1 / 1;gap:2px;padding:5px;flex:none;max-height:none;min-height:unset;overflow:visible;box-sizing:border-box;background:#1e3a4a;border-radius:10px;box-shadow:0 4px 20px #00d9ff40,0 0 40px #0009;margin:0 auto}.game-screen .board-cell{min-width:0;min-height:0;border-radius:3px;border:1px solid #b8ccd6;gap:0;background:#fffef8;box-shadow:inset 0 1px 2px #00000014}.game-screen .board-cell.corner-wild{background:linear-gradient(135deg,#0d1e2e,#1a3a50);border-color:#00d9ff}.game-screen .board-cell.has-chip{border-color:transparent}.game-screen .board-cell.valid-move{border-color:#0f8;box-shadow:0 0 6px #0f89}.game-screen .card-rank-top{font-size:clamp(7px,2.9vw,14px);line-height:1;font-weight:900}.game-screen .card-suit-top{font-size:clamp(5px,2.4vw,11px);line-height:1}.game-screen .corner-row{font-size:clamp(6px,2.6vw,12px);color:#fff!important;gap:2px}.game-screen .corner-row span{color:#fff!important}.game-screen .chip{width:68%;height:68%;border-width:2px}.game-screen .chip-ghost{font-size:clamp(5px,1.8vw,8px)}.game-screen .sidebar{width:100%;display:flex;flex-direction:column;gap:10px}.game-screen .player-section{padding:8px 12px;border-radius:10px;background:#ffffff14;border:1px solid rgba(0,217,255,.2)}.game-screen .player-section h3{font-size:.9em;margin:0 0 4px;color:#fff}.game-screen .current-player{display:flex;flex-direction:row;gap:12px;padding:5px 8px;border-radius:8px;font-size:.82em;flex-wrap:wrap}.game-screen .hand-count,.game-screen .sequences{font-size:.82em;font-weight:600}.game-screen .section:has(.cards-list){background:#ffffff0f;border-radius:10px;padding:8px 10px;border:1px solid rgba(255,255,255,.1)}.game-screen .section:has(.cards-list) h3{font-size:.88em;margin-bottom:6px;color:#fff}.game-screen .cards-list{display:flex;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;gap:7px;padding:4px 2px 10px;scrollbar-width:thin;scrollbar-color:rgba(0,217,255,.4) transparent}.game-screen .hand-card{width:52px;height:72px;flex-shrink:0;border-radius:6px;box-shadow:0 2px 8px #0000004d;border:2px solid #d0d0d0}.game-screen .hand-card-jack{width:52px;height:72px;flex-shrink:0}.game-screen .hand-card-selected{border-color:#00d9ff!important;box-shadow:0 0 12px #00d9ffb3!important;transform:translateY(-5px)}.game-screen .jack-eye-badge{font-size:7px;padding:2px 3px;bottom:2px}.game-screen .score-list{display:flex;flex-direction:row;flex-wrap:wrap;gap:6px}.game-screen .score-item{flex:1;min-width:70px;padding:6px 8px;font-size:.8em;border-radius:8px}.game-screen .msg-list{max-height:55px;padding:4px 8px;border-radius:8px}.game-screen .msg{font-size:.75em;padding:3px 6px;margin:0}.game-screen .section>div[style*=color]{font-size:.8em!important}}
