.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);font-weight:600;border-radius:var(--radius-md);transition:all var(--transition-fast)}.button--sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:.875rem}.button--md{padding:var(--spacing-sm) var(--spacing-md);font-size:1rem}.button--lg{padding:var(--spacing-md) var(--spacing-lg);font-size:1.125rem}.button--primary{background:linear-gradient(135deg,var(--color-gold) 0%,var(--color-gold-light) 100%);color:#1a1a2e}.button--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #d4af3766}.button--primary:active:not(:disabled){transform:translateY(0)}.button--secondary{background:#ffffff1a;color:var(--color-text);border:1px solid rgba(255,255,255,.2)}.button--secondary:hover:not(:disabled){background:#ffffff26;border-color:#ffffff4d}.button--danger{background:var(--color-error);color:#fff}.button--danger:hover:not(:disabled){background:#d32f2f}.button--ghost{background:transparent;color:var(--color-text-muted)}.button--ghost:hover:not(:disabled){color:var(--color-text);background:#ffffff0d}.button--full-width{width:100%}.input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-label{font-size:.875rem;font-weight:500;color:var(--color-text-muted)}.input{padding:var(--spacing-sm) var(--spacing-md);font-size:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--color-text);transition:all var(--transition-fast)}.input:focus{border-color:var(--color-gold);background:#ffffff14}.input--error{border-color:var(--color-error)}.input-error{font-size:.75rem;color:var(--color-error)}.input::placeholder{color:var(--color-text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal{background:#1a2332;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.1);max-width:500px;width:100%;max-height:min(90vh,90dvh);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;box-shadow:var(--shadow-lg)}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1)}.modal__title{font-size:1.25rem;font-weight:600;margin:0}.modal__close{background:none;border:none;color:var(--color-text-muted);font-size:1.5rem;line-height:1;cursor:pointer;padding:var(--spacing-xs)}.modal__close:hover{color:var(--color-text)}.modal__content{padding:var(--spacing-lg)}.landing{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-background) 0%,#162447 100%);padding:var(--spacing-md)}.landing__content{text-align:center;max-width:400px;width:100%}.landing__logo{display:flex;justify-content:center;margin-bottom:var(--spacing-lg);animation:fadeInScale .6s ease-out}.landing__logo img{filter:drop-shadow(0 4px 20px rgba(212,175,55,.3));animation:gentleFloat 3s ease-in-out infinite}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes gentleFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.landing__title{font-size:3.5rem;font-weight:700;color:var(--color-gold);text-shadow:0 4px 20px rgba(212,175,55,.3);margin-bottom:var(--spacing-xs);letter-spacing:.15em}.landing__subtitle{font-size:1.1rem;color:#d4af37b3;margin-bottom:var(--spacing-xl);letter-spacing:.05em;font-weight:500;text-transform:uppercase}.landing__actions{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-xl)}.landing__player-info{padding-top:var(--spacing-lg);border-top:1px solid rgba(255,255,255,.1)}.landing__guest-name{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);flex-wrap:wrap;color:var(--color-text-muted);font-size:.875rem;margin:0}.landing__guest-name strong{color:var(--color-gold);font-size:1.1rem}.landing__change-name{background:#d4af371f;border:1px solid rgba(212,175,55,.4);border-radius:var(--radius-sm);color:var(--color-gold);cursor:pointer;padding:3px 10px;font-size:.8rem;font-weight:600;letter-spacing:.02em;transition:background var(--transition-fast)}.landing__change-name:hover{background:#d4af3740}.landing__name-edit{display:flex;gap:var(--spacing-sm);justify-content:center}.landing__name-edit .input-wrapper{flex:1;max-width:200px}.create-game-form,.join-game-form{display:flex;flex-direction:column;gap:var(--spacing-md)}@media (max-height: 650px){.create-game-form,.join-game-form{gap:var(--spacing-sm)}.radio-option{padding:var(--spacing-xs) var(--spacing-sm)}}.form-group{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group label{font-weight:500;color:var(--color-text-muted);font-size:.875rem}.radio-group{display:flex;gap:var(--spacing-sm)}.radio-option{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.radio-option:hover{background:#ffffff14}.radio-option:has(input:checked){background:#d4af3733;border-color:var(--color-gold);color:var(--color-gold)}.radio-option input{display:none}.radio-option span{font-weight:500}.toggle-group{display:flex}.toggle-option{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);width:100%}.toggle-option:hover{background:#ffffff14}.toggle-option:has(input:checked){background:#d4af3733;border-color:var(--color-gold);color:var(--color-gold)}.toggle-option input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-gold);cursor:pointer}.toggle-label{font-weight:500}.landing__version{margin-top:var(--spacing-lg);font-size:.75rem;color:var(--color-text-muted);opacity:.6;text-align:center}.landing__version-warning{margin-top:var(--spacing-xs);color:#ff9800;font-weight:600;opacity:1}.paused-games-list{display:flex;flex-direction:column;gap:1rem}.paused-game-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:.9rem;display:flex;flex-direction:column;gap:.5rem}.paused-game-card__header{display:flex;justify-content:space-between;align-items:center}.paused-game-card__code{font-weight:700;color:var(--color-gold, #ffd700);font-size:.95rem;letter-spacing:.05em}.paused-game-card__date{font-size:.75rem;color:#fff6}.paused-game-card__info{font-size:.8rem;color:#ffffff8c}.paused-game-card__players{display:flex;flex-wrap:wrap;gap:.4rem}.paused-game-card__player{font-size:.78rem;background:#ffffff14;border-radius:4px;padding:.15rem .4rem;color:#fffc}.paused-game-card__player--bot{color:#ffffff59}.landing__google-badge{font-size:.7rem;background:#4285f440;color:#7ab3f5;border-radius:4px;padding:.1rem .35rem;margin-left:.4rem;vertical-align:middle}.landing__menu-btn{position:absolute;top:1rem;right:1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#ffffffb3;font-size:1.1rem;width:36px;height:36px;cursor:pointer;display:flex;align-items:center;justify-content:center}.landing__signin-link{background:none;border:none;color:#ffffff8c;font-size:.85rem;cursor:pointer;padding:.25rem 0;text-decoration:underline;text-underline-offset:3px}.landing__signin-link:hover{color:#ffffffd9}.chat-panel{position:fixed;right:0;top:0;bottom:0;width:320px;background:#000000f2;border-left:1px solid rgba(255,255,255,.15);display:flex;flex-direction:column;z-index:1000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.chat-panel__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.1)}.chat-panel__tabs{display:flex;gap:var(--spacing-xs)}.chat-panel__tab{padding:var(--spacing-xs) var(--spacing-sm);background:transparent;border:none;color:var(--color-text-muted);font-size:.875rem;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--transition-fast)}.chat-panel__tab.active{color:var(--color-gold);border-bottom-color:var(--color-gold)}.chat-panel__close{background:none;border:none;color:var(--color-text);font-size:1.5rem;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast)}.chat-panel__close:hover{color:var(--color-gold)}.chat-panel__content{flex:1;overflow-y:auto;padding:var(--spacing-md)}.chat-panel__quick-messages{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.chat-panel__quick-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-height:80px}.chat-panel__quick-btn:hover{background:#d4af3733;border-color:var(--color-gold);transform:scale(1.05)}.chat-panel__quick-text{font-size:.875rem;color:var(--color-text);margin-bottom:var(--spacing-xs)}.chat-panel__quick-emoji{font-size:1.5rem}.chat-panel__emojis{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-sm)}.chat-panel__emoji-btn{aspect-ratio:1;font-size:1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.chat-panel__emoji-btn:hover{background:#d4af3733;border-color:var(--color-gold);transform:scale(1.1)}.chat-panel__custom{display:flex;flex-direction:column;gap:var(--spacing-sm)}.chat-panel__input{width:100%;padding:var(--spacing-sm);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:var(--color-text);font-size:.875rem;font-family:inherit;resize:none}.chat-panel__input:focus{outline:none;border-color:var(--color-gold)}.chat-panel__custom-footer{display:flex;justify-content:space-between;align-items:center}.chat-panel__char-count{font-size:.75rem;color:var(--color-text-muted)}@media (max-width: 768px){.chat-panel{width:100%}.chat-panel__quick-messages{grid-template-columns:repeat(2,1fr)}.chat-panel__emojis{grid-template-columns:repeat(5,1fr)}}.chat-messages{position:absolute;left:50%;transform:translate(-50%);display:flex;gap:var(--spacing-xs);z-index:400;pointer-events:none;max-width:380px;width:90%;height:33%;overflow:hidden}.chat-messages--others{top:0;flex-direction:column;justify-content:flex-start;align-items:center}.chat-messages--me{bottom:0;flex-direction:column-reverse;justify-content:flex-start;align-items:center}.chat-message{background:#000000bf;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);opacity:0;transform:translateY(8px);transition:opacity .3s ease-out,transform .3s ease-out;text-align:center;box-shadow:0 2px 8px #0006;white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}.chat-messages--others .chat-message{transform:translateY(-8px)}.chat-message.visible{opacity:1;transform:translateY(0)}.chat-message.fading{opacity:0;transition:opacity .5s ease-out,transform .5s ease-out}.chat-message--me{border-left:3px solid var(--color-gold)}.chat-message__name{color:var(--color-gold);font-weight:600;margin-right:var(--spacing-xs);font-size:1rem}.chat-message__text{color:var(--color-text);font-size:1.15rem}.chat-message__emoji{font-size:2em;line-height:1;vertical-align:middle}@media (max-width: 768px){.chat-message__name,.chat-message__text{font-size:1rem}.chat-message{padding:var(--spacing-xs) var(--spacing-sm)}}.lobby{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-background) 0%,#162447 100%);padding:var(--spacing-md)}.lobby .chat-messages--others{top:auto;bottom:50%;flex-direction:column-reverse;justify-content:flex-start}.lobby .chat-messages--me{bottom:auto;top:50%}.lobby__content{text-align:center;max-width:500px;width:100%}.lobby__title{font-size:2rem;font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-lg)}.lobby__code-section{margin-bottom:var(--spacing-lg)}.lobby__code-label{display:block;font-size:.875rem;color:var(--color-text-muted);margin-bottom:var(--spacing-sm)}.lobby__code-box{display:inline-flex;align-items:center;gap:var(--spacing-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md)}.lobby__code{font-size:1.5rem;font-weight:700;letter-spacing:.05em;color:var(--color-gold)}.lobby__copy-btn,.lobby__share-btn{background:#ffffff1a;border:none;border-radius:var(--radius-sm);padding:var(--spacing-xs) var(--spacing-sm);color:var(--color-text);font-size:.75rem;cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.lobby__copy-btn:hover,.lobby__share-btn:hover{background:#fff3}.lobby__share-btn{border:1px solid rgba(212,175,55,.4);color:var(--color-gold)}.lobby__settings{display:flex;justify-content:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);color:var(--color-text-muted);font-size:.875rem}.lobby__players{margin-bottom:var(--spacing-lg)}.lobby__players h2{font-size:1rem;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.lobby__player-slots{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.lobby__player-slot{background:#ffffff08;border:1px dashed rgba(255,255,255,.1);border-radius:var(--radius-md);padding:var(--spacing-md);min-height:60px;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.lobby__player-slot--filled{background:#ffffff0d;border-style:solid;border-color:#ffffff26}.lobby__player-name{font-weight:500;display:flex;align-items:center;gap:var(--spacing-sm)}.lobby__host-badge,.lobby__bot-badge,.lobby__you-badge{font-size:.625rem;padding:2px 6px;border-radius:var(--radius-sm);font-weight:600;text-transform:uppercase}.lobby__host-badge{background:var(--color-gold);color:#1a1a2e}.lobby__bot-badge{background:#fff3;color:var(--color-text)}.lobby__you-badge{background:var(--color-success);color:#fff}.lobby__waiting{color:var(--color-text-muted);font-style:italic}.lobby__actions{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-lg)}.lobby__waiting-host{color:var(--color-text-muted);font-style:italic}.lobby__timer{font-size:.8rem;color:var(--color-text-muted);margin-bottom:var(--spacing-md);letter-spacing:.02em}.lobby__timer--urgent{color:#e74c3c;font-weight:600}.lobby__away-badge{font-size:.625rem;padding:2px 6px;border-radius:var(--radius-sm);font-weight:600;text-transform:uppercase;background:#ffa50040;color:orange}.lobby__remove-btn{background:none;border:none;color:#ffffff4d;font-size:1.1rem;line-height:1;cursor:pointer;padding:0 4px;margin-left:auto;transition:color var(--transition-fast)}.lobby__remove-btn:hover{color:#e74c3c}.lobby__footer{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md);margin-top:var(--spacing-sm)}.lobby__chat-btn{position:relative;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);color:var(--color-text);font-size:.875rem;cursor:pointer;transition:background var(--transition-fast);white-space:nowrap}.lobby__chat-btn:hover{background:#ffffff26}.lobby__chat-badge{position:absolute;top:-6px;right:-6px;background:var(--color-gold);color:#1a1a2e;font-size:.6rem;font-weight:700;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}.lobby__host-notice{background:#4caf5033;border:1px solid rgba(76,175,80,.5);color:var(--color-success, #4caf50);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md);font-weight:600;margin-bottom:var(--spacing-md);text-align:center;animation:fadeInDown .4s ease-out}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.lobby__confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000}.lobby__confirm-box{background:var(--color-surface, #1a1a2e);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:320px;width:90%;text-align:center}.lobby__confirm-box p{margin-bottom:var(--spacing-lg);font-size:1rem;color:var(--color-text)}.lobby__confirm-actions{display:flex;gap:var(--spacing-md);justify-content:center}.playing-card{position:relative;background:#fff;border-radius:var(--radius-md);box-shadow:var(--shadow-md);transition:transform var(--transition-fast),box-shadow var(--transition-fast),outline var(--transition-fast);-webkit-user-select:none;user-select:none;color:#000;z-index:1}.game-table__hand-cards .playing-card{z-index:500}.game-table__hand-cards .playing-card:hover{z-index:510}.game-table__hand-cards .playing-card--selected{z-index:520}.playing-card--sm{width:40px;height:56px;font-size:.625rem}.playing-card--md{width:69px;height:97px;font-size:1rem}.playing-card--lg{width:58px;height:81px;font-size:.85rem}@media (max-width: 768px){.playing-card--lg{width:45px;height:63px;font-size:.75rem}.playing-card--md{width:58px;height:81px;font-size:.875rem}.playing-card--sm{width:35px;height:49px;font-size:.6rem}}.playing-card--red{color:#dc143c}.playing-card__face{width:100%;height:100%;padding:4px;display:flex;flex-direction:column}.playing-card__corner{display:flex;flex-direction:column;align-items:flex-start;line-height:1;gap:1px}.playing-card__rank{font-weight:700;font-size:1.1em}.playing-card__suit{font-size:1em}.playing-card__center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.playing-card__suit-large{font-size:3em;opacity:1}.playing-card__back{width:100%;height:100%;background:#1a472a;border-radius:inherit;padding:4px;overflow:hidden}.playing-card__back-pattern{width:100%;height:100%;background:repeating-linear-gradient(45deg,transparent,transparent 3px,rgba(255,255,255,.1) 3px,rgba(255,255,255,.1) 6px);border:2px solid rgba(255,255,255,.2);border-radius:calc(var(--radius-md) - 4px)}.playing-card--playable{cursor:pointer}.playing-card--playable:not(.playing-card--selected):hover{transform:scale(1.08);box-shadow:var(--shadow-lg),0 0 20px #d4af374d}.playing-card--selected{outline:2px solid var(--color-gold);box-shadow:var(--shadow-lg),0 0 16px #d4af3799;cursor:pointer;transform:scale(1.15);transform-origin:bottom center}.game-table__hand-cards .playing-card:not(.playing-card--playable):not(.playing-card--face-down){opacity:.9;filter:saturate(.5) brightness(.85)}.trick-area .playing-card{opacity:1!important;filter:none!important}.player-info{position:relative;background:#0006;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);display:flex;flex-direction:row;align-items:center;overflow:hidden;box-sizing:border-box;transition:border-color var(--transition-normal),box-shadow var(--transition-normal),background var(--transition-normal)}.player-info--active{border-color:var(--color-gold);box-shadow:0 0 14px #d4af3759;animation:glow 2s infinite}.player-info--declarer{background:#d4af371a}.player-info--me{background:#4caf501a;border-color:#4caf504d}.player-info--disconnected{opacity:.5}.player-info--speaking{border-color:#4ecdc4;box-shadow:0 0 12px #4ecdc480;animation:speaking-pulse .8s ease-in-out infinite}@keyframes speaking-pulse{0%,to{box-shadow:0 0 8px #4ecdc466}50%{box-shadow:0 0 18px #4ecdc4cc}}.player-info__header{flex:1;min-width:0;display:flex;align-items:center;gap:4px;flex-wrap:nowrap;overflow:hidden;padding:6px 8px}.player-info__name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:3px;min-width:0}.player-info__rank-icon{font-size:15px;display:inline-block;flex-shrink:0}.player-info__bot-badge{font-size:10px;padding:1px 3px;background:#fff3;border-radius:var(--radius-sm);flex-shrink:0}.player-info__declarer-badge{font-size:13px;padding:1px 5px;background:var(--color-gold);color:#1a1a2e;border-radius:var(--radius-sm);font-weight:700;white-space:nowrap;flex-shrink:0}.player-info__mid-status{position:absolute;left:50%;transform:translate(-50%);font-size:15px;font-weight:700;white-space:nowrap;text-align:center;pointer-events:none}.player-info__mid-status--passed{color:#fff6;font-style:italic;font-weight:400}.player-info__mid-status--bid{color:var(--color-gold)}.player-info__mid-status--bid-outbid{color:#ffffff59}.player-info__mid-status--finalbid{color:#fff}.player-info__mid-status--declared{color:#ffffffa6;font-size:15px}.player-info__mid-status--wonbid{font-size:15px}.player-info__mid-status-sub{color:#ffffff4d;font-weight:400;font-style:normal;font-size:13px}.player-info__stats{display:grid;grid-template-columns:44px;width:44px;flex-shrink:0;padding:4px 0}.player-info__stat{display:flex;flex-direction:column;align-items:center;justify-content:center}.player-info__stat-label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;line-height:1.2}.player-info__stat-value{font-size:15px;font-weight:700;line-height:1.15}.player-info__bid,.player-info__passed,.player-info__bid-turn,.player-info__cards,.player-info__card-count,.player-info__turn-indicator{display:none}.player-info__disconnected-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;border-radius:inherit;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;color:var(--color-error)}.player-info--top,.player-info--bottom{min-width:308px;max-height:52px}.player-info--left,.player-info--right{min-width:308px;max-width:308px}@media (max-width: 768px) and (orientation: portrait){.player-info--top,.player-info--bottom,.player-info--left,.player-info--right{min-width:100%;max-width:100%;max-height:44px}}.bidding-panel{background:#000c;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md);max-width:500px;width:100%;position:relative;z-index:700}.bidding-panel__header,.bidding-panel__final{text-align:center;margin-bottom:var(--spacing-sm)}.bidding-panel__header h3,.bidding-panel__final h3{font-size:1rem;margin-bottom:var(--spacing-xs)}.bidding-panel__current{color:var(--color-gold);font-weight:500;font-size:.875rem}.bidding-panel__hint{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--spacing-xs)}.bidding-panel__selection{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.bidding-panel__tricks label,.bidding-panel__trump label{display:block;font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--spacing-xs);text-transform:uppercase;font-weight:600}.bidding-panel__trick-options{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.bidding-panel__trick-btn{width:44px;height:44px;border-radius:var(--radius-sm);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--color-text);font-weight:600;font-size:1.125rem;transition:all var(--transition-fast);cursor:pointer;position:relative;z-index:10}.bidding-panel__trick-btn:hover:not(:disabled){background:#ffffff26;transform:scale(1.05)}.bidding-panel__trick-btn.selected{background:#d4af3733;color:var(--color-gold);border-color:var(--color-gold);font-weight:700;box-shadow:0 0 12px #d4af3799}.bidding-panel__trick-btn:disabled{opacity:.3;cursor:not-allowed}.bidding-panel__trump-options{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.bidding-panel__trump-btn{flex:1;min-width:60px;min-height:52px;padding:var(--spacing-sm) var(--spacing-xs);border-radius:var(--radius-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--color-text);font-size:1.75rem;transition:all var(--transition-fast);cursor:pointer;position:relative;z-index:10}.bidding-panel__trump-btn.red{color:var(--color-hearts)}.bidding-panel__trump-btn:hover:not(:disabled){background:#ffffff26;transform:scale(1.05)}.bidding-panel__trump-btn.selected{background:#d4af374d;border-color:var(--color-gold);box-shadow:0 0 10px #d4af374d}.bidding-panel__trump-btn:disabled{opacity:.3;cursor:not-allowed}.bidding-panel__preview{text-align:center;padding:var(--spacing-xs) var(--spacing-sm);background:#ffffff0d;border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);font-size:.875rem}.bidding-panel__preview strong{color:var(--color-gold);font-size:1rem}.bidding-panel__invalid{display:inline-block;font-size:.75rem;color:var(--color-error);margin-left:var(--spacing-xs)}.bidding-panel__actions{display:flex;gap:var(--spacing-sm);position:relative;z-index:10}.bidding-panel__actions .button{flex:1;cursor:pointer;position:relative;z-index:10}@media (max-width: 768px) and (orientation: portrait){.bidding-panel{max-width:95%;padding:var(--spacing-xs) var(--spacing-sm)}.bidding-panel__header h3,.bidding-panel__final h3{font-size:.875rem}.bidding-panel__trick-btn{width:38px;height:38px;font-size:1rem}.bidding-panel__trump-btn{font-size:1.5rem;min-height:46px;padding:var(--spacing-xs)}}.declaration-panel{background:#000000f2;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--spacing-md);max-width:400px;width:100%;position:relative;z-index:700;box-shadow:0 8px 32px #000c}.declaration-panel__header{text-align:center;margin-bottom:var(--spacing-md)}.declaration-panel__header h3{font-size:1.125rem;margin-bottom:var(--spacing-xs)}.declaration-panel__total{color:var(--color-text-muted)}.declaration-panel__total strong{color:var(--color-gold);font-size:1.25rem}.declaration-panel__warning{margin-top:var(--spacing-sm);padding:var(--spacing-sm);background:#f443361a;border:1px solid rgba(244,67,54,.3);border-radius:var(--radius-sm);color:var(--color-error);font-size:.875rem}.declaration-panel__options{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.declaration-panel__option{position:relative;aspect-ratio:1;border-radius:var(--radius-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--color-text);font-size:1.125rem;font-weight:600;transition:all var(--transition-fast)}.declaration-panel__option:hover:not(:disabled){background:#ffffff1a;border-color:#fff3}.declaration-panel__option.selected{background:#ffffff26;color:var(--color-gold);border-color:var(--color-gold);font-weight:700;box-shadow:0 0 12px #d4af3799}.declaration-panel__option:disabled{opacity:.3;cursor:not-allowed}.declaration-panel__option.blocked{background:#f443361a;border-color:#f443364d;color:var(--color-error);opacity:1}.declaration-panel__blocked-x{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--color-error);pointer-events:none}.declaration-panel__hint{text-align:center;font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.declaration-panel__actions{margin-top:var(--spacing-md)}@media (max-width: 768px) and (orientation: portrait){.declaration-panel{max-width:95%;padding:var(--spacing-sm)}.declaration-panel__header h3{font-size:.875rem}.declaration-panel__options{grid-template-columns:repeat(7,1fr);gap:4px}.declaration-panel__option{font-size:.875rem}.declaration-panel__warning,.declaration-panel__hint{font-size:.7rem}}.trick-area{position:relative;display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);min-width:200px;min-height:200px}.trick-area--empty{justify-content:center}.trick-area__lead-hint{color:var(--color-text-muted);font-style:italic}.trick-area__position{display:flex;align-items:center;justify-content:center;min-height:60px}.trick-area__middle{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xl)}.trick-area__center{width:60px;height:60px;display:flex;align-items:center;justify-content:center}.trick-area__lead-suit{display:flex;flex-direction:column;align-items:center;gap:2px;background:#d4af3726;border:1px solid rgba(212,175,55,.5);border-radius:6px;padding:4px 6px;text-align:center}.trick-area__lead-label{font-size:.6rem;color:var(--color-gold);text-transform:uppercase;letter-spacing:.5px;font-weight:600;line-height:1}.trick-area__lead-symbol{font-size:1.5rem;line-height:1}.trick-area__card-wrapper{position:relative;display:flex;align-items:center;gap:var(--spacing-xs)}.trick-area__card{transition:transform var(--transition-normal);opacity:1!important}.trick-area__player-name{font-size:.7rem;color:var(--color-text-muted);white-space:nowrap;font-weight:500;padding:2px 6px;background:#00000080;border-radius:4px}.trick-area__player-name--waiting{opacity:.5}.trick-area__position--top .trick-area__card-wrapper,.trick-area__position--bottom .trick-area__card-wrapper,.trick-area__position--left .trick-area__card-wrapper,.trick-area__position--right .trick-area__card-wrapper{flex-direction:column-reverse}@keyframes cardPlay{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.trick-area__card-wrapper{animation:cardPlay .5s ease-out}.trick-area__card-wrapper .playing-card{opacity:1!important}@keyframes cardJustPlayed{0%,to{box-shadow:0 0 10px #d4af3780}50%{box-shadow:0 0 25px #d4af37}}.trick-area__card--just-played{animation:cardJustPlayed 1s ease-in-out 1}.trick-area--winner .trick-area__card--winner{box-shadow:0 0 20px var(--color-gold);animation:glow 1s infinite}@keyframes moveToTop{to{transform:translateY(-200px) scale(.5);opacity:0}}@keyframes moveToBottom{to{transform:translateY(200px) scale(.5);opacity:0}}@keyframes moveToLeft{to{transform:translate(-200px) scale(.5);opacity:0}}@keyframes moveToRight{to{transform:translate(200px) scale(.5);opacity:0}}.trick-area__card--collecting.to-top{animation:moveToTop .6s ease-in forwards}.trick-area__card--collecting.to-bottom{animation:moveToBottom .6s ease-in forwards}.trick-area__card--collecting.to-left{animation:moveToLeft .6s ease-in forwards}.trick-area__card--collecting.to-right{animation:moveToRight .6s ease-in forwards}@keyframes flyToTop{to{transform:translateY(-320px) scale(0);opacity:0}}@keyframes flyToBottom{to{transform:translateY(320px) scale(0);opacity:0}}@keyframes flyToLeft{to{transform:translate(-320px) scale(0);opacity:0}}@keyframes flyToRight{to{transform:translate(320px) scale(0);opacity:0}}.trick-area__card--flying.to-top{animation:flyToTop .6s ease-in forwards}.trick-area__card--flying.to-bottom{animation:flyToBottom .6s ease-in forwards}.trick-area__card--flying.to-left{animation:flyToLeft .6s ease-in forwards}.trick-area__card--flying.to-right{animation:flyToRight .6s ease-in forwards}.trick-area__pack{position:absolute;width:52px;height:72px;z-index:20;cursor:pointer;animation:packAppear .25s ease-out;transition:filter .15s ease}.trick-area__pack:hover{filter:brightness(1.3)}.trick-area__pack--top{top:0;left:50%;margin-left:-26px}.trick-area__pack--bottom{bottom:0;left:50%;margin-left:-26px}.trick-area__pack--left{left:0;top:50%;margin-top:-36px}.trick-area__pack--right{right:0;top:50%;margin-top:-36px}.trick-area__pack-card{position:absolute;top:0;left:0;transform-origin:center bottom}@keyframes packAppear{0%{transform:scale(.2);opacity:0}to{transform:scale(1);opacity:1}}.trick-area__inspect{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:200;display:flex;gap:6px;background:#000000e0;border:1px solid rgba(212,175,55,.6);border-radius:10px;padding:10px 14px;animation:inspectAppear .2s ease-out;pointer-events:none}.trick-area__inspect--fading{opacity:0;transition:opacity .5s ease}@keyframes inspectAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.85)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.trick-area__inspect-card{flex-shrink:0}.bidding-area{position:relative;display:flex;flex-direction:column;align-items:center;width:100%;padding:var(--spacing-sm) 0;gap:var(--spacing-sm)}.bidding-area__top,.bidding-area__bottom{display:flex;justify-content:center;align-items:center;min-height:36px}.bidding-area__middle{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:36px}.bidding-area__side{min-width:90px;display:flex;align-items:center;justify-content:center}.bidding-area__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;display:flex;align-items:center;justify-content:center}.bidding-area__name{display:flex;align-items:center;gap:5px;font-size:.82rem;font-weight:500;color:var(--color-text-muted);background:#00000073;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:4px 10px;white-space:nowrap;transition:all .2s}.bidding-area__name--active{color:var(--color-gold);border-color:var(--color-gold);background:#d4af371f;box-shadow:0 0 10px #d4af3740;font-weight:700}.bidding-area__arrow{font-size:.65rem;color:var(--color-gold);animation:bidding-arrow-pulse .8s ease-in-out infinite}@keyframes bidding-arrow-pulse{0%,to{opacity:1}50%{opacity:.25}}.bidding-area__bot{font-size:.6rem;color:var(--color-text-muted);opacity:.65}.round-results{background:#000000b3;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:500px;width:100%}.round-results__title{text-align:center;font-size:1.5rem;margin-bottom:var(--spacing-md)}.round-results__contract{text-align:center;color:var(--color-text-muted);margin-bottom:var(--spacing-lg)}.round-results__contract strong{color:var(--color-gold)}.round-results__table{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.round-results__header,.round-results__row{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr 1fr;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);align-items:center}.round-results__header{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.1)}.round-results__row{background:#ffffff08;border-radius:var(--radius-sm)}.round-results__row--me{background:#4caf501a;border:1px solid rgba(76,175,80,.3)}.round-results__player{font-weight:500;display:flex;align-items:center;gap:var(--spacing-xs)}.round-results__declarer-badge{font-size:.625rem;padding:1px 4px;background:var(--color-gold);color:#1a1a2e;border-radius:var(--radius-sm);font-weight:600}.round-results__result{font-size:.875rem}.round-results__result.success{color:var(--color-success)}.round-results__result.failure{color:var(--color-error)}.round-results__points{font-weight:700;text-align:right}.round-results__points.positive{color:var(--color-success)}.round-results__canceled{text-align:center;background:#dc35451f;border:1px solid rgba(220,53,69,.4);border-radius:var(--radius-sm);color:#ff6b6b;font-weight:600;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-lg);font-size:.95rem;letter-spacing:.3px}.round-results__next{text-align:center;color:var(--color-text-muted);font-style:italic;animation:pulse 2s infinite}.game-end{background:#000000f2;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:var(--spacing-xl);max-width:400px;width:100%;text-align:center;position:relative;z-index:1000;box-shadow:0 10px 40px #000c}.game-end__close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1.1rem;line-height:1;padding:6px 8px;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast)}.game-end__close:hover{color:var(--color-text);background:#ffffff14}.game-end__title{font-size:2rem;color:var(--color-gold);margin-bottom:var(--spacing-xl)}.game-end__standings{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.game-end__player{display:grid;grid-template-columns:60px 1fr auto;gap:var(--spacing-md);padding:var(--spacing-md);background:#ffffff08;border-radius:var(--radius-md);align-items:center}.game-end__player--rank-1{background:linear-gradient(90deg,#d4af3733,#d4af370d);border:1px solid rgba(212,175,55,.3)}.game-end__player--rank-2{background:linear-gradient(90deg,#c0c0c026,#c0c0c008)}.game-end__player--rank-3{background:linear-gradient(90deg,#cd7f3226,#cd7f3208)}.game-end__rank{font-weight:600;font-size:.875rem}.game-end__player--rank-1 .game-end__rank{color:var(--color-gold)}.game-end__name{font-weight:500;text-align:left}.game-end__score{font-weight:700;color:var(--color-gold)}.game-end__actions{display:flex;gap:var(--spacing-md);justify-content:center}.game-end__actions .button{min-width:120px}.winner-celebration{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#0000008c;animation:winner-bg-in .4s ease-out}.winner-celebration--lose{background:#000000b8}@keyframes winner-bg-in{0%{opacity:0}to{opacity:1}}.winner-celebration__canvas{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.winner-celebration__content{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 48px;background:#0a0f1ed9;border:2px solid rgba(212,175,55,.6);border-radius:24px;box-shadow:0 0 60px #d4af374d,0 20px 60px #000c;animation:winner-card-in .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes winner-card-in{0%{opacity:0;transform:scale(.5) translateY(40px)}to{opacity:1;transform:scale(1) translateY(0)}}.winner-celebration__crown{font-size:72px;animation:crown-bounce .8s cubic-bezier(.175,.885,.32,1.275) .3s both,crown-float 3s ease-in-out 1.1s infinite;display:block;line-height:1}@keyframes crown-bounce{0%{transform:scale(0) rotate(-20deg);opacity:0}to{transform:scale(1) rotate(0);opacity:1}}@keyframes crown-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.winner-celebration__message{font-size:2.6rem;font-weight:800;color:var(--color-gold, #FFD700);text-shadow:0 0 30px rgba(212,175,55,.8),0 2px 8px rgba(0,0,0,.6);margin:0;animation:winner-text-in .5s ease-out .4s both;letter-spacing:.02em}@keyframes winner-text-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.winner-celebration__subtitle{font-size:1.15rem;color:#ffffffbf;margin:0;animation:winner-text-in .5s ease-out .6s both}.winner-celebration__dismiss{font-size:.75rem;color:#ffffff4d;margin:8px 0 0;letter-spacing:.05em;text-transform:uppercase;animation:winner-text-in .5s ease-out 1.2s both}.winner-celebration--lose .winner-celebration__content{border-color:#ffffff26;box-shadow:0 0 40px #0009,0 20px 60px #000c;background:#080a12e6}.winner-celebration__crown--lose{font-size:64px;filter:grayscale(1) opacity(.6);animation:crown-bounce .8s cubic-bezier(.175,.885,.32,1.275) .3s both}.winner-celebration__message--lose{color:#ffffffb3;text-shadow:none;font-size:2rem}.winner-celebration__winner-name{font-size:.9rem;color:#ffffff59;margin:0;animation:winner-text-in .5s ease-out .8s both}.score-table{max-height:400px;overflow-y:auto}.score-table--empty{text-align:center;color:var(--color-text-muted);padding:var(--spacing-xl)}.score-table__table{width:100%;border-collapse:collapse;font-size:.875rem}.score-table__table th,.score-table__table td{padding:var(--spacing-sm) var(--spacing-md);text-align:center;border-bottom:1px solid rgba(255,255,255,.1)}.score-table__table th{font-weight:600;color:var(--color-text-muted);text-transform:uppercase;font-size:.75rem;background:#0003}.score-table__me{background:#4caf501a!important}.score-table__round{font-weight:500;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs)}.score-table__trump-mini{font-size:.75rem;opacity:.6}.score-table__cell{position:relative}.score-table__points{display:block;font-weight:600}.score-table__made .score-table__points{color:var(--color-success)}.score-table__missed .score-table__points{color:var(--color-text-muted)}.score-table__declaration{display:block;font-size:.625rem;color:var(--color-text-muted)}.score-table__totals{background:#0000004d}.score-table__totals td{font-size:1rem;border-bottom:none}.score-table__totals strong{color:var(--color-gold)}.score-table__void-round td{text-decoration:line-through;opacity:.4}.game-table{min-height:100vh;height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse at center,var(--color-table-green) 0%,var(--color-table-dark) 100%);overflow:hidden}@media (max-width: 768px){.game-table{height:calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom));min-height:calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom))}}.game-table__header{flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-md);background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1);min-height:40px}.game-table__info{display:flex;gap:var(--spacing-lg);font-size:.875rem;align-items:center}.game-table__trump{color:var(--color-gold)}.game-table__trump strong{font-size:1.25rem}.game-table__actions{display:flex;gap:var(--spacing-sm)}.game-table__area{flex:1 1 auto;display:grid;grid-template-areas:". top ." "left center right" ". bottom .";grid-template-columns:308px 1fr 308px;grid-template-rows:50px 1fr 50px;gap:var(--spacing-xs);padding:var(--spacing-xs) 10px;overflow:visible;min-height:0;position:relative;z-index:600}.game-table__position{display:flex;align-items:center;justify-content:center}.game-table__position--top{grid-area:top}.game-table__position--bottom{grid-area:bottom}.game-table__position--left{grid-area:left}.game-table__position--right{grid-area:right}.game-table__center{grid-area:center;display:flex;align-items:center;justify-content:center;min-height:150px;max-height:100%;overflow:visible;position:relative}.game-table__hand{flex:0 0 auto;padding:var(--spacing-sm) var(--spacing-md);background:linear-gradient(to top,#000000b3,#0006);border-top:2px solid rgba(212,175,55,.5);min-height:100px;max-height:180px;display:flex!important;flex-direction:column;justify-content:center;align-items:center;position:relative;z-index:500;width:100%;box-sizing:border-box;overflow:visible;flex-shrink:0}.game-table__hand-title{text-align:center;font-size:.75rem;color:var(--color-gold);margin-bottom:var(--spacing-sm);font-weight:600;text-transform:uppercase;letter-spacing:1px;opacity:.8}.game-table__hand-placeholder{text-align:center;color:var(--color-text-muted);font-style:italic;padding:var(--spacing-lg);font-size:.875rem}.game-table__hand-cards{display:flex;justify-content:center;align-items:center;gap:4px;flex-wrap:wrap;padding:4px}.game-table__hand-cards .playing-card{margin-left:0;transition:transform .2s,box-shadow .2s;animation:dealCard .5s ease-out backwards}.game-table__hand-cards .playing-card:not(.playing-card--selected):hover{transform:scale(1.05)}.game-table__play-action{position:absolute;bottom:calc(50px + var(--spacing-xs) + 8px);left:50%;transform:translate(-50%);z-index:600}.voice-controls{position:absolute;bottom:calc(50px + var(--spacing-xs) + 8px);left:8px;display:flex;align-items:center;gap:6px;z-index:600}.voice-btn{border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;background:#ffffff26;color:#fff;transition:background .2s,transform .15s}.voice-btn:hover{transform:scale(1.05);background:#ffffff40}.voice-btn--join{border-radius:20px;padding:0 14px;height:36px;gap:6px;font-size:.8rem;font-weight:500}.voice-btn--join.voice-btn--active{background:#dc32328c}.voice-btn--mic{width:36px;height:36px;border-radius:50%}.voice-btn--muted{background:#ffffff1f}.phase-announcement{text-align:center;padding:var(--spacing-xl);background:#00000080;border-radius:var(--radius-lg);animation:fadeIn .3s}.phase-announcement h2{font-size:1.5rem;margin-bottom:var(--spacing-md)}.phase-announcement p{color:var(--color-text-muted)}.waiting-message{text-align:center;padding:var(--spacing-lg);color:var(--color-text-muted);font-style:italic;animation:pulse 2s infinite}.game-menu{display:flex;flex-direction:column;gap:var(--spacing-md)}@media (max-width: 1024px) and (orientation: landscape){.game-table__area{grid-template-columns:140px 1fr 140px;grid-template-rows:45px 1fr 45px}.game-table__hand{min-height:80px;max-height:100px}}@media (max-width: 768px) and (orientation: portrait){.game-table__area{display:flex;flex-direction:column;padding:var(--spacing-xs);gap:var(--spacing-xs)}.game-table__position[data-player-index="0"]:not(.game-table__position--bottom){order:0}.game-table__position[data-player-index="1"]:not(.game-table__position--bottom){order:1}.game-table__position[data-player-index="2"]:not(.game-table__position--bottom){order:2}.game-table__position[data-player-index="3"]:not(.game-table__position--bottom){order:3}.game-table__center{order:10;flex:1;min-height:150px}.game-table__position--bottom{order:20}.game-table__position{width:100%;height:auto}.game-table__hand{min-height:90px;max-height:165px;padding:var(--spacing-xs) var(--spacing-sm)}.game-table__hand-cards{gap:3px;flex-wrap:wrap;align-content:center}.game-table__hand-cards .playing-card{margin-left:0}}@media (max-width: 768px){.game-table__header{padding:var(--spacing-xs) var(--spacing-sm);min-height:35px}.game-table__info{gap:var(--spacing-sm);font-size:.75rem}.game-table__trump strong{font-size:1rem}.game-table__status{font-size:.7rem;padding:4px var(--spacing-xs);min-height:20px}}@media (max-width: 768px){.game-table__area{grid-template-columns:120px 1fr 120px}.game-table__hand{min-height:90px;max-height:165px}}.game-menu__version{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid rgba(255,255,255,.1);font-size:.75rem;color:var(--color-text-muted);text-align:center;opacity:.7}.leaderboard-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:0}.leaderboard-tab{flex:1;background:none;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted);cursor:pointer;font-size:.875rem;font-weight:500;padding:var(--spacing-sm) var(--spacing-md);transition:color var(--transition-fast),border-color var(--transition-fast);margin-bottom:-1px}.leaderboard-tab:hover{color:var(--color-text)}.leaderboard-tab--active{color:var(--color-gold);border-bottom-color:var(--color-gold)}.game-end-bottom-actions{display:flex;gap:var(--spacing-md);justify-content:center;align-items:center;height:100%}.game-end-bottom-actions .button{min-width:130px;font-size:1rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes dealCard{0%{opacity:0;transform:translateY(-100px) translate(-50px) rotate(-10deg) scale(.5)}60%{transform:translateY(5px) rotate(2deg) scale(1.05)}to{opacity:1;transform:translateY(0) translate(0) rotate(0) scale(1)}}.chat-button{position:absolute;bottom:calc(50px + var(--spacing-xs) + 8px);right:8px;width:44px;height:44px;border-radius:50%;background:var(--color-gold);border:none;color:#000;font-size:1.25rem;cursor:pointer;box-shadow:0 4px 12px #0000004d;z-index:600;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.chat-button:hover{box-shadow:0 6px 16px #0006}.observer{display:flex;flex-direction:column;height:100vh;background:#0f1a0f;color:#d4d4d4;font-family:monospace;overflow:hidden}.observer__header{display:flex;align-items:center;gap:16px;padding:6px 16px;background:#1a2a1a;border-bottom:1px solid #2a4a2a;flex-shrink:0;flex-wrap:wrap;font-size:.85rem}.obs-header__title{font-weight:700;color:#7fff7f;font-size:.95rem}.obs-header__status{color:#888}.obs-header__status--live{color:#f44}.obs-header__phase{background:#2a4a2a;padding:2px 8px;border-radius:4px;color:#afa}.obs-header__trump{color:gold}.obs-header__contract{color:#87ceeb}.obs-header__round{color:#aaa}.obs-header__turn{color:#fff}.obs-header__turn strong{color:#7fff7f}.observer__table{display:grid;grid-template-areas:".    top    ." "left center right" ".    bottom .";grid-template-columns:1fr 2fr 1fr;grid-template-rows:1fr auto 1fr;flex:1;gap:4px;padding:8px;overflow:hidden}.obs-area--top{grid-area:top}.obs-area--left{grid-area:left}.obs-area--center{grid-area:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px}.obs-area--right{grid-area:right}.obs-area--bottom{grid-area:bottom}.obs-player{display:flex;flex-direction:column;gap:6px;background:#1a2a1a;border:1px solid #2a4a2a;border-radius:8px;padding:8px;height:100%;overflow:hidden}.obs-player--active{border-color:#7fff7f;box-shadow:0 0 8px #7fff7f4d}.obs-player--empty{background:transparent;border:none}.obs-player__header{display:flex;align-items:center;gap:6px;flex-shrink:0}.obs-player__name{font-weight:700;color:#eee;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.obs-player__stats{display:flex;flex-wrap:wrap;gap:8px;font-size:.78rem;color:#aaa;flex-shrink:0}.obs-player__hand{display:flex;flex-wrap:wrap;gap:2px;overflow-y:auto;flex:1}.obs-player__hand--vertical{display:grid;grid-template-columns:repeat(5,auto);justify-content:start;gap:2px;overflow-y:auto;flex:1}.obs-player__no-cards{color:#555;font-size:.8rem;align-self:center}.obs-card-wrapper{flex-shrink:0}.obs-badge{padding:1px 6px;border-radius:3px;font-size:.7rem;font-weight:700;white-space:nowrap}.obs-badge--bot{background:#1a3a5a;color:#87ceeb}.obs-badge--turn{background:#2a4a2a;color:#7fff7f}.obs-badge--away{background:#3a2a1a;color:#ffa07a}.obs-badge--pass{background:#3a1a1a;color:#ff6b6b}.obs-trick{background:#1a2a1a;border:1px solid #2a4a2a;border-radius:8px;padding:12px;min-width:200px;text-align:center}.obs-trick__label{font-size:.75rem;color:#888;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.obs-trick__cards{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;min-height:80px;align-items:center}.obs-trick__entry{display:flex;flex-direction:column;align-items:center;gap:4px}.obs-trick__player-name{font-size:.7rem;color:#aaa;white-space:nowrap}.obs-trick__empty{color:#444;font-size:1.5rem;line-height:80px}.obs-trick__lead{margin-top:8px;font-size:.8rem;color:gold}.obs-info{background:#1a2a1a;border:1px solid #2a4a2a;border-radius:6px;padding:8px 14px;font-size:.85rem;color:#ccc;text-align:center}.obs-error,.obs-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:12px;color:#ccc;font-family:monospace;background:#0f1a0f}.obs-error h2{color:#ff6b6b;margin:0}.obs-error__hint{color:#666;font-size:.85rem}.obs-error__hint code{background:#1a2a1a;padding:2px 6px;border-radius:3px}.error-toast{position:fixed;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);background:var(--color-error);color:#fff;padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-md);display:flex;align-items:center;gap:var(--spacing-md);box-shadow:var(--shadow-lg);z-index:1000}.error-toast__message{font-weight:500}.error-toast__close{background:none;border:none;color:#fff;font-size:1.5rem;line-height:1;cursor:pointer;opacity:.8}.error-toast__close:hover{opacity:1}.app{min-height:100vh;display:flex;flex-direction:column}.join-via-link{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-background) 0%,#162447 100%);padding:var(--spacing-md)}.join-via-link__box{text-align:center;max-width:400px;width:100%;display:flex;flex-direction:column;gap:var(--spacing-md)}.join-via-link__title{font-size:1.75rem;font-weight:700;color:var(--color-text);margin:0}.join-via-link__subtitle{color:var(--color-text-muted);margin:0}*{margin:0;padding:0;box-sizing:border-box}:root{--color-table-green: #1a472a;--color-table-dark: #0f2d1a;--color-card-white: #fffef5;--color-gold: #d4af37;--color-gold-light: #f4d03f;--color-spades: #1a1a2e;--color-hearts: #c62828;--color-diamonds: #c62828;--color-clubs: #1a1a2e;--color-active: #ffd700;--color-success: #4caf50;--color-error: #f44336;--color-neutral: #9e9e9e;--color-background: #0d1b2a;--color-text: #ffffff;--color-text-muted: #a0a0a0;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .2);--shadow-md: 0 4px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .4);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--color-background);color:var(--color-text);min-height:100vh;overflow:hidden;padding-top:max(env(safe-area-inset-top),20px);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}#root{min-height:100vh;display:flex;flex-direction:column}button{font-family:inherit;cursor:pointer;border:none;outline:none;transition:all var(--transition-fast)}button:disabled{cursor:not-allowed;opacity:.5}input{font-family:inherit;outline:none}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-gold{color:var(--color-gold)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes glow{0%,to{box-shadow:0 0 10px var(--color-gold)}50%{box-shadow:0 0 20px var(--color-gold),0 0 30px var(--color-gold)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes cardDeal{0%{transform:translate(-50%,-50%) scale(0);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.animate-pulse{animation:pulse 1.5s infinite}.animate-glow{animation:glow 2s infinite}.animate-shake{animation:shake .3s}.animate-fadeIn{animation:fadeIn .3s}.animate-slideUp{animation:slideUp .4s}
