:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-synthesis:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--shadow-color: rgba(0, 0, 0, .07);--accent: #4f46e5;--accent-light: #7c3aed;--tag-success-bg: rgba(34, 197, 94, .1);--tag-success-text: #16a34a;--tag-success-border: rgba(34, 197, 94, .25);--tag-warning-bg: rgba(245, 158, 11, .1);--tag-warning-text: #d97706;--tag-warning-border: rgba(245, 158, 11, .25);--tag-error-bg: rgba(239, 68, 68, .1);--tag-error-text: #dc2626;--tag-error-border: rgba(239, 68, 68, .25);--btn-danger-text: #dc2626;--btn-danger-border: rgba(239, 68, 68, .4);--btn-danger-hover: rgba(239, 68, 68, .06);--card-default-bg: #818cf8;--sidebar-w: 240px}[data-theme=dark]{color-scheme:dark;--bg-primary: #0f172a;--bg-secondary: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--border-color: #334155;--shadow-color: rgba(0, 0, 0, .3);--tag-success-bg: rgba(34, 197, 94, .15);--tag-success-text: #4ade80;--tag-success-border: rgba(34, 197, 94, .3);--tag-warning-bg: rgba(245, 158, 11, .15);--tag-warning-text: #fbbf24;--tag-warning-border: rgba(245, 158, 11, .3);--tag-error-bg: rgba(239, 68, 68, .15);--tag-error-text: #f87171;--tag-error-border: rgba(239, 68, 68, .3);--btn-danger-text: #f87171;--btn-danger-border: rgba(239, 68, 68, .4);--btn-danger-hover: rgba(239, 68, 68, .1);--card-default-bg: #6366f1}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{min-width:320px;height:100dvh;overflow:hidden;background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s,color .3s}#root{height:100dvh;display:flex;flex-direction:column}.home{display:flex;width:100dvw;height:100dvh}.home-left{flex:1;display:flex;justify-content:center;align-items:center;border-right:1px solid var(--border-color);overflow:hidden}.home-right{flex:1;display:flex;justify-content:center;align-items:center}.home-toolbar{position:absolute;top:16px;right:16px;z-index:10;display:flex;gap:4px}.home-form-wrapper{width:600px}.home-title{font-size:1.8rem;font-weight:800;margin-bottom:4px;color:var(--text-primary)}.home-subtitle{font-size:.95rem;color:var(--text-secondary);margin-bottom:1.5rem}.locale-picker{position:relative}.locale-menu{position:absolute;top:calc(100% + 4px);right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px var(--shadow-color);list-style:none;padding:4px;z-index:100;animation:dropdownOpen .15s ease-out}.locale-option{padding:6px 16px;border-radius:4px;cursor:pointer;font-size:.8rem;font-weight:600;color:var(--text-secondary);transition:background .1s}.locale-option:hover{background:var(--bg-secondary)}.locale-option.active{color:var(--accent);background:var(--bg-secondary)}.flip-card-scene{display:flex;justify-content:center;align-items:center;height:100%}.flip-card-container{width:200px;height:280px;perspective:1000px}.flip-card-inner{width:100%;height:100%;position:relative;transform-style:preserve-3d;border-radius:8px;transition:transform 1s;transform:rotate(-30deg) rotateY(0)}.form-panel{width:600px}.form-panel h2{font-size:1.4rem;margin-bottom:1rem;color:var(--text-primary)}.form-panel input{width:100%;padding:.75rem .85rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;margin-bottom:.75rem;outline:none;transition:border-color .2s;background:var(--bg-primary);color:var(--text-primary)}.form-panel input:focus{border-color:var(--accent)}.form-panel input:disabled{background:var(--bg-secondary);color:var(--text-secondary)}.deck-select{position:relative;width:100%;margin-bottom:.75rem}.deck-select-trigger{width:100%;padding:.75rem .85rem;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:border-color .2s}.deck-select-trigger:hover{border-color:var(--accent)}.deck-select-arrow{font-size:.65rem;color:var(--text-secondary)}.deck-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 16px var(--shadow-color);list-style:none;z-index:100;padding:4px;animation:dropdownOpen .15s ease-out}@keyframes dropdownOpen{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.deck-select-option{padding:8px 12px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .1s}.deck-select-option:hover,.deck-select-option.active{background:var(--bg-secondary)}.deck-option-label{font-weight:500;color:var(--text-primary)}.deck-option-desc{font-size:.8rem;color:#9ca3af}.form-panel>button{width:100%;padding:.75rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;background:var(--accent);color:#fff;transition:opacity .2s}.form-panel>button:hover:not(:disabled){opacity:.9}.form-panel>button:disabled{opacity:.5;cursor:not-allowed}.button-row button{padding:.75rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;background:var(--accent);color:#fff;transition:opacity .2s}.button-row button:hover:not(:disabled){opacity:.9}.button-row button:disabled{opacity:.5;cursor:not-allowed}.button-row button.secondary{background:transparent;color:var(--accent);border:1px solid var(--accent)}.button-row{display:flex;gap:.75rem}.button-row button{flex:1}.error-text{color:#ef4444;font-size:.85rem;margin-bottom:.5rem}.room{display:flex;flex-direction:column;height:100dvh;overflow:hidden;position:relative}.room-head{position:relative;flex:0 0 auto;z-index:20}.room-banners{position:absolute;top:100%;left:0;right:0;display:flex;flex-direction:column;pointer-events:none}body.has-room-sidebar .room-banners{right:var(--sidebar-w)}@media(max-width:768px){body.has-room-sidebar .room-banners{right:0}}.room-banners>*{pointer-events:auto}.room-header{width:100%;flex:0 0 auto;display:flex;justify-content:space-between;align-items:center;padding:12px 20px;border-bottom:1px solid var(--border-color)}.room-header-left{display:flex;align-items:center;gap:12px}.room-header-left h2{font-size:1.2rem;font-weight:700;margin:0}.room-header-right{display:flex;align-items:center;gap:8px}.status-tag{display:inline-block;padding:2px 10px;border-radius:4px;font-size:.75rem;font-weight:600;line-height:1.6}.tag-success{background:var(--tag-success-bg);color:var(--tag-success-text);border:1px solid var(--tag-success-border)}.tag-warning{background:var(--tag-warning-bg);color:var(--tag-warning-text);border:1px solid var(--tag-warning-border)}.tag-error{background:var(--tag-error-bg);color:var(--tag-error-text);border:1px solid var(--tag-error-border)}.btn-icon{position:relative;display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:background .15s,color .15s}.btn-icon:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-icon-badge{position:absolute;top:2px;right:2px;min-width:14px;height:14px;border-radius:7px;background:var(--accent);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px}.btn-outlined{padding:5px 16px;font-size:.85rem;font-weight:500;border-radius:6px;cursor:pointer;background:transparent;transition:background .15s}.btn-outlined.primary{color:var(--accent);border:1px solid var(--accent)}.btn-outlined.primary:hover{background:#4f46e50f}.btn-outlined.danger{color:var(--btn-danger-text);border:1px solid var(--btn-danger-border)}.btn-outlined.danger:hover{background:var(--btn-danger-hover)}.connection-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px 16px;font-size:.85rem;font-weight:500;animation:bannerSlideDown .25s ease-out}.connection-banner.warning{background:var(--tag-warning-bg);color:var(--tag-warning-text);border-bottom:1px solid var(--tag-warning-border)}.connection-banner.error{background:var(--tag-error-bg);color:var(--tag-error-text);border-bottom:1px solid var(--tag-error-border)}@keyframes bannerSlideDown{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.user-group{flex:1 1 0;min-height:0;display:flex;flex-wrap:wrap;justify-content:center;align-items:center;align-content:center;overflow:auto;padding:1rem}.user-group.circular{position:relative;display:block;overflow:visible;padding:0}.user-group.circular:before{content:"";position:absolute;left:50%;top:50%;width:var(--table-w, 320px);height:var(--table-h, 220px);transform:translate(-50%,-50%);border-radius:50%;border:1px dashed color-mix(in srgb,var(--text-secondary) 18%,transparent);pointer-events:none}.player-slot{display:inline-block;position:relative}.user-group.circular .player-slot{position:absolute;transform:translate(-50%,-50%);transition:left .45s cubic-bezier(.4,0,.2,1),top .45s cubic-bezier(.4,0,.2,1)}.user-card{display:flex;flex-direction:column;align-items:center;gap:7px;margin:8px 6px;position:relative}.user-card-action{position:absolute;width:20px;height:20px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 1px 4px #0003;color:#fff;padding:0;opacity:0;transition:opacity .15s}.user-card:hover .user-card-action{opacity:1}.user-card-action.kick{top:-6px;right:-6px;background:#ef4444}.user-card-action.kick:hover{background:#dc2626}.user-card-action.transfer{top:-6px;left:-6px;background:#f59e0b}.user-card-action.transfer:hover{background:#d97706}.user-card.disconnected{opacity:.4}.card-flip-container{perspective:800px}.card-flip{width:var(--card-flip-w, 72px);height:var(--card-flip-h, 104px);position:relative;transform-style:preserve-3d;transition:transform .55s cubic-bezier(.4,0,.2,1)}.card-flip.flipped{transform:rotateY(180deg)}.card-front,.card-back{position:absolute;width:100%;height:100%;border-radius:10px;backface-visibility:hidden;overflow:hidden}.card-front{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;background:var(--card-default-bg);box-shadow:inset 0 0 0 1px #0000001f}.card-front:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-color:color-mix(in srgb,var(--pattern-color, #ffffff) var(--pattern-alpha, 7%),transparent);mask-repeat:repeat;-webkit-mask-repeat:repeat}.card-front.pattern-none:before{display:none}.card-front.pattern-stripes:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10'><path d='M0,10 L10,0 M-1,1 L1,-1 M9,11 L11,9' stroke='black' stroke-width='1.5' fill='none'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10'><path d='M0,10 L10,0 M-1,1 L1,-1 M9,11 L11,9' stroke='black' stroke-width='1.5' fill='none'/></svg>");mask-size:10px 10px;-webkit-mask-size:10px 10px}.card-front.pattern-dots:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='8'><circle cx='4' cy='4' r='1' fill='black'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='8'><circle cx='4' cy='4' r='1' fill='black'/></svg>");mask-size:8px 8px;-webkit-mask-size:8px 8px}.card-front.pattern-grid:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12'><path d='M0,0 L12,0 M0,0 L0,12' stroke='black' stroke-width='0.8' fill='none'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12'><path d='M0,0 L12,0 M0,0 L0,12' stroke='black' stroke-width='0.8' fill='none'/></svg>");mask-size:12px 12px;-webkit-mask-size:12px 12px}.card-front.pattern-waves:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='8'><path d='M0,4 Q5,0 10,4 T20,4' stroke='black' stroke-width='1.2' fill='none'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='8'><path d='M0,4 Q5,0 10,4 T20,4' stroke='black' stroke-width='1.2' fill='none'/></svg>");mask-size:20px 8px;-webkit-mask-size:20px 8px}.card-front.pattern-zigzag:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='8'><path d='M0,6 L4,2 L8,6 L12,2 L16,6' stroke='black' stroke-width='1.2' fill='none'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='8'><path d='M0,6 L4,2 L8,6 L12,2 L16,6' stroke='black' stroke-width='1.2' fill='none'/></svg>");mask-size:16px 8px;-webkit-mask-size:16px 8px}.card-check{color:#fffffff2;font-size:26px;font-weight:700}.card-waiting{width:28px;height:28px;border-radius:50%;border:2px dashed rgba(255,255,255,.45)}.card-back{background:var(--bg-primary);border:2px solid var(--border-color);transform:rotateY(180deg);display:flex;align-items:center;justify-content:center}.card-back-stripe{position:absolute;top:0;left:0;right:0;height:5px;border-radius:8px 8px 0 0;background:var(--card-default-bg)}.card-vote{font-size:26px;font-weight:800;color:var(--text-primary);letter-spacing:-1px}.user-card-name{font-size:var(--card-name-fs, 11px);font-weight:600;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:var(--card-flip-w, 72px);text-align:center;display:flex;align-items:center;justify-content:center;gap:2px}.crown{color:#f59e0b;font-size:10px}.vote-summary{display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 4px 16px var(--shadow-color);animation:voteSummaryIn .25s cubic-bezier(.34,1.56,.64,1) both}.vote-summary-main{font-size:1.05rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.vote-summary-detail{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}@keyframes voteSummaryIn{0%{opacity:0;transform:translateY(-8px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}.room-stage{flex:1 1 0;position:relative;min-height:0;display:flex;flex-direction:column}.room-stage .user-group{flex:1 1 auto}.room-stage-center{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:25;pointer-events:none}.room-stage-center>*{pointer-events:auto}.room-stage-center .vote-summary{padding:14px 22px;box-shadow:0 8px 24px var(--shadow-color)}.room-stage-center .vote-summary-main{font-size:1.25rem}.room-stage-center .vote-summary-detail{font-size:.85rem}.room-body{flex:1 1 0;min-height:0;display:flex;align-items:stretch}.room-sidebar{flex:0 0 var(--sidebar-w);display:flex;flex-direction:column;gap:16px;padding:16px;border-left:1px solid var(--border-color);background:var(--bg-secondary);overflow:hidden;min-height:0}.sidebar-section{display:flex;flex-direction:column;align-items:stretch;gap:10px}.sidebar-section-controls,.sidebar-section-extras{flex:0 0 auto}.sidebar-section-deck{flex:1 1 0;min-height:0}.sidebar-section-controls .control-buttons{padding:0}.sidebar-section-controls .btn-control{width:100%;justify-content:center;min-height:clamp(44px,7vh,72px);font-size:clamp(.78rem,1.5vh,1rem);padding:clamp(4px,1.1vh,10px) 16px}.sidebar-section-deck .voting-deck{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:1fr;gap:6px;padding:10px;margin:0;width:100%;height:100%;box-sizing:border-box}.sidebar-section-deck .action-card{width:100%;height:100%;margin:0;min-height:0}.sidebar-section-deck .action-card-center{font-size:clamp(14px,2.4vh,28px)}.sidebar-section-deck .action-card-corner{font-size:clamp(9px,1.2vh,13px)}.sidebar-section-extras .btn-break{font-size:clamp(.72rem,1.2vh,.92rem);padding:clamp(4px,1vh,8px) 12px}.sidebar-section-extras .reaction-btn{font-size:clamp(1.05rem,2vh,1.5rem)}.sidebar-section-deck .action-card.hovered{transform:translateY(-4px)}.sidebar-section-deck .action-card.selected{transform:translateY(-6px)}.sidebar-section-extras{margin-top:auto;align-items:center;gap:16px}.sidebar-section-extras .reaction-bar{flex-wrap:wrap;justify-content:center;padding:6px 8px;gap:3px;width:100%}.sidebar-section-extras .reaction-btn{font-size:1.25rem;padding:4px 6px}.sidebar-section-extras .btn-break{width:100%;justify-content:center}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:998;animation:fadeIn .15s ease-out}.drawer{position:fixed;top:0;right:0;width:400px;max-width:90vw;height:100vh;background:var(--bg-primary);box-shadow:-4px 0 24px #00000026;display:flex;flex-direction:column;animation:drawerSlideIn .2s ease-out}@keyframes drawerSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.drawer-header h3{font-size:1.1rem;font-weight:700;margin:0}.drawer-close{background:none;border:none;font-size:1rem;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:4px}.drawer-close:hover{background:var(--bg-secondary)}.drawer-content{flex:1;overflow-y:auto;padding:16px 20px}.drawer-empty{color:var(--text-secondary);font-size:.9rem}.round-card{margin-bottom:16px;padding:12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-secondary)}.round-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.round-mean{padding:2px 10px;border-radius:4px;font-size:.75rem;font-weight:600;background:#4f46e51a;color:var(--accent)}.round-table{width:100%;border-collapse:collapse;font-size:.85rem}.round-table th{text-align:left;padding:6px 8px;border-bottom:1px solid var(--border-color);color:var(--text-secondary);font-weight:500}.round-table td{padding:6px 8px;border-bottom:1px solid var(--border-color)}.round-vote-cell{text-align:center;font-weight:600;width:80px}.control-buttons{display:flex;justify-content:flex-start;gap:10px}.btn-control{padding:8px 24px;font-size:.9rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .15s}.btn-control.solid{background:var(--accent);color:#fff;border:2px solid var(--accent)}.btn-control.solid:hover:not(:disabled){opacity:.9}.btn-control.outlined{background:transparent;color:var(--accent);border:2px solid var(--accent)}.btn-control.outlined:hover:not(:disabled){background:#4f46e50f}.btn-control:disabled{opacity:.5;cursor:not-allowed}.voting-deck{display:inline-flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:4px;padding:8px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;box-shadow:0 2px 8px var(--shadow-color)}.action-card{position:relative;width:64px;height:92px;border-radius:10px;border:2px solid var(--border-color);background:var(--bg-primary);box-shadow:0 2px 6px #00000012;transform:translateY(0);transition:transform .18s ease,box-shadow .18s ease;cursor:pointer;-webkit-user-select:none;user-select:none;margin:0 4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;outline:none;touch-action:manipulation}.action-card.hovered{transform:translateY(-8px);box-shadow:0 6px 16px #00000024}.action-card.selected{background:linear-gradient(145deg,var(--accent) 0%,var(--accent-light) 100%);border-color:var(--accent);box-shadow:0 8px 20px #4f46e573;transform:translateY(-14px)}.action-card.disabled{opacity:.4;cursor:default}.action-card-corner{position:absolute;font-size:12px;font-weight:700;line-height:1;color:#94a3b8}.action-card.selected .action-card-corner{color:#ffffffbf}.action-card-corner.top-left{top:7px;left:8px}.action-card-corner.bottom-right{bottom:7px;right:8px;transform:rotate(180deg)}.action-card-center{font-size:24px;font-weight:800;color:var(--text-primary);letter-spacing:-.5px}.action-card.selected .action-card-center{color:#fff}.mini-view-loading{display:flex;align-items:center;justify-content:center;height:100vh;background:var(--bg-primary);color:var(--text-secondary);font-size:.95rem;padding:24px;text-align:center;line-height:1.6}.mini-view{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);padding:12px 16px;gap:12px;overflow:auto}.mini-view-header{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.mini-view-reactions{display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:wrap}.mini-view-room{font-size:1rem;font-weight:700;color:var(--text-primary)}.tag-accent{background:#4f46e51a;color:var(--accent);border:1px solid rgba(79,70,229,.3)}.tag-info{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.3)}.tag-default{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color)}.toast-container{position:fixed;top:0;left:0;right:0;z-index:1000;pointer-events:none}body.has-room-sidebar .toast-container{right:var(--sidebar-w)}.toast{position:absolute;left:50%;transform:translate(-50%);white-space:nowrap;padding:10px 20px;border-radius:8px;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px #00000026;animation:toastIn .25s ease-out}@media(max-width:768px){body.has-room-sidebar .toast-container{right:0}}.toast-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.toast-icon-success{background:#16a34a}.toast-icon-error{background:#dc2626}.toast-icon-warning{background:#d97706}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast-success{background:var(--tag-success-bg);color:var(--tag-success-text);border:1px solid var(--tag-success-border)}.toast-error{background:var(--tag-error-bg);color:var(--tag-error-text);border:1px solid var(--tag-error-border)}.toast-warning{background:var(--tag-warning-bg);color:var(--tag-warning-text);border:1px solid var(--tag-warning-border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;justify-content:center;align-items:center;z-index:999;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-primary);border-radius:12px;padding:24px;width:400px;max-width:90vw;box-shadow:0 8px 32px #0003;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{font-size:1.1rem;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.modal-message{font-size:.9rem;color:var(--text-secondary);margin-bottom:20px;line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.modal-btn{padding:8px 20px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s}.modal-btn.cancel{background:transparent;border:1px solid var(--border-color);color:var(--text-primary)}.modal-btn.cancel:hover{background:var(--bg-secondary)}.modal-btn.confirm{background:var(--accent);border:none;color:#fff}.modal-btn.confirm:hover{opacity:.9}.modal-btn.confirm.danger{background:#dc2626}.style-editor .style-preview{position:relative;width:100%;height:80px;border-radius:10px;border:1px solid var(--border-color);margin-bottom:16px;overflow:hidden}.style-editor .style-section{display:flex;flex-direction:column;gap:10px;padding:14px 0;border-top:1px solid var(--border-color)}.style-editor .style-section:first-of-type{border-top:none;padding-top:0}.style-editor .style-section:last-of-type{padding-bottom:4px}.style-editor .style-section-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.style-editor .style-row{display:flex;align-items:center;gap:10px;min-height:32px;font-size:.9rem;color:var(--text-primary)}.style-editor .style-row-indent{padding-left:22px}.style-editor .style-row-label{flex:1;cursor:inherit}.style-editor .style-row-inline{display:flex;align-items:center;gap:10px;flex:1.5}.style-editor .style-row-number{width:56px;height:30px;padding:0 6px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;text-align:center;font-variant-numeric:tabular-nums;flex:0 0 auto}.style-editor .style-row-number:focus{outline:2px solid var(--accent);outline-offset:1px;border-color:transparent}.style-editor .style-row-suffix{font-size:.85rem;color:var(--text-secondary);flex:0 0 auto}.style-editor .color-field{position:relative;flex:0 0 auto}.style-editor .color-swatch{display:inline-flex;align-items:center;gap:8px;padding:4px 8px 4px 4px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:.82rem;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;transition:border-color .15s}.style-editor .color-swatch:hover,.style-editor .color-swatch.open{border-color:var(--accent)}.style-editor .color-swatch-chip{width:22px;height:22px;border-radius:4px;box-shadow:inset 0 0 0 1px #0000001f;flex:0 0 auto}.style-editor .color-swatch-hex{color:var(--text-secondary);letter-spacing:.02em}.style-editor .color-popover{position:absolute;top:calc(100% + 6px);right:0;z-index:10;padding:10px;border-radius:10px;background:var(--bg-primary);border:1px solid var(--border-color);box-shadow:0 8px 24px var(--shadow-color);display:flex;flex-direction:column;gap:8px}.style-editor .color-popover .react-colorful{width:200px;height:160px}.style-editor .color-popover-input{display:flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem}.style-editor .color-popover-input span{color:var(--text-secondary)}.style-editor .color-popover-input input{flex:1;width:0;border:none;background:transparent;color:var(--text-primary);font:inherit;text-transform:uppercase;letter-spacing:.02em;outline:none}.style-editor .style-row-indent-group{padding-left:22px}.style-editor .style-row input[type=checkbox]{width:16px;height:16px;cursor:pointer;flex:0 0 auto;accent-color:var(--accent)}.style-editor .style-row input[type=range]{flex:1;cursor:pointer;accent-color:var(--accent)}.style-editor .style-row label{cursor:pointer}.style-editor .style-pattern-options{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.style-editor .style-pattern-btn{display:flex;align-items:center;gap:6px;padding:6px 8px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-size:.78rem;transition:border-color .15s,background .15s}.style-editor .style-pattern-btn:hover{border-color:var(--accent)}.style-editor .style-pattern-btn.active{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 15%,var(--bg-secondary))}.style-editor .style-pattern-swatch{position:relative;width:22px;height:22px;border-radius:4px;background:var(--text-primary);flex:0 0 auto;overflow:hidden}.style-editor .style-pattern-swatch:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-color:var(--bg-primary);mask-repeat:repeat;-webkit-mask-repeat:repeat}.style-editor .style-pattern-swatch.pattern-none:before{display:none}.style-editor .style-pattern-swatch.pattern-stripes:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10'><path d='M0,10 L10,0 M-1,1 L1,-1 M9,11 L11,9' stroke='black' stroke-width='1.5' fill='none'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10'><path d='M0,10 L10,0 M-1,1 L1,-1 M9,11 L11,9' stroke='black' stroke-width='1.5' fill='none'/></svg>");mask-size:10px 10px;-webkit-mask-size:10px 10px}.style-editor .style-pattern-swatch.pattern-dots:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='8'><circle cx='4' cy='4' r='1' fill='black'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='8' height='8'><circle cx='4' cy='4' r='1' fill='black'/></svg>");mask-size:8px 8px;-webkit-mask-size:8px 8px}.style-editor .style-pattern-swatch.pattern-grid:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12'><path d='M0,0 L12,0 M0,0 L0,12' stroke='black' stroke-width='0.8' fill='none'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12'><path d='M0,0 L12,0 M0,0 L0,12' stroke='black' stroke-width='0.8' fill='none'/></svg>");mask-size:12px 12px;-webkit-mask-size:12px 12px}.style-editor .style-pattern-swatch.pattern-waves:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='8'><path d='M0,4 Q5,0 10,4 T20,4' stroke='black' stroke-width='1.2' fill='none'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='8'><path d='M0,4 Q5,0 10,4 T20,4' stroke='black' stroke-width='1.2' fill='none'/></svg>");mask-size:20px 8px;-webkit-mask-size:20px 8px}.style-editor .style-pattern-swatch.pattern-zigzag:before{mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='8'><path d='M0,6 L4,2 L8,6 L12,2 L16,6' stroke='black' stroke-width='1.2' fill='none'/></svg>");-webkit-mask-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='8'><path d='M0,6 L4,2 L8,6 L12,2 L16,6' stroke='black' stroke-width='1.2' fill='none'/></svg>");mask-size:16px 8px;-webkit-mask-size:16px 8px}.style-editor .modal-actions{margin-top:16px}.style-editor .style-editor-actions{justify-content:space-between;align-items:center}.style-editor .style-editor-actions-right{display:flex;gap:8px}.modal-btn.reset{background:transparent;border:1px solid var(--btn-danger-border);color:var(--btn-danger-text)}.modal-btn.reset:hover{background:var(--btn-danger-hover)}.user-card.editable .card-flip-container{cursor:pointer}.user-card.editable .card-flip-container:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:10px}.user-card-edit-hint{position:absolute;bottom:22px;right:-6px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #0003;z-index:5;pointer-events:none;opacity:0;transition:opacity .15s}.user-card.editable:hover .user-card-edit-hint,.user-card.editable:has(.card-flip-container:focus-visible) .user-card-edit-hint{opacity:1}.btn-break{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;border:1px solid var(--border-color);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.btn-break:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-break.active{background:var(--tag-warning-bg);color:var(--tag-warning-text);border-color:var(--tag-warning-border)}.reaction-bar{display:inline-flex;align-items:center;gap:2px;padding:4px 6px;border:1px solid var(--border-color);border-radius:8px;background:transparent}.reaction-btn{background:transparent;border:none;font-size:1.15rem;line-height:1;cursor:pointer;padding:4px 6px;border-radius:6px;transition:background .15s,transform .1s}.reaction-btn:hover{background:var(--bg-secondary);transform:scale(1.2)}.reaction-btn:active{transform:scale(.95)}.reaction-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:30}.reaction-bubble{position:fixed;font-size:1.5rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));animation:reactionFloat 2.8s ease-out forwards;will-change:transform,opacity}@keyframes reactionFloat{0%{opacity:0;transform:translate(calc(-50% + var(--drift, 0px)),-4px) scale(.5)}15%{opacity:1;transform:translate(calc(-50% + var(--drift, 0px)),-28px) scale(1.1)}30%{transform:translate(calc(-50% + var(--drift, 0px) * .6),-64px) scale(1)}to{opacity:0;transform:translate(calc(-50% + var(--drift, 0px) * -1),-210px) scale(.85)}}.break-banner{display:flex;align-items:center;justify-content:center;gap:16px;padding:10px 20px;background:var(--tag-warning-bg);color:var(--tag-warning-text);border-bottom:1px solid var(--tag-warning-border);font-size:.9rem;font-weight:500;animation:breakBannerPulse .4s ease-out}.break-banner-label{display:inline-flex;align-items:center;gap:8px}.break-banner-clear{padding:4px 12px;border:1px solid var(--tag-warning-border);border-radius:6px;background:transparent;color:var(--tag-warning-text);font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s}.break-banner-clear:hover{background:var(--tag-warning-border)}@keyframes breakBannerPulse{0%{opacity:0;transform:translateY(-100%)}60%{opacity:1;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fireworks{position:absolute;width:100%;height:100%;overflow:hidden;pointer-events:none;left:0;top:0;z-index:50}.particle{position:absolute;width:10px;height:10px;animation:explodeParticle 2s ease-out forwards;clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}@keyframes explodeParticle{0%{transform:rotate(var(--dz)) translate(0);opacity:1}to{transform:rotate(var(--dz)) translate(var(--dx),var(--dy));opacity:0}}.icon-spin{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-outlined,.btn-control,.form-panel>button,.button-row button{display:inline-flex;align-items:center;justify-content:center;gap:6px}@keyframes dealCard{0%{opacity:0;transform:translateY(60px) scale(.8) rotate(-8deg)}60%{opacity:1;transform:translateY(-4px) scale(1.02) rotate(1deg)}to{opacity:1;transform:translateY(0) scale(1) rotate(0)}}.card-deal{animation:dealCard .4s cubic-bezier(.34,1.56,.64,1) both}.user-card-throw-hint{position:absolute;bottom:16px;right:-6px;width:20px;height:20px;border-radius:50%;background:#0ea5e9;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px #00000040;pointer-events:none;z-index:10;opacity:0;transform:scale(.85);transition:opacity .18s ease,transform .18s ease}.user-card.targetable:hover .user-card-throw-hint,.user-card.targetable:has(.card-flip-container:focus-visible) .user-card-throw-hint{opacity:1;transform:scale(1)}.user-card.targetable .card-flip-container{cursor:pointer}.throw-popover{position:absolute;left:50%;bottom:calc(100% + 6px);transform:translate(-50%);display:flex;gap:4px;padding:6px 8px;border-radius:12px;background:var(--bg-primary);border:1px solid var(--border-color);box-shadow:0 8px 24px #0000002e;z-index:40;animation:throwPopoverIn .16s ease-out both}.throw-popover:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--border-color)}.throw-popover:before{content:"";position:absolute;top:calc(100% - 1px);left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--bg-primary);z-index:1}@keyframes throwPopoverIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.throw-item{background:transparent;border:none;font-size:1.3rem;line-height:1;cursor:pointer;padding:4px 6px;border-radius:8px;transition:background .15s,transform .1s}.throw-item:hover{background:var(--bg-secondary);transform:scale(1.18)}.throw-item:active{transform:scale(.92)}.throw-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;z-index:60}.throw-flight{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none}.throw-flight .throw-projectile{position:fixed;display:inline-block;font-size:1.5rem;line-height:1;filter:drop-shadow(0 4px 6px rgba(0,0,0,.25));animation:throwArc var(--flight-ms, 1s) cubic-bezier(.42,0,.58,1) forwards;will-change:left,top,transform}@keyframes throwArc{0%{left:var(--from-x);top:var(--from-y);transform:translate(-50%,-50%) rotate(0) scale(.85)}50%{left:var(--peak-x);top:var(--peak-y);transform:translate(-50%,-50%) rotate(220deg) scale(1.05)}to{left:var(--to-x);top:var(--to-y);transform:translate(-50%,-50%) rotate(420deg) scale(.95);opacity:0}}.throw-impact{position:fixed;width:48px;height:48px;pointer-events:none;opacity:0;border-radius:50%;background:radial-gradient(circle,var(--impact-color, rgba(255, 255, 255, .85)) 0%,color-mix(in srgb,var(--impact-color, rgba(255, 255, 255, .85)) 45%,transparent) 45%,transparent 75%);box-shadow:0 0 18px var(--impact-color, rgba(255, 255, 255, .6));transform:translate(-50%,-50%);animation:throwImpactPop var(--impact-ms, .9s) ease-out var(--flight-ms, 1s) forwards}@keyframes throwImpactPop{0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}30%{opacity:1;transform:translate(-50%,-50%) scale(1.25)}to{opacity:0;transform:translate(-50%,-50%) scale(1.7)}}.throw-particle{position:fixed;display:inline-block;font-size:1rem;line-height:1;pointer-events:none;opacity:0;transform:translate(-50%,-50%);filter:drop-shadow(0 1px 2px rgba(0,0,0,.3));animation:throwParticleBurst .95s cubic-bezier(.2,.7,.3,1) forwards}@keyframes throwParticleBurst{0%{opacity:0;transform:translate(-50%,-50%) scale(.3) rotate(0)}20%{opacity:1;transform:translate(calc(-50% + var(--dx) * .35),calc(-50% + var(--dy) * .35)) scale(var(--scale, 1)) rotate(calc(var(--rot, 0deg) * .3))}70%{opacity:1}to{opacity:0;transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy) + 10px)) scale(var(--scale, 1)) rotate(var(--rot, 0deg))}}@media(prefers-reduced-motion:reduce){.throw-flight .throw-projectile,.throw-impact,.throw-particle{animation-duration:.01ms}}@media(max-width:768px){.home{flex-direction:column}.home-left{flex:0 0 200px;border-right:none;border-bottom:1px solid var(--border-color)}.home-right{flex:1;padding:1.5rem}.room-header{padding:10px 12px}.room-header-left h2{font-size:1rem}.room-body{flex-direction:column}.room-sidebar{flex:0 0 auto;border-left:none;border-top:1px solid var(--border-color);overflow-y:visible;padding:12px;gap:10px}.sidebar-section-deck .voting-deck{grid-template-columns:repeat(auto-fit,minmax(56px,1fr))}.sidebar-section-extras .reaction-bar{justify-content:center}}
