*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a1a2e;--bg-card: #16213e;--bg-surface: #0f3460;--text: #eee;--text-dim: #aaa;--primary: #e94560;--primary-hover: #ff6b81;--secondary: #533483;--accent: #f1c40f;--green: #2ecc71;--red: #e74c3c;--blue: #3498db;--orange: #e67e22;--radius: 12px;--card-w: 88px;--card-h: 130px}html,body,#root{height:100%}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden}.app{min-height:100%;display:flex;flex-direction:column}.connection-banner{position:fixed;top:0;left:0;right:0;background:var(--red);color:#fff;text-align:center;padding:8px;z-index:1000;font-weight:600;animation:pulse 1.5s ease-in-out infinite}.btn{padding:10px 24px;border:none;border-radius:var(--radius);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;text-transform:uppercase;letter-spacing:.5px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{background:var(--bg-surface);color:var(--text);border:1px solid #555}.btn-secondary:hover:not(:disabled){background:#1a4a7a}.btn-hit{background:linear-gradient(135deg,var(--green),#27ae60);color:#fff;font-size:22px;padding:16px 48px;border-radius:16px;box-shadow:0 4px 15px #2ecc7166}.btn-hit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2ecc7180}.btn-stay{background:linear-gradient(135deg,var(--orange),#d35400);color:#fff;font-size:22px;padding:16px 48px;border-radius:16px;box-shadow:0 4px 15px #e67e2266}.btn-stay:hover{transform:translateY(-2px);box-shadow:0 6px 20px #e67e2280}input[type=text]{padding:12px 16px;border-radius:var(--radius);border:2px solid #444;background:var(--bg-card);color:var(--text);font-size:16px;outline:none;transition:border-color .2s}input[type=text]:focus{border-color:var(--primary)}.screen{flex:1;display:flex;flex-direction:column;padding:20px}.home-screen{justify-content:center;align-items:center;background:radial-gradient(ellipse at center,var(--bg-card) 0%,var(--bg) 70%)}.home-card{text-align:center;padding:48px;background:var(--bg-card);border-radius:24px;border:1px solid #333;box-shadow:0 20px 60px #00000080}.home-logo{margin-bottom:12px}.logo-flip{font-size:48px;font-weight:300;color:var(--text);letter-spacing:4px}.logo-seven{font-size:72px;font-weight:900;color:var(--primary);margin-left:8px}.home-subtitle{color:var(--text-dim);margin-bottom:32px;font-size:18px}.home-form{display:flex;flex-direction:column;gap:16px;align-items:center}.input-nick{width:280px;text-align:center;font-size:18px}.nick-input-wrapper{position:relative;width:280px}.nick-input-wrapper .input-nick{width:100%;padding-right:44px;padding-left:44px}.icon-picker-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;border:none;background:transparent;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s;padding:0;line-height:1;opacity:.85}.icon-picker-btn:hover{transform:translateY(-50%) scale(1.15);opacity:1}.icon-empty{color:var(--text-dim);font-size:16px;font-weight:700}.icon-picker-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;padding:10px;background:var(--bg-surface);border:1px solid #444;border-radius:12px;width:280px}.icon-option{width:38px;height:38px;border-radius:8px;border:2px solid transparent;background:var(--bg-card);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0}.icon-option:hover{transform:scale(1.08);border-color:var(--accent)}.icon-option.selected{border-color:var(--primary);background:#e9456026}.icon-none{color:var(--text-dim);font-size:20px;font-weight:300}.browse-screen{max-width:800px;margin:0 auto;width:100%}.browse-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.browse-header h2{flex:1}.create-room-form{display:flex;gap:12px;margin-bottom:20px;padding:16px;background:var(--bg-card);border-radius:var(--radius)}.input-room-name{flex:1}.room-list{display:flex;flex-direction:column;gap:8px}.empty-rooms{text-align:center;color:var(--text-dim);padding:48px;font-size:18px}.room-item{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-card);border-radius:var(--radius);border:1px solid #333;transition:border-color .2s}.room-item:hover{border-color:var(--primary)}.room-info{flex:1;display:flex;flex-direction:column;gap:4px}.room-name{font-weight:600;font-size:18px}.room-host{color:var(--text-dim);font-size:14px}.room-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.room-players{color:var(--text-dim);font-size:14px}.room-status-badge{padding:2px 8px;border-radius:8px;font-size:12px;font-weight:600;text-transform:uppercase}.room-status-badge.waiting{background:var(--green);color:#000}.room-status-badge.playing{background:var(--orange);color:#000}.mode-selector{display:flex;gap:6px}.mode-btn{padding:8px 16px;border-radius:var(--radius);border:2px solid #555;background:var(--bg-surface);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.mode-btn.active{border-color:var(--primary);background:var(--primary);color:#fff}.mode-btn:hover:not(.active){border-color:var(--text-dim)}.room-mode-badge{padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600;text-transform:uppercase}.room-mode-badges{display:inline-flex;gap:4px;align-items:center}.room-mode-badge.mode-classic{background:var(--blue);color:#fff}.room-mode-badge.mode-vengeance{background:var(--red);color:#fff}.room-mode-badge.mode-vengeance_brutal{background:#1a1a1a;color:var(--red);border:1px solid var(--red)}.mode-btn-brutal{border-color:#666!important}.mode-btn-brutal.active{background:#1a1a1a!important;border-color:var(--red)!important;color:var(--red)!important}.lobby-screen{justify-content:center;align-items:center}.lobby-card{width:100%;max-width:500px;padding:32px;background:var(--bg-card);border-radius:24px;border:1px solid #333}.lobby-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.lobby-header h2{flex:1}.lobby-room-id{text-align:center;color:var(--text-dim);margin-bottom:24px;font-size:14px}.lobby-room-id code{color:var(--accent);font-size:16px}.lobby-players-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.lobby-players h3{margin:0}.btn-add-bot{padding:4px 10px;border:1px solid var(--green);background:transparent;color:var(--green);border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.btn-add-bot:hover{background:#2ecc7126}.bot-badge{margin-right:4px;font-size:14px}.bot-tag{color:var(--text-dim);font-size:12px;font-weight:400;font-style:italic}.lobby-player.is-bot{background:#2ecc7114}.player-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.lobby-player{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--bg-surface);border-radius:8px}.lobby-player.is-me{border:1px solid var(--primary)}.lobby-player-name{flex:1;font-weight:500}.host-badge{background:var(--accent);color:#000;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:700}.btn-kick{margin-left:auto;width:28px;height:28px;border-radius:50%;border:1px solid #666;background:transparent;color:var(--red);font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;opacity:.5}.btn-kick:hover{opacity:1;background:#e74c3c26;border-color:var(--red)}.me-badge{background:var(--primary);color:#fff;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:700}.btn-start{width:100%;padding:14px;font-size:18px}.waiting-message{text-align:center;color:var(--text-dim);font-style:italic;padding:12px}.game-screen{padding:12px;gap:12px;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;display:flex;flex-direction:row;overflow:hidden}.game-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.game-top-bar{display:flex;align-items:center;gap:16px;padding:10px 16px;background:var(--bg-card);border-radius:var(--radius);border:1px solid #333;flex-shrink:0}.btn-leave-game{padding:8px 16px;font-size:13px;opacity:.5;transition:opacity .2s}.btn-leave-game:hover{opacity:1}.round-info{font-size:20px;font-weight:700;color:var(--accent)}.deck-info{display:flex;align-items:center;gap:8px;color:var(--text-dim)}.deck-mini{width:30px;height:42px}.deck-stack .card{box-shadow:2px 2px 0 -1px #1e325080,4px 4px 0 -1px #1e325040}.deck-stack.deck-thin .card{box-shadow:none}.my-score-display{margin-left:auto;font-size:18px}.score-animated{font-weight:700;color:var(--accent);font-size:24px}.players-grid{flex:1;display:flex;flex-wrap:wrap;gap:12px;align-content:flex-start;overflow-y:auto;min-height:0}.game-sidebar{width:300px;display:flex;flex-direction:column;gap:8px;flex-shrink:0;min-height:0;overflow:hidden}.player-area{width:calc(50% - 6px);padding:12px;background:var(--bg-card);border-radius:var(--radius);border:2px solid transparent;transition:border-color .3s,opacity .3s;position:relative}.player-area.current-turn{border-color:var(--accent);box-shadow:0 0 15px #f1c40f4d}.player-area.is-me{border-color:var(--primary)}.player-area.current-turn.is-me{border-color:var(--accent)}.player-area.player-busted{opacity:.6}.player-area.player-disconnected{opacity:.4}.player-area.targetable{border-color:#e74c3c;cursor:pointer;animation:targetPulse 1s ease-in-out infinite}.player-area.targetable:hover{border-color:#ff6b81;box-shadow:0 0 20px #e74c3c80;transform:scale(1.02)}.target-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#e74c3c26;border-radius:var(--radius);font-size:20px;font-weight:900;color:#e74c3c;z-index:6;pointer-events:none;letter-spacing:2px}@keyframes targetPulse{0%,to{box-shadow:0 0 5px #e74c3c4d}50%{box-shadow:0 0 20px #e74c3c99}}.player-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.player-name{font-weight:600;font-size:16px}.player-name .me-badge{font-size:11px;opacity:.7}.player-scores{display:flex;gap:10px;font-size:13px;color:var(--text-dim);align-items:center}.card-count{background:var(--bg-surface);color:var(--text);padding:1px 6px;border-radius:6px;font-weight:700;font-size:12px;border:1px solid #555}.total-score .score-value{color:var(--accent);font-weight:700}.status-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-12deg);font-size:24px;font-weight:900;padding:8px 20px;border-radius:8px;pointer-events:none;z-index:5;animation:stampIn .3s ease-out}.status-busted{background:var(--red);color:#fff}.status-stayed{background:var(--green);color:#000}.status-frozen{background:var(--blue);color:#fff}.status-disconnected{background:#666;color:#fff}.status-left{background:#444;color:#ccc;border:1px dashed #888}.player-area.player-left{opacity:.35}.scoreboard-row.is-left{opacity:.55}.scoreboard-left-tag{color:var(--text-dim);font-size:11px;font-style:italic}.status-flip7{background:linear-gradient(135deg,#f1c40f,#e67e22);color:#000;font-size:28px;padding:10px 24px;box-shadow:0 0 30px #f1c40f99}.player-cards{display:flex;flex-wrap:wrap;gap:6px;min-height:56px}.no-cards{color:var(--text-dim);font-style:italic;display:flex;align-items:center}.card{width:var(--card-w);height:var(--card-h);border-radius:10px;flex-shrink:0;position:relative;transition:transform .2s;box-shadow:0 0 10px #a0bef066,0 0 4px #b4d2ff40}[data-theme=light] .card{box-shadow:1px 2px 8px #00000040,0 1px 3px #0000001a}.card:hover{transform:translateY(-4px)}.card-tooltip-portal{position:fixed;transform:translate(-50%,-100%);background:#14141ef5;color:#fff;padding:8px 12px;border-radius:8px;max-width:260px;pointer-events:none;z-index:10000;box-shadow:0 4px 20px #0006;text-align:center;animation:tooltipIn .12s ease-out}.card-tooltip-portal.tooltip-below{transform:translate(-50%)}.card-tooltip-portal:after{content:"";position:absolute;left:50%;margin-left:-5px;border:5px solid transparent}.card-tooltip-portal:not(.tooltip-below):after{top:100%;border-top-color:#14141ef5}.card-tooltip-portal.tooltip-below:after{bottom:100%;border-bottom-color:#14141ef5}.card-tooltip-title{font-weight:700;font-size:14px;color:#fff;margin-bottom:2px;white-space:nowrap}.card-tooltip-desc{font-size:12px;color:#ccc;font-weight:400}@keyframes tooltipIn{0%{opacity:0}to{opacity:1}}.deck-mini{pointer-events:none}.card-targetable{cursor:pointer;outline:2px solid var(--accent);outline-offset:2px;animation:targetPulse 1s ease-in-out infinite}.card-targetable:hover{outline-color:var(--primary);transform:translateY(-6px) scale(1.05)}.card-selected{outline:3px solid var(--green);outline-offset:2px;transform:translateY(-6px)}.card-special{width:calc(var(--card-w) - 6px);height:calc(var(--card-h) - 8px);border:2px dashed rgba(241,196,15,.6);border-radius:10px}@keyframes cardAppear{0%{opacity:0;transform:scale(.7)}60%{opacity:1;transform:scale(1.06)}to{transform:scale(1)}}.card-deal{animation:cardAppear .3s ease-out both}@keyframes cardFly{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:1;transform:translate(var(--fly-dx, 0px),var(--fly-dy, 0px)) scale(1)}}@keyframes cardFlyToDiscard{0%{opacity:1;transform:translate(0) scale(1)}70%{opacity:1}to{opacity:0;transform:translate(var(--fly-dx, 0px),var(--fly-dy, 0px)) scale(.3)}}.card-flight-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:60}.flying-card{position:fixed;animation:cardFly var(--fly-duration, .5s) cubic-bezier(.2,.7,.3,1) forwards}.flying-card.to-discard{animation-name:cardFlyToDiscard}.discard-pile{display:flex;align-items:center;gap:6px;color:var(--text-dim);font-size:13px;margin-left:12px;opacity:.7}.discard-mini{width:26px;height:36px;transform:rotate(8deg);pointer-events:none;opacity:.6}.flip3-zone{display:flex;gap:6px;margin-left:16px;padding:6px 10px;background:#e67e2214;border-radius:10px}.flip3-slot,.flip3-slot .card{width:var(--card-w);height:var(--card-h)}.flip3-slot .card.card-special{width:calc(var(--card-w) - 6px);height:calc(var(--card-h) - 8px)}.flip3-slot-empty{width:var(--card-w);height:var(--card-h);border:2px dashed rgba(230,126,34,.3);border-radius:8px}.card-arriving{opacity:0!important}.card-bust-flipped{animation:bustFlip .5s ease-in-out}@keyframes bustFlip{0%{transform:rotateY(0) scale(1)}50%{transform:rotateY(90deg) scale(.95)}to{transform:rotateY(0) scale(1)}}@keyframes cardFlip{0%{transform:perspective(600px) rotateY(0)}50%{transform:perspective(600px) rotateY(90deg)}to{transform:perspective(600px) rotateY(0)}}@keyframes cardDiscard{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(40px) scale(.7) rotate(15deg)}}@keyframes stampIn{0%{transform:translate(-50%,-50%) rotate(-12deg) scale(2);opacity:0}to{transform:translate(-50%,-50%) rotate(-12deg) scale(1);opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card-flip{animation:cardFlip .6s ease-in-out}.card-discard{animation:cardDiscard .4s ease-in forwards}.scoreboard{background:var(--bg-card);border-radius:var(--radius);padding:12px;border:1px solid #333;flex-shrink:0}.scoreboard-title{font-size:15px;margin-bottom:8px}.target-score{color:var(--text-dim);font-weight:400;font-size:13px}.scoreboard-list{display:grid;grid-template-columns:24px minmax(40px,auto) 1fr max-content max-content;gap:4px 4px;align-items:center}.scoreboard-row{display:grid;grid-column:1 / -1;grid-template-columns:subgrid;align-items:center;padding:4px 6px;border-radius:6px}.scoreboard-row.is-me{background:#e945601f}.scoreboard-row.is-me{background:#e9456026}.scoreboard-rank{color:var(--text-dim);font-size:13px;width:28px}.scoreboard-name{flex:0 0 80px;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.scoreboard-bar-container{flex:1;height:12px;background:#1a2a3a;border-radius:6px;overflow:hidden;position:relative}.scoreboard-bar{height:100%;transition:width .6s ease-out;position:absolute;top:0;left:0}.scoreboard-bar-banked{background:var(--primary);border-radius:6px;z-index:2}.scoreboard-bar-pending{background:var(--green);border-radius:6px;z-index:1;opacity:.7;animation:pendingPulse 1.2s ease-in-out infinite}@keyframes pendingPulse{0%,to{opacity:.3}50%{opacity:.55}}.scoreboard-total{font-weight:700;color:var(--accent);font-size:14px;line-height:1;text-align:right}.scoreboard-pending{font-weight:700;color:var(--accent);font-size:14px;line-height:1;opacity:.5;white-space:nowrap}.game-log{background:var(--bg-card);border-radius:var(--radius);padding:12px;border:1px solid #333;flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.log-title{font-size:15px;margin-bottom:6px;flex-shrink:0}.log-entries{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.log-tabs{display:flex;gap:4px;margin-bottom:8px;flex-shrink:0;border-bottom:1px solid rgba(128,128,128,.2)}.log-tab{position:relative;padding:6px 12px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-dim);font-size:14px;font-weight:600;cursor:pointer;transition:all .15s}.log-tab:hover{color:var(--text)}.log-tab.active{color:var(--text);border-bottom-color:var(--primary)}.chat-unread-badge{display:inline-block;margin-left:6px;min-width:18px;height:18px;padding:0 5px;background:var(--primary);color:#fff;border-radius:9px;font-size:11px;font-weight:700;line-height:18px;text-align:center;vertical-align:middle;animation:pulse 1.5s ease-in-out infinite}.chat-panel{flex:1;display:flex;flex-direction:column;min-height:0;gap:6px}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.chat-empty{color:var(--text-dim);font-style:italic;font-size:13px;text-align:center;padding:20px 0}.chat-msg{font-size:13px;padding:4px 8px;border-radius:6px;background:#80808014;animation:slideUp .2s ease-out;word-wrap:break-word;overflow-wrap:break-word}.chat-msg-mine{background:#e945601f}.chat-msg-author{font-weight:700;color:var(--accent);margin-right:6px}.chat-msg-text{color:var(--text)}.chat-input-form{display:flex;gap:4px;flex-shrink:0}.chat-input{flex:1;padding:6px 10px;border:1px solid rgba(128,128,128,.3);border-radius:6px;background:var(--bg-surface);color:var(--text);font-size:13px;outline:none}.chat-input:focus{border-color:var(--primary)}.chat-send-btn{padding:6px 12px;background:var(--primary);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:12px;transition:background .15s}.chat-send-btn:hover:not(:disabled){background:var(--primary-hover)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.log-entry{font-size:13px;padding:4px 8px;border-radius:4px;animation:slideUp .2s ease-out}.log-info{color:var(--text-dim)}.log-action{color:var(--text)}.log-bust{color:var(--red);font-weight:600}.log-score{color:var(--green)}.log-special{color:var(--accent);font-weight:600}.log-system{color:var(--blue);font-style:italic}.game-actions{display:flex;align-items:center;padding:12px;flex-shrink:0;position:relative}.game-actions-center{flex:1;display:flex;justify-content:center;align-items:center}.action-prompt{display:flex;align-items:center;gap:12px;padding:12px 24px;background:#e74c3c33;border:2px solid var(--red);border-radius:var(--radius);animation:targetPulse 1.5s ease-in-out infinite}.action-prompt-text{font-size:18px;font-weight:600;color:var(--text)}.round-end-message{font-size:20px;font-weight:600;color:var(--accent);padding:16px 32px;background:var(--bg-card);border-radius:var(--radius);border:1px solid #444;animation:pulse 1.5s ease-in-out infinite}.pause-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:100;animation:fadeIn .3s ease-out}.game-over-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:100;animation:fadeIn .3s ease-out}.pause-card,.game-over-card{background:var(--bg-card);padding:40px;border-radius:24px;text-align:center;max-width:500px;width:90%;border:1px solid #444;position:relative;box-shadow:0 20px 60px #00000080}.game-over-close{position:absolute;top:12px;right:16px;width:32px;height:32px;border-radius:50%;border:1px solid #555;background:transparent;color:var(--text);font-size:22px;font-weight:400;cursor:pointer;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s;opacity:.6}.game-over-close:hover{opacity:1;background:#e74c3c26;border-color:var(--red)}.pause-card h3{font-size:24px;margin-bottom:12px}.pause-info{color:var(--text-dim);margin-top:8px}.game-over-title{font-size:32px;color:var(--accent);margin-bottom:16px}.game-over-winner{font-size:24px;margin-bottom:24px;color:var(--green);font-weight:700}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar-toggle,.sidebar-backdrop{display:none}@media (max-width: 1024px) and (min-width: 769px){:root{--card-w: 78px;--card-h: 115px}.game-sidebar{width:250px}.scoreboard{padding:10px}.scoreboard-name{max-width:60px}.game-log{padding:10px}.log-entry{font-size:12px}.game-top-bar{padding:8px 12px;gap:10px}.round-info{font-size:17px}.my-score-display{font-size:16px}.score-animated{font-size:20px}.player-area{width:calc(50% - 6px);padding:10px}.player-header{font-size:14px}.player-scores{font-size:12px;gap:6px}.btn-hit,.btn-stay{font-size:18px;padding:12px 36px}.btn-leave-game{padding:6px 12px;font-size:12px}.home-card{padding:32px}.logo-flip{font-size:40px}.logo-seven{font-size:60px}.lobby-card{max-width:450px;padding:24px}.browse-screen{max-width:700px}}@media (max-width: 900px) and (min-width: 769px){.game-sidebar{width:220px}.scoreboard-name{max-width:50px}.player-area{padding:8px}:root{--card-w: 70px;--card-h: 104px}}@media (max-width: 768px){.game-screen{flex-direction:column}.game-left{min-height:0;flex:1}.player-area{width:100%}:root{--card-w: 64px;--card-h: 95px}.btn-hit,.btn-stay{font-size:18px;padding:12px 32px}.game-sidebar{position:fixed;top:0;right:0;bottom:0;width:300px;transform:translate(100%);transition:transform .3s ease;z-index:200;background:var(--bg);border-left:1px solid #444;padding:16px;box-shadow:-4px 0 20px #0006;flex-direction:column;overflow-y:auto}.game-sidebar.sidebar-open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:199}.sidebar-toggle{display:flex;position:fixed;top:50%;right:0;transform:translateY(-50%);z-index:201;width:36px;height:56px;border:1px solid #555;border-right:none;border-radius:10px 0 0 10px;background:var(--bg-card);color:var(--text);font-size:16px;cursor:pointer;align-items:center;justify-content:center;box-shadow:-2px 0 8px #00000040;transition:right .3s ease}}.toast-container{position:fixed;top:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:9999;pointer-events:none}.toast{padding:12px 20px;border-radius:10px;font-size:15px;font-weight:600;animation:toastIn .3s ease-out;box-shadow:0 4px 20px #0006;max-width:360px}.toast-info{background:var(--bg-surface);color:var(--text);border:1px solid #555}.toast-error{background:#c0392b;color:#fff}.toast-success{background:#27ae60;color:#fff}.toast-special{background:linear-gradient(135deg,#f39c12,#e74c3c);color:#fff}@keyframes toastIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.card-img{width:100%;height:100%;object-fit:fill;border-radius:inherit;pointer-events:none}[data-theme=classic]{--bg: #e8e0cc;--bg-card: #f0e8d4;--bg-surface: #ddd4be;--text: #2a2520;--text-dim: #7a7060;--primary: #c0392b;--primary-hover: #a93226;--accent: #b8860b}[data-theme=classic] input[type=text]{background:#f0e8d4;color:#2a2520;border-color:#c9b99a}[data-theme=classic] .scoreboard-bar-container{background:#d5cbb0}[data-theme=classic] .scoreboard-bar{background:linear-gradient(90deg,#c0392b,#b8860b)}[data-theme=classic] .card{border-radius:6px;box-shadow:2px 3px 8px #3c280a59}[data-theme=classic] .card-special{border-color:#b48c3299}[data-theme=classic] .game-top-bar,[data-theme=classic] .scoreboard,[data-theme=classic] .game-log,[data-theme=classic] .player-area{border-color:#c9b99a}[data-theme=classic] .player-area.is-me{border-color:#c0392b}[data-theme=classic] .player-area.current-turn{border-color:#b8860b;box-shadow:0 0 12px #b8860b4d}[data-theme=classic] .deck-stack .card{box-shadow:2px 2px 0 -1px #8c785099,4px 4px 0 -1px #8c78504d}[data-theme=light]{--bg: #f0f2f5;--bg-card: #ffffff;--bg-surface: #e8ecf1;--text: #1a1a2e;--text-dim: #666;--primary: #e94560;--primary-hover: #d63851}[data-theme=light] input[type=text]{background:#fff;color:#1a1a2e;border-color:#ccc}[data-theme=light] .connection-banner{background:#e74c3c}[data-theme=light] .deck-stack .card{box-shadow:2px 2px 0 -1px #78828c99,4px 4px 0 -1px #78828c4d}[data-theme=light] .scoreboard-bar-container{background:#ccc}[data-theme=light] .scoreboard-bar-pending{background:#e67e22;opacity:.6}[data-theme=light] .log-entries{background:#00000005}[data-theme=mint]{--bg: #a0d4cc;--bg-card: rgba(255, 255, 255, .75);--bg-surface: rgba(255, 255, 255, .55);--text: #1a3a3a;--text-dim: #4a7a7a;--primary: #e04858;--primary-hover: #c83545;--secondary: #2a7a7a;--accent: #c87820;--green: #27a66b;--red: #d04050;--blue: #2890b8;--orange: #d07828}[data-theme=mint] body{background:linear-gradient(135deg,#6fc4b5,#8ed3c8,#a8ddd6,#b8e4e4,#bcdceb,#d0cce0);background-attachment:fixed}[data-theme=mint] body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;opacity:.35;filter:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='t'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23t)'/%3E%3C/svg%3E#t");pointer-events:none}[data-theme=mint] input[type=text]{background:#fffc;color:#1a3a3a;border-color:#90c8c0}[data-theme=mint] input[type=text]:focus{border-color:var(--primary)}[data-theme=mint] .home-screen{background:transparent}[data-theme=mint] .home-card{background:#fffc;border-color:#ffffff80;box-shadow:0 20px 60px #00505026;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=mint] .game-top-bar,[data-theme=mint] .scoreboard,[data-theme=mint] .game-log{border-color:#00646426;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=mint] .player-area{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-color:#0064641f}[data-theme=mint] .player-area.is-me{border-color:var(--primary)}[data-theme=mint] .player-area.current-turn{border-color:var(--accent);box-shadow:0 0 12px #c878204d}[data-theme=mint] .scoreboard-bar-container{background:#0050501f}[data-theme=mint] .card{box-shadow:1px 2px 10px #003c3c33,0 1px 3px #003c3c1a}[data-theme=mint] .deck-stack .card{box-shadow:2px 2px 0 -1px #3c645a80,4px 4px 0 -1px #3c645a40}[data-theme=mint] .card-special{border-color:#c8782080}[data-theme=mint] .btn-secondary{background:#fff9;border-color:#00646433}[data-theme=mint] .btn-secondary:hover:not(:disabled){background:#ffffffd9}[data-theme=mint] .room-item,[data-theme=mint] .lobby-card,[data-theme=mint] .create-room-form{background:#ffffffb3;border-color:#0064641f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}[data-theme=mint] .lobby-player{background:#ffffff80}[data-theme=mint] .toast-info{background:#ffffffe6;border-color:#00646433;color:#1a3a3a}[data-theme=mint] .game-sidebar{background:#a0d4ccf2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=mint] .pause-card,[data-theme=mint] .game-over-card{background:#ffffffd9;border-color:#00646426;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}[data-theme=mint] .mode-btn{background:#ffffff80;border-color:#00646433}[data-theme=mint] .mode-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}[data-theme=mint] .round-end-message{background:#ffffffb3;border-color:#00646426}[data-theme=mint] .connection-banner{background:var(--red)}[data-theme=mint] .sidebar-toggle{background:#fffc;border-color:#00646433}.settings-toggles{position:fixed;bottom:16px;right:16px;display:flex;gap:8px;z-index:500}.settings-toggles.in-game{right:320px}@media (max-width: 1024px) and (min-width: 901px){.settings-toggles.in-game{right:266px}}@media (max-width: 900px) and (min-width: 769px){.settings-toggles.in-game{right:236px}}@media (max-width: 768px){.settings-toggles.in-game{right:16px}}.theme-toggle,.sound-toggle{width:40px;height:40px;border-radius:50%;border:2px solid #555;background:var(--bg-card);color:var(--text);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 10px #0000004d;position:static}.theme-toggle:hover,.sound-toggle:hover{transform:scale(1.1)}.drum-score{display:inline-flex;overflow:hidden;line-height:1}.drum-minus{display:inline-block;line-height:1.15em;margin-right:1px}.drum-digit-wrapper{display:inline-block;width:.65em;height:1.15em;overflow:hidden;position:relative;text-align:center}.drum-digit{display:block;width:100%;height:1.15em;line-height:1.15em}.drum-digit-old{position:absolute;top:0;left:0;animation:drumRollOut .6s cubic-bezier(.4,0,.2,1) forwards}.drum-digit-new{position:absolute;top:0;left:0;animation:drumRollIn .6s cubic-bezier(.4,0,.2,1) forwards}@keyframes drumRollOut{0%{transform:translateY(0);opacity:1}to{transform:translateY(-120%);opacity:0}}@keyframes drumRollIn{0%{transform:translateY(120%);opacity:0}40%{opacity:1}to{transform:translateY(0);opacity:1}}.footer-links{position:fixed;bottom:12px;left:16px;z-index:500;display:flex;gap:16px;align-items:center}.contact-link{color:var(--text-dim);font-size:18px;text-decoration:none;opacity:.4;transition:opacity .2s;background:none;border:none;padding:0;font-family:inherit;cursor:pointer}.contact-link:hover{opacity:.8;text-decoration:underline}.contact-link[data-tooltip]{position:relative}.contact-link[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 10px);left:0;white-space:nowrap;background:var(--bg-card);border:1px solid #444;border-radius:10px;padding:10px 14px;font-size:15px;color:var(--text);box-shadow:0 8px 24px #00000080;opacity:0;transform:translateY(4px);pointer-events:none;transition:opacity .15s,transform .15s;z-index:1001}.contact-link[data-tooltip]:hover:after{opacity:1;transform:translateY(0)}.rules-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#000000a6;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.rules-modal{position:relative;width:100%;max-width:680px;background:var(--bg-card);border:1px solid #333;border-radius:20px;padding:32px 36px 40px;box-shadow:0 24px 70px #0009;color:var(--text);line-height:1.55}.rules-close{position:absolute;top:14px;right:16px;width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-surface);color:var(--text-dim);font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.rules-close:hover{background:var(--primary);color:#fff}.rules-title{font-size:26px;font-weight:800;margin-bottom:18px}.rules-title .logo-flip{font-size:26px;letter-spacing:2px}.rules-title .logo-seven{font-size:30px;margin-left:4px}.rules-modal p{color:var(--text);margin:0 0 12px;font-size:15px}.rules-modal strong{color:var(--text);font-weight:700}.rules-h{font-size:18px;font-weight:700;color:var(--primary);margin:24px 0 10px;padding-bottom:6px;border-bottom:1px solid #333}.rules-list{margin:0 0 12px;padding-left:22px}.rules-list li{margin-bottom:8px;font-size:15px}.rules-video{margin:18px 0;padding:12px 16px;background:var(--bg-surface);border-radius:12px;border:1px solid #333}.rules-video a{color:var(--primary);font-weight:600;text-decoration:none;font-size:15px}.rules-video a:hover{text-decoration:underline}.rules-mode-switch{display:flex;gap:8px;align-items:center;margin-bottom:8px}.rules-deck-total{color:var(--text-dim);font-size:13px;margin-left:auto}.rules-deck-hint{color:var(--text-dim);font-size:13px;margin-bottom:14px!important}.rules-deck{--card-w: 56px;--card-h: 83px;display:flex;flex-wrap:wrap;gap:16px 12px}.rules-deck-item{display:flex;flex-direction:column;align-items:center;gap:4px}.rules-deck-count{font-size:13px;font-weight:700;color:var(--text-dim)}.key-hint{font-size:11px;color:var(--text-dim);text-align:center;margin-top:4px}
