@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@600;700;800;900&family=Manrope:wght@400;500;600;700;800&family=Cormorant+Garamond:ital,wght@0,500;0,600;1,500&display=swap";:root{--bg-dark: #0a0f1a;--bg-darker: #050810;--bg-deepest: #02050c;--felt-dark: #0b4d3c;--felt-main: #0d5f4a;--felt-light: #10745c;--felt-glow: rgba(13, 95, 74, .55);--gold: #f4c430;--gold-soft: #f6d365;--gold-deep: #b8881e;--gold-dark: #d1a626;--gold-glow: rgba(244, 196, 48, .5);--gold-glow-soft: rgba(244, 196, 48, .18);--ivory: #f4ecd8;--ivory-dim: #d8cdb3;--wood-dark: #2b1a12;--wood-mid: #4a2f1a;--wood-light: #6b4022;--white: #ffffff;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--success: #10b981;--danger: #dc2626;--info: #38bdf8;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .25);--shadow-2xl: 0 25px 50px rgba(0, 0, 0, .35);--shadow-cinematic: 0 30px 80px rgba(0, 0, 0, .65), 0 8px 24px rgba(0, 0, 0, .4);--shadow-card-glow: 0 24px 60px rgba(0, 0, 0, .6), 0 0 0 1px rgba(244, 196, 48, .18), inset 0 1px 0 rgba(255, 255, 255, .06);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-out-expo: cubic-bezier(.19, 1, .22, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-fast: .14s;--dur-base: .24s;--dur-slow: .42s;--dur-cinematic: .72s}.connection-dot{display:inline-block;width:12px;height:12px;border-radius:50%;background-color:#666;margin-right:8px;animation:pulse-subtle 2s ease-in-out infinite;box-shadow:0 0 8px #66666680}.connection-dot[style*="background-color: rgb(13, 95, 74)"],.connection-dot[style*="background-color: #0d5f4a"]{background-color:var(--felt-main)!important;box-shadow:0 0 12px #0d5f4acc;animation:pulse 2s ease-in-out infinite}.connection-dot[style*="background-color: rgb(244, 196, 48)"],.connection-dot[style*="background-color: #f4c430"]{background-color:var(--gold)!important;box-shadow:0 0 12px #f4c430cc;animation:pulse 1.5s ease-in-out infinite}.connection-dot[style*="background-color: rgb(255, 68, 68)"],.connection-dot[style*="background-color: #ff4444"]{background-color:#f44!important;box-shadow:0 0 12px #f44c;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}@keyframes pulse-subtle{0%{opacity:.7}50%{opacity:.4}to{opacity:.7}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Manrope,Segoe UI,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;background:radial-gradient(1200px 600px at 20% -10%,rgba(244,196,48,.08),transparent 60%),radial-gradient(900px 500px at 80% 10%,rgba(13,95,74,.2),transparent 55%),linear-gradient(160deg,var(--bg-darker),var(--bg-dark));color:var(--white);min-height:100vh}.auth-scene{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:clamp(16px,4vw,48px);overflow:hidden;background:var(--bg-deepest);color:var(--ivory);isolation:isolate;animation:auth-scene-in .6s var(--ease-out-expo) both}.auth-scene.hidden{display:none}@keyframes auth-scene-in{0%{opacity:0}to{opacity:1}}.auth-scene__bg{position:absolute;inset:0;z-index:-1;overflow:hidden;background:radial-gradient(ellipse 100% 70% at 50% 100%,rgba(13,95,74,.35),transparent 60%),radial-gradient(ellipse 80% 60% at 50% 0%,rgba(244,196,48,.08),transparent 55%),linear-gradient(180deg,#02050c,#050810,#02050c)}.auth-scene__vignette{position:absolute;inset:0;background:radial-gradient(ellipse 100% 100% at 50% 50%,transparent 40%,rgba(0,0,0,.65) 100%);pointer-events:none}.auth-scene__glow{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55;pointer-events:none;animation:auth-glow-drift 18s ease-in-out infinite alternate}.auth-scene__glow--gold{width:520px;height:520px;top:-120px;left:-120px;background:radial-gradient(circle,rgba(244,196,48,.45) 0%,transparent 70%)}.auth-scene__glow--felt{width:620px;height:620px;bottom:-180px;right:-180px;background:radial-gradient(circle,rgba(16,116,92,.55) 0%,transparent 70%);animation-direction:alternate-reverse;animation-duration:22s}@keyframes auth-glow-drift{0%{transform:translate(0) scale(1)}to{transform:translate(40px,-30px) scale(1.1)}}.auth-scene__grain{position:absolute;inset:0;opacity:.05;mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.6'/></svg>")}.auth-scene__container{position:relative;display:grid;grid-template-columns:minmax(0,1fr);gap:clamp(28px,4vw,56px);width:100%;max-width:1080px;align-items:center;animation:auth-container-in .7s var(--ease-out-expo) .12s both}@keyframes auth-container-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(min-width:900px){.auth-scene__container{grid-template-columns:minmax(0,1.2fr) minmax(380px,.8fr);gap:64px}}.auth-hero{display:flex;flex-direction:column;gap:28px;position:relative}.auth-hero__brand{display:flex;align-items:center}.auth-hero__logo{width:88px;height:auto;filter:drop-shadow(0 8px 24px rgba(244,196,48,.35));transition:transform var(--dur-slow) var(--ease-out-expo)}.auth-hero__logo:hover{transform:rotate(-3deg) scale(1.04)}.auth-hero__copy{display:flex;flex-direction:column;gap:14px;max-width:520px}.auth-hero__eyebrow{font-family:Manrope,sans-serif;font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin:0;display:inline-flex;align-items:center;gap:12px}.auth-hero__eyebrow:before{content:"";width:28px;height:1px;background:linear-gradient(90deg,var(--gold),transparent);display:inline-block}.auth-hero__title{font-family:Cinzel,serif;font-weight:800;font-size:clamp(34px,5vw,56px);line-height:1.05;letter-spacing:-.01em;margin:0;color:var(--ivory);text-shadow:0 4px 24px rgba(0,0,0,.6)}.auth-hero__lede{font-family:Cormorant Garamond,Cinzel,serif;font-style:italic;font-size:clamp(17px,1.6vw,21px);line-height:1.55;color:var(--ivory-dim);margin:0;max-width:460px}.auth-hero__mascots{position:relative;margin-top:8px;display:none}@media(min-width:900px){.auth-hero__mascots{display:block}}.auth-hero__mascot{max-width:320px;width:100%;height:auto;filter:drop-shadow(0 24px 40px rgba(0,0,0,.6));animation:auth-mascot-float 6s ease-in-out infinite}@keyframes auth-mascot-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.auth-hero__meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.auth-hero__chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;font-family:Manrope,sans-serif;font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ivory);background:#f4c43014;border:1px solid rgba(244,196,48,.28);border-radius:999px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.auth-hero__chip--ghost{background:#ffffff08;border-color:#ffffff1a;color:var(--ivory-dim)}.auth-hero__chip-dot{width:8px;height:8px;border-radius:50%;background:var(--success);box-shadow:0 0 8px var(--success);animation:auth-pulse-dot 2s ease-in-out infinite}@keyframes auth-pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.auth-scene .auth-card{position:relative;background:linear-gradient(160deg,#121c2deb,#080e18f2);border:1px solid rgba(244,196,48,.22);border-radius:24px;padding:clamp(28px,4vw,40px);box-shadow:var(--shadow-card-glow);-webkit-backdrop-filter:blur(20px) saturate(1.2);backdrop-filter:blur(20px) saturate(1.2);overflow:hidden;max-width:100%}.auth-scene .auth-card:before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,rgba(244,196,48,.5),transparent 40%,transparent 60%,rgba(244,196,48,.25));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.auth-card__header{margin-bottom:20px}.auth-card__eyebrow{font-family:Manrope,sans-serif;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:0 0 6px}.auth-card__title{font-family:Cinzel,serif;font-size:26px;font-weight:700;color:var(--ivory);margin:0;letter-spacing:-.005em}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;background:#0006;border:1px solid rgba(244,196,48,.12);border-radius:12px;margin-bottom:20px}.auth-tab{padding:10px 14px;background:transparent;border:none;border-radius:8px;color:var(--gray-400);font-family:Manrope,sans-serif;font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;transition:all var(--dur-base) var(--ease-out)}.auth-tab:hover{color:var(--ivory);background:#f4c4300f;transform:none;box-shadow:none}.auth-tab.is-active{background:linear-gradient(135deg,#f4c4302e,#f4c43014);color:var(--gold);box-shadow:inset 0 0 0 1px #f4c43066;text-shadow:0 0 12px rgba(244,196,48,.5)}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-form__lede{font-size:14px;color:var(--ivory-dim);margin:0 0 4px;line-height:1.5}.auth-form[data-mode=login] [data-mode-only=register],.auth-form[data-mode=register] [data-mode-only=login]{display:none!important}.auth-field{display:flex;flex-direction:column;gap:8px}.auth-field__label{font-family:Manrope,sans-serif;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);opacity:.85}.auth-input{width:100%;padding:14px 16px;background:#0006;border:1px solid rgba(244,196,48,.18);border-radius:10px;color:var(--ivory);font-family:Manrope,sans-serif;font-size:15px;font-weight:500;letter-spacing:.005em;transition:border-color var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}.auth-input::placeholder{color:var(--gray-500);font-weight:400}.auth-input:hover:not(:focus){border-color:#f4c4304d;background:#00000080}.auth-input:focus{outline:none;border-color:var(--gold);background:#0000008c;box-shadow:0 0 0 3px #f4c43026,0 0 24px #f4c4301f}.auth-form__row{display:flex;justify-content:flex-end;margin-top:-4px}.auth-link{font-family:Manrope,sans-serif;font-size:13px;font-weight:600;color:var(--gold);text-decoration:none;letter-spacing:.01em;transition:color var(--dur-fast) var(--ease-out),text-shadow var(--dur-fast) var(--ease-out)}.auth-link:hover{color:var(--gold-soft);text-shadow:0 0 16px rgba(244,196,48,.4)}.auth-form__cta{display:flex;flex-direction:column;gap:10px;margin-top:12px}.auth-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border:none;border-radius:12px;font-family:Manrope,sans-serif;font-size:14px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;overflow:hidden;isolation:isolate;transition:transform var(--dur-fast) var(--ease-spring),box-shadow var(--dur-base) var(--ease-out),filter var(--dur-base) var(--ease-out)}.auth-btn>span:not(.auth-btn__shine){position:relative;z-index:2}.auth-btn:hover:not(:disabled){transform:translateY(-2px)}.auth-btn:active:not(:disabled){transform:translateY(0)}.auth-btn:disabled{opacity:.55;cursor:not-allowed;transform:none}.auth-btn:focus-visible{outline:none;box-shadow:0 0 0 3px #f4c43073}.auth-btn--primary{background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold) 50%,var(--gold-deep) 100%);color:#1a1208;box-shadow:0 10px 28px #f4c43052,inset 0 1px #fff6,inset 0 -2px #00000026}.auth-btn--primary:hover:not(:disabled){box-shadow:0 14px 36px #f4c43073,inset 0 1px #ffffff80,inset 0 -2px #0000002e}.auth-btn__shine{position:absolute;top:0;left:-120%;width:50%;height:100%;background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.55) 50%,transparent 70%);transform:skew(-20deg);pointer-events:none;z-index:1}.auth-btn--primary:hover .auth-btn__shine{animation:auth-btn-shine .9s var(--ease-out-expo)}@keyframes auth-btn-shine{0%{left:-120%}to{left:220%}}.auth-btn--ghost{background:#ffffff0a;color:var(--ivory);border:1px solid rgba(244,196,48,.25);box-shadow:inset 0 1px #ffffff0a}.auth-btn--ghost:hover:not(:disabled){background:#f4c43014;border-color:#f4c43073}.auth-card__legal{margin:20px 0 0;font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-500);text-align:center}.auth-scene .auth-message{min-height:0;margin-bottom:16px;padding:0;border-radius:10px;font-size:13px;font-weight:600;display:none;background:transparent;border:none;color:var(--ivory)}.auth-scene .auth-message.visible{display:block;padding:12px 14px;border:1px solid currentColor}.auth-scene .auth-message.success{background:#10b9811a;border-color:#10b98159;color:#6ee7b7}.auth-scene .auth-message.info{background:#38bdf81a;border-color:#38bdf859;color:#7dd3fc}.auth-scene .auth-message.error{background:#dc26261f;border-color:#dc262666;color:#fca5a5}@media(max-width:640px){.auth-hero__brand{justify-content:center}.auth-hero__copy{align-items:center;text-align:center}.auth-hero__eyebrow,.auth-hero__meta{justify-content:center}}@media(prefers-reduced-motion:reduce){.auth-scene,.auth-scene__container,.auth-scene__glow,.auth-hero__mascot,.auth-hero__chip-dot{animation:none!important}.auth-btn__shine{display:none}}.lobby-scene{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:column;padding:0;overflow-y:auto;background:var(--bg-deepest);color:var(--ivory);isolation:isolate;animation:auth-scene-in .6s var(--ease-out-expo) both}.lobby-scene.hidden{display:none}.lobby-scene__bg{position:fixed;inset:0;z-index:-1;overflow:hidden;background:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(13,95,74,.32),transparent 60%),radial-gradient(ellipse 60% 40% at 100% 100%,rgba(244,196,48,.06),transparent 60%),linear-gradient(180deg,#02050c,#050810,#02050c)}.lobby-scene__vignette{position:absolute;inset:0;background:radial-gradient(ellipse 100% 100% at 50% 50%,transparent 50%,rgba(0,0,0,.55) 100%);pointer-events:none}.lobby-scene__glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;pointer-events:none;animation:auth-glow-drift 20s ease-in-out infinite alternate}.lobby-scene__glow--gold{width:580px;height:580px;top:-160px;right:-160px;background:radial-gradient(circle,rgba(244,196,48,.4) 0%,transparent 70%)}.lobby-scene__glow--felt{width:720px;height:720px;bottom:-220px;left:-200px;background:radial-gradient(circle,rgba(16,116,92,.5) 0%,transparent 70%);animation-direction:alternate-reverse;animation-duration:24s}.lobby-scene__grain{position:absolute;inset:0;opacity:.05;mix-blend-mode:overlay;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.6'/></svg>")}.lobby-scene__shell{position:relative;width:100%;max-width:1200px;margin:0 auto;padding:clamp(20px,3vw,36px);padding-bottom:80px;display:flex;flex-direction:column;gap:28px;animation:auth-container-in .7s var(--ease-out-expo) .12s both}.lobby-top{display:flex;align-items:center;justify-content:space-between;gap:20px;padding-bottom:20px;border-bottom:1px solid rgba(244,196,48,.12)}.lobby-top__brand{display:flex;align-items:center;gap:14px}.lobby-top__logo{width:52px;height:auto;filter:drop-shadow(0 4px 14px rgba(244,196,48,.35))}.lobby-top__brand-copy{display:flex;flex-direction:column}.lobby-top__eyebrow{font-family:Manrope,sans-serif;font-size:10px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin:0 0 2px}.lobby-top__title{font-family:Cinzel,serif;font-size:22px;font-weight:800;color:var(--ivory);letter-spacing:.01em;margin:0}.lobby-top__actions{display:flex;gap:10px}.lobby-icon-btn{padding:10px 18px;background:#ffffff0a;color:var(--ivory-dim);border:1px solid rgba(244,196,48,.2);border-radius:10px;font-family:Manrope,sans-serif;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all var(--dur-base) var(--ease-out)}.lobby-icon-btn:hover{background:#f4c4301a;border-color:#f4c43073;color:var(--ivory);transform:none;box-shadow:none}.lobby-hero{position:relative;display:grid;grid-template-columns:1fr;gap:28px;padding:clamp(24px,4vw,44px);border-radius:24px;background:radial-gradient(ellipse 80% 100% at 0% 0%,rgba(244,196,48,.1),transparent 50%),linear-gradient(135deg,#142032f2,#080e18f2);border:1px solid rgba(244,196,48,.22);box-shadow:var(--shadow-card-glow);overflow:hidden}@media(min-width:900px){.lobby-hero{grid-template-columns:1.4fr .6fr;align-items:center}}.lobby-hero__copy{display:flex;flex-direction:column;gap:14px;max-width:580px}.lobby-hero__eyebrow{font-family:Manrope,sans-serif;font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin:0;display:inline-flex;align-items:center;gap:10px}.lobby-hero__eyebrow:before{content:"";width:24px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}.lobby-hero__title{font-family:Cinzel,serif;font-size:clamp(28px,3.6vw,42px);font-weight:800;color:var(--ivory);letter-spacing:-.01em;line-height:1.05;margin:0}.lobby-hero__lede{font-family:Cormorant Garamond,serif;font-style:italic;font-size:clamp(16px,1.6vw,19px);color:var(--ivory-dim);line-height:1.55;margin:0 0 8px}.lobby-hero__create{display:grid;grid-template-columns:1fr;gap:12px;margin-top:8px}@media(min-width:540px){.lobby-hero__create{grid-template-columns:1fr auto;align-items:end}}.lobby-hero__create-field{display:flex;flex-direction:column;gap:6px}.lobby-hero__create-label{font-family:Manrope,sans-serif;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);opacity:.85}.lobby-input{width:100%;padding:14px 16px;background:#00000073;border:1px solid rgba(244,196,48,.2);border-radius:10px;color:var(--ivory);font-family:Manrope,sans-serif;font-size:15px;font-weight:500;transition:border-color var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}.lobby-input::placeholder{color:var(--gray-500)}.lobby-input:focus{outline:none;border-color:var(--gold);background:#0009;box-shadow:0 0 0 3px #f4c43026,0 0 24px #f4c4301f}.lobby-cta{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold) 50%,var(--gold-deep) 100%);color:#1a1208;font-family:Manrope,sans-serif;font-size:14px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;overflow:hidden;isolation:isolate;box-shadow:0 10px 28px #f4c43052,inset 0 1px #fff6,inset 0 -2px #00000026;transition:transform var(--dur-fast) var(--ease-spring),box-shadow var(--dur-base) var(--ease-out)}.lobby-cta>span:not(.auth-btn__shine){position:relative;z-index:2}.lobby-cta:hover{transform:translateY(-2px);box-shadow:0 14px 36px #f4c43073,inset 0 1px #ffffff80,inset 0 -2px #0000002e}.lobby-cta:hover .auth-btn__shine{animation:auth-btn-shine .9s var(--ease-out-expo)}.lobby-cta:active{transform:translateY(0)}.lobby-cta__icon{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:#1a12082e;font-size:18px;font-weight:900;line-height:1}.lobby-cta--ghost{background:#ffffff0d;color:var(--ivory);border:1px solid rgba(244,196,48,.3);box-shadow:inset 0 1px #ffffff0a}.lobby-cta--ghost:hover{background:#f4c4301a;border-color:#f4c4308c}.lobby-hero__advanced{margin-top:16px}.lobby-hero__advanced-summary{font-family:Manrope,sans-serif;font-size:13px;font-weight:600;color:var(--gold);cursor:pointer;padding:8px 0;list-style:none;display:inline-flex;align-items:center;gap:6px;-webkit-user-select:none;user-select:none;transition:color var(--dur-fast) var(--ease-out)}.lobby-hero__advanced-summary::-webkit-details-marker{display:none}.lobby-hero__advanced-summary:before{content:"▸";display:inline-block;transition:transform var(--dur-base) var(--ease-out)}.lobby-hero__advanced[open] .lobby-hero__advanced-summary:before{transform:rotate(90deg)}.lobby-hero__advanced-summary:hover{color:var(--gold-soft)}.lobby-hero__advanced-body{margin-top:12px;display:grid;gap:10px;grid-template-columns:1fr;max-width:460px}@media(min-width:540px){.lobby-hero__advanced-body{grid-template-columns:1fr auto;align-items:end}}.lobby-hero__mascots{position:relative;display:none;min-height:180px;align-items:center;justify-content:center;pointer-events:none}@media(min-width:900px){.lobby-hero__mascots{display:flex}}.lobby-hero__mascot{position:absolute;max-width:160px;height:auto;filter:drop-shadow(0 18px 32px rgba(0,0,0,.55))}.lobby-hero__mascot--toro{left:20%;transform:rotate(-6deg);animation:lobby-mascot-float 5.2s ease-in-out infinite}.lobby-hero__mascot--pato{right:18%;bottom:0;max-width:130px;transform:rotate(8deg);animation:lobby-mascot-float 6.4s ease-in-out .4s infinite reverse}@keyframes lobby-mascot-float{0%,to{transform:translateY(0) rotate(-6deg)}50%{transform:translateY(-10px) rotate(-3deg)}}.lobby-toast{display:none;padding:12px 16px;border-radius:10px;font-size:13px;font-weight:600;border:1px solid currentColor}.lobby-toast.visible{display:block}.lobby-toast.success{background:#10b9811a;border-color:#10b98159;color:#6ee7b7}.lobby-toast.info{background:#38bdf81a;border-color:#38bdf859;color:#7dd3fc}.lobby-toast.error{background:#dc26261f;border-color:#dc262666;color:#fca5a5}.lobby-grid{display:grid;grid-template-columns:1fr;gap:28px}@media(min-width:900px){.lobby-grid{grid-template-columns:minmax(0,1.6fr) minmax(280px,.7fr);align-items:start}}.lobby-tables,.lobby-ranking{padding:24px;border-radius:20px;background:linear-gradient(160deg,#0f1726d9,#080c16eb);border:1px solid rgba(244,196,48,.14);box-shadow:0 16px 40px #0000008c,inset 0 1px #ffffff0a}.lobby-section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid rgba(244,196,48,.12)}.lobby-section-head__copy{display:flex;flex-direction:column;gap:2px}.lobby-section-title{font-family:Cinzel,serif;font-size:20px;font-weight:700;color:var(--ivory);margin:0;letter-spacing:.01em}.lobby-section-sub{font-family:Cormorant Garamond,serif;font-style:italic;font-size:13px;color:var(--ivory-dim);margin:0}.lobby-section-badge{display:inline-flex;align-items:center;padding:6px 10px;font-family:Manrope,sans-serif;font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);background:#f4c43014;border:1px solid rgba(244,196,48,.28);border-radius:999px}.lobby-ghost-btn{padding:8px 14px;background:#ffffff0a;color:var(--ivory-dim);border:1px solid rgba(244,196,48,.2);border-radius:8px;font-family:Manrope,sans-serif;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all var(--dur-base) var(--ease-out)}.lobby-ghost-btn:hover{background:#f4c4301a;border-color:#f4c43073;color:var(--ivory);transform:none;box-shadow:none}.lobby-ghost-btn__icon{font-size:14px;line-height:1}.lobby-scene .rooms-list{list-style:none;display:grid;gap:10px;padding:0;margin:0}.lobby-scene .room-item{position:relative;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;background:#00000059;border:1px solid rgba(244,196,48,.18);border-radius:14px;overflow:hidden;transition:border-color var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out)}.lobby-scene .room-item:hover{border-color:#f4c43073;background:#f4c4300a;transform:translateY(-2px)}.lobby-scene .room-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--gold),transparent);opacity:0;transition:opacity var(--dur-base) var(--ease-out)}.lobby-scene .room-item:hover:before{opacity:1}.lobby-scene .room-item-empty{justify-content:center;color:var(--ivory-dim);font-family:Cormorant Garamond,serif;font-style:italic;font-size:16px;background:#00000040;border:1px dashed rgba(244,196,48,.2)}.lobby-scene .room-item .room-meta{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}.lobby-scene .room-item strong{font-family:Cinzel,serif;font-size:16px;font-weight:700;color:var(--ivory);letter-spacing:.005em}.lobby-scene .room-item small{font-family:Manrope,sans-serif;font-size:12px;color:var(--ivory-dim);letter-spacing:.01em}.lobby-scene .room-item button{padding:10px 16px;background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold) 100%);color:#1a1208;border:none;border-radius:10px;font-family:Manrope,sans-serif;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:transform var(--dur-fast) var(--ease-spring),box-shadow var(--dur-base) var(--ease-out);box-shadow:0 6px 18px #f4c43047;white-space:nowrap}.lobby-scene .room-item button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 26px #f4c4306b}.lobby-scene .room-item button:disabled{background:#ffffff14;color:var(--gray-500);cursor:not-allowed;box-shadow:none}.lobby-scene .ranking-list{list-style:none;display:grid;gap:10px;padding:0;margin:0}.lobby-scene .ranking-list .room-item{padding:12px 14px}.lobby-scene .ranking-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.lobby-scene .ranking-pos{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-family:Cinzel,serif;font-size:13px;font-weight:800;border:1px solid rgba(255,255,255,.18);color:var(--ivory);background:#0006;flex-shrink:0}.lobby-scene .ranking-pos.gold{background:linear-gradient(135deg,#fce46f 0%,var(--gold) 50%,var(--gold-deep) 100%);color:#1a1208;border-color:var(--gold);box-shadow:0 0 0 3px #f4c43040,0 4px 14px #f4c43059}.lobby-scene .ranking-pos.silver{background:linear-gradient(135deg,#f8fafc,#cbd5e1);color:#1f2937;border-color:#cbd5e1;box-shadow:0 0 0 3px #cbd5e133,0 4px 12px #00000059}.lobby-scene .ranking-pos.bronze{background:linear-gradient(135deg,#f59e0b,#b45309);color:#fff;border-color:#b45309;box-shadow:0 0 0 3px #b4530940,0 4px 12px #0000004d}.lobby-scene .ranking-list .room-name{font-family:Manrope,sans-serif;font-size:14px;font-weight:700;color:var(--ivory);letter-spacing:.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lobby-scene .ranking-list .room-meta{font-family:Manrope,sans-serif;font-size:11px;color:var(--ivory-dim);letter-spacing:.02em;white-space:nowrap}@media(max-width:540px){.lobby-top{flex-wrap:wrap;gap:12px}.lobby-hero{padding:22px}.lobby-tables,.lobby-ranking{padding:18px}}.auth-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;background:#050810f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000}.auth-overlay.hidden{display:none}#tournament-result-overlay .auth-card{background:linear-gradient(160deg,#142032f5,#080e18fa);border:1px solid rgba(244,196,48,.28);border-radius:22px;padding:36px;box-shadow:var(--shadow-card-glow);color:var(--ivory)}#tournament-result-overlay .panel-header{border-bottom:1px solid rgba(244,196,48,.18);padding-bottom:16px;margin-bottom:20px}#tournament-result-overlay .panel-kicker{color:var(--gold)}#tournament-result-overlay h1{color:var(--ivory)}#tournament-result-overlay .panel-card{background:transparent;border:none;box-shadow:none;padding:0;margin:0}#tournament-result-overlay .tournament-result-message{color:var(--ivory-dim);font-family:Cormorant Garamond,serif;font-style:italic;font-size:18px;line-height:1.55}#tournament-result-overlay button.accent{background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold) 50%,var(--gold-deep) 100%);color:#1a1208;font-weight:800;letter-spacing:.08em;border-radius:12px;box-shadow:0 10px 28px #f4c4304d}#app{background:radial-gradient(ellipse 100% 60% at 50% 100%,rgba(13,95,74,.18),transparent 60%),linear-gradient(180deg,#050810,#02050c)}#ui.panel{background:linear-gradient(180deg,#0c121ef5,#060a12fa);border-right:1px solid rgba(244,196,48,.16);box-shadow:inset -1px 0 #ffffff08,8px 0 32px #00000073;padding:22px 18px}#ui.panel::-webkit-scrollbar{width:6px}#ui.panel::-webkit-scrollbar-track{background:#00000040}#ui.panel::-webkit-scrollbar-thumb{background:#f4c43040;border-radius:3px}#ui.panel::-webkit-scrollbar-thumb:hover{background:#f4c43073}#ui.panel .panel-header{border-bottom:1px solid rgba(244,196,48,.16);padding-bottom:14px;margin-bottom:20px}#ui.panel .panel-kicker{color:var(--gold);font-family:Manrope,sans-serif;letter-spacing:.18em;font-size:10px}#ui.panel h1{font-family:Cinzel,serif;font-size:20px;color:var(--ivory);letter-spacing:.01em}#ui.panel .panel-toggle{background:#0006;border:1px solid rgba(244,196,48,.3);color:var(--gold);width:32px;height:32px;border-radius:8px;transition:all var(--dur-base) var(--ease-out)}#ui.panel .panel-toggle:hover{background:#f4c4301f;border-color:var(--gold);color:var(--gold-soft)}#app.panel-collapsed .panel-toggle{background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold) 100%);color:#1a1208;border-color:var(--gold-deep);box-shadow:0 6px 18px #f4c43059}#ui.panel .panel-card{background:#0000004d;border:1px solid rgba(244,196,48,.12);border-radius:12px;padding:16px;margin-bottom:14px;box-shadow:inset 0 1px #ffffff08}#ui.panel .panel-card h2{font-family:Manrope,sans-serif;font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);opacity:.85;margin-bottom:12px}#ui.panel .status-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}#ui.panel .status-grid>div{display:flex;flex-direction:column;gap:2px;padding:8px 10px;background:#00000059;border-radius:8px;border:1px solid rgba(255,255,255,.04);transition:border-color var(--dur-base) var(--ease-out)}#ui.panel .status-grid>div:hover{border-color:#f4c4302e}#ui.panel .status-grid span{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ivory-dim);opacity:.7}#ui.panel .status-grid strong{font-family:Manrope,sans-serif;font-size:13px;font-weight:700;color:var(--ivory);letter-spacing:.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#ui.panel .players{display:flex;flex-direction:column;gap:6px}#ui.panel .players li{padding:10px 12px;background:#00000059;border:1px solid rgba(244,196,48,.08);border-radius:8px;font-family:Manrope,sans-serif;font-size:13px;color:var(--ivory);display:flex;align-items:center;gap:8px;transition:border-color var(--dur-base) var(--ease-out)}#ui.panel .players li:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 8px #f4c43080;flex-shrink:0}#ui.panel .panel-log pre{background:#0000008c;color:var(--ivory-dim);padding:10px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.04);font-size:10px;line-height:1.5;max-height:160px;overflow:auto;font-family:SF Mono,Monaco,monospace}#ui.panel .history-list{max-height:220px;padding-right:4px}#ui.panel .history-item{padding:10px 12px;border-radius:8px;background:#0006;border:1px solid rgba(244,196,48,.1);color:var(--ivory);font-size:12px}#ui.panel .history-header{color:var(--gold);font-family:Manrope,sans-serif;font-weight:700;font-size:12px}#ui.panel .history-time{color:var(--ivory-dim);font-size:10px;opacity:.7}#ui.panel .history-body{color:var(--ivory-dim);font-size:12px}#ui.panel .history-empty{background:#00000040;border:1px dashed rgba(244,196,48,.18);color:var(--ivory-dim);font-family:Cormorant Garamond,serif;font-style:italic;font-size:13px}#ui.panel .connection-dot{width:10px;height:10px;box-shadow:0 0 12px currentColor}#table{padding:32px 24px 110px}.badge{padding:7px 14px;background:#060a12d9;-webkit-backdrop-filter:blur(12px) saturate(1.4);backdrop-filter:blur(12px) saturate(1.4);border:1px solid rgba(244,196,48,.35);border-radius:999px;font-family:Manrope,sans-serif;font-size:11px;font-weight:700;letter-spacing:.08em;color:var(--ivory);text-transform:uppercase}.badge-pot{padding:12px 24px;font-size:13px;background:radial-gradient(circle at 30% 0%,rgba(255,255,255,.28),transparent 55%),linear-gradient(135deg,#f4c4302e,#0a0f1aeb 60%);border:1px solid rgba(244,196,48,.5);box-shadow:0 8px 28px #f4c43059,inset 0 1px #ffffff2e;color:var(--gold-soft);text-shadow:0 0 12px rgba(244,196,48,.5)}.badge-pot span{font-family:Cinzel,serif;font-size:20px;font-weight:800;color:var(--ivory)}.badge.timer span{font-family:Cinzel,serif;font-size:13px;font-weight:700;color:var(--gold)}.badge-meta{font-size:10px;background:#060a12e6;border-color:#f4c4304d}.turn-reason{font-family:Manrope,sans-serif;font-size:9px;font-weight:700;background:linear-gradient(135deg,#f4c4302e,#f4c43014);color:var(--gold-soft);border:1px solid rgba(244,196,48,.4);padding:3px 8px}.your-turn-indicator{top:32px;right:32px;padding:14px 26px;background:linear-gradient(135deg,#f4c430f2,#c8901af2);color:#1a1208;font-family:Cinzel,serif;font-size:16px;font-weight:800;letter-spacing:.18em;border-radius:14px;box-shadow:0 16px 40px #f4c43080,inset 0 1px #fff6,0 0 0 2px #f4c4304d;animation:pulse-turn 1.6s ease-in-out infinite;text-shadow:0 1px 0 rgba(255,255,255,.25);display:inline-flex;align-items:center;gap:10px}.your-turn-indicator:before{content:"▶";display:inline-block;font-size:14px;animation:turn-arrow-bounce 1.6s ease-in-out infinite}@keyframes pulse-turn{0%,to{transform:scale(1);box-shadow:0 16px 40px #f4c43080,inset 0 1px #fff6,0 0 0 2px #f4c4304d}50%{transform:scale(1.04);box-shadow:0 20px 50px #f4c430b3,inset 0 1px #ffffff80,0 0 0 4px #f4c43073}}@keyframes turn-arrow-bounce{0%,to{transform:translate(0)}50%{transform:translate(3px)}}.seat{width:168px;padding:14px 14px 12px;border-radius:16px;background:linear-gradient(160deg,#080e18d9,#04080eeb);border:1px solid rgba(244,196,48,.28);box-shadow:0 10px 28px #00000080,inset 0 1px #ffffff0a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:border-color var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out),transform var(--dur-slow) var(--ease-out)}.seat-badge{font-family:Manrope,sans-serif;font-size:9px;letter-spacing:.16em;color:var(--gold);opacity:.7;margin-bottom:6px}.seat-name{font-family:Cinzel,serif;font-size:15px;font-weight:700;color:var(--ivory);letter-spacing:.005em;margin-bottom:8px}.seat-meta{font-family:Manrope,sans-serif;font-size:11px;color:var(--ivory-dim);letter-spacing:.02em}.seat-chip,.seat-bet{background:#0000008c;border:1px solid rgba(244,196,48,.35);padding:4px 10px;font-family:Manrope,sans-serif;font-weight:700;font-size:11px}.seat-pill{font-family:Manrope,sans-serif;font-size:8px;letter-spacing:.12em;font-weight:800}.seat-pill.dealer{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#1a1208;box-shadow:0 2px 8px #f4c43066}.seat-pill.turn{background:linear-gradient(135deg,#7dd3fc,#38bdf8);color:#0c2640;box-shadow:0 2px 8px #38bdf866}.seat.you{border-color:var(--gold);box-shadow:0 0 0 2px #f4c43059,0 14px 30px #f4c43033,inset 0 1px #ffffff0f}.seat.turn{border-color:#38bdf8b3;box-shadow:0 0 0 2px #38bdf84d,0 14px 30px #38bdf840,inset 0 1px #ffffff0f;animation:seat-turn-pulse 2s ease-in-out infinite}@keyframes seat-turn-pulse{0%,to{box-shadow:0 0 0 2px #38bdf84d,0 14px 30px #38bdf840,inset 0 1px #ffffff0f}50%{box-shadow:0 0 0 4px #38bdf873,0 18px 40px #38bdf866,inset 0 1px #ffffff14}}.seat.folded{opacity:.4;filter:grayscale(.6)}.seat-current-hand{font-family:Cinzel,serif;color:var(--gold);text-shadow:0 0 14px rgba(244,196,48,.55);letter-spacing:.04em}.seat-winning-hand{font-family:Manrope,sans-serif;background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold) 50%,var(--gold-deep) 100%);color:#1a1208;box-shadow:0 4px 14px #f4c43080,inset 0 1px #fff6;font-weight:800;letter-spacing:.1em}.game-actions{bottom:24px;right:24px;padding:14px 18px;background:linear-gradient(180deg,#0c121ef5,#060a12fc);-webkit-backdrop-filter:blur(24px) saturate(1.5);backdrop-filter:blur(24px) saturate(1.5);border:1px solid rgba(244,196,48,.35);border-radius:18px;box-shadow:0 24px 56px #0009,0 0 0 1px #f4c43014,inset 0 1px #ffffff0a;gap:10px}.game-btn{position:relative;padding:11px 18px;background:#00000073;color:var(--ivory);border:1px solid rgba(244,196,48,.2);border-radius:10px;font-family:Manrope,sans-serif;font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;overflow:hidden;transition:transform var(--dur-fast) var(--ease-spring),border-color var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}.game-btn:hover:not(:disabled){transform:translateY(-2px);background:#f4c4301a;border-color:var(--gold);box-shadow:0 8px 20px #f4c4302e}.game-btn:focus-visible{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #f4c43059}.game-btn:disabled{opacity:.35;cursor:not-allowed;filter:grayscale(.5)}.game-btn.accent{background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold) 50%,var(--gold-deep) 100%);color:#1a1208;border-color:var(--gold-deep);box-shadow:0 8px 22px #f4c43059,inset 0 1px #ffffff59}.game-btn.accent:hover:not(:disabled){background:linear-gradient(135deg,#fce46f 0%,var(--gold-soft) 50%,var(--gold) 100%);box-shadow:0 12px 28px #f4c43080,inset 0 1px #ffffff73}.game-btn.alert{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff;border-color:#7f1d1d;box-shadow:0 6px 18px #dc262659,inset 0 1px #ffffff2e}.game-btn.alert:hover:not(:disabled){background:linear-gradient(135deg,#f87171,#dc2626);box-shadow:0 10px 26px #dc262680,inset 0 1px #ffffff38}.bet-input{width:100px;padding:11px 14px;background:#0000008c;border:1px solid rgba(244,196,48,.25);border-radius:10px;color:var(--ivory);font-family:Manrope,sans-serif;font-size:14px;font-weight:700;text-align:center;letter-spacing:.05em;transition:border-color var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out)}.bet-input:focus{outline:none;border-color:var(--gold);background:#000000a6;box-shadow:0 0 0 3px #f4c4302e}.phase-dot{width:8px;height:8px;background:#f4c4301f;border:1px solid rgba(244,196,48,.28)}.phase-dot.is-filled{background:var(--gold);border-color:var(--gold);box-shadow:0 0 10px #f4c430b3,0 0 20px #f4c43059;transform:scale(1.15)}.winner-banner{padding:18px 32px;background:radial-gradient(circle at 30% 0%,rgba(255,255,255,.4),transparent 55%),linear-gradient(135deg,#142032f7,#080e18fc);border:2px solid var(--gold);font-family:Cinzel,serif;font-size:22px;font-weight:800;letter-spacing:.12em;color:var(--gold-soft);text-shadow:0 0 24px rgba(244,196,48,.6),0 2px 0 rgba(0,0,0,.4);box-shadow:0 28px 80px #000000d9,0 0 60px #f4c4308c,inset 0 1px #ffffff26}@media(max-width:1100px){#ui.panel{box-shadow:0 4px 18px #00000080;border-right:none;border-bottom:1px solid rgba(244,196,48,.16)}}@media(max-width:768px){.game-actions{bottom:16px;right:16px;left:16px;width:auto;padding:12px 14px;gap:8px}.game-btn{padding:10px 12px;font-size:11px}.your-turn-indicator{top:16px;right:16px;padding:10px 18px;font-size:13px}}.card{position:relative;width:92px;height:130px;background:linear-gradient(160deg,#faf6ea,#f0e6cf);border-radius:9px;border:none;padding:0;display:block;overflow:hidden;flex-shrink:0;isolation:isolate;transform-style:preserve-3d;box-shadow:0 2px 4px #0003,0 10px 22px #0006,0 0 0 1px #0000002e,inset 0 0 0 1px #fff9,inset 0 1px #fffc;transition:transform var(--dur-base) var(--ease-spring),box-shadow var(--dur-base) var(--ease-out);cursor:default}.card:after{content:"";position:absolute;inset:3px;border-radius:6px;pointer-events:none;box-shadow:inset 0 0 0 1px #f4c43038;z-index:3}.card img{position:relative;z-index:1;display:block;width:100%;height:100%;object-fit:cover;border-radius:inherit}.card.has-image{padding:0;background:transparent}.card .rank,.card .suit{position:absolute;font-family:Cinzel,serif;font-weight:800;line-height:1;color:#1f2937;z-index:2}.card .rank{top:8px;left:8px;font-size:22px}.card .suit{bottom:8px;right:8px;font-size:22px}.card.red .rank,.card.red .suit{color:#b91c1c}.card.black .rank,.card.black .suit{color:#0f172a}.card:hover{transform:translateY(-6px) rotate(.4deg) scale(1.03);box-shadow:0 6px 12px #00000040,0 22px 42px #0000008c,0 0 0 1px #f4c43059,0 0 24px #f4c4302e,inset 0 0 0 1px #ffffffb3,inset 0 1px #ffffffd9}.card.card-back,.card.back{background:radial-gradient(ellipse 70% 70% at 50% 50%,rgba(244,196,48,.16),transparent 60%),radial-gradient(circle at 30% 30%,rgba(244,196,48,.12),transparent 50%),linear-gradient(135deg,#0a2218,#0d2820,#061410);border-color:#f4c43080;box-shadow:0 2px 4px #00000073,0 10px 24px #0009,0 0 0 1px #f4c43059,inset 0 0 0 2px #f4c4302e,inset 0 0 30px #00000059}.card.card-back:after,.card.back:after{box-shadow:inset 0 0 0 1px #f4c4308c,inset 0 0 0 4px #00000080,inset 0 0 0 5px #f4c43038}.card.card-back img{object-fit:contain;padding:16%;opacity:.92;filter:drop-shadow(0 4px 12px rgba(244,196,48,.45)) brightness(1.1);mix-blend-mode:normal}.card-row--community .card{width:152px;height:213px;border-radius:12px;box-shadow:0 4px 8px #0000004d,0 20px 44px #0009,0 0 0 1px #0003,inset 0 0 0 1px #ffffff80,inset 0 1px #fffc}.card-row--community .card:after{inset:4px;border-radius:8px;box-shadow:inset 0 0 0 1px #f4c43047}.card-row--community .card:hover{transform:translateY(-10px) scale(1.04) rotate(-.5deg);box-shadow:0 8px 18px #00000059,0 32px 64px #000000b3,0 0 0 2px #f4c43073,0 0 50px #f4c43040}.card-row--community .card .rank{font-size:32px;top:12px;left:12px}.card-row--community .card .suit{font-size:28px;bottom:12px;right:12px}.card-row--community .card.card-back{animation:community-back-breathe 4s ease-in-out infinite}@keyframes community-back-breathe{0%,to{box-shadow:0 4px 8px #0000004d,0 20px 44px #0009,0 0 0 1px #f4c43066,inset 0 0 0 2px #f4c43038}50%{box-shadow:0 4px 8px #0000004d,0 20px 44px #0009,0 0 0 1px #f4c43099,inset 0 0 0 2px #f4c43059,0 0 30px #f4c43033}}.card-popover-cards .card{width:180px;height:252px;border-radius:14px}.card-popover-cards .card .rank{font-size:36px;top:14px;left:14px}.card-popover-cards .card .suit{font-size:32px;bottom:14px;right:14px}.seat-hand .card.mini{width:64px;height:90px;border-radius:7px;box-shadow:0 2px 4px #0000004d,0 8px 18px #00000080,0 0 0 1px #0003,inset 0 0 0 1px #ffffff73}.seat-hand .card.mini:after{inset:2px;border-radius:5px}.seat-hand .card.mini .rank{font-size:14px;top:4px;left:4px}.seat-hand .card.mini .suit{font-size:14px;bottom:4px;right:4px}.seat-hand .card.mini:first-child{margin-right:-22px}.seat-hand:hover .card.mini:first-child{transform:rotate(-14deg) translateY(-6px) scale(1.05);box-shadow:0 10px 24px #0000008c,0 0 18px #f4c43040}.seat-hand:hover .card.mini:last-child{transform:rotate(10deg) translateY(-6px) scale(1.05);box-shadow:0 10px 24px #0000008c,0 0 18px #f4c43040}.table-zone--your-cards .card{border-radius:10px;box-shadow:0 4px 10px #00000059,0 14px 30px #0000008c,0 0 0 1px #f4c43073,inset 0 0 0 1px #ffffff80}.card.is-perla,.has-perla .card.mini,.has-perla>.card{animation:card-perla-glow 2.4s ease-in-out infinite;border-color:var(--gold)}.card.is-perla:after,.has-perla .card.mini:after,.has-perla>.card:after{box-shadow:inset 0 0 0 1px #f4c430f2,inset 0 0 0 3px #0000004d,inset 0 0 14px #f4c43066}.card.is-perla:before,.has-perla .card.mini:before,.has-perla>.card:before{content:"✦";position:absolute;top:4px;right:6px;font-size:14px;font-weight:900;color:var(--gold);text-shadow:0 0 12px rgba(244,196,48,.9),0 0 4px rgba(255,255,255,.6);animation:card-perla-sparkle 2.6s ease-in-out infinite;z-index:4;line-height:1}.has-perla .card.mini:before{font-size:11px;top:2px;right:3px}.card-row--community .card.is-perla:before{font-size:22px;top:8px;right:10px}@keyframes card-perla-glow{0%,to{box-shadow:0 4px 10px #00000059,0 12px 28px #00000080,0 0 0 2px #f4c430b3,0 0 24px #f4c43073,inset 0 0 0 1px #fff9}50%{box-shadow:0 6px 14px #0006,0 16px 36px #0000008c,0 0 0 3px #f4c430f2,0 0 44px #f4c430b3,inset 0 0 0 1px #fffc}}@keyframes card-perla-sparkle{0%,to{opacity:.65;transform:scale(1) rotate(0)}50%{opacity:1;transform:scale(1.25) rotate(12deg)}}.seat.has-perla{border-color:var(--gold)!important;box-shadow:0 0 0 2px #f4c43099,0 18px 40px #f4c43040,0 12px 24px #00000073,inset 0 1px #ffffff14!important}.seat.has-perla:after{content:"LA PERLA";position:absolute;top:-10px;left:50%;transform:translate(-50%);padding:3px 10px;background:linear-gradient(135deg,var(--gold-soft) 0%,var(--gold) 50%,var(--gold-deep) 100%);color:#1a1208;font-family:Cinzel,serif;font-size:9px;font-weight:800;letter-spacing:.2em;border-radius:999px;box-shadow:0 4px 12px #f4c43099,0 0 24px #f4c43066;white-space:nowrap;z-index:5;animation:perla-badge-pulse 2.4s ease-in-out infinite}@keyframes perla-badge-pulse{0%,to{transform:translate(-50%) scale(1)}50%{transform:translate(-50%) scale(1.06)}}.card.is-revealing{animation:card-flip-reveal .7s var(--ease-out-expo) both;backface-visibility:hidden}@keyframes card-flip-reveal{0%{opacity:0;transform:rotateY(-110deg) scale(.85) translateY(-12px)}60%{opacity:1;transform:rotateY(8deg) scale(1.02)}to{opacity:1;transform:rotateY(0) scale(1) translateY(0)}}.card.is-dealing{animation:card-deal-in .5s var(--ease-out-expo) both}@keyframes card-deal-in{0%{opacity:0;transform:translateY(-60px) translate(-20px) rotate(-12deg) scale(.6)}to{opacity:1;transform:translateY(0) translate(0) rotate(0) scale(1)}}@media(prefers-reduced-motion:reduce){.card.is-perla,.has-perla .card.mini,.has-perla>.card,.seat.has-perla:after,.card.is-revealing,.card.is-dealing,.card-row--community .card.card-back{animation:none!important}}@media(max-width:768px){.card-row--community .card{width:88px;height:124px}.card-row--community .card .rank{font-size:20px;top:8px;left:8px}.card-row--community .card .suit{font-size:18px;bottom:8px;right:8px}}@media(max-width:520px){.card-row--community .card{width:64px;height:90px}.card-row--community .card .rank{font-size:14px}.card-row--community .card .suit{font-size:12px}}@supports (padding: env(safe-area-inset-top)){.auth-scene{padding-top:max(20px,env(safe-area-inset-top));padding-bottom:max(20px,env(safe-area-inset-bottom))}.lobby-scene__shell{padding-top:max(20px,env(safe-area-inset-top));padding-bottom:max(40px,env(safe-area-inset-bottom))}.game-actions{bottom:max(16px,env(safe-area-inset-bottom));right:max(16px,env(safe-area-inset-right))}.your-turn-indicator{top:max(16px,env(safe-area-inset-top));right:max(16px,env(safe-area-inset-right))}}@media(max-width:640px){.auth-scene__grain,.lobby-scene__grain{display:none}.auth-hero__logo{width:64px}.auth-hero__title{font-size:clamp(28px,7vw,36px)}.auth-hero__lede{font-size:16px}.auth-scene .auth-card{border-radius:18px}.auth-tabs{margin-bottom:16px}.auth-btn{padding:13px 20px;font-size:13px}.auth-input{padding:12px 14px;font-size:14px}}@media(max-width:640px){.lobby-top__logo{width:40px}.lobby-top__title{font-size:18px}.lobby-top__eyebrow{font-size:9px}.lobby-hero{padding:20px;border-radius:18px}.lobby-hero__title{font-size:clamp(24px,6vw,32px)}.lobby-hero__lede{font-size:15px}.lobby-tables,.lobby-ranking{padding:16px;border-radius:16px}.lobby-section-title{font-size:17px}.lobby-scene .room-item{padding:14px;gap:10px}.lobby-scene .room-item strong{font-size:14px}.lobby-scene .room-item small{font-size:11px}.lobby-scene .room-item button{padding:8px 12px;font-size:11px}}@media(max-width:768px){.game-btn{min-height:44px;padding:10px 14px;font-size:12px}.bet-input,.auth-tab{min-height:44px}.lobby-cta{min-height:48px}}button,.auth-tab,.lobby-icon-btn,.lobby-ghost-btn,.lobby-cta,.auth-btn,.game-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation}@media(max-width:768px){.auth-input,.lobby-input,.bet-input{font-size:16px}}.hidden{display:none!important}.auth-card{width:100%;max-width:420px;background:var(--white);border-radius:20px;box-shadow:0 32px 64px #00000059,0 0 0 1px #ffffff0d;padding:40px;border:1px solid var(--gray-200)}.lobby-card{max-width:560px}.landing-page{width:100%;max-width:960px;margin:0 auto;padding:24px 20px 40px;max-height:calc(100vh - 48px);overflow-y:auto}.landing-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.12)}.landing-brand{display:flex;flex-direction:column;gap:2px}.landing-title{font-family:Cinzel,serif;font-size:28px;font-weight:700;color:var(--white);letter-spacing:.02em}.landing-tagline{font-size:13px;color:var(--gray-400);font-weight:500}.landing-logout{padding:10px 18px;background:transparent;color:var(--gray-300);border:1px solid rgba(255,255,255,.2);border-radius:10px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:color .2s,border-color .2s,background .2s}.landing-logout:hover{color:var(--white);border-color:#ffffff59;background:#ffffff0f}.landing-hero{font-size:17px;color:var(--gray-300);margin-bottom:28px;font-weight:500}.landing-main{display:grid;gap:24px;grid-template-columns:1fr}@media(min-width:768px){.landing-main{grid-template-columns:320px 1fr;align-items:start}}.landing-ranking{order:1}.landing-lobby{order:2;display:flex;flex-direction:column;gap:20px}.landing-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:22px;box-shadow:0 4px 24px #0003}.landing-card-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-400);margin-bottom:16px}.ranking-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.ranking-list .room-item{background:#ffffff0f;border-color:#ffffff1a}.ranking-list .room-item-empty{color:var(--gray-500);background:transparent;border:1px dashed rgba(255,255,255,.15)}.ranking-list .room-name{color:var(--white);font-weight:600}.ranking-list .room-meta{color:var(--gray-400);font-size:13px}.ranking-left{display:flex;align-items:center;gap:10px}.ranking-pos{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:999px;font-size:13px;font-weight:700;border:1px solid rgba(255,255,255,.35);color:var(--white);background:#0006}.ranking-pos.gold{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:#1f2937;box-shadow:0 0 0 2px #f4c43099}.ranking-pos.silver{background:linear-gradient(135deg,#e5e7eb,#d1d5db);color:#111827}.ranking-pos.bronze{background:linear-gradient(135deg,#f97316,#ea580c);color:#1f2937}.landing-card .rooms-list .room-item{background:#ffffff0f;border-color:#ffffff1a}.landing-card .rooms-list .room-item-empty{color:var(--gray-500);background:transparent;border:1px dashed rgba(255,255,255,.15)}.landing-card .rooms-list .room-item{color:var(--gray-100)}.landing-card .rooms-list .room-item strong{color:var(--white)}.landing-card .rooms-list .room-meta small{color:var(--gray-300)}.landing-card .field input{background:#ffffff14;border-color:#ffffff26;color:var(--white)}.landing-card .field input::placeholder{color:var(--gray-500)}.landing-card .field span{color:var(--gray-400)}.landing-card .button-row{margin-top:16px}.landing-card button.accent{background:var(--felt-main);color:var(--white)}.landing-card button.accent:hover{background:var(--felt-light)}.landing-card button:not(.accent){background:#ffffff1a;color:var(--white);border:1px solid rgba(255,255,255,.2)}.landing-card button:not(.accent):hover{background:#ffffff26}.landing-card .auth-message.visible{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--gray-200)}.landing-card .auth-message.visible.error{background:#dc262633;border-color:#dc262666;color:#fca5a5}.landing-card .auth-message.visible.success{background:#22c55e33;border-color:#22c55e66;color:#86efac}.landing-card .auth-message.visible.info{background:#3b82f633;border-color:#3b82f666;color:#93c5fd}.lobby-actions{display:flex;justify-content:flex-end;margin-bottom:14px}.rooms-list{list-style:none;display:grid;gap:10px;padding:0;margin:0}.room-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border:1px solid var(--gray-200);border-radius:12px;background:var(--gray-50)}.room-item-empty{justify-content:center;color:var(--gray-700);font-size:15px}.room-item strong{color:var(--gray-900)}.room-meta{display:flex;flex-direction:column;gap:2px}.room-meta small{color:var(--gray-600)}.room-item button{padding:10px 14px;border-radius:10px}.tournament-result-message{font-size:16px;color:var(--gray-800);line-height:1.5}.auth-message{min-height:44px;margin-bottom:20px;padding:12px 16px;border-radius:8px;font-size:14px;display:none}.auth-message.visible{display:block}.auth-message.success{background:#d1fae5;color:#065f46;border:1px solid #a7f3d0}.auth-message.info{background:#e0f2fe;color:#075985;border:1px solid #bae6fd}.auth-message.error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}#app{display:grid;grid-template-columns:300px 1fr;min-height:100vh;transition:grid-template-columns .3s var(--ease-in-out)}#app.panel-collapsed{grid-template-columns:0 1fr}#ui{background:var(--white);overflow-y:auto;transition:transform .3s var(--ease-in-out)}#app.panel-collapsed #ui{transform:translate(-100%)}#table{display:flex;align-items:center;justify-content:center;padding:40px 20px;position:relative}.your-turn-indicator{position:fixed;top:24px;right:24px;padding:16px 28px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:28px;font-weight:800;letter-spacing:2px;border-radius:12px;box-shadow:0 10px 30px #ef444466;z-index:200;animation:pulse-turn 1s ease-in-out infinite;text-transform:uppercase}.your-turn-indicator.hidden{display:none}@keyframes pulse-turn{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.idle-timeout-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top,#00000080,#000000d9);z-index:250}.idle-timeout-modal.hidden{display:none}.idle-timeout-content{max-width:360px;width:90%;background:#0f172afa;border-radius:16px;padding:20px 22px;box-shadow:var(--shadow-xl);border:1px solid rgba(148,163,184,.5)}.idle-timeout-content h2{font-size:18px;margin-bottom:8px}.idle-timeout-content p{font-size:14px;color:var(--gray-200);margin-bottom:16px}@keyframes pulse-winner{0%,to{border-color:var(--gold);box-shadow:0 0 0 3px #f4c43099,0 8px 32px #f4c4304d}50%{border-color:var(--gold-dark);box-shadow:0 0 0 6px #f4c430cc,0 8px 32px #f4c43080}}.panel{padding:24px 20px;height:100vh;overflow-y:auto}.panel::-webkit-scrollbar{width:6px}.panel::-webkit-scrollbar-track{background:var(--gray-100)}.panel::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:3px}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--gray-200)}.panel-kicker{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--gray-600);margin-bottom:4px}h1{font-family:Cinzel,serif;font-size:24px;font-weight:800;color:var(--gray-900);letter-spacing:-.5px}.panel-pill{padding:6px 12px;background:var(--felt-main);color:var(--white);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;border-radius:20px}.panel-toggle{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--gray-100);border:1px solid var(--gray-300);border-radius:8px;color:var(--gray-700);font-size:16px;cursor:pointer;transition:all .2s}.panel-toggle:hover{background:var(--gray-200);border-color:var(--gray-400)}#app.panel-collapsed .panel-toggle{position:fixed;top:24px;left:24px;z-index:100;background:var(--white);box-shadow:var(--shadow-lg)}.panel-card{background:var(--white);border:1px solid var(--gray-200);border-radius:14px;padding:22px;margin-bottom:18px;box-shadow:var(--shadow-sm)}.panel-card h2{font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-700);margin-bottom:16px}.field-grid{display:grid;gap:16px}.field{display:flex;flex-direction:column;gap:8px}.field span{font-size:13px;font-weight:600;color:var(--gray-700);text-transform:uppercase;letter-spacing:.5px}.field input{padding:12px 14px;background:var(--white);border:2px solid var(--gray-300);border-radius:8px;font-size:15px;font-family:inherit;color:var(--gray-900);transition:all .2s}.field input:focus{outline:none;border-color:var(--felt-main);box-shadow:0 0 0 3px #0d5f4a1a}.forgot-password-row{margin-top:4px}.forgot-password-link{font-size:13px;color:var(--felt-main, #0d5f4a);text-decoration:none}.forgot-password-link:hover{text-decoration:underline}.forgot-password-block{margin-top:16px}.forgot-password-block .forgot-password-text{margin:0 0 16px;font-size:14px;color:var(--gray-700)}.forgot-password-block .field{margin-bottom:8px}.button-row{display:flex;gap:10px;margin-top:20px}button.secondary{background:var(--gray-600)}button.secondary:hover:not(:disabled){background:var(--gray-500)}button{padding:12px 20px;background:var(--gray-800);color:var(--white);border:none;border-radius:10px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:transform .15s var(--ease-out),box-shadow .15s,background .15s;font-family:inherit}button:hover:not(:disabled){background:var(--gray-900);transform:translateY(-2px);box-shadow:var(--shadow-md)}button:focus-visible{outline:none;box-shadow:0 0 0 3px #0d5f4a59}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button.accent{background:var(--felt-main)}button.accent:hover:not(:disabled){background:var(--felt-dark)}.status-grid{display:grid;gap:12px}.status-grid>div{display:flex;flex-direction:column;gap:4px}.status-grid span{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-600)}.status-grid strong{font-size:14px;font-weight:600;color:var(--gray-900)}.players{list-style:none;display:grid;gap:8px}.players li{padding:10px 12px;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;font-size:14px;color:var(--gray-900)}.panel-log pre{background:var(--gray-900);color:var(--gray-100);padding:12px;border-radius:8px;font-size:11px;line-height:1.5;max-height:200px;overflow:auto;font-family:SF Mono,Monaco,monospace}.table-surface{width:100%;max-width:980px;min-height:640px;background:radial-gradient(ellipse 120% 100% at 50% 50%,#0f8f6a 0%,var(--felt-main) 45%,var(--felt-dark) 100%);border-radius:50%/38%;padding:60px 70px;position:relative;box-shadow:0 32px 88px #000000a6;border:16px solid var(--wood-mid);overflow:visible}.table-surface:before{content:"";position:absolute;inset:10px;border-radius:50%/38%;border:3px solid rgba(244,196,48,.6);box-shadow:inset 0 0 40px #0006,0 0 35px #00000073;pointer-events:none}.table-surface:after{content:"";position:absolute;inset:34px;border-radius:50%/38%;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.06),transparent 45%),radial-gradient(circle at 75% 30%,rgba(255,255,255,.03),transparent 50%);opacity:.25;pointer-events:none}#pixi-layer{position:absolute;inset:0;pointer-events:none;z-index:10;border-radius:50%/38%;overflow:hidden}#pixi-layer canvas{width:100%;height:100%}.table-surface--pixi-cards .card-row .card,.table-surface--pixi-cards .seat-hand .card{visibility:hidden}.table-surface--pixi-cards .seat-hand{min-width:72px;min-height:52px}.table-header{position:relative;z-index:5;display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:32px}.table-kicker{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:#fff9;margin-bottom:4px}.table-title{font-family:Cinzel,serif;font-size:28px;font-weight:800;color:var(--white);text-shadow:0 2px 8px rgba(0,0,0,.5);letter-spacing:-.5px;margin:0}.table-header-row{display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap}.table-header-row--pot{margin-bottom:4px}.table-header-row--meta{opacity:.9;min-height:36px}@media(max-width:600px){.table-header-row--meta{min-height:52px}}.badge{padding:6px 12px;background:#0a0f1ae6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(244,196,48,.5);border-radius:6px;font-size:12px;font-weight:600;color:var(--white);text-transform:uppercase;letter-spacing:.5px}.badge-pot{padding:10px 20px;font-size:15px;border-radius:999px;box-shadow:0 0 18px #f4c43099;background:radial-gradient(circle at 30% 0%,rgba(255,255,255,.22),transparent 50%),#0a0f1af5;transition:transform .2s ease-out;transform:scale(1)}.badge-pot--pulse{transform:scale(1.06)}.badge-pot span{font-size:18px}.badge-meta{font-size:11px;border-color:#f4c43059;background:#0a0f1acc}.badge.timer span{color:var(--gold);font-weight:700}.badge-phase{display:inline-flex;align-items:center;gap:8px}.phase-progress{display:inline-flex;align-items:center;gap:4px}.phase-dot{width:7px;height:7px;border-radius:50%;background:#f4c43026;border:1px solid rgba(244,196,48,.35);transition:background .24s ease,transform .24s ease,box-shadow .24s ease}.phase-dot.is-filled{background:var(--gold);border-color:var(--gold);box-shadow:0 0 6px #f4c4308c;transform:scale(1.05)}.badge-turn{display:inline-flex;align-items:center;gap:6px}.turn-reason{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border-radius:999px;background:#f4c43026;color:var(--gold);border:1px solid rgba(244,196,48,.35);white-space:nowrap;transition:opacity .2s ease}.turn-reason.hidden{display:none}.winner-banner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.9);padding:14px 24px;border-radius:999px;background:radial-gradient(circle at 20% 0%,rgba(255,255,255,.3),transparent 55%),#0a0f1af2;border:2px solid rgba(244,196,48,.85);color:var(--white);font-family:Cinzel,serif;font-size:18px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 20px 60px #000c,0 0 30px #f4c430e6;z-index:30;text-align:center;pointer-events:none;opacity:0;transition:opacity .3s ease-out,transform .3s ease-out}.winner-banner.visible{opacity:1;transform:translate(-50%,-50%) scale(1)}.seats{position:absolute;inset:0;z-index:15;pointer-events:none}.seat{position:absolute;width:160px;padding:12px 14px;border-radius:14px;background:#060a12b3;border:1px solid rgba(244,196,48,.35);box-shadow:0 8px 20px #00000059;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);text-align:center;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;overflow:visible;pointer-events:auto}.seat[data-seat="0"]{top:-4%;left:50%}.seat[data-seat="1"]{top:10%;left:94%}.seat[data-seat="2"]{top:90%;left:94%}.seat[data-seat="3"]{top:104%;left:50%}.seat[data-seat="4"]{top:90%;left:6%}.seat[data-seat="5"]{top:10%;left:6%}.seat-badge{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#ffffffa6;margin-bottom:6px}.seat-status{display:flex;gap:6px;justify-content:center;margin-bottom:6px}.seat-pill{display:none;padding:2px 6px;border-radius:999px;font-size:9px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--gray-900)}.seat-pill.dealer{background:var(--gold)}.seat-pill.turn{background:#7dd3fc}.seat.dealer .seat-pill.dealer,.seat.turn .seat-pill.turn{display:inline-flex}.seat-name{font-weight:700;font-size:14px;color:var(--white);margin-bottom:6px}.seat-meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:#ffffffbf}.seat-chip,.seat-bet{padding:4px 8px;border-radius:999px;background:#00000059;border:1px solid rgba(244,196,48,.3);font-weight:700}.seat.you{border-color:#f4c430e6;box-shadow:0 0 0 2px #f4c43059,0 12px 26px #00000073}.seat.folded{opacity:.55}.seat.winner{animation:pulse-winner 1.2s ease-in-out infinite;background:linear-gradient(135deg,#f4c4302e,#d1a6261f);transform:translate(-50%,-50%) scale(1.04)}.seat.winner .seat-badge{background:var(--gold);color:var(--bg-darker);font-weight:700}.seat-winning-hand{margin-top:8px;padding:6px 10px;background:linear-gradient(135deg,var(--gold) 0%,var(--gold-dark) 100%);border-radius:6px;font-size:11px;font-weight:700;text-align:center;color:var(--bg-darker);text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #f4c43066}.seat-current-hand{margin-top:6px;font-size:15px;font-weight:700;color:var(--gold);text-align:center;text-shadow:0 0 12px rgba(244,196,48,.5);letter-spacing:.5px}.seat-hand{display:flex;justify-content:center;align-items:center;margin-bottom:10px;cursor:pointer;padding:10px 6px;perspective:120px;gap:0;min-height:88px;overflow:visible}.seat:hover .seat-hand{visibility:visible}.seat-hand:hover{background:#f4c43026;border-radius:8px}.seat-hand .card.mini{width:70px;height:98px;padding:0;border-radius:6px;box-shadow:0 4px 14px #00000080;transition:transform .2s ease,box-shadow .2s ease;flex-shrink:0;overflow:hidden}.seat-hand .card.mini:first-child{transform:rotate(-12deg) translateY(-2px);z-index:2;margin-right:-26px}.seat-hand .card.mini:last-child{transform:rotate(10deg) translateY(-2px);z-index:1}.seat-hand .card.mini:only-child{transform:none;margin-right:0}.seat-hand:hover .card.mini:first-child{transform:rotate(-10deg) translateY(-4px);box-shadow:0 6px 18px #00000080}.seat-hand:hover .card.mini:last-child{transform:rotate(8deg) translateY(-4px);box-shadow:0 6px 18px #00000080}.seat-hand .card.mini img{border-radius:4px}.seat-hand .card.mini .rank,.seat-hand .card.mini .suit{font-size:14px}.table-zones{position:relative;z-index:5;display:grid;gap:28px}.table-zone{background:#050810b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(244,196,48,.3);border-radius:12px;padding:18px}.table-zone--your-cards{display:none}.table-zone--your-cards .card{padding:0;overflow:hidden}.table-zone--community{background:transparent;border:none;-webkit-backdrop-filter:none;backdrop-filter:none;padding:20px 0;display:flex;justify-content:center;align-items:center;width:100%}.table-zone--community .zone-title{display:none}.card-row--community{gap:18px;display:flex;justify-content:center;align-items:center;flex-wrap:nowrap}.card-row--community .card{width:138px;height:193px;box-shadow:0 8px 24px #00000073;flex-shrink:0;padding:0;overflow:hidden}.card-row--community .card .rank{font-size:24px}.card-row--community .card .suit{font-size:22px}.zone-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#fffc;margin-bottom:14px}.card-row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.card{width:85px;height:120px;background:var(--white);border-radius:6px;box-shadow:var(--shadow-md);border:2px solid var(--gray-300);display:flex;flex-direction:column;justify-content:space-between;padding:6px;transition:transform .2s;flex-shrink:0}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card img{display:block;width:100%;height:100%;object-fit:contain;border-radius:4px}.card-row--community .card img,.table-zone--your-cards .card img,.seat-hand .card.mini img{border-radius:inherit}.card.card-back,.card.back{background:linear-gradient(135deg,#1a3d30,#0d2820);border-color:var(--gold)}.card.has-image{padding:0}.card.has-image .rank,.card.has-image .suit{display:none}.card .rank{font-family:Poppins,sans-serif;font-size:18px;font-weight:800;line-height:1}.card .suit{font-size:16px;line-height:1}.card.red{color:#dc2626}.card.black{color:#171717}.card-popover{position:fixed;z-index:1000;pointer-events:none;opacity:0;transform:scale(.92) translateY(4px);transition:opacity .2s ease,transform .2s ease}.card-popover:not(.hidden){opacity:1;transform:scale(1) translateY(0);pointer-events:auto}.card-popover-inner{background:linear-gradient(145deg,#121c2dfa,#080e18fc);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(244,196,48,.4);border-radius:14px;padding:20px 24px;box-shadow:0 20px 50px #00000080,0 0 0 1px #ffffff0f}.card-popover-cards{display:flex;gap:16px;justify-content:center}.card-popover-cards .card{width:160px;height:224px;box-shadow:0 8px 28px #00000073}.card-popover-cards .card .rank{font-size:32px}.card-popover-cards .card .suit{font-size:28px}.game-actions{position:fixed;inset:auto 28px 28px auto;transform:none;display:flex;flex-direction:row;gap:12px;align-items:center;padding:18px 20px;background:#050810f7;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(244,196,48,.45);border-radius:16px;box-shadow:0 20px 50px #0000008c,0 0 0 1px #f4c4301a;z-index:50;width:auto;max-width:calc(100vw - 56px)}.action-group,.bet-group{display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap}.game-btn{padding:10px 18px;background:var(--gray-700);color:var(--white);border:2px solid var(--gray-600);border-radius:8px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:transform .15s var(--ease-out),border-color .15s,background .15s;font-family:inherit;white-space:nowrap}.game-btn:hover:not(:disabled){background:var(--gray-800);border-color:var(--gold);transform:translateY(-2px)}.game-btn:focus-visible{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px #f4c43040}.game-btn:disabled{opacity:.4;cursor:not-allowed}.game-btn.accent{background:var(--felt-main);border-color:var(--felt-dark);color:var(--white)}.game-btn.accent:hover:not(:disabled){background:var(--felt-light);border-color:var(--gold)}.game-btn.alert{background:#c41e3a;border-color:#8b0000;color:var(--white)}.game-btn.alert:hover:not(:disabled){background:#e63946;border-color:#f1faee}.bet-input{width:110px;padding:10px 12px;background:#ffffff1a;border:2px solid rgba(244,196,48,.3);border-radius:6px;color:var(--white);font-size:14px;font-weight:700;text-align:center;font-family:inherit}.bet-input:focus{outline:none;border-color:var(--gold);background:#ffffff26}.table-footer{position:relative;z-index:5;margin-top:0;display:flex;justify-content:center}.mobile-seat-panel{display:none;width:100%;background:transparent;border:none;padding:0}.mobile-seat-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:#ffffffb3;margin-bottom:12px}.mobile-seat-list{list-style:none;display:grid;gap:8px}.mobile-seat-list li{padding:12px;background:#ffffff0d;border:1px solid rgba(244,196,48,.2);border-radius:8px;font-size:13px;color:var(--white);position:relative}.mobile-seat-name{font-weight:700;margin-bottom:4px}.mobile-seat-meta{font-size:12px;color:#ffffffb3}.mobile-seat-badge{position:absolute;top:8px;right:8px;padding:3px 8px;background:var(--gold);color:var(--gray-900);font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:1px;border-radius:4px}.mobile-seat-list li.is-you{border-color:var(--gold);background:#f4c4301a}.mobile-seat-list li.is-turn{border-color:var(--gold);box-shadow:0 0 0 2px #f4c4304d}.mobile-seat-list li.is-folded{opacity:.5}@media(max-width:1100px){#app{grid-template-columns:1fr;grid-template-rows:auto 1fr}#ui{height:auto;max-height:280px}.table-surface{padding:50px;min-height:560px}}@media(max-width:768px){#ui,.panel-toggle{display:none}#table{padding:20px}.table-surface{padding:24px 16px;min-height:520px;display:flex;flex-direction:column;gap:20px}.table-header{flex-direction:column;align-items:center;margin-bottom:16px}.table-title{font-size:22px}.mobile-seat-panel{display:block;max-height:120px;overflow-y:auto}.mobile-seat-title{font-size:10px;margin-bottom:6px}.mobile-seat-list li{padding:8px 10px;font-size:12px}.seats{display:none}.table-zones{gap:20px;order:1;display:flex;flex-direction:column}.table-zone--community{order:1;padding:16px 12px;background:#050810d9;border-radius:12px;border:2px solid rgba(244,196,48,.4)}.table-zone--community .zone-title{display:block;font-size:12px;margin-bottom:10px;color:#ffffffe6}.card-row--community{gap:10px;justify-content:center;flex-wrap:wrap}.card-row--community .card{width:72px;height:102px;box-shadow:0 4px 16px #00000080;padding:0;overflow:hidden}.card-row--community .card .rank{font-size:18px}.card-row--community .card .suit{font-size:16px}.table-zone--your-cards{display:flex!important;flex-direction:column;align-items:center;padding:16px 12px;background:linear-gradient(135deg,#f4c43026,#050810e6);border:2px solid rgba(244,196,48,.6);border-radius:12px;order:2}.table-zone--your-cards.hidden{display:flex!important}.table-zone--your-cards .zone-title{display:block;font-size:14px;font-weight:700;color:var(--gold);margin-bottom:12px;text-transform:uppercase;letter-spacing:1px}.table-zone--your-cards .card-row{gap:12px;justify-content:center}.table-zone--your-cards .card{width:80px;height:114px;box-shadow:0 6px 20px #00000073;border:2px solid var(--gold);padding:0;overflow:hidden}.table-zone--your-cards .card .rank{font-size:20px}.table-zone--your-cards .card .suit{font-size:18px}.table-footer{order:3}.game-actions{order:4;flex-direction:column;align-items:stretch;width:calc(100% - 40px);left:20px;right:20px;bottom:20px;padding:16px 18px}.card{width:75px;height:105px}.card .rank{font-size:16px}}@media(max-width:520px){#app{grid-template-columns:1fr}.table-title{font-size:18px}.badge{font-size:10px;padding:5px 10px}.card{width:65px;height:92px}.card .rank{font-size:14px}.card .suit{font-size:12px}.game-btn{padding:8px 12px;font-size:11px}.card-row--community .card{width:58px;height:82px}.card-row--community .card .rank{font-size:14px}.card-row--community .card .suit{font-size:12px}.table-zone--your-cards .card{width:68px;height:96px}.table-zone--your-cards .card .rank{font-size:16px}.table-zone--your-cards .card .suit{font-size:14px}}.history-list{list-style:none;display:flex;flex-direction:column;gap:12px;max-height:260px;overflow-y:auto;padding-right:6px}.history-item{padding:12px;border-radius:10px;background:#f8fafc;border:1px solid #e2e8f0;color:#0f172a;font-size:13px;display:flex;flex-direction:column;gap:8px}.history-header{display:grid;grid-template-columns:1fr;gap:4px;font-weight:600;color:#1e293b}.history-time{font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.04em}.history-body{display:flex;flex-direction:column;gap:4px;color:#334155}.history-empty{padding:12px;border-radius:10px;background:#f1f5f9;border:1px dashed #cbd5f5;color:#475569;font-size:13px}.rebuy-dialog-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px)}to{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}.rebuy-dialog{background:linear-gradient(135deg,#1e293b,#0f172a);border:2px solid var(--gold);border-radius:16px;padding:32px;max-width:400px;width:90%;box-shadow:0 20px 60px #000c;text-align:center;animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.rebuy-icon{font-size:64px;margin-bottom:16px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.rebuy-dialog h2{color:#f44;font-family:Cinzel,serif;font-size:28px;font-weight:700;margin-bottom:12px;text-shadow:0 2px 10px rgba(255,68,68,.3)}.rebuy-dialog p{color:#e2e8f0;font-size:16px;margin-bottom:8px}.rebuy-dialog strong{color:var(--gold);font-weight:700}.rebuy-timer{background:#f4c4301a;border:1px solid rgba(244,196,48,.3);border-radius:8px;padding:12px;margin:20px 0}.rebuy-timer p{color:var(--gold);font-size:14px;margin:0}#rebuy-countdown{color:#f44;font-weight:700;font-size:18px}.rebuy-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px}.rebuy-buttons .btn{padding:12px 20px;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.05em}.rebuy-buttons .btn-primary{background:linear-gradient(135deg,var(--gold) 0%,#d1a626 100%);color:#0a0f1a}.rebuy-buttons .btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f4c43066}.rebuy-buttons .btn-primary:active{transform:translateY(0)}.rebuy-buttons .btn-secondary{background:#e5e7eb1a;color:#e5e7eb;border:1px solid rgba(229,231,235,.2)}.rebuy-buttons .btn-secondary:hover{background:#e5e7eb33;border-color:#e5e7eb66}.rebuy-buttons .btn-secondary:active{transform:scale(.98)}.reconnect-banner{position:fixed;top:0;left:0;right:0;z-index:9000;display:flex;align-items:center;justify-content:center;gap:.6em;padding:.45em 1em;font-size:.85rem;font-weight:500;letter-spacing:.01em;color:#1a1a1a;background:#ffd166eb;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);box-shadow:0 1px 8px #0000002e;transform:translateY(0);transition:transform .2s ease-out,opacity .2s ease-out;pointer-events:none}.reconnect-banner--hidden{transform:translateY(-100%);opacity:0;pointer-events:none}.reconnect-banner--degraded{background:#dc3545f2;color:#fff}.reconnect-banner__dot{width:8px;height:8px;border-radius:50%;background:currentColor;animation:reconnect-dot-pulse 1.2s ease-in-out infinite}@keyframes reconnect-dot-pulse{0%,to{opacity:.4}50%{opacity:1}}#ui.panel .status-grid>div.debug-only{display:none}body.debug-mode #ui.panel .status-grid>div.debug-only{display:flex}
