@import"https://fonts.googleapis.com/css2?family=Itim&family=Outfit:wght@300;400;500;600;700;800;900&family=Noto+Color+Emoji&display=swap";:root{--bg-deep: hsl(225, 25%, 6%);--bg-surface: hsl(225, 20%, 12%);--bg-elevated: hsl(225, 18%, 18%);--table-bg-start: hsl(200, 25%, 18%);--table-bg-end: hsl(200, 30%, 10%);--table-rail-glow: hsl(200, 80%, 50% / .25);--accent: hsl(160, 70%, 45%);--accent-glow: hsl(160, 80%, 50%);--gold: hsl(42, 85%, 55%);--card-back: hsl(230, 30%, 20%);--text-primary: hsl(0, 0%, 92%);--text-muted: hsl(0, 0%, 55%);--danger: hsl(0, 70%, 55%);--glass-bg: hsl(225 25% 10% / .6);--glass-border: hsl(0 0% 100% / .08);--glass-highlight: hsl(0 0% 100% / .04);--shadow-color: hsl(225 40% 4% / .5);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 9999px;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-back: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .15s;--duration-normal: .3s;--duration-slow: .6s;--in-oklch: }@supports (background: linear-gradient(in oklch,white,black)){:root{--in-oklch: in oklch}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;color-scheme:dark;-webkit-text-size-adjust:100%;text-size-adjust:100%;hanging-punctuation:first last}body{min-height:100dvh;background-color:var(--bg-deep);color:var(--text-primary);font-family:Itim,"Noto Color Emoji",system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}::selection{background-color:#22c38e4d;color:var(--text-primary)}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:var(--accent);text-decoration:none}ul,ol{list-style:none}#root{min-height:100dvh;display:flex;flex-direction:column;isolation:isolate}.app{min-height:100dvh;position:relative;overflow:hidden;display:flex;flex-direction:column;background:radial-gradient(ellipse 80% 60% at 50% 40%,hsl(160 40% 8% / .25),transparent),radial-gradient(ellipse 60% 50% at 80% 20%,hsl(230 40% 12% / .2),transparent),var(--bg-deep)}.landing-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:48px 0 0;position:relative;overflow:hidden;background:transparent}.floating-suits{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none;z-index:0}.floating-suit{position:absolute;font-size:2rem;font-weight:700;opacity:0;color:var(--text-muted);animation:float 18s linear infinite;will-change:transform}.floating-suit:nth-child(1){left:8%;animation-delay:0s;font-size:1.8rem}.floating-suit:nth-child(2){left:22%;animation-delay:-3s;font-size:2.4rem}.floating-suit:nth-child(3){left:38%;animation-delay:-7s;font-size:1.6rem}.floating-suit:nth-child(4){left:55%;animation-delay:-11s;font-size:2.8rem}.floating-suit:nth-child(5){left:70%;animation-delay:-4s;font-size:2rem}.floating-suit:nth-child(6){left:85%;animation-delay:-9s;font-size:2.2rem}.floating-suit:nth-child(7){left:15%;animation-delay:-14s;font-size:1.5rem}.floating-suit:nth-child(8){left:48%;animation-delay:-6s;font-size:3rem}.floating-suit:nth-child(9){left:62%;animation-delay:-16s;font-size:1.4rem}.floating-suit:nth-child(10){left:92%;animation-delay:-2s;font-size:2.6rem}.floating-suit:nth-child(11){left:5%;animation-delay:-12s;font-size:2rem}.floating-suit:nth-child(12){left:33%;animation-delay:-8s;font-size:1.8rem}.landing-card{position:relative;z-index:1;width:100%;max-width:480px;padding:48px 40px;background:var(--glass-bg);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:0 4px 24px var(--shadow-color),0 0 0 1px var(--glass-highlight) inset;animation:scaleIn var(--duration-slow) var(--ease-out-expo) both}.landing-title{font-family:Outfit,sans-serif;font-size:clamp(1.8rem,5vw,2.6rem);font-weight:700;letter-spacing:-.02em;line-height:1.15;text-align:center;margin-bottom:8px;background:linear-gradient(89deg var(--in-oklch),hsl(124.26deg 99.41% 30.42%),hsl(195.49deg 85% 55%));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.landing-subtitle{text-align:center;color:var(--text-muted);font-size:.95rem;margin-bottom:36px}.landing-input{display:block;width:100%;padding:14px 18px;background:var(--bg-deep);border:1px solid hsl(0 0% 100% / .08);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease;outline:none}.landing-input::placeholder{color:var(--text-muted)}.landing-input:focus{border-color:#22c38e80;box-shadow:0 0 0 3px #22c38e1f}.landing-code-input{display:block;width:100%;padding:14px 18px;background:var(--bg-deep);border:1px solid hsl(0 0% 100% / .08);border-radius:var(--radius-md);color:var(--text-primary);font-family:Inter,monospace;font-size:1.6rem;font-weight:600;letter-spacing:.6em;text-align:center;text-transform:uppercase;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease;outline:none}.landing-code-input::placeholder{letter-spacing:.15em;font-size:.9rem;font-weight:400;color:var(--text-muted)}.landing-code-input:focus{border-color:#22c38e80;box-shadow:0 0 0 3px #22c38e1f}.landing-actions{display:flex;flex-direction:column;gap:8px;margin-top:24px}.landing-action-section{width:100%}.landing-join-row{display:flex;flex-direction:column;gap:12px;width:100%}.landing-card .btn-primary,.landing-card .btn-secondary{width:100%}.landing-divider{display:flex;align-items:center;gap:16px;margin:28px 0;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.08em}.landing-divider:before,.landing-divider:after{content:"";flex:1;height:1px;background:#ffffff14}.landing-divider-small{display:flex;align-items:center;gap:16px;margin:16px 0;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}.landing-divider-small:before,.landing-divider-small:after{content:"";flex:1;height:1px;background:#ffffff14}.btn-link{display:block;width:max-content;margin:16px auto 0;background:none;border:none;color:var(--text-muted);font-size:.85rem;text-decoration:underline;cursor:pointer;font-family:inherit;transition:color var(--duration-fast) ease}.btn-link:hover{color:var(--text-primary)}.landing-card-wide{max-width:680px;transition:max-width .3s ease-in-out}.landing-step-form{display:flex;flex-direction:column;gap:20px;margin-top:12px}.landing-label{display:block;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;text-align:left}.landing-submit-btn{margin-top:8px}.player-badge-container{display:flex;justify-content:center;margin-bottom:24px}.player-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#22c38e14;border:1px solid hsl(160 70% 45% / .25);border-radius:var(--radius-full);font-size:.9rem;color:var(--text-primary);box-shadow:0 2px 10px #22c38e0d}.player-badge-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent);animation:pulse-glow 2s infinite ease-in-out}.player-badge-label{color:var(--text-muted);font-size:.85rem}.player-badge-name{color:var(--text-primary);font-weight:600}.player-badge-edit{background:none;border:none;color:var(--accent);cursor:pointer;padding:4px;margin-left:-2px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;justify-content:center;transition:color var(--duration-fast) ease,background-color var(--duration-fast) ease,transform var(--duration-fast) ease}.player-badge-edit:hover{color:var(--accent-glow);background-color:#22c38e1f;transform:scale(1.1)}.edit-icon-svg{display:block}@keyframes pulse-glow{0%,to{opacity:.6;transform:scale(.9)}50%{opacity:1;transform:scale(1.1)}}.landing-actions-split{display:flex;gap:32px;margin-top:16px;position:relative}.landing-option-box{flex:1 1 0px;min-width:0;display:flex;flex-direction:column;justify-content:space-between;padding:24px;background:#ffffff05;border:1px solid hsl(0 0% 100% / .06);border-radius:var(--radius-lg);transition:border-color .2s ease,transform .2s ease}.landing-option-box:hover{border-color:#ffffff1f;background:#ffffff08}.landing-option-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.landing-option-icon{font-size:1.4rem}.landing-option-title{font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:600;color:var(--text-primary)}.landing-option-desc{font-size:.85rem;color:var(--text-muted);line-height:1.4;margin-bottom:24px;flex-grow:1}.landing-divider-vertical{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;pointer-events:none}.landing-divider-vertical:before,.landing-divider-vertical:after{content:"";width:1px;flex:1;background:#ffffff0f}.landing-divider-vertical:before{margin-bottom:12px}.landing-divider-vertical:after{margin-top:12px}.landing-join-form{width:100%;display:flex;flex-direction:column;gap:12px}.landing-code-input-small{display:block;width:100%;padding:12px 14px;background:var(--bg-deep);border:1px solid hsl(0 0% 100% / .08);border-radius:var(--radius-md);color:var(--text-primary);font-family:Inter,monospace;font-size:1.25rem;font-weight:600;letter-spacing:.4em;text-align:center;text-transform:uppercase;outline:none;transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.landing-code-input-small:focus{border-color:#22c38e80;box-shadow:0 0 0 3px #22c38e1f}.landing-code-input-small::placeholder{letter-spacing:.15em;font-size:.9rem;font-weight:400;color:var(--text-muted)}@media(max-width:640px){.landing-actions-split{flex-direction:column;gap:16px}.landing-divider-vertical{flex-direction:row;margin:8px 0}.landing-divider-vertical:before,.landing-divider-vertical:after{height:1px;width:auto;flex:1}.landing-divider-vertical:before{margin-right:12px;margin-bottom:0}.landing-divider-vertical:after{margin-left:12px;margin-top:0}}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;background:var(--accent);color:#0b0d13;font-weight:600;font-size:.95rem;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--duration-fast) ease,transform var(--duration-fast) ease;outline:none}.btn-primary:hover{background:var(--accent-glow)}.btn-primary:active{transform:scale(.97)}.btn-primary:focus-visible{box-shadow:0 0 0 3px #22c38e66}.btn-primary:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;background:transparent;color:var(--text-primary);font-weight:500;font-size:.95rem;border:1px solid hsl(0 0% 100% / .12);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--duration-fast) ease,border-color var(--duration-fast) ease,transform var(--duration-fast) ease;outline:none}.btn-secondary:hover{background:#ffffff0f;border-color:#fff3}.btn-secondary:active{transform:scale(.97)}.btn-secondary:focus-visible{box-shadow:0 0 0 3px #ffffff1f}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-sm{padding:8px 16px;font-size:.85rem}.btn-large{padding:16px 36px;font-size:1.1rem}.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;background:transparent;color:var(--danger);font-weight:500;font-size:.85rem;border:1px solid hsl(0 70% 55% / .25);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--duration-fast) ease,border-color var(--duration-fast) ease;outline:none}.btn-danger:hover{background:#dd3c3c1a;border-color:#dd3c3c66}.btn-danger:focus-visible{box-shadow:0 0 0 3px #dd3c3c33}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:transparent;color:var(--text-muted);border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--duration-fast) ease,color var(--duration-fast) ease}.btn-icon:hover{background:#ffffff14;color:var(--text-primary)}.app-header{position:sticky;top:0;z-index:100;width:100%;background:#0f121abf;backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);border-bottom:1px solid var(--glass-border)}.header-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:580px;margin:0 auto;padding:12px 24px;gap:16px}@media(min-width:1024px){.header-inner{display:grid;grid-template-columns:580px 320px;max-width:1004px;gap:40px;padding:12px 32px}}.app-header-left{display:flex;align-items:center;gap:16px}.app-header-title{font-family:Outfit,sans-serif;font-size:1rem;font-weight:600;background:linear-gradient(89deg var(--in-oklch),hsl(124.26deg 99.41% 30.42%),hsl(195.49deg 85% 55%));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-decoration:none;cursor:pointer;transition:opacity var(--duration-fast) ease}.app-header-title:hover{opacity:.8}.app-header-right{display:flex;align-items:center;justify-content:flex-end}@media(min-width:1024px){.app-header-right{justify-content:flex-start}}.room-code-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:#ffffff0f;border:1px solid hsl(0 0% 100% / .08);border-radius:var(--radius-full);font-size:.8rem;font-weight:600;letter-spacing:.08em;color:var(--text-muted);cursor:pointer;transition:background-color var(--duration-fast) ease,color var(--duration-fast) ease;-webkit-user-select:none;user-select:none}.room-code-pill:hover{background:#ffffff1a;color:var(--text-primary)}.room-code-pill .copy-icon{opacity:.5;font-size:.75rem;transition:opacity var(--duration-fast) ease}.room-code-pill:hover .copy-icon{opacity:1}.ticket-indicator{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-muted)}.ticket-indicator-label{color:var(--text-muted);font-weight:400}.ticket-indicator-name{color:var(--text-primary);font-weight:600;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leave-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;background:transparent;color:var(--danger);font-size:.8rem;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--duration-fast) ease,opacity var(--duration-fast) ease}.leave-btn:hover{background:#dd3c3c1a}.lobby-screen{display:flex;flex-direction:column;width:100%;flex:1}.lobby-footer{margin-top:auto;text-align:center;padding:32px 24px 14px;font-size:.85rem;color:var(--text-muted)}.lobby-content{display:grid;grid-template-columns:1fr;gap:24px;max-width:580px;margin:0 auto;padding:24px;width:100%;justify-content:center}@media(min-width:1024px){.lobby-content{grid-template-columns:580px 320px;max-width:1004px;gap:40px;padding:32px}}.lobby-main{display:flex;flex-direction:column;gap:24px;min-width:0}.lobby-sidebar{display:flex;flex-direction:column;gap:24px;padding-left:4px}.lobby-start-section{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:16px;padding:24px;background:#ffffff05;border:1px dashed hsl(0 0% 100% / .08);border-radius:var(--radius-lg);text-align:center}.lobby-hint{font-size:.85rem;color:var(--text-muted)}.panel{background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.panel-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.ticket-manager{display:flex;flex-direction:column;gap:16px}.ticket-input-row{display:flex;gap:10px;align-items:center}.ticket-input-row .landing-input{flex:1}#add-ticket-btn{width:48px;height:48px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--accent);color:#0b0d13;border:none;cursor:pointer;transition:background-color var(--duration-fast) ease,transform var(--duration-fast) ease}#add-ticket-btn:hover{background:var(--accent-glow)}#add-ticket-btn:active{transform:scale(.95)}.add-ticket-icon{width:22px;height:22px;display:block}.ticket-list{display:flex;flex-direction:column;gap:4px}.ticket-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);transition:background-color var(--duration-fast) ease,border-color var(--duration-fast) ease,transform var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.ticket-item:hover{background:var(--bg-elevated);transform:translateY(-1px);box-shadow:0 2px 8px var(--shadow-color)}.ticket-item.active{border-left:3px solid var(--accent);background:#22c38e0a;box-shadow:0 0 12px #22c38e0f}.ticket-item.done{opacity:.5}.ticket-item.done .ticket-title{text-decoration:line-through;color:var(--text-muted)}.ticket-drag-handle{color:var(--text-muted);cursor:grab;opacity:.4;font-size:1rem;transition:opacity var(--duration-fast) ease;flex-shrink:0;-webkit-user-select:none;user-select:none}.ticket-item:hover .ticket-drag-handle{opacity:.8}.ticket-title{flex:1;font-size:.9rem;font-weight:500;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticket-status{display:inline-flex;align-items:center;padding:3px 10px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full);flex-shrink:0}.ticket-status.pending{background:#ffffff0f;color:var(--text-muted)}.ticket-status.active{background:#22c38e1f;color:var(--accent)}.ticket-status.done{background:#eeb32b1f;color:var(--gold)}.ticket-size{font-size:.85rem;font-weight:700;color:var(--gold);min-width:24px;text-align:center}.ticket-actions{display:flex;gap:2px;opacity:0;transition:opacity var(--duration-fast) ease}.ticket-item:hover .ticket-actions{opacity:1}.ticket-list-readonly{display:flex;flex-direction:column;gap:4px}.ticket-list-readonly .ticket-item{cursor:default}.ticket-list-readonly .ticket-item:hover{transform:none;box-shadow:none}.participant-list{display:flex;flex-direction:column;gap:6px}.participant-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;background:#ffffff14;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;color:var(--text-muted)}.participant-item{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:var(--radius-md);transition:background-color var(--duration-fast) ease}.participant-item:hover{background:#ffffff08}.avatar{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;font-size:1.05rem;font-weight:800;color:#fff;flex-shrink:0;text-transform:uppercase;position:relative}.online-dot{position:absolute;bottom:0;right:0;width:10px;height:10px;background:#33cc73;border:2px solid var(--bg-surface);border-radius:50%}.participant-name{font-size:1.05rem;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.host-badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 7px;background:#eeb32b26;color:var(--gold);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;border-radius:var(--radius-full);flex-shrink:0;line-height:1}.you-badge{font-size:.75rem;color:var(--text-muted);font-weight:400}.poker-table-container{position:relative;display:flex;align-items:center;justify-content:center;width:100%;min-height:500px;padding:24px 24px 120px}.poker-table{position:relative;margin-top:10px;width:min(520px,72vw);height:min(290px,40vw);border-radius:9999px;background:radial-gradient(ellipse 70% 60% at 50% 45%,var(--table-bg-start),var(--table-bg-end));border:8px solid transparent;background-clip:padding-box;box-shadow:inset 0 2px 20px #08090dcc,inset 0 0 40px #0b0d1366,0 4px 30px #06080e99,0 0 60px #22c38e0a}.poker-table:before{content:"";position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;border-radius:9999px;background:linear-gradient(160deg,#313749,#191d29,#131620);z-index:-1;border:1.5px solid hsl(200,70%,45% / .4);box-shadow:inset 0 1px 3px #ffffff1a,0 0 30px var(--table-rail-glow),0 12px 40px #06080eb3}.table-center-info{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;z-index:1;pointer-events:none}.table-center-ticket{font-size:.85rem;font-weight:600;color:#ffffffb3;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-center-status{font-size:.75rem;color:#ffffff59;margin-top:4px}.player-seat{position:absolute;display:flex;flex-direction:column;align-items:center;gap:6px;transform:translate(-50%,-28%);animation:scaleInSeat var(--duration-slow) var(--ease-out-back) both;animation-delay:calc(var(--seat-index, 0) * 80ms);z-index:2}.seat-avatar{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;font-size:1.4rem;font-weight:800;color:#fff;text-transform:uppercase;border:2px solid hsl(0 0% 100% / .1);transition:border-color var(--duration-normal) ease,box-shadow var(--duration-normal) ease}.player-seat.is-you .seat-avatar{border-color:var(--accent);box-shadow:0 0 12px #22c38e40}.seat-name{font-size:1.05rem;font-weight:500;color:#ffffffb3;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.seat-card-slot{width:50px;height:70px;position:relative}.player-seat.has-voted .seat-card-slot:after{display:none}.card{aspect-ratio:2.5 / 3.5;perspective:1000px;cursor:pointer;-webkit-user-select:none;user-select:none}.card-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.34,1.56,.64,1)}.card.flipped .card-inner{transform:rotateY(180deg)}.card-front,.card-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;border-radius:var(--radius-md);overflow:hidden}.card-front{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f9f9fb,#e7e9ef);border:2px solid hsl(225,25%,82%);box-shadow:0 4px 12px #06080e26,inset 0 1px 2px #fffc;transform:rotateY(180deg);transition:border-color var(--duration-fast) ease,box-shadow var(--duration-fast) ease}.card.selected .card-front{border-color:var(--accent);box-shadow:0 0 16px #22c38e59,0 4px 15px #06080e33}.card-value{font-size:2.5rem;font-weight:800;color:#1b2132;line-height:1;text-shadow:0 1px 2px hsl(225 30% 15% / .08)}.card-corner{position:absolute;font-size:.65em;font-weight:800;color:#434e70;line-height:1}.card-corner.top-left{top:6px;left:6px}.card-corner.bottom-right{bottom:6px;right:6px;transform:rotate(180deg)}.card-back{background:radial-gradient(circle at 50% 50%,#242b4c,#141729);border:2px solid hsl(230,30%,26%);box-shadow:0 4px 12px var(--shadow-color)}.card-back-pattern{position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:calc(var(--radius-md) - 4px);border:1px dashed hsl(230 40% 40% / .4);background:radial-gradient(circle at 50% 50%,hsl(160 70% 45% / .06),transparent 75%),repeating-linear-gradient(45deg,hsl(230 30% 18% / .15) 0 2px,transparent 0 6px);pointer-events:none}.card-back-logo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.4rem;font-weight:900;letter-spacing:-.03em;color:#b3b7cc;line-height:1;-webkit-user-select:none;user-select:none}.card-sm{width:50px}.card-md{width:70px}.card-lg{width:90px}.card-picker{position:fixed;bottom:0;left:0;right:0;z-index:50;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:16px;padding:12px 16px 24px;background:linear-gradient(to top,hsl(225 25% 6% / .95) 0%,hsl(225 25% 6% / .7) 60%,transparent 100%);animation:slideUp var(--duration-slow) var(--ease-out-expo) both}.card-picker-hand{display:flex;align-items:flex-end;justify-content:center;gap:0;padding:0 20px;width:100%;max-width:100%}.card-picker-card{--fan-angle: 0deg;transform:rotate(var(--fan-angle)) translateY(calc(abs(var(--fan-offset, 0))/2px));transform-origin:bottom center;margin:0 -6px;transition:transform var(--duration-normal) var(--ease-out-back),box-shadow var(--duration-normal) ease,z-index 0ms;z-index:1;position:relative}.card-picker-card:hover{transform:rotate(0) translateY(-18px) scale(1.08);z-index:10}.card-picker-card:hover .card-front,.card-picker-card:hover .card-back{box-shadow:0 8px 30px #06080e80,0 0 20px #22c38e1a}.card-picker-card.selected{transform:rotate(0) translateY(-14px) scale(1.05);z-index:9}.card-picker-card.selected .card-front{border-color:var(--accent);box-shadow:0 0 16px #22c38e4d,0 4px 20px #06080e66}.card-picker-card:nth-child(1){--fan-angle: -9deg;--fan-offset: 9}.card-picker-card:nth-child(2){--fan-angle: -6deg;--fan-offset: 6}.card-picker-card:nth-child(3){--fan-angle: -3deg;--fan-offset: 3}.card-picker-card:nth-child(4){--fan-angle: 0deg;--fan-offset: 0}.card-picker-card:nth-child(5){--fan-angle: 3deg;--fan-offset: 3}.card-picker-card:nth-child(6){--fan-angle: 6deg;--fan-offset: 6}.card-picker-card:nth-child(7){--fan-angle: 9deg;--fan-offset: 9}.host-controls{position:absolute;bottom:24px;right:24px;z-index:100;display:flex;justify-content:center;animation:slideUp var(--duration-slow) var(--ease-out-expo) both}.host-controls .btn-primary{padding:16px 36px;font-size:1.05rem;font-weight:700;border-radius:var(--radius-full);transition:background-color var(--duration-fast) ease,transform var(--duration-fast) ease}.host-controls .btn-primary:hover{transform:translateY(-2px) scale(1.02)}.host-controls .btn-primary:active{transform:translateY(1px) scale(.98)}.game-content{position:relative;width:100%;min-height:calc(100vh - 120px)}.game-sidebar{display:flex;flex-direction:column;width:100%;max-width:480px;margin:0 auto 24px;padding:0 24px}.game-sidebar .ticket-list-heading{font-size:.95rem;margin-bottom:12px}.game-sidebar .ticket-item{padding:8px 12px;gap:8px;border-radius:var(--radius-sm)}.game-sidebar .ticket-title{font-size:.85rem}.game-sidebar .ticket-status{font-size:.65rem;padding:2px 6px}.game-sidebar .ticket-size{font-size:.8rem}@media(min-width:1280px){.game-sidebar{position:absolute;top:24px;right:16px;width:280px;margin:0;padding:0;max-height:calc(100vh - 120px);overflow-y:auto}}.vote-chart-sidebar{display:flex;flex-direction:column;width:100%;max-width:280px;margin:24px auto;padding:0 16px;animation:slideInLeft var(--duration-slow) var(--ease-out-expo) both;z-index:10}.vote-chart-sidebar .vote-chart-panel{background:transparent!important;border:none!important;box-shadow:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;padding:0!important;width:100%!important;max-height:none!important;animation:none!important}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@media(min-width:1280px){.vote-chart-sidebar{position:absolute;top:120px;left:16px;margin:0;padding:0}}.vote-chart-panel{width:100%;overflow-y:auto}.vote-chart-title{font-size:1.05rem;font-weight:700;margin-bottom:8px;text-align:center}.chart-rows{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.chart-row{display:flex;flex-direction:column;align-items:stretch;gap:4px}.chart-row-top{display:flex;align-items:center;gap:8px}.chart-row-bottom{padding-left:28px}.chart-label{width:20px;font-size:.95rem;font-weight:700;color:var(--text-primary);text-align:right;flex-shrink:0}.chart-bar-container{flex:1;height:24px;position:relative}.chart-bar{height:100%;width:var(--bar-width, 0%);background:var(--accent);border-radius:var(--radius-sm);animation:barGrow .8s var(--ease-out-expo) both;animation-delay:calc(var(--bar-index, 0) * .1s);display:flex;align-items:center;padding-left:8px;min-width:fit-content;flex-shrink:0}.chart-bar.majority{background:linear-gradient(90deg var(--in-oklch),var(--gold),hsl(38,80%,50%));box-shadow:0 0 12px #eeb32b33}.chart-names{display:flex;flex-wrap:wrap;gap:4px;align-items:center}.chart-voter-badge{display:inline-flex;align-items:center;padding:2px 6px;background:#ffffff14;border:1px solid hsl(0 0% 100% / .12);border-radius:var(--radius-sm);font-size:.75rem;font-weight:500;color:var(--text-primary);animation:scaleIn var(--duration-normal) var(--ease-out-back) both}.chart-count{width:20px;font-size:.8rem;font-weight:600;color:var(--text-muted);text-align:center;flex-shrink:0}.chart-bar .chart-count{color:#0f121a;font-weight:800;font-size:.8rem}.chart-actions{display:flex;gap:8px;justify-content:center;padding-top:16px;margin-top:16px;border-top:1px solid var(--glass-border)}.chart-actions button{padding:8px 16px!important;font-size:.8rem!important}.chart-summary{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:8px}.chart-summary-value{font-size:1.6rem;font-weight:700;background:linear-gradient(135deg var(--in-oklch),var(--accent),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.chart-summary-label{font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.waiting-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;text-align:center}.waiting-state-text{color:var(--text-muted);font-size:.95rem}.waiting-dots{display:flex;gap:6px}.waiting-dots span{width:8px;height:8px;background:var(--text-muted);border-radius:50%;animation:pulse 1.4s ease-in-out infinite}.waiting-dots span:nth-child(2){animation-delay:.2s}.waiting-dots span:nth-child(3){animation-delay:.4s}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 24px;text-align:center;color:var(--text-muted)}.empty-state-icon{font-size:2.4rem;opacity:.3;margin-bottom:4px}.empty-state-title{font-size:.95rem;font-weight:600;color:var(--text-primary)}.empty-state-text{font-size:.85rem;max-width:280px}.glass{background:var(--glass-bg);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border:1px solid var(--glass-border)}.glow{box-shadow:0 0 20px #19e6a233,0 0 40px #19e6a214}.fade-in{animation:fadeIn var(--duration-normal) ease both}.slide-up{animation:slideUp var(--duration-slow) var(--ease-out-expo) both}.scale-in{animation:scaleIn var(--duration-slow) var(--ease-out-expo) both}.text-gradient{background:linear-gradient(135deg var(--in-oklch),var(--accent),var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.text-muted{color:var(--text-muted)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes float{0%{transform:translateY(110vh) rotate(0);opacity:0}10%{opacity:var(--float-opacity, .04)}90%{opacity:var(--float-opacity, .04)}to{transform:translateY(-10vh) rotate(360deg);opacity:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes scaleInSeat{0%{opacity:0;transform:translate(-50%,-28%) scale(.92)}to{opacity:1;transform:translate(-50%,-28%) scale(1)}}@keyframes cardFlip{0%{transform:rotateY(0)}to{transform:rotateY(180deg)}}@keyframes barGrow{0%{width:0%}to{width:var(--bar-width, 0%)}}@keyframes pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes dealCard{0%{opacity:0;transform:scale(.5) translateY(40px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.poker-table{width:min(640px,92vw);height:min(340px,50vw)}.table-center-ticket{font-size:1.25rem;max-width:320px}.table-center-status{font-size:.95rem}.seat-avatar{width:64px;height:64px;font-size:1.6rem}.seat-name{font-size:1.25rem;max-width:120px}.seat-card-slot{width:64px;height:90px}.seat-card-slot .card-sm{width:64px}.seat-card-slot .card-value{font-size:2.2rem}.card-picker-card .card-md{width:96px}.card-picker-card{margin:0 -14px}.card-picker-card .card-value{font-size:3.2rem}.card-picker-card .card-corner{font-size:.85rem}.card-picker-reveal-btn{padding:16px 36px;font-size:1.15rem}.game-sidebar{max-width:620px}.game-sidebar .ticket-list-heading{font-size:1.15rem}.game-sidebar .ticket-title{font-size:1rem}.game-sidebar .ticket-status{font-size:.8rem}.game-sidebar .ticket-size{font-size:.95rem}}@media(max-width:767px){.app-header{padding:10px 16px;flex-wrap:wrap}.ticket-indicator-name{max-width:120px}.lobby-content{padding:16px;gap:16px}.panel{padding:16px}.back-to-lobby-btn{top:12px;left:12px;padding:8px 14px;font-size:.8rem}.game-content{padding-bottom:160px}.host-controls{position:relative;bottom:auto;left:auto;right:auto;transform:none;z-index:100;display:flex;justify-content:center;pointer-events:none;width:100%}.host-controls .btn-primary{pointer-events:auto;width:auto;min-width:160px;max-width:220px;padding:10px 20px;font-size:.85rem;font-weight:600;border-radius:var(--radius-full);box-shadow:0 6px 20px #22c38e4d,0 0 10px #22c38e26}.poker-table-container{min-height:350px;padding:20px 12px 60px}.poker-table{width:min(280px,70vw);height:min(180px,45vw)}.poker-table:before{top:-10px;right:-10px;bottom:-10px;left:-10px}.seat-avatar{width:34px;height:34px;font-size:.95rem}.seat-name{font-size:.75rem;max-width:60px}.seat-card-slot{width:36px;height:50px}.card-picker{padding:8px 8px 16px}.card-picker-card .card-md{width:clamp(32px,9.5vw,50px)}.card-picker-card{margin:0 -1.5vw}.card-picker-card:nth-child(1){--fan-angle: -6deg;--fan-offset: 6}.card-picker-card:nth-child(2){--fan-angle: -4deg;--fan-offset: 4}.card-picker-card:nth-child(3){--fan-angle: -2deg;--fan-offset: 2}.card-picker-card:nth-child(4){--fan-angle: 0deg;--fan-offset: 0}.card-picker-card:nth-child(5){--fan-angle: 2deg;--fan-offset: 2}.card-picker-card:nth-child(6){--fan-angle: 4deg;--fan-offset: 4}.card-picker-card:nth-child(7){--fan-angle: 6deg;--fan-offset: 6}.vote-chart-panel{padding:24px 20px}.landing-card{padding:32px 24px}.landing-actions{flex-direction:column}}@media(max-width:480px){.poker-table{width:88vw;height:55vw}.seat-avatar{width:30px;height:30px;font-size:.85rem;border-width:1.5px}.seat-name{display:none}.seat-card-slot{width:30px;height:42px}.player-seat{gap:3px}}@media(min-width:1440px){.poker-table{width:800px;height:440px}.seat-avatar{width:56px;height:56px;font-size:1.5rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.fade-in,.slide-up,.scale-in{animation:none!important;opacity:1!important;transform:none!important}.card-inner{transition:none!important}.floating-suit{display:none}.card-picker-card{transform:none!important}.card-picker-card.selected{transform:translateY(-8px)!important}}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}:focus:not(:focus-visible){outline:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#fff3}@supports (scrollbar-color: auto){*{scrollbar-width:thin;scrollbar-color:hsl(0 0% 100% / .12) transparent}}.spinner{width:20px;height:20px;border:2px solid hsl(0 0% 100% / .15);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.shimmer{background:linear-gradient(90deg,#fff0,#ffffff0d,#fff0);background-size:200% 100%;animation:shimmer 2s linear infinite}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:200;display:flex;align-items:center;gap:10px;padding:12px 20px;background:var(--bg-surface);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:0 8px 32px var(--shadow-color);font-size:.85rem;font-weight:500;animation:slideUp var(--duration-normal) var(--ease-out-expo) both}.toast.success{border-color:#22c38e4d}.toast.error{border-color:#dd3c3c4d}.emoji-tester-section{margin-top:24px;display:flex;justify-content:center;z-index:10}.emoji-tester-toggle{font-weight:600;border:1px solid hsl(0 0% 100% / .12);background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 16px;border-radius:var(--radius-md);font-size:.85rem;transition:background-color var(--duration-fast) ease,border-color var(--duration-fast) ease}.emoji-tester-toggle:hover{background:#ffffff14;border-color:#fff3}.emoji-tester-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#08090dbf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn var(--duration-normal) ease both}.emoji-tester-content{width:min(640px,92vw);max-height:85dvh;overflow-y:auto;padding:32px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:0 16px 64px #06080e99,0 0 0 1px var(--glass-highlight) inset;animation:scaleIn var(--duration-slow) var(--ease-out-expo) both}.emoji-tester-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;border-bottom:1px solid var(--glass-border);padding-bottom:12px}.emoji-tester-header h3{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.emoji-tester-close{font-size:1.8rem;font-weight:300;color:var(--text-muted);cursor:pointer;background:transparent;border:none;line-height:1;transition:color var(--duration-fast) ease}.emoji-tester-close:hover{color:var(--text-primary)}.emoji-tester-intro{font-size:.9rem;color:var(--text-muted);margin-bottom:24px}.emoji-tester-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:16px}.emoji-tester-card{display:flex;flex-direction:column;align-items:center;padding:16px;background:#ffffff08;border:1px solid hsl(0 0% 100% / .06);border-radius:var(--radius-lg);text-align:center;transition:transform var(--duration-fast) ease,background var(--duration-fast) ease}.emoji-tester-card:hover{transform:translateY(-2px);background:#ffffff0f}.emoji-tester-preview{display:flex;align-items:center;justify-content:center;width:64px;height:64px;margin-bottom:12px;background:#ffffff08;border-radius:var(--radius-md)}.emoji-img-preview{width:40px;height:40px;object-fit:contain}.emoji-text-preview{font-size:2.2rem;line-height:1}.font-outline{font-family:"Noto Emoji",sans-serif!important}.emoji-tester-info{display:flex;flex-direction:column;gap:4px}.emoji-tester-name{font-size:.8rem;font-weight:700;color:var(--text-primary)}.emoji-tester-desc{font-size:.65rem;color:var(--text-muted)}.game-screen{position:relative;width:100%;min-height:100vh}.back-to-lobby-btn{position:absolute;top:24px;left:24px;z-index:150;display:inline-flex;align-items:center;gap:8px;padding:10px 18px;font-size:.9rem;font-weight:600;color:var(--text-primary);background:var(--glass-bg);backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2);border:1px solid var(--glass-border);border-radius:var(--radius-full);cursor:pointer;transition:background-color var(--duration-fast) ease,border-color var(--duration-fast) ease,transform var(--duration-fast) ease,box-shadow var(--duration-fast) ease;box-shadow:0 4px 12px #06080e26}.back-to-lobby-btn:hover{background:#ffffff14;border-color:var(--accent);transform:translate(-2px);box-shadow:0 6px 16px #06080e40,0 0 12px #22c38e26}.back-to-lobby-btn:active{transform:translate(1px)}.landing-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 0 16px;animation:fadeIn var(--duration-normal) ease both}.loading-spinner-wrapper{position:relative;width:64px;height:64px;margin-bottom:24px;display:flex;align-items:center;justify-content:center}.spinner-large{width:48px;height:48px;border:3px solid hsl(0 0% 100% / .08);border-top-color:var(--accent);border-right-color:var(--accent);border-radius:50%;animation:spin .8s cubic-bezier(.4,0,.2,1) infinite}.spinner-glow{position:absolute;width:48px;height:48px;border-radius:50%;box-shadow:0 0 20px #19e6a226;animation:pulse 2s ease-in-out infinite}.landing-loading-title{font-family:Outfit,sans-serif;font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:6px;text-align:center}.landing-loading-subtitle{font-size:.85rem;color:var(--text-muted);text-align:center;animation:pulse 2s ease-in-out infinite}.card-picker-reveal-btn{padding:14px 32px;font-size:1rem;font-weight:700;border-radius:var(--radius-full);margin-bottom:8px;box-shadow:0 6px 20px #22c38e33,0 0 10px #22c38e1a;transition:background-color var(--duration-fast) ease,transform var(--duration-fast) ease,box-shadow var(--duration-fast) ease;z-index:10;pointer-events:auto;position:absolute;right:16px;bottom:16px}.card-picker-reveal-btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 24px #22c38e4d,0 0 12px #22c38e26}.card-picker-reveal-btn:active{transform:translateY(1px) scale(.98)}@media(max-width:767px){.card-picker-reveal-btn{min-width:140px;max-width:200px;padding:10px 20px;font-size:.85rem;font-weight:600;margin-bottom:12px;position:relative}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:#08090dbf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn var(--duration-normal) ease both}.modal-content{width:min(420px,92vw);padding:36px 32px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:0 16px 64px #06080e99,0 0 0 1px var(--glass-highlight) inset;text-align:center;animation:scaleIn var(--duration-slow) var(--ease-out-expo) both;display:flex;flex-direction:column;align-items:center;gap:16px}.modal-icon{font-size:3rem;margin-bottom:4px;animation:pulse 2s ease-in-out infinite}.modal-title{font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.modal-text{font-size:.9rem;color:var(--text-muted);line-height:1.5;margin-bottom:8px}.modal-actions{display:flex;flex-direction:column;gap:12px;width:100%}.modal-actions .btn-primary,.modal-actions .btn-secondary{width:100%;padding:12px 24px;font-weight:600}
