*{box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(to bottom,rgb(4,5,11),var(--bg-surface))}:root{--rift-orange: #FF8A1F;--rift-orange-deep: #E06A00;--rift-orange-glow: #FFB066;--rift-purple: #8B5CF6;--rift-purple-deep: #6D28D9;--rift-purple-glow: #BFA5FF;--rift-aqua: #2DD4BF;--rift-aqua-deep: #0F766E;--rift-aqua-glow: #6EE7D8;--bg-base: #0B0F1A;--bg-surface: #12182A;--bg-raised: #1A2138;--text-primary: #F8FAFC;--text-secondary: #CBD5E1;--text-muted: #94A3B8;--border-subtle: #2A3558}.wrapper{min-height:100vh;box-sizing:content-box}.home-header{position:absolute;top:0;left:0;display:flex;justify-content:flex-start;padding:16px 24px;z-index:50}.home-logo{padding:8px;font-size:16px;font-weight:800;line-height:16px;border:2px solid white;display:inline-block;box-shadow:0 0 12px #fff3;box-sizing:content-box;text-align:left;color:var(--text-primary);text-decoration:none}.header{color:var(--text-primary);display:flex;flex-flow:column nowrap;justify-content:center;align-items:center;background:linear-gradient(#0b0f1acc,#0b0f1acc),url(/media/world.jpg);background-size:cover;background-position:center bottom;padding:72px 48px;box-sizing:border-box;min-height:100vh;border-bottom:1px solid var(--border-subtle)}.footer .title{padding:8px;font-size:16px;font-weight:800;line-height:16px;border:2px solid white;display:inline-block;box-shadow:0 0 12px #fff3;margin:0;box-sizing:content-box}.header .header-hero{display:flex;flex-flow:column nowrap;align-items:center;justify-content:center;max-width:800px;width:100%;text-align:center}.header .hero-icon{font-size:48px;color:var(--rift-orange);margin-bottom:32px}.header .hero-tagline{font-size:clamp(32px,5vw,48px);font-weight:600;line-height:1.1;margin:0 0 24px;color:var(--text-primary);letter-spacing:-.02em}.header .hero-teaser{font-size:clamp(16px,2vw,20px);font-weight:400;line-height:1.6;color:#fffc;margin:0 0 40px;max-width:640px}.header .hero-buttons{display:flex;flex-direction:column;gap:16px;justify-content:center;align-items:center}.header a,.hero a:hover{text-decoration:none}.header button{font-size:20px;font-weight:400;padding:0 32px;height:56px;background:#ff8a1f59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#ffffffe6;border:1px solid rgba(255,138,31,.6);border-radius:28px;display:block;margin:0 auto;box-sizing:content-box;transition:all .3s ease;box-shadow:0 8px 32px #ff8a1f4d,inset 0 0 20px #ff8a1f66,inset 0 1px #ffffff4d,inset 0 -1px #ff8a1f66;position:relative;overflow:hidden}.header button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.header button:hover{background:#ff8a1f73;border-color:#ff8a1fcc;box-shadow:0 12px 40px #ff8a1f80,inset 0 0 30px #ff8a1f80,inset 0 1px #fff6,inset 0 -1px #ff8a1f80;cursor:pointer;transform:translateY(-2px);color:#fff}.header button:hover:before{left:100%}.header .hero-button{font-size:20px;font-weight:400;padding:0 32px;height:56px;border-radius:28px;display:inline-flex;align-items:center;justify-content:center;box-sizing:content-box;transition:all .3s ease;text-decoration:none;position:relative;overflow:hidden;background:#ff8a1f59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#ffffffe6;border:1px solid rgba(255,138,31,.6);box-shadow:0 8px 32px #ff8a1f4d,inset 0 0 20px #ff8a1f66,inset 0 1px #ffffff4d,inset 0 -1px #ff8a1f66}.header .hero-button:hover{background:#ff8a1f73;border-color:#ff8a1fcc;box-shadow:0 12px 40px #ff8a1f80,inset 0 0 30px #ff8a1f80,inset 0 1px #fff6,inset 0 -1px #ff8a1f80;transform:translateY(-2px);color:#fff}.header .hero-button.subtle,.header button.hero-button.subtle{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border:none;box-shadow:none;color:var(--text-primary);height:auto;padding:4px 12px;font-size:16px;border-radius:0}.header .hero-button.subtle:hover,.header button.hero-button.subtle:hover{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border:none;box-shadow:none;color:var(--text-secondary);transform:none;text-decoration:underline}.header button.hero-button.subtle:before{display:none}.content{padding:64px 72px;box-sizing:content-box}.content-heading{font-size:clamp(28px,4vw,36px);font-weight:600;color:var(--text-primary);text-align:center;margin:0 0 24px}@media(max-width:640px){.header,.content{padding:64px 20px!important}}h1{color:var(--rift-aqua)}.content .game-elements{display:flex;flex-direction:row;flex-wrap:wrap;margin:12px -12px 0}.content-cta{padding:48px 0 0;text-align:center}.content-cta-text{font-size:clamp(18px,2.5vw,24px);font-weight:500;color:var(--text-secondary);margin:0 0 24px}.content-cta button{font-size:20px;font-weight:400;padding:0 32px;height:56px;background:#ff8a1f59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#ffffffe6;border:1px solid rgba(255,138,31,.6);border-radius:28px;display:block;margin:0 auto;box-sizing:content-box;transition:all .3s ease;box-shadow:0 8px 32px #ff8a1f4d,inset 0 0 20px #ff8a1f66,inset 0 1px #ffffff4d,inset 0 -1px #ff8a1f66;position:relative;overflow:hidden;cursor:pointer}.content-cta button:hover{background:#ff8a1f73;border-color:#ff8a1fcc;box-shadow:0 12px 40px #ff8a1f80,inset 0 0 30px #ff8a1f80,inset 0 1px #fff6,inset 0 -1px #ff8a1f80;transform:translateY(-2px);color:#fff}.content .game-element{margin:12px;border:none;padding:clamp(24px,4vw,48px);font-size:14px;box-shadow:0 0 8px #00050a33;flex:1 0 320px;border-radius:24px;background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-sizing:content-box;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;overflow:hidden}.content .game-element span.callout{font-size:12px;font-weight:600;color:var(--rift-purple);text-transform:uppercase;margin-bottom:4px}.game-element span{display:block}.game-element .fa-solid{font-size:18px;width:24px;height:24px;padding:12px;background:#2dd4bf40;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(45,212,191,.4);border-radius:12px;display:flex;justify-content:center;align-items:center;color:var(--rift-aqua-glow);margin-bottom:24px;box-sizing:content-box;box-shadow:0 4px 16px #2dd4bf33,inset 0 0 12px #2dd4bf4d,inset 0 1px #fff3,inset 0 -1px #2dd4bf4d;position:relative;overflow:hidden;align-self:center}.game-element .step{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:8px;text-align:center;max-width:360px}.game-element .explanation{font-size:16px;font-weight:400;color:var(--text-secondary);flex-grow:1;text-align:center;max-width:360px}.game-element button{font-size:14px;font-weight:600;padding:0 24px;height:48px;background-color:var(--rift-aqua);color:var(--bg-base);border:none;border-radius:24px;display:block;align-self:flex-end;margin-top:24px;box-sizing:content-box;transition:background-color .2s ease}.game-element button.emphasis{background-color:var(--rift-orange);color:var(--text-primary)}.game-element button:hover:not(:disabled){background-color:var(--rift-aqua-glow);cursor:pointer}.game-element button.emphasis:hover:not(:disabled){background-color:var(--rift-orange-glow)}.game-element button:disabled{opacity:.5;cursor:not-allowed}.footer{background-color:var(--bg-base);padding:72px 72px 18px;display:flex;flex-flow:column nowrap;align-items:center;color:var(--text-primary);box-sizing:content-box;border-top:1px solid var(--border-subtle)}.footer .fa-solid{color:var(--rift-aqua)}.footer .built-in{font-size:14px;font-weight:600;color:var(--rift-aqua);margin-top:12px;margin-bottom:48px}.footer .copyright{font-size:12px;opacity:.3}.content.setup{min-height:100vh;display:flex;flex-flow:row nowrap;justify-content:center;align-items:center;max-width:640px;margin:0 auto}.setup .card{margin:12px;padding:32px;text-align:center;font-size:14px;box-shadow:0 0 12px #0000004d;width:640px;flex-grow:1;border-radius:24px;background-color:var(--bg-raised);border:1px solid var(--border-subtle)}.setup .card .details{text-align:left;position:relative}.setup .card span{display:block}.setup .card span.name{font-size:24px;font-weight:600;color:var(--text-primary);margin:8px 0}.setup .card span.players{font-size:14px;font-weight:400;color:var(--text-muted)}.setup .card span.callout{font-size:12px;font-weight:600;color:var(--rift-purple);text-transform:uppercase}.setup .card span.feature.featured{color:var(--rift-orange)}.setup .card span.description{font-size:16px;font-weight:500;color:var(--text-secondary)}.setup .card .bottom_bar{display:flex;justify-content:space-between;align-items:center;margin-top:24px}.setup .card button{font-size:14px;font-weight:400;padding:12px 24px;background-color:var(--rift-aqua);color:var(--bg-base);border:none;border-radius:20px;transition:background-color .2s ease}.setup .card button:hover{background-color:var(--rift-aqua-glow);cursor:pointer}.pickers{display:flex;flex-flow:column nowrap;text-align:left}.dropdown{padding:12px 0;display:flex;flex-flow:column nowrap;align-items:left}.dropdown label{font-size:14px;font-weight:600;vertical-align:middle;margin-bottom:8px;width:120px;color:var(--text-primary)}.dropdown select{appearance:none;font-size:14px;font-weight:400;background:none;border:1px solid var(--border-subtle);color:var(--text-secondary);padding:8px;background-color:var(--bg-surface);width:160px;border-radius:4px}.dropdown select:focus{outline:none}.global-header{position:fixed;top:0;right:0;left:0;display:flex;justify-content:flex-end;padding:16px 24px;z-index:100;pointer-events:none}.global-header>*{pointer-events:auto}.tutorial-pill{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:#8b5cf626;border:1px solid var(--rift-purple);border-radius:50%;color:var(--rift-purple-glow);font-size:18px;cursor:pointer;transition:all .2s ease;z-index:100}.tutorial-pill:hover{background:#8b5cf640;border-color:var(--rift-purple-glow);transform:translateY(-1px)}.about-hero{background:linear-gradient(#0b0f1ad9,#0b0f1ad9),url(/media/war.jpg);background-size:cover;background-position:center bottom;padding:72px 48px;border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);text-align:center;min-height:100vh;box-sizing:border-box;display:flex;flex-direction:column;justify-content:center;align-items:center}.about-hero-content{max-width:800px;margin:0 auto;padding-left:24px;padding-right:24px}.about-title{font-size:clamp(32px,5vw,48px);font-weight:600;color:var(--text-primary);margin:0 0 24px}.about-hero-text{font-size:clamp(16px,2vw,18px);line-height:1.7;color:#fffc;margin:0 auto 16px;max-width:640px}.about-hero-text:last-child{margin-bottom:0}.about-hero~.content .content-heading{max-width:700px;margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px}.design-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;max-width:1400px;margin:64px auto;padding:clamp(24px,4vw,48px);border-radius:24px;background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);box-shadow:0 0 8px #00050a33}@media(max-width:1000px){.design-cards{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.design-cards{grid-template-columns:1fr}}.design-card{text-align:left}.design-card-header{display:flex;align-items:center;gap:10px;margin-bottom:12px}.design-card-header i{font-size:16px;color:var(--rift-aqua)}.design-card-header span{font-size:16px;font-weight:600;color:var(--text-primary)}.design-card p{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0}.about-closing{margin-top:48px;max-width:700px;margin-left:auto;margin-right:auto;text-align:center;padding-left:24px;padding-right:24px}.about-closing p{font-size:15px;line-height:1.7;color:var(--text-secondary);margin:0 0 16px}.about-closing p:last-child{margin-bottom:0}.about-rules{margin-top:64px;max-width:700px;margin-left:auto;margin-right:auto;padding-top:64px;position:relative}.about-rules+.content-cta{padding-top:64px}.about-rules:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:100vw;border-top:1px solid var(--border-subtle)}.rules-heading{font-size:14px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;margin:0 0 24px;text-align:center}.accordion-container{display:flex;flex-direction:column;gap:12px}@media(max-width:640px){.about-hero{padding:64px 20px}.about-hero~.content{padding:64px 20px}}.auth-modal-backdrop{position:fixed;inset:0;background:#0b0f1ad9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.auth-modal{background:#1a2138f2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-subtle);border-radius:24px;padding:32px;width:100%;max-width:400px;position:relative;box-shadow:0 24px 48px #0006,0 0 0 1px #ffffff0d}.auth-modal-close{position:absolute;top:16px;right:16px;background:transparent;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease}.auth-modal-close:hover{color:var(--text-primary);background:#ffffff1a}.auth-modal-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 24px;text-align:center}.auth-modal-tabs{display:flex;gap:8px;margin-bottom:24px;background:#0003;padding:4px;border-radius:12px}.auth-tab{flex:1;padding:10px 16px;background:transparent;border:none;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s ease}.auth-tab:hover{color:var(--text-secondary)}.auth-tab.active{background:#2dd4bf33;color:var(--rift-aqua)}.auth-modal-form{display:flex;flex-direction:column;gap:16px}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:13px;font-weight:500;color:var(--text-secondary)}.auth-field input{padding:12px 16px;background:#0000004d;border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);font-size:15px;transition:all .2s ease}.auth-field input::placeholder{color:var(--text-muted)}.auth-field input:focus{outline:none;border-color:var(--rift-aqua);box-shadow:0 0 0 3px #2dd4bf26}.auth-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:14px}.auth-error i{color:#ef4444}.auth-submit{margin-top:8px;padding:14px 24px;background:var(--rift-aqua);border:none;border-radius:12px;color:var(--bg-base);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.auth-submit:hover:not(:disabled){background:var(--rift-aqua-glow);transform:translateY(-1px)}.auth-submit:disabled{opacity:.7;cursor:not-allowed}.auth-loading{display:flex;align-items:center;justify-content:center;gap:8px}.auth-modal-footer{margin-top:20px;text-align:center;font-size:14px;color:var(--text-muted)}.auth-link{background:none;border:none;color:var(--rift-aqua);font-size:14px;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px}.auth-link:hover{color:var(--rift-aqua-glow)}@media(max-width:480px){.auth-modal{padding:24px;border-radius:16px}.auth-modal-title{font-size:20px}}.quick-start-backdrop{position:fixed;inset:0;background:#0b0f1a4d;display:flex;align-items:flex-end;justify-content:flex-start;z-index:1000;padding:32px}.quick-start-modal{background:#1a2138f2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-subtle);border-radius:16px;padding:20px 24px 24px;width:100%;max-width:400px;position:relative;box-shadow:0 16px 32px #0000004d,0 0 0 1px #ffffff0d;display:flex;flex-direction:column}.quick-start-close{position:absolute;top:16px;right:16px;background:transparent;border:none;color:var(--text-muted);font-size:16px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s ease}.quick-start-close:hover{color:var(--text-primary);background:#ffffff1a}.quick-start-content{display:flex;flex-direction:column;min-height:0}.quick-start-slide{display:flex;flex-direction:column;align-items:flex-start;gap:10px}.quick-start-slide-header{display:flex;align-items:center;gap:12px}.quick-start-icon{font-size:16px;color:var(--rift-aqua);flex-shrink:0}.quick-start-slide-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.quick-start-slide-description{font-size:14px;line-height:1.5;color:var(--text-secondary);margin:0}.quick-start-inline-link{background:none;border:none;color:var(--rift-aqua);font-size:inherit;font-family:inherit;cursor:pointer;padding:0;text-decoration:underline;text-underline-offset:2px;transition:color .2s ease}.quick-start-inline-link:hover{color:var(--rift-aqua-glow)}.quick-start-footer{display:flex;justify-content:space-between;align-items:center;margin-top:20px}.quick-start-dots{display:flex;gap:6px}.quick-start-dot{width:6px;height:6px;border-radius:50%;background:#fff3;border:none;padding:0;cursor:pointer;transition:all .2s ease}.quick-start-dot:hover{background:#fff6}.quick-start-dot.active{background:var(--rift-aqua);width:18px;border-radius:3px}.quick-start-nav{display:flex;gap:12px;align-items:center}.quick-start-nav-btn{background:transparent;border:none;padding:4px 6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:4px;color:var(--text-muted)}.quick-start-nav-btn:hover:not(:disabled){color:var(--text-primary)}.quick-start-nav-btn:disabled{opacity:.3;cursor:not-allowed}.quick-start-nav-btn.next{color:var(--rift-aqua)}.quick-start-nav-btn.next:hover{color:var(--rift-aqua-glow)}.quick-start-nav-btn.next.primary{color:var(--rift-aqua)}.quick-start-nav-btn.next.primary:hover{color:var(--rift-aqua-glow)}@media(max-width:640px){.quick-start-backdrop{background:#0b0f1ad9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);align-items:center;justify-content:center;padding:16px}.quick-start-modal{max-width:100%}}.profile-modal-backdrop{position:fixed;inset:0;background:#0b0f1ad9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.profile-modal{background:#1a2138f2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-subtle);border-radius:24px;padding:32px;width:100%;max-width:440px;position:relative;box-shadow:0 24px 48px #0006,0 0 0 1px #ffffff0d}.profile-modal-close{position:absolute;top:16px;right:16px;background:transparent;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease}.profile-modal-close:hover{color:var(--text-primary);background:#ffffff1a}.profile-modal-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 20px;text-align:center}.profile-modal-tabs{display:flex;gap:8px;margin-bottom:24px;padding:4px;background:#0003;border-radius:12px}.profile-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:transparent;border:none;border-radius:8px;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.profile-tab:hover{color:var(--text-secondary)}.profile-tab.active{background:#ffffff1a;color:var(--text-primary)}.profile-tab i{font-size:14px}.profile-modal-form{display:flex;flex-direction:column;gap:16px}.profile-field{display:flex;flex-direction:column;gap:6px}.profile-field label{font-size:13px;font-weight:500;color:var(--text-secondary)}.profile-field input{padding:12px 16px;background:#0000004d;border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);font-size:15px;transition:all .2s ease}.profile-field input::placeholder{color:var(--text-muted)}.profile-field input:focus{outline:none;border-color:var(--rift-aqua);box-shadow:0 0 0 3px #2dd4bf26}.profile-field-hint{font-size:12px;color:var(--text-muted)}.profile-error{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:14px}.profile-error i{color:#ef4444}.profile-success{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:8px;color:#86efac;font-size:14px}.profile-success i{color:#22c55e}.profile-submit{margin-top:8px;padding:14px 24px;background:var(--rift-aqua);border:none;border-radius:12px;color:var(--bg-base);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.profile-submit:hover:not(:disabled){background:var(--rift-aqua-glow);transform:translateY(-1px)}.profile-submit:disabled{opacity:.7;cursor:not-allowed}.profile-loading{display:flex;align-items:center;justify-content:center;gap:8px}@media(max-width:480px){.profile-modal{padding:24px;border-radius:16px}.profile-modal-title{font-size:20px}.profile-tab{padding:8px 12px;font-size:13px}}.user-menu{position:relative}.user-menu-loading{padding:8px 16px;color:var(--text-muted)}.user-menu-login{display:flex;align-items:center;gap:8px;padding:6px 12px;min-height:40px;box-sizing:border-box;background:#ffffff0d;border:1px solid var(--border-subtle);border-radius:24px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.user-menu-login:hover{background:#ffffff1a;border-color:#fff3;transform:translateY(-1px)}.user-menu-trigger{display:flex;align-items:center;gap:10px;padding:6px 12px;background:#ffffff0d;border:1px solid var(--border-subtle);border-radius:24px;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.user-menu-trigger:hover{background:#ffffff1a;border-color:#fff3}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--rift-purple);display:flex;align-items:center;justify-content:center;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-initials{font-size:11px;font-weight:600;color:#fff}.user-name{font-size:14px;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase}.role-badge.role-admin{background:#ef444433;color:#fca5a5}.role-badge.role-host{background:#8b5cf633;color:var(--rift-purple-glow)}.role-badge.role-user,.role-badge.role-player{background:#94a3b833;color:var(--text-muted)}.role-badge.role-pending{background:#fbbf2433;color:#fbbf24}.user-menu-trigger i{font-size:10px;color:var(--text-muted);margin-left:2px}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:#1a2138fa;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:0 16px 48px #0006,0 0 0 1px #ffffff0d;overflow:hidden;z-index:1000}.user-menu-header{padding:12px 16px}.user-menu-email{font-size:13px;color:var(--text-muted)}.user-menu-username{font-size:13px;font-weight:600;color:#fff}.user-menu-divider{height:1px;background:var(--border-subtle);margin:0}.user-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:transparent;border:none;color:var(--text-primary);font-size:14px;cursor:pointer;transition:background .15s ease;text-align:left}.user-menu-item:hover:not(:disabled){background:#ffffff0d}.user-menu-item i{width:16px;text-align:center;color:var(--text-muted)}.user-menu-item:hover:not(:disabled) i{color:var(--text-secondary)}.user-menu-item-muted{color:var(--text-muted);cursor:not-allowed}.user-menu-item-muted i{color:var(--text-muted)}.user-menu-item-danger:hover:not(:disabled){background:#ef44441a}.user-menu-item-danger:hover:not(:disabled),.user-menu-item-danger:hover:not(:disabled) i{color:#fca5a5}@media(max-width:640px){.user-name{display:none}.user-menu-trigger{padding:6px 10px}.user-menu-dropdown{right:-8px;min-width:200px}}.accordion-section{border:1px solid var(--border-subtle);border-radius:12px;background:#1a213880;overflow:hidden;transition:border-color .2s ease}.accordion-section:hover{border-color:#2dd4bf4d}.accordion-section.open{border-color:#2dd4bf66}.accordion-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:transparent;border:none;cursor:pointer;transition:background .2s ease}.accordion-header:hover{background:#ffffff08}.accordion-header-left{display:flex;align-items:center;gap:12px}.accordion-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#2dd4bf26;border:1px solid rgba(45,212,191,.3);border-radius:8px;color:var(--rift-aqua);font-size:14px}.accordion-title{font-size:16px;font-weight:600;color:var(--text-primary)}.accordion-chevron{color:var(--text-muted);font-size:12px;transition:transform .2s ease}.accordion-section.open .accordion-chevron{color:var(--rift-aqua)}.accordion-content-wrapper{display:grid;grid-template-rows:0fr;transition:grid-template-rows .3s ease}.accordion-section.open .accordion-content-wrapper{grid-template-rows:1fr}.accordion-content{overflow:hidden}.accordion-content>*{padding:0 20px 20px}.accordion-content h4{font-size:14px;font-weight:600;color:var(--rift-aqua);margin:16px 0 8px;text-transform:uppercase;letter-spacing:.05em}.accordion-content h4:first-child{margin-top:0}.accordion-content p{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0 0 12px}.accordion-content p:last-child{margin-bottom:0}.accordion-content ul{margin:0 0 12px;padding-left:20px}.accordion-content li{font-size:14px;line-height:1.6;color:var(--text-secondary);margin-bottom:6px}.accordion-content li:last-child{margin-bottom:0}.accordion-content .configurable{font-size:13px;color:var(--text-muted);font-style:italic;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-subtle)}.accordion-content table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}.accordion-content th,.accordion-content td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--border-subtle)}.accordion-content th{color:var(--text-muted);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.accordion-content td{color:var(--text-secondary)}.accordion-content tr:last-child td{border-bottom:none}@media(max-width:600px){.accordion-header{padding:14px 16px}.accordion-icon{width:28px;height:28px;font-size:12px}.accordion-title{font-size:15px}.accordion-content>*{padding:0 16px 16px}}.require-auth-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px;color:var(--text-muted);font-size:16px}.require-auth-loading i{font-size:32px;color:var(--rift-aqua)}.require-auth-prompt{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:24px}.require-auth-card{background:#1a2138f2;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-subtle);border-radius:24px;padding:48px;text-align:center;max-width:400px}.require-auth-card i{font-size:48px;color:var(--rift-aqua);margin-bottom:24px}.require-auth-card.require-auth-denied i{color:#ef4444}.require-auth-card h2{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 12px}.require-auth-card p{font-size:16px;color:var(--text-secondary);margin:0 0 24px}.require-auth-card button{padding:12px 32px;background:var(--rift-aqua);border:none;border-radius:12px;color:var(--bg-base);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.require-auth-card button:hover{background:var(--rift-aqua-glow);transform:translateY(-1px)}.require-auth-role{display:block;font-size:13px;color:var(--text-muted);margin-top:16px}.toast{position:fixed;top:1rem;left:50%;transform:translate(-50%);min-width:300px;max-width:500px;padding:1rem 1.25rem;border-radius:4px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 6px #0000001a;z-index:1001;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(-50%,-100%);opacity:0}to{transform:translate(-50%);opacity:1}}.toast-success{background-color:#efe;border:1px solid #cfc;color:#3c3}.toast-error{background-color:#fee;border:1px solid #fcc;color:#c33}.toast-message{flex:1;font-weight:500}.toast-close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:inherit;padding:0;margin-left:1rem;line-height:1;opacity:.7;transition:opacity .2s}.toast-close-btn:hover{opacity:1}@media(max-width:640px){.toast{left:1rem;right:1rem;transform:translate(0);min-width:auto;max-width:none}@keyframes slideIn{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}}.config-container{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.config-container.config-fullscreen{position:fixed;top:0;left:0;width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}.config-loading,.config-error{display:flex;align-items:center;justify-content:center;height:100vh;text-align:center;padding:3rem}.config-home-button{position:fixed!important;top:1rem;right:2rem;left:auto;z-index:1000;font-size:16px;font-weight:400;padding:0 24px;height:44px;background:#2dd4bf59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#ffffffe6;border:1px solid rgba(45,212,191,.6);border-radius:22px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;width:auto;transition:all .3s ease;box-shadow:0 8px 32px #2dd4bf4d,inset 0 0 20px #2dd4bf66,inset 0 1px #ffffff4d,inset 0 -1px #2dd4bf66;overflow:hidden}.config-home-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.config-home-button:hover{background:#2dd4bf73;border-color:#2dd4bfcc;color:#fff;box-shadow:0 12px 40px #2dd4bf80,inset 0 0 30px #2dd4bf80,inset 0 1px #fff6,inset 0 -1px #2dd4bf80;transform:translateY(-2px)}.config-home-button:hover:before{left:100%}.config-editor-wrapper{position:fixed;top:0;left:0;width:100%;height:100vh;margin:0;padding:0}.config-editor-wrapper .monaco-editor{border:none}.login-form input:focus{outline:none;border-color:var(--rift-aqua)}.config-header{position:fixed;top:1rem;right:2rem;z-index:1000;display:flex;gap:1rem;align-items:center}.config-logout-button{padding:0 24px;height:44px;background:#d32f2f59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#ffffffe6;border:1px solid rgba(211,47,47,.6);border-radius:22px;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;cursor:pointer;font-size:16px;font-weight:400;transition:all .3s ease}.config-logout-button:hover{background:#d32f2f73;border-color:#d32f2fcc;color:#fff;transform:translateY(-2px)}@media(max-width:640px){.config-editor-wrapper .content{padding:16px!important}.admin-login{padding:16px 16px 24px;margin:0;width:100%;box-sizing:border-box}.login-form input,.login-form button{max-width:100%;width:100%}}.user-table-container{background:#1a213899;border:1px solid var(--border-subtle);border-radius:16px;overflow:hidden}.user-table-controls{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-subtle);gap:16px;flex-wrap:wrap}.user-table-filters{display:flex;gap:8px}.filter-button{padding:8px 16px;background:transparent;border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s ease}.filter-button:hover{border-color:var(--rift-aqua);color:var(--text-primary)}.filter-button.active{background:var(--rift-aqua);border-color:var(--rift-aqua);color:var(--bg-base)}.filter-button.filter-pending{border-color:#fbbf2466;color:#fbbf24}.filter-button.filter-pending:hover{border-color:#fbbf24}.filter-button.filter-pending.active{background:#fbbf24;border-color:#fbbf24;color:var(--bg-base)}.user-table-search{display:flex;align-items:center;gap:10px;padding:8px 14px;background:#0003;border:1px solid var(--border-subtle);border-radius:8px;min-width:250px}.user-table-search i{color:var(--text-muted);font-size:14px}.user-table-search input{background:transparent;border:none;outline:none;color:var(--text-primary);font-size:14px;width:100%}.user-table-search input::placeholder{color:var(--text-muted)}.user-table{width:100%;border-collapse:collapse}.user-table th{text-align:left;padding:12px 16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:#00000026;border-bottom:1px solid var(--border-subtle)}.user-table td{padding:14px 16px;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-subtle)}.user-table tbody tr:hover{background:#64ffda08}.user-table tbody tr.inactive-row{opacity:.6}.user-table tbody tr:last-child td{border-bottom:none}.user-cell{min-width:200px}.user-info{display:flex;flex-direction:column;gap:2px}.user-email{font-weight:500}.user-display-name{font-size:12px;color:var(--text-muted)}.date-cell{font-size:13px;color:var(--text-secondary);white-space:nowrap}.role-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.role-admin{background:#ec489926;color:#ec4899}.role-host{background:#64ffda26;color:var(--rift-aqua)}.role-pending{background:#fbbf2426;color:#fbbf24}.role-user{background:#94a3b826;color:#94a3b8}.status-badge{display:inline-block;padding:4px 10px;border-radius:6px;font-size:12px;font-weight:500}.status-active{background:#22c55e26;color:#22c55e}.status-inactive{background:#ef444426;color:#ef4444}.actions-cell{width:120px}.action-buttons{display:flex;gap:8px}.action-btn{width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.action-btn:disabled,.action-btn-text:disabled{opacity:.5;cursor:not-allowed}.action-btn-text{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;white-space:nowrap;transition:all .2s ease}.action-approve{background:#64ffda26;color:var(--rift-aqua)}.action-approve:hover:not(:disabled){background:#64ffda40}.action-revoke{background:#fbbf2426;color:#fbbf24}.action-revoke:hover:not(:disabled){background:#fbbf2440}.action-deactivate{background:#ef444426;color:#ef4444}.action-deactivate:hover:not(:disabled){background:#ef444440}.action-reactivate{background:#22c55e26;color:#22c55e}.action-reactivate:hover:not(:disabled){background:#22c55e40}.action-reset-password{background:#8b5cf626;color:#a78bfa}.action-reset-password:hover:not(:disabled){background:#8b5cf640}.self-indicator,.admin-protected{font-size:12px;color:var(--text-muted);font-style:italic}.user-table-empty{padding:48px 24px;text-align:center;color:var(--text-muted);font-size:15px}.user-table-footer{padding:12px 20px;font-size:13px;color:var(--text-muted);background:#0000001a;border-top:1px solid var(--border-subtle)}@media(max-width:768px){.user-table-controls{flex-direction:column;align-items:stretch}.user-table-filters{flex-wrap:wrap}.user-table-search{min-width:100%}.user-table{display:block;overflow-x:auto}}.admin-login{max-width:400px;margin:0 auto;padding:clamp(24px,4vw,48px);background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:24px;box-shadow:0 0 8px #00050a33;border:none}.admin-login-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;width:100%;padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle)}.admin-login-header-row h2{margin:0!important;padding:0;border:none;color:var(--rift-aqua)}.admin-login-description{margin-bottom:1.5rem;color:var(--text-secondary);font-size:1rem;font-weight:400}.login-form{display:flex;flex-direction:column;gap:1rem;width:100%}.login-form label{font-weight:500;color:var(--text-primary);font-size:14px}.login-form input{width:100%;max-width:300px;padding:.5rem;border:1px solid var(--border-subtle);border-radius:4px;background:var(--bg-surface);color:var(--text-primary);font-size:1rem;box-sizing:border-box}.login-form input:focus{outline:none;border-color:var(--rift-aqua);box-shadow:0 0 0 3px #2dd4bf33}.login-form button{width:100%;max-width:300px;padding:0;height:56px;background:#ff8a1f59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,138,31,.6);border-radius:28px;color:var(--text-primary);font-size:20px;font-weight:400;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px #ff8a1f4d,inset 0 0 20px #ff8a1f66,inset 0 1px #ffffff4d,inset 0 -1px #ff8a1f66;position:relative;overflow:hidden;margin-top:1.5rem}.login-form button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.login-form button:hover:not(:disabled){background:#ff8a1f73;border-color:#ff8a1fcc;box-shadow:0 12px 40px #ff8a1f80,inset 0 0 30px #ff8a1f80,inset 0 1px #fff6,inset 0 -1px #ff8a1f80;transform:translateY(-2px)}.login-form button:hover:not(:disabled):before{left:100%}.login-form button:disabled{opacity:.6;cursor:not-allowed;transform:none}.create-game-link{color:var(--text-secondary);text-decoration:none;font-size:14px;transition:color .2s ease}.create-game-link:hover{color:var(--text-primary)}.admin-dashboard{max-width:1200px;margin:0 auto;width:100%}.admin-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;width:100%;padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle)}.admin-header-row h2{margin:0!important;padding:0;border:none;color:var(--rift-aqua)}.admin-actions{display:flex;gap:1rem;align-items:center}.button-link{color:var(--text-secondary);text-decoration:none;font-size:14px;transition:color .2s ease}.button-link:hover{color:var(--text-primary)}.logout-button,.revoke-button,.delete-game-button{padding:.5rem 1rem;height:auto;background:#ff8a1f59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,138,31,.6);border-radius:28px;color:var(--text-primary);font-size:.9rem;font-weight:400;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px #ff8a1f4d,inset 0 0 20px #ff8a1f66,inset 0 1px #ffffff4d,inset 0 -1px #ff8a1f66;position:relative;overflow:hidden}.logout-button:before,.revoke-button:before,.delete-game-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.logout-button:hover:not(:disabled),.revoke-button:hover:not(:disabled),.delete-game-button:hover:not(:disabled){background:#ff8a1f73;border-color:#ff8a1fcc;box-shadow:0 12px 40px #ff8a1f80,inset 0 0 30px #ff8a1f80,inset 0 1px #fff6,inset 0 -1px #ff8a1f80;transform:translateY(-2px)}.logout-button:hover:not(:disabled):before,.revoke-button:hover:not(:disabled):before,.delete-game-button:hover:not(:disabled):before{left:100%}.logout-button:disabled,.revoke-button:disabled,.delete-game-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.dashboard-section{margin-bottom:2rem;padding:clamp(24px,4vw,48px);background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:24px;box-shadow:0 0 8px #00050a33;border:none}.dashboard-section h2{margin-top:0;margin-bottom:1.5rem;color:var(--rift-aqua)}.create-host-key{display:flex;flex-direction:column;gap:1rem;width:100%}.create-host-key input{width:100%;max-width:300px;padding:.5rem;border:1px solid var(--border-subtle);border-radius:4px;background:var(--bg-surface);color:var(--text-primary);font-size:1rem;box-sizing:border-box}.create-host-key input:focus{outline:none;border-color:var(--rift-aqua);box-shadow:0 0 0 3px #2dd4bf33}.create-host-key input:disabled{background:var(--bg-raised);color:var(--text-muted);cursor:not-allowed;opacity:.5}.create-host-key-button{width:100%;max-width:300px;padding:0 32px;height:56px;background:#ff8a1f59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,138,31,.6);border-radius:28px;color:var(--text-primary);font-size:20px;font-weight:400;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px #ff8a1f4d,inset 0 0 20px #ff8a1f66,inset 0 1px #ffffff4d,inset 0 -1px #ff8a1f66;position:relative;overflow:hidden;margin-top:0}.create-host-key-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.create-host-key-button:hover:not(:disabled){background:#ff8a1f73;border-color:#ff8a1fcc;box-shadow:0 12px 40px #ff8a1f80,inset 0 0 30px #ff8a1f80,inset 0 1px #fff6,inset 0 -1px #ff8a1f80;transform:translateY(-2px)}.create-host-key-button:hover:not(:disabled):before{left:100%}.create-host-key-button:disabled{background:#ff8a1f26;border-color:#ff8a1f4d;color:#ffffff80;cursor:not-allowed;transform:none;box-shadow:0 0 8px #ff8a1f1a}.host-key-card{margin-bottom:1.5rem;padding:clamp(24px,4vw,48px);background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:24px;box-shadow:0 0 8px #00050a33;border:none}.host-key-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.host-key-info{flex:1}.host-key-label{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.5rem}.host-key-label strong{color:var(--text-primary);font-size:1.1rem}.host-key-value{font-family:monospace;font-size:.9rem;color:var(--text-secondary);word-break:break-all}.host-key-meta{font-size:.85rem;color:var(--text-secondary)}.host-key-games{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.host-key-games h3{margin-top:0;margin-bottom:1rem;color:var(--text-primary);font-size:1rem}.empty-games{color:var(--text-secondary);font-style:italic}.games-list{display:flex;flex-direction:column;gap:.75rem}.game-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#ffffff0d;backdrop-filter:blur(10px) saturate(180%);-webkit-backdrop-filter:blur(10px) saturate(180%);border-radius:12px;border:1px solid var(--border-subtle);gap:1rem}.game-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.game-code{font-family:monospace;font-weight:700;color:var(--text-primary);font-size:1rem}.game-details{font-size:.85rem;color:var(--text-secondary)}.dashboard-actions{margin-top:2rem;text-align:center}.refresh-button{padding:.75rem 1.5rem;height:auto;background:var(--rift-aqua);color:var(--bg-base);border:none;border-radius:28px;cursor:pointer;font-size:1rem;font-weight:400;transition:background-color .2s ease}.refresh-button:hover:not(:disabled){background:var(--rift-aqua-glow)}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.error-message{padding:1rem;background:#ff8a1f1a;border:1px solid rgba(255,138,31,.3);border-radius:4px;margin-bottom:1rem;color:var(--rift-orange-glow)}.loading{text-align:center;color:var(--text-secondary);padding:2rem}.empty-state{text-align:center;color:var(--text-secondary);padding:2rem;font-style:italic}@media(max-width:640px){.admin-login~.content{padding:16px!important}.admin-login{padding:16px 16px 24px;margin:0;width:100%;box-sizing:border-box}.login-form input,.login-form button{max-width:100%;width:100%}.admin-dashboard{width:100%}.dashboard-section{padding:16px 16px 24px}.host-key-card{padding:16px}.host-key-header{flex-direction:column;align-items:stretch;gap:1rem}.revoke-button{width:100%}.game-item{flex-direction:column;align-items:stretch}.delete-game-button,.create-host-key{width:100%}.create-host-key input,.create-host-key-button{max-width:100%;width:100%}.admin-header-row{flex-direction:column;align-items:flex-start;gap:1rem}.admin-actions{width:100%;flex-direction:column;align-items:stretch}.logout-button{width:100%}}.player-list{width:100%}.player-list-header{margin-bottom:1rem;font-weight:600;color:var(--text-primary)}.player-list-count{font-size:1rem;color:var(--text-secondary)}.player-list-items{display:flex;gap:.75rem;flex-wrap:wrap;list-style:none;padding:0;margin:0}.player-list-item{display:flex;align-items:center;gap:.75rem;padding:8px;background:#ffffff14;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-subtle);border-radius:28px;transition:all .3s ease;box-shadow:0 2px 8px #00050a1a}.player-list-item:hover{background:#2dd4bf1a;border-color:#2dd4bf4d;box-shadow:0 4px 12px #2dd4bf26,inset 0 0 8px #2dd4bf0d}.player-list-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;flex-shrink:0;box-shadow:0 2px 8px #0003}.player-list-icon i{text-shadow:0 1px 2px rgba(0,0,0,.3)}.player-list-name{font-weight:600;color:var(--text-primary);font-size:.875rem;white-space:nowrap;margin-right:16px}.player-list-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.player-list-empty p{margin:.5rem 0;color:var(--text-secondary)}.player-list-empty-hint{font-size:.875rem;color:var(--text-muted)}@media(max-width:640px){.player-list-item{padding:6px 10px;gap:.5rem}.player-list-icon{width:32px;height:32px;font-size:.875rem}.player-list-name{font-size:.8rem}}.display-lobby-container{min-height:100vh;display:flex;flex-direction:column}.display-lobby-content{flex:1;padding:48px 72px;display:flex;justify-content:center;align-items:center;box-sizing:border-box;min-height:100vh;overflow:hidden}.display-lobby-main-card{width:100%;max-width:800px;background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:24px;border:none;box-shadow:0 0 8px #00050a33;padding:clamp(24px,4vw,48px);display:flex;flex-direction:column;gap:1.5rem;box-sizing:border-box;max-height:calc(100vh - 96px);overflow-y:auto;margin:auto}.display-lobby-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;width:100%;padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle)}.display-lobby-header-row h2{margin:0!important;padding:0;border:none;color:var(--rift-aqua);font-size:1.5rem;font-weight:600}.display-lobby-link{color:var(--text-secondary);text-decoration:none;font-size:14px;transition:color .2s ease}.display-lobby-link:hover{color:var(--text-primary)}.display-lobby-section{display:flex;flex-direction:column;gap:.75rem}.display-lobby-label{font-weight:500;color:var(--text-primary);font-size:14px}.display-lobby-code-container{background:#2dd4bf26;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(45,212,191,.4);border-radius:16px;padding:1.5rem;text-align:center;box-shadow:0 4px 16px #2dd4bf33,inset 0 0 12px #2dd4bf33,inset 0 1px #ffffff1a;margin:.5rem 0}.display-lobby-code{font-size:clamp(2rem,6vw,3.5rem);font-weight:700;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--rift-aqua-glow);letter-spacing:.1em;text-align:center;margin:0;text-shadow:0 0 12px rgba(45,212,191,.5)}.display-lobby-status-text{text-align:center;color:var(--text-secondary);font-size:1rem;margin:0}.display-lobby-url{padding:1rem;background:#ffffff14;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-subtle);border-radius:12px;text-align:center;position:relative;transition:all .3s ease;cursor:pointer}.display-lobby-url:hover{background:#2dd4bf1a;border-color:#2dd4bf66;box-shadow:0 4px 16px #2dd4bf26,inset 0 0 8px #2dd4bf1a}.display-lobby-url-text{font-family:Courier New,monospace;font-size:clamp(.9rem,2vw,1.1rem);color:var(--text-secondary);word-break:break-all;margin:0}.display-lobby-copied{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#2dd4bfe6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--bg-base);padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;pointer-events:none;z-index:10;animation:fadeInOut 2s ease-in-out;box-shadow:0 4px 12px #2dd4bf66}@keyframes fadeInOut{0%,to{opacity:0;transform:translate(-50%,-50%) scale(.9)}10%,90%{opacity:1;transform:translate(-50%,-50%) scale(1)}}.display-lobby-warning{padding:1rem;background:#8b5cf626;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(139,92,246,.3);border-radius:12px;margin-bottom:1rem;box-shadow:0 4px 12px #8b5cf626,inset 0 0 8px #8b5cf61a}.display-lobby-warning p{color:var(--rift-purple-glow);margin:0;font-weight:500;font-size:.9rem}.display-lobby-connection-status{padding:.75rem 1rem;background:#ffffff0d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border-subtle);border-radius:8px;text-align:center}.display-lobby-connection-status p{margin:0;color:var(--text-muted);font-size:.875rem}.display-lobby-error{text-align:center;padding:3rem 1rem;background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:24px;border:1px solid rgba(255,138,31,.3);box-shadow:0 4px 16px #ff8a1f33,inset 0 0 8px #ff8a1f1a}.display-lobby-error h2{color:var(--rift-orange-glow);margin-bottom:1rem;font-size:1.5rem;font-weight:600}.display-lobby-error p{color:var(--text-secondary);margin-bottom:2rem;font-size:1rem}.display-lobby-loading{text-align:center;padding:3rem 1rem}.display-lobby-loading p{color:var(--text-secondary);font-size:1.1rem;margin:.5rem 0}@media(max-width:640px){.display-lobby-content{padding:24px}.display-lobby-main-card{max-width:100%;padding:clamp(24px,4vw,32px)}.display-lobby-header-row{flex-direction:column;align-items:flex-start;gap:1rem}.display-lobby-header-row h2{font-size:1.25rem}.display-lobby-code{font-size:2rem}.display-lobby-code-container{padding:1rem}.display-lobby-url-text{font-size:.9rem}}.leaderboard{width:100%;background-color:#fff;border-bottom:2px solid #e5e7eb;padding:1rem 1.5rem}.leaderboard-header{margin-bottom:1rem}.leaderboard-title{margin:0;font-size:1.25rem;font-weight:600;color:#213547}.leaderboard-players{display:flex;flex-wrap:wrap;gap:1rem;align-items:center}.leaderboard-player{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;transition:all .2s}.leaderboard-player:hover{background-color:#f3f4f6;border-color:#d1d5db}.leaderboard-player-indicator{display:flex;align-items:center;gap:.5rem}.leaderboard-player-color{width:18px;height:18px;border-radius:50%;border:2px solid rgba(0,0,0,.1);flex-shrink:0}.leaderboard-player-icon{font-size:1.1rem;line-height:1;width:20px;text-align:center;flex-shrink:0}.leaderboard-player-info{display:flex;flex-direction:column;gap:.25rem}.leaderboard-player-name{font-weight:500;color:#213547;white-space:nowrap}.leaderboard-player-superpower{font-size:.85rem;color:#6b7280;font-style:italic}.leaderboard-empty{text-align:center;padding:1rem;color:#6b7280}.leaderboard-empty p{margin:0}@media(max-width:640px){.leaderboard{padding:.75rem 1rem}.leaderboard-title{font-size:1.1rem}.leaderboard-players{gap:.75rem}.leaderboard-player{padding:.4rem .75rem;gap:.5rem}.leaderboard-player-color{width:16px;height:16px}.leaderboard-player-icon{font-size:1rem;width:18px}.leaderboard-player-name{font-size:.9rem}}.territory-map-container{width:100%;position:relative;display:flex;flex-direction:column;height:calc(100vh - 80px);max-height:calc(100vh - 80px);overflow:hidden}.territory-map-status-pill{position:absolute;top:1rem;left:50%;transform:translate(-50%);background-color:#fff;color:#213547;padding:8px 16px;border-radius:9999px;font-size:.875rem;font-weight:600;z-index:10;box-shadow:0 0 8px 8px #00050a1a;display:flex;align-items:center;gap:.5rem}.territory-map-status-pill-victory{padding:12px 20px;font-size:1rem}.territory-map-status-pill-victory a{color:#fff;text-decoration:underline;cursor:pointer;font-weight:400}.territory-map-status-pill-victory a:hover{opacity:.8}.territory-map-status-pill-blink{animation:territory-map-status-pill-blink .6s ease-in-out}@keyframes territory-map-status-pill-blink{0%,to{opacity:1;transform:translate(-50%) scale(1)}25%{opacity:.7;transform:translate(-50%) scale(1.05)}50%{opacity:1;transform:translate(-50%) scale(1)}75%{opacity:.8;transform:translate(-50%) scale(1.02)}}.territory-map-background{position:relative;width:100%;height:100%;flex:1;background-image:url(/media/world-map.png);background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center}.territory-map-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,#04050bcc,#12182ab3);pointer-events:none}.territory-map-columns{position:relative;display:flex;gap:12px;z-index:1;margin:0 auto;width:fit-content;align-items:flex-start}.territory-map-column{display:flex;flex-direction:column;gap:12px;flex:0 0 auto;width:min(12.5vw,240px);min-width:180px;max-width:280px}.territory-map-column.odd{margin-top:calc(clamp(120px,min(10vh,160px),200px)/2 + 6px)}.territory-map-column.even{margin-top:0}.territory-map-column-empty{flex:0 0 auto;width:min(12.5vw,240px);min-width:180px;max-width:280px}.territory-map-card{width:min(12.5vw,240px);height:clamp(120px,min(10vh,160px),200px);min-width:180px;max-width:280px;padding:16px;border:none;border-radius:24px;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);transition:all .2s;position:relative;overflow:hidden;box-sizing:border-box;box-shadow:0 0 8px #00050a33;--card-height: clamp(120px, min(10vh, 160px), 200px)}.territory-map-card.available{background-color:#ffffff1a}.territory-map-card-content{height:100%;display:flex;flex-direction:column;justify-content:space-between}.territory-map-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;position:relative}.territory-map-card-name{font-size:1rem;font-weight:600;line-height:1.2;margin:0;color:#fff}.territory-map-card-player{width:24px;height:1.05rem;display:flex;align-items:center;justify-content:center;font-size:.875rem;line-height:1.2;color:#fff;position:absolute;top:0;right:0}.territory-map-card-stats{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.territory-map-card-stat{display:flex;align-items:center;gap:.25rem;font-size:.875rem;color:#fff;font-weight:600}.territory-map-card-stat i{font-size:.75rem;opacity:.8}.territory-map-card-influence-bars{position:absolute;top:16px;right:16px;display:flex;flex-direction:column-reverse;gap:3px;width:24px;align-items:center}.territory-map-card-influence-bar{width:24px;height:6px;background-color:transparent;border:1px solid rgba(255,255,255,.4);border-radius:3px}.territory-map-card-influence-bar.filled-heavy{background-color:#fff;border-color:#fff}.territory-map-card-influence-bar.filled-light{background-color:#fff6;border-color:#fff6}.territory-map-card-bottom-left{position:absolute;bottom:16px;left:16px;display:flex;flex-direction:column;gap:.25rem}.territory-map-card-icon-row{display:flex;gap:.125rem;flex-wrap:wrap}.territory-map-card-icon-row i{font-size:.75rem;color:#fff;width:.75rem;height:.75rem;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.territory-map-card-resource-row{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#fff;font-weight:600}.territory-map-card-resource-row i{font-size:.75rem}.territory-map-card-vp{position:absolute;bottom:16px;right:16px;font-size:1.5rem;font-weight:400;line-height:1;color:#fff;width:24px;text-align:center;display:flex;align-items:flex-end;justify-content:center}.territory-map-card-vp-superpower{font-weight:600}.territory-map-loading{text-align:center;color:#666;padding:2rem}@media(max-width:1200px){.territory-map-card{width:min(13vw,200px);height:min(11vh,140px)}.territory-map-column{width:min(13vw,200px)}}@media(max-width:768px){.territory-map-card{width:min(14vw,180px);height:min(12vh,120px);padding:16px}.territory-map-column{width:min(14vw,180px)}.territory-map-columns{gap:8px;padding:0 2vw}.territory-map-card-name{font-size:.875rem}.territory-map-card-stat{font-size:.75rem}}.breaking-news-backdrop{position:fixed;inset:0 0 100px;width:100%;height:calc(100% - 100px);background:linear-gradient(to bottom,rgb(4,5,11),var(--bg-surface));opacity:.9;backdrop-filter:blur(20px) saturate(20%);-webkit-backdrop-filter:blur(20px) saturate(20%);z-index:999;animation:backdropFadeIn .3s ease-out}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:.7}}.breaking-news-popup{position:fixed;top:calc((100vh - 100px)/2);left:50%;transform:translate(-50%,-50%);background:#fff;border:none;border-radius:24px;min-width:500px;max-width:700px;width:85%;max-height:calc(100vh - 120px);box-shadow:0 0 8px #00050a80;z-index:1000;animation:cardAppear .3s ease-out;overflow:hidden;display:flex;flex-direction:column}@keyframes cardAppear{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.breaking-news-image-section{position:relative;width:100%;height:100%;min-height:300px;overflow:hidden;background:#f3f4f6;border-radius:24px}.breaking-news-image{width:100%;height:100%;object-fit:cover;display:block}.breaking-news-image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#e5e7eb;color:#6b7280}.placeholder-icon{font-size:4rem;margin-bottom:1rem}.placeholder-text{font-size:1.25rem;font-weight:500}.breaking-news-banner{position:absolute;top:32px;left:0;background:#ff4361;color:#fff;padding:.75rem 1.5rem;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;box-shadow:0 2px 8px #0000004d;border-radius:0 8px 8px 0;z-index:10}.breaking-news-text-section{position:absolute;bottom:8px;left:8px;right:8px;height:88px;padding:8px;background:#fff;display:flex;flex-direction:row;gap:0;align-items:center;border-radius:16px}.pnp-news-logo-block{background:#3446b7;width:96px;height:72px;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:8px}.pnp-news-logo-content{color:#fff;font-weight:700;font-size:16px;line-height:16px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center}.pnp-news-text{display:block;text-align:left;line-height:1.2}.pnp-news-text i{font-size:16px;line-height:16px;margin-left:.25em}.breaking-news-content-block{flex:0 1 auto;display:flex;flex-direction:column;background:#fff;padding:0 16px}.breaking-news-headline{font-size:24px;font-weight:600;color:#111827;line-height:24px;margin:0 0 8px}.breaking-news-description{font-size:16px;font-weight:400;color:#374151;line-height:16px;margin:0}@media(max-width:768px){.breaking-news-popup{min-width:90%;max-width:95%}.breaking-news-image-section{min-height:200px;max-height:250px}.breaking-news-headline{font-size:1.5rem}.breaking-news-description{font-size:1rem}.breaking-news-text-section{padding:1rem 1.5rem}}.event-effect-display{background:#000000b3;border:2px solid #4a5568;border-radius:8px;padding:16px;margin:16px 0;color:#e2e8f0;font-size:14px}.event-effect-display h4{margin:0 0 8px;color:#fbbf24;font-size:16px;font-weight:600}.event-effect-display .macro-effects{margin-bottom:16px}.event-effect-display .micro-effects{margin-top:16px}.event-effect-display ul{list-style:none;padding:0;margin:0}.event-effect-display .effect-item{padding:4px 0;color:#cbd5e0}.event-effect-display .effect-item:before{content:"• ";color:#60a5fa;font-weight:700}.display-gameboard-container{max-width:1200px;margin:0 auto;padding:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;min-height:100vh;display:flex;flex-direction:column;background-color:#f9fafb}.display-gameboard-container.full-screen-map{max-width:none;margin:0;width:100vw;height:100vh;overflow:hidden;background:linear-gradient(to bottom,rgb(4,5,11),var(--bg-surface));position:fixed;top:0;left:0}.display-gameboard-container.full-screen-map .display-gameboard-main{padding:0;flex:1;overflow:hidden;position:relative;min-height:0}.display-gameboard-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background-color:#fff;border-bottom:2px solid #e5e7eb}.display-gameboard-header h1{margin:0;color:#213547;font-size:1.75rem}.display-gameboard-room-code{font-family:Courier New,monospace;font-size:1.25rem;font-weight:600;color:#646cff;letter-spacing:.1em}.display-gameboard-main{flex:1;padding:2rem;display:flex;flex-direction:column;gap:2rem}.display-gameboard-section{display:flex;flex-direction:column;gap:.75rem;padding:1.5rem;background-color:#fff;border:1px solid #e5e7eb;border-radius:8px}.display-gameboard-label{font-weight:600;color:#213547;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.display-gameboard-status-badge{display:inline-block;padding:.5rem 1rem;border-radius:6px;font-weight:600;font-size:1rem;width:fit-content}.display-gameboard-status-badge[data-status=setup]{background-color:#fef3c7;color:#92400e;border:1px solid #fbbf24}.display-gameboard-status-badge[data-status=in_progress]{background-color:#d1fae5;color:#065f46;border:1px solid #10b981}.display-gameboard-phase{font-size:1.25rem;font-weight:500;color:#213547}.display-gameboard-current-selector{margin-top:.75rem;padding:.75rem 1rem;background-color:#eff6ff;border:1px solid #3b82f6;border-radius:6px;color:#1e40af;font-size:1rem;font-weight:500}.display-gameboard-territories-count{font-size:1.1rem;color:#6b7280}.display-gameboard-loading,.display-gameboard-error{text-align:center;padding:3rem 1rem}.display-gameboard-loading p{color:#6b7280;font-size:1.1rem;margin:.5rem 0}.display-gameboard-status{color:#9ca3af;font-size:.9rem}.display-gameboard-error h2{color:#ef4444;margin-bottom:1rem}.display-gameboard-error p{color:#6b7280;margin-bottom:2rem}.display-gameboard-content{flex:1;display:flex;flex-direction:column;justify-content:center}@media(max-width:640px){.display-gameboard-container{padding:0}.display-gameboard-header{flex-direction:column;align-items:flex-start;gap:1rem;padding:1rem}.display-gameboard-header h1{font-size:1.5rem}.display-gameboard-room-code{font-size:1rem}.display-gameboard-main{padding:1rem;gap:1.5rem}.display-gameboard-section{padding:1rem}}.display-gameboard-bottom-bar{position:fixed;bottom:0;left:0;right:0;width:100vw;background-color:#fff;padding:1.5rem 2rem;z-index:100;box-shadow:0 -2px 8px #00000026;min-height:80px}.display-gameboard-bottom-bar-content{display:flex;justify-content:space-between;align-items:center;gap:2rem;max-width:100%;margin:0;width:100%}.display-gameboard-title-lockup{flex-shrink:0}.display-gameboard-title-text{padding:8px 0;font-size:16px;font-weight:800;display:inline-block;color:#00050a;line-height:1.2}.display-gameboard-turn-order{flex:1}.display-gameboard-bottom-bar-title{color:#213547;font-size:.875rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem}.display-gameboard-players-list{display:flex;gap:.75rem;flex-wrap:wrap}.display-gameboard-player-indicator{display:flex;align-items:center;gap:.75rem;padding:8px;background-color:#f9fafb;transition:all .2s;box-shadow:0 0 8px #00050a1a;border-radius:28px}.display-gameboard-player-indicator.current-turn{box-shadow:0 0 8px #00050a1a}.display-gameboard-player-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;flex-shrink:0}.display-gameboard-player-name{color:#213547;font-size:.875rem;font-weight:600}.display-gameboard-player-indicator.current-turn .display-gameboard-player-name{color:#fff}.display-gameboard-player-vp{color:#6b7280;font-size:.875rem;font-weight:600;background-color:#ffffff80;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.display-gameboard-player-indicator.current-turn .display-gameboard-player-vp{color:#213547;background-color:#ffffffe6}.display-gameboard-trade-offers{min-width:200px}.display-gameboard-offer-box{display:flex;align-items:center;gap:8px;padding:.5rem 1rem;background-color:#00050ab3;border-radius:8px;color:#fff;box-shadow:0 0 8px #00050a1a;height:56px;box-sizing:border-box}.display-gameboard-offer-box i{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;font-size:16px}.display-gameboard-offer-arrow{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}.display-gameboard-offer-quantity{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;flex-shrink:0}.display-gameboard-offer-ratio{width:36px;height:24px;display:flex;align-items:center;font-size:16px;font-weight:400;flex-shrink:0}.display-gameboard-offer-ratio.ratio-left{justify-content:flex-start}.display-gameboard-offer-ratio.ratio-right{justify-content:flex-end}.display-gameboard-offer-item i{font-size:.75rem;opacity:.8}@media(max-width:768px){.display-gameboard-bottom-bar-content{flex-direction:column;gap:1rem}.display-gameboard-players-list{flex-direction:column;gap:.5rem}.display-gameboard-trade-offers{width:100%}}.display-gameboard-container.side-by-side-layout{display:flex;flex-direction:row;max-width:none;margin:0;width:100vw;height:100vh;overflow:hidden;background:linear-gradient(to bottom,rgb(4,5,11),var(--bg-surface));position:fixed;top:0;left:0}.display-gameboard-container.side-by-side-layout .display-gameboard-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;min-width:0;padding:0;min-height:0}.display-gameboard-container.side-by-side-layout .display-gameboard-bottom-bar{position:fixed;bottom:0;left:0;right:400px;width:auto}.display-gameboard-container.side-by-side-layout.drawer-collapsed .display-gameboard-bottom-bar{right:0}.display-gameboard-container.side-by-side-child{max-width:none;margin:0;flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;background:transparent}.display-gameboard-container.side-by-side-child .display-gameboard-main{padding:0;flex:1;overflow:hidden;position:relative;min-height:0}.controller-drawer{position:fixed;bottom:20px;right:20px;z-index:1000;background:var(--bg-primary, #1a1a1a);border-radius:12px;box-shadow:0 8px 32px #0000004d;overflow:hidden;transition:width .3s cubic-bezier(.4,0,.2,1),height .3s cubic-bezier(.4,0,.2,1),opacity .2s cubic-bezier(.4,0,.2,1),box-shadow .3s cubic-bezier(.4,0,.2,1)}.controller-drawer.collapsed{display:none}.controller-drawer.expanded{width:400px;height:calc(100vh - 40px);box-shadow:0 12px 48px #00000080}.controller-drawer-toggle-bar{display:flex;align-items:center;justify-content:space-between;height:60px;background:var(--bg-secondary, #2a2a2a);border-bottom:1px solid #333}.controller-drawer-toggle{height:100%;background:none;border:none;color:var(--text-primary, #e0e0e0);font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;padding:0 20px;position:relative;transition:background .2s ease}.controller-drawer-toggle:hover{background:var(--bg-tertiary, #333)}.controller-drawer-toggle i{font-size:.875rem}.controller-drawer-exit{height:100%;background:none;border:none;color:var(--text-secondary, #999);font-size:.875rem;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;padding:0 20px;transition:background .2s ease,color .2s ease}.controller-drawer-exit:hover{background:var(--bg-tertiary, #333);color:var(--text-primary, #e0e0e0)}.controller-drawer-exit i{font-size:1rem}.controller-drawer-notification-badge{position:absolute;top:12px;right:12px;width:12px;height:12px;background:#ef4444;border-radius:50%;animation:pulse-notification 2s ease-in-out infinite}@keyframes pulse-notification{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.controller-drawer-content{height:calc(100% - 60px);overflow-y:auto;overflow-x:hidden;padding:0;opacity:1;transition:opacity .2s cubic-bezier(.4,0,.2,1)}.controller-drawer.expanded>.controller-drawer-content:only-child{height:100%}.controller-drawer-content::-webkit-scrollbar{width:8px}.controller-drawer-content::-webkit-scrollbar-track{background:var(--bg-primary, #1a1a1a)}.controller-drawer-content::-webkit-scrollbar-thumb{background:var(--bg-tertiary, #444);border-radius:4px}.controller-drawer-content::-webkit-scrollbar-thumb:hover{background:var(--bg-quaternary, #555)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.controller-drawer.side-by-side{position:static;bottom:auto;right:auto;border-radius:0;height:100vh;width:400px;flex-shrink:0;box-shadow:-4px 0 12px #0000004d;margin:0}.controller-drawer.side-by-side.collapsed{display:none}.controller-drawer.side-by-side .controller-drawer-content{height:calc(100% - 60px)}.play-wrapper{background:linear-gradient(#0b0f1acc,#0b0f1acc),url(/media/world.jpg);background-size:cover;background-position:center bottom}.play-header{padding:16px 24px;display:flex;justify-content:flex-start}.play-logo-link{text-decoration:none;color:inherit}.play-logo{padding:8px;font-size:16px;font-weight:800;line-height:16px;border:2px solid white;display:inline-block;box-shadow:0 0 12px #fff3;box-sizing:content-box;text-align:left;color:var(--text-primary)}.play-content{min-height:calc(100vh - 72px);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0 clamp(24px,4vw,48px) clamp(24px,4vw,48px);box-sizing:border-box}.play-content-centered{max-width:500px;margin:0 auto;width:100%}.play-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1100px;width:100%}.play-cards-grid-single{grid-template-columns:1fr;max-width:400px;margin:0 auto}.play-card{background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:24px;padding:clamp(24px,3vw,32px);display:flex;flex-direction:column;box-shadow:0 0 8px #00050a33;min-height:400px}.play-card-icon{font-size:24px;width:56px;height:56px;background:#2dd4bf40;border:1px solid rgba(45,212,191,.4);border-radius:16px;display:flex;justify-content:center;align-items:center;color:var(--rift-aqua-glow);margin-bottom:20px;align-self:center}.play-card-title{font-size:20px;font-weight:600;color:var(--text-primary);text-align:center;margin:0 0 8px}.play-card-description{font-size:14px;color:var(--text-secondary);text-align:center;margin:0 0 24px;line-height:1.5;min-height:42px}.play-card-content{flex:1;display:flex;flex-direction:column;gap:.75rem}.play-card-input{padding:.75rem 1rem;font-size:1rem;border:1px solid var(--border-subtle);border-radius:8px;background-color:var(--bg-surface);color:var(--text-primary);width:100%;box-sizing:border-box;font-family:inherit;transition:all .2s}.play-card-input:focus{outline:none;border-color:var(--rift-aqua);box-shadow:0 0 0 3px #2dd4bf33}.play-card-input:disabled{background-color:var(--bg-raised);color:var(--text-muted);cursor:not-allowed;opacity:.5}.play-card-input::placeholder{color:var(--text-muted)}.play-card-select{padding:.75rem 2.5rem .75rem 1rem;font-size:1rem;border:1px solid var(--border-subtle);border-radius:8px;background-color:var(--bg-surface);color:var(--text-primary);width:100%;box-sizing:border-box;font-family:inherit;transition:all .2s;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23888' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer}.play-card-select:focus{outline:none;border-color:var(--rift-aqua);box-shadow:0 0 0 3px #2dd4bf33}.play-card-select:disabled{background-color:var(--bg-raised);color:var(--text-muted);cursor:not-allowed;opacity:.5}.play-card-button{padding:0 24px;height:48px;font-size:16px;font-weight:400;border:none;border-radius:24px;cursor:pointer;background:#ff8a1f59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#ffffffe6;border:1px solid rgba(255,138,31,.6);transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 8px 32px #ff8a1f4d,inset 0 0 20px #ff8a1f66,inset 0 1px #ffffff4d,inset 0 -1px #ff8a1f66;position:relative;overflow:hidden;box-sizing:border-box;width:100%;margin-top:auto}.play-card-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.play-card-button:hover:not(:disabled){background:#ff8a1f73;border-color:#ff8a1fcc;color:#fff;box-shadow:0 12px 40px #ff8a1f80,inset 0 0 30px #ff8a1f80,inset 0 1px #fff6,inset 0 -1px #ff8a1f80;transform:translateY(-2px)}.play-card-button:hover:not(:disabled):before{left:100%}.play-card-button:disabled{background:#ff8a1f26;border-color:#ff8a1f4d;color:#ffffff80;cursor:not-allowed;transform:none;box-shadow:0 0 8px #ff8a1f1a}.play-card-button.disabled-appearance{background:#ff8a1f26;border-color:#ff8a1f4d;color:#fff9;box-shadow:0 0 8px #ff8a1f1a}.play-card-button.disabled-appearance.clickable{cursor:pointer}.play-card-button.disabled-appearance.clickable:hover{background:#ff8a1f40;border-color:#ff8a1f80;color:#fffc}.play-card-link{font-size:.875rem;color:var(--text-secondary);text-decoration:underline;cursor:pointer;background:none;border:none;padding:0;text-align:left;transition:color .2s}.play-card-link:hover{color:var(--text-primary)}.play-card-link-centered{text-align:center;width:100%;margin-bottom:16px}.play-card-status{text-align:center;color:var(--text-secondary);font-size:.875rem;margin:0}.play-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:play-spin .8s linear infinite}@keyframes play-spin{to{transform:rotate(360deg)}}.play-customization-section{display:flex;flex-direction:column;gap:.75rem;background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);padding:clamp(24px,4vw,48px);border-radius:24px;border:none;box-shadow:0 0 8px #00050a33}.play-form-group{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.play-form-group:last-child{margin-bottom:0}.play-label{font-weight:600;color:var(--text-primary);font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.play-input{padding:1rem;font-size:1.1rem;border:1px solid var(--border-subtle);border-radius:8px;transition:all .2s;font-family:inherit;background-color:var(--bg-surface);color:var(--text-primary);width:100%;box-sizing:border-box}.play-input:focus{outline:none;border-color:var(--rift-aqua);box-shadow:0 0 0 3px #2dd4bf33}.play-input:disabled{background-color:var(--bg-raised);color:var(--text-muted);cursor:not-allowed;opacity:.5}.play-button{padding:0 32px;height:56px;font-size:20px;font-weight:400;border:none;border-radius:28px;cursor:pointer;background:#ff8a1f59;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#ffffffe6;border:1px solid rgba(255,138,31,.6);transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 8px 32px #ff8a1f4d,inset 0 0 20px #ff8a1f66,inset 0 1px #ffffff4d,inset 0 -1px #ff8a1f66;position:relative;overflow:hidden;box-sizing:border-box;width:100%}.play-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.play-button:hover:not(:disabled){background:#ff8a1f73;border-color:#ff8a1fcc;color:#fff;box-shadow:0 12px 40px #ff8a1f80,inset 0 0 30px #ff8a1f80,inset 0 1px #fff6,inset 0 -1px #ff8a1f80;transform:translateY(-2px)}.play-button:hover:not(:disabled):before{left:100%}.play-button:disabled{background:#ff8a1f26;border-color:#ff8a1f4d;color:#ffffff80;cursor:not-allowed;transform:none;box-shadow:0 0 8px #ff8a1f1a}.play-button-start{margin-bottom:1.5rem}.play-hint{text-align:center;color:var(--text-secondary);font-size:.875rem;margin:0}.play-color-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-top:.5rem}.play-color-swatch{aspect-ratio:1;border:3px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;position:relative;display:flex;align-items:center;justify-content:center;min-height:60px}.play-color-swatch:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 8px #0003}.play-color-swatch.selected{border-color:#213547;box-shadow:0 0 0 3px #21354733}.play-color-swatch.taken{opacity:.5;cursor:not-allowed;position:relative}.play-color-swatch.taken:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(0,0,0,.3) 10px,rgba(0,0,0,.3) 20px);border-radius:8px}.play-checkmark{color:#fff;font-size:1.5rem;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.5);z-index:1}.play-taken-overlay{position:absolute;color:#ef4444;font-size:1.5rem;font-weight:700;text-shadow:0 1px 2px rgba(255,255,255,.8);z-index:2}.play-icon-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-top:.5rem}.play-icon-button{aspect-ratio:1;border:1px solid var(--border-subtle);border-radius:8px;background:#ffffff0d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);cursor:pointer;transition:all .2s;position:relative;display:flex;align-items:center;justify-content:center;min-height:60px;font-size:1.5rem;color:var(--text-primary)}.play-icon-button:hover:not(:disabled){border-color:var(--rift-aqua);background:#2dd4bf1a;transform:scale(1.05)}.play-icon-button.selected{border-color:var(--rift-aqua);background:#2dd4bf33;box-shadow:0 0 0 3px #2dd4bf4d}.play-icon-button:disabled{opacity:.6;cursor:not-allowed}.play-icon-checkmark{position:absolute;top:4px;right:4px;background-color:var(--rift-aqua);color:var(--bg-base);border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}@media(max-width:900px){.play-cards-grid{grid-template-columns:1fr;max-width:400px}.play-card{min-height:auto}}@media(max-width:640px){.play-header{padding:1rem 16px}.play-content{padding:16px}.play-card,.play-customization-section{padding:20px}.play-color-grid,.play-icon-grid{grid-template-columns:repeat(4,1fr);gap:.5rem}.play-color-swatch,.play-icon-button{min-height:50px}.play-footer{flex-direction:column;gap:1rem;text-align:center;padding:24px 16px}}.controller-drawer .play-customization-section{border-radius:0}.territory-deployment-card{width:100%;max-width:400px;height:clamp(120px,min(10vh,160px),200px);min-width:240px;min-height:140px;padding:16px;border:none;border-radius:24px;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);transition:all .2s ease;position:relative;overflow:hidden;box-sizing:border-box;box-shadow:0 0 8px #00050a33;cursor:pointer}.territory-deployment-card:hover:not(.territory-deployment-card-disabled):not(.territory-deployment-card-deploying){opacity:.85}.territory-deployment-card:active:not(.territory-deployment-card-disabled):not(.territory-deployment-card-deploying){transform:scale(.98)}.territory-deployment-card-deploying{animation:territory-deployment-click .4s ease;pointer-events:none}@keyframes territory-deployment-click{0%{transform:scale(1)}25%{transform:scale(.95);background-color:#ff8a1f66}50%{transform:scale(1.03);background-color:#ff8a1f80}to{transform:scale(1)}}.territory-deployment-card-disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.territory-deployment-card-content{height:100%;display:flex;flex-direction:column;justify-content:space-between}.territory-deployment-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;position:relative}.territory-deployment-card-name{font-size:1rem;font-weight:600;line-height:1.2;margin:0;color:#fff;max-width:calc(100% - 32px)}.territory-deployment-card-player{width:24px;height:1.05rem;display:flex;align-items:center;justify-content:center;font-size:.875rem;line-height:1.2;color:#fff;position:absolute;top:0;right:0}.territory-deployment-card-influence-bars{position:absolute;top:16px;right:16px;display:flex;flex-direction:column-reverse;gap:3px;width:24px;align-items:center}.territory-deployment-card-influence-bar{width:24px;height:6px;background-color:transparent;border:1px solid rgba(255,255,255,.4);border-radius:3px}.territory-deployment-card-influence-bar.filled-heavy{background-color:#fff;border-color:#fff}.territory-deployment-card-influence-bar.filled-light{background-color:#fff6;border-color:#fff6}.territory-deployment-card-bottom-left{position:absolute;bottom:16px;left:16px;display:flex;flex-direction:column;gap:.25rem}.territory-deployment-card-icon-row{display:flex;gap:.125rem;flex-wrap:wrap}.territory-deployment-card-icon-row i{font-size:.75rem;color:#fff;width:.75rem;height:.75rem;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.territory-deployment-card-vp{position:absolute;bottom:16px;right:16px;font-size:1.5rem;font-weight:400;line-height:1;color:#fff;width:24px;text-align:center;display:flex;align-items:flex-end;justify-content:center}.territory-deployment-card-spinner-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:24px;z-index:20}.territory-deployment-card-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#ff8a1fcc;border-radius:50%;animation:territory-deployment-spinner .6s linear infinite}@keyframes territory-deployment-spinner{to{transform:rotate(360deg)}}@media(max-width:768px){.territory-deployment-card{width:100%;max-width:100%;min-height:140px}.territory-deployment-card-preview{font-size:.85rem;padding:10px 14px}.territory-deployment-card-name{font-size:1.1rem}}@media(max-width:1200px)and (min-width:769px){.territory-deployment-card{max-width:350px}}.territory-deployment-container{display:flex;flex-direction:column;width:100%;align-items:stretch;container-type:inline-size}.territory-deployment-message{background:#ff8a1f33;border:1px solid rgba(255,138,31,.4);border-radius:12px;padding:12px 16px;margin-bottom:1rem;text-align:center;color:#fff;font-size:.9rem;font-weight:500}.territory-deployment-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;padding:0 1rem}@container (max-width: 550px){.territory-deployment-cards{padding:0 .25rem}}@media(max-width:550px){.territory-deployment-cards{padding:0 .25rem}}.player-controller-container{min-height:100vh;background:linear-gradient(to bottom,rgb(4,5,11),var(--bg-surface));color:var(--text-primary);padding:0;position:relative}.player-controller-top-bar{display:flex;align-items:center;justify-content:space-between;width:100%;height:64px;padding:0 2rem;background-color:var(--bg-raised);color:var(--text-primary);box-shadow:0 2px 8px #0000004d;position:sticky;top:0;z-index:100;border-bottom:3px solid var(--border-subtle)}.player-controller-top-bar-icon{width:40px;height:40px;border-radius:50%;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0;border:1px solid rgba(255,255,255,.2)}.player-controller-top-bar-name{flex:1;text-align:center;font-size:1.5rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-primary)}.player-controller-top-bar-vp{background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:.375rem 1.25rem;font-size:1.5rem;font-weight:700;color:var(--text-primary);min-width:50px;text-align:center;flex-shrink:0;box-shadow:0 0 8px #0003}.player-controller-summary-bar{background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-subtle);padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-around;gap:1rem;flex-wrap:wrap;position:sticky;top:64px;z-index:99;box-shadow:0 2px 4px #0003}.player-controller-summary-item{display:flex;align-items:center;gap:.375rem}.player-controller-summary-item i{font-size:1rem;color:var(--text-primary)}.player-controller-summary-item span{font-weight:600;font-size:.875rem;color:var(--text-primary)}.player-controller-content{max-width:800px;margin:0 auto;padding:2rem}.player-controller-main{display:flex;flex-direction:column;gap:1.5rem;padding:16px}.player-controller-section{background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:24px;border:none;padding:24px;box-shadow:0 0 8px #00050a33}.player-controller-label{color:var(--text-primary);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.player-controller-phase{font-size:1.25rem;font-weight:500;color:var(--text-primary);margin-bottom:.5rem}.player-controller-phase-hint{color:var(--text-secondary);font-size:.875rem;margin:0}.player-controller-players-count,.player-controller-territories-count{font-size:1.25rem;font-weight:500;color:var(--text-primary)}.player-status-badge{display:inline-block;padding:.5rem 1rem;border-radius:6px;font-weight:600;font-size:1rem}.player-status-setup{background:#8b5cf633;color:var(--rift-purple-glow);border:1px solid var(--rift-purple);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.player-status-in-progress{background:#2dd4bf33;color:var(--rift-aqua-glow);border:1px solid var(--rift-aqua);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.player-controller-loading,.player-controller-error{text-align:center;padding:3rem;background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:24px;border:none;box-shadow:0 0 8px #00050a33}.player-controller-error h2{color:var(--rift-orange);margin-bottom:1rem}.player-controller-connection-status{margin-top:2rem;padding:1rem;background:#ff8a1f33;border:1px solid var(--rift-orange);border-radius:8px;text-align:center;color:var(--rift-orange-glow);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.player-controller-turn-indicator{margin-bottom:1.5rem;padding:1rem;background:#2dd4bf26;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(45,212,191,.4);border-radius:12px;text-align:center;box-shadow:0 0 8px #2dd4bf33}.player-controller-your-turn{color:#fff;font-size:1.1rem;font-weight:400;margin:0}.player-controller-waiting{color:var(--text-secondary);font-size:1rem;margin:0}.player-controller-superpower-selection{margin-top:1rem}.player-controller-superpowers{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1rem}.player-controller-superpower-card{background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-subtle);border-radius:12px;padding:1.5rem;box-shadow:0 0 8px #00050a33}.player-controller-superpower-card.taken{opacity:.5;border-color:var(--border-subtle);background:#ffffff0d}.player-controller-superpower-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.player-controller-superpower-header h3{color:var(--text-primary);font-size:1.25rem;margin:0;font-weight:600}.player-controller-superpower-taken{color:var(--rift-orange);font-size:.875rem}.player-controller-superpower-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.player-controller-superpower-stat{display:flex;justify-content:space-between;padding:.5rem;background:#ffffff0d;border-radius:6px}.player-controller-superpower-stat .stat-label{color:var(--text-secondary);font-size:.875rem}.player-controller-superpower-stat .stat-value{color:var(--text-primary);font-weight:600;font-size:.875rem}.player-controller-territory-selection{margin-top:1rem}.player-controller-territories{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1rem}.player-controller-territory-card{background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid var(--border-subtle);border-radius:12px;padding:1.5rem;box-shadow:0 0 8px #00050a33}.player-controller-territory-card.taken{opacity:.5;border-color:var(--border-subtle);background:#ffffff0d}.player-controller-territory-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.player-controller-territory-header h3{color:var(--text-primary);font-size:1.25rem;margin:0;font-weight:600}.player-controller-territory-taken{color:var(--rift-orange);font-size:.875rem}.player-controller-territory-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.player-controller-territory-stat{display:flex;justify-content:space-between;padding:.5rem;background:#ffffff0d;border-radius:6px}.player-controller-territory-stat .stat-label{color:var(--text-secondary);font-size:.875rem}.player-controller-territory-stat .stat-value{color:var(--text-primary);font-weight:600;font-size:.875rem}.player-controller-select-button{width:100%;padding:0 32px;height:56px;font-size:20px;font-weight:400;background:#ff8a1f59!important;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#ffffffe6;border:1px solid rgba(255,138,31,.6)!important;border-radius:28px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #ff8a1f4d,inset 0 0 20px #ff8a1f66,inset 0 1px #ffffff4d,inset 0 -1px #ff8a1f66;position:relative;overflow:hidden;margin-top:1rem}.player-controller-select-button-superpower{width:100%;padding:.75rem 1.5rem;height:auto;font-size:1rem;font-weight:400;background-color:var(--rift-aqua);color:#fff;border:none;border-radius:24px;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center}.player-controller-select-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.player-controller-select-button:hover:not(:disabled){background:#ff8a1f73;border-color:#ff8a1fcc;color:#fff;box-shadow:0 12px 40px #ff8a1f80,inset 0 0 30px #ff8a1f80,inset 0 1px #fff6,inset 0 -1px #ff8a1f80;transform:translateY(-2px)}.player-controller-select-button-superpower:hover:not(:disabled){background-color:var(--rift-aqua-glow);cursor:pointer}.player-controller-select-button:hover:not(:disabled):before{left:100%}.player-controller-select-button:active:not(:disabled){transform:translateY(0)}.player-controller-select-button:disabled{background:#ff8a1f26;border-color:#ff8a1f4d;color:#ffffff80;cursor:not-allowed;opacity:.6;transform:none;box-shadow:0 0 8px #ff8a1f1a}.player-controller-select-button-superpower:disabled{opacity:.5;cursor:not-allowed}.player-controller-button-secondary{padding:.75rem 1.5rem;background-color:var(--rift-aqua);color:var(--bg-base);border:none;border-radius:24px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s ease}.player-controller-button-secondary:hover:not(:disabled){background-color:var(--rift-aqua-glow);cursor:pointer}.player-controller-button-secondary:disabled{opacity:.5;cursor:not-allowed}.player-controller-input,.player-controller-select{width:100%;padding:.5rem;border:1px solid var(--border-subtle);border-radius:4px;font-size:1rem;background-color:var(--bg-surface);color:var(--text-primary);font-family:inherit;box-sizing:border-box}.player-controller-input:focus,.player-controller-select:focus{outline:none;border-color:var(--rift-aqua);box-shadow:0 0 0 3px #2dd4bf33}.player-controller-input:disabled,.player-controller-select:disabled{background-color:var(--bg-raised);color:var(--text-muted);cursor:not-allowed;opacity:.5}.player-controller-victory-screen{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;pointer-events:auto}.player-controller-victory-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px}.player-controller-victory-icon{height:120px;display:flex;align-items:center;justify-content:center;color:#fff}.player-controller-victory-icon i{font-size:120px;line-height:1}.player-controller-victory-text{font-size:48px;font-weight:700;color:#fff;text-transform:uppercase;text-align:center;line-height:1.2}.player-controller-victory-play-again{position:absolute;top:32px;right:32px;font-size:16px;color:#fff;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:8px;cursor:pointer;padding:.5rem 1rem;text-decoration:none;font-family:inherit;display:flex;align-items:center;gap:.5rem;transition:all .2s ease}.player-controller-victory-play-again:hover{background:#fff3;border-color:#ffffff80}.player-controller-victory-play-again:active{opacity:.8}.player-controller-dialog-overlay{position:fixed;inset:0;background-color:#000000e6;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.player-controller-dialog{background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);padding:24px;border-radius:24px;border:1px solid var(--border-subtle);max-width:400px;width:90%;box-shadow:0 0 8px #00050a33}.player-controller-dialog h3{margin-top:0;margin-bottom:16px;color:var(--text-primary)}.player-controller-dialog p{margin-bottom:20px;color:var(--text-secondary)}.player-controller-dialog-actions{display:flex;gap:10px;justify-content:flex-end}.player-controller-dialog-button{padding:8px 16px;border:1px solid var(--border-subtle);border-radius:8px;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-family:inherit;font-size:1rem}.player-controller-dialog-button:hover:not(:disabled){background:#ffffff26;border-color:var(--rift-aqua)}.player-controller-dialog-button:disabled{opacity:.5;cursor:not-allowed}.player-controller-dialog-button-primary{background:#ff8a1f59;border-color:#ff8a1f99;color:#fff}.player-controller-dialog-button-primary:hover:not(:disabled){background:#ff8a1f73;border-color:#ff8a1fcc}.player-controller-dialog-button-danger{background:#ff8a1f59;border-color:#ff8a1f99;color:#fff}.player-controller-dialog-button-danger:hover:not(:disabled){background:#ff8a1f73;border-color:#ff8a1fcc}.player-controller-form-container{padding:0;background:none;backdrop-filter:none;-webkit-backdrop-filter:none;border-radius:0;border:none}.player-controller-trade-card{margin-bottom:1rem;padding:1rem;background:#ffffff1a;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:12px;border:1px solid var(--border-subtle);display:flex;align-items:center;gap:1rem;flex-wrap:wrap;box-shadow:0 0 8px #00050a33}.player-controller-trade-icon{font-size:1.5rem;color:var(--text-secondary)}.player-controller-trade-controls{display:flex;align-items:center;gap:.75rem;margin-left:auto}.player-controller-trade-ratio{font-size:.95rem;font-weight:600;color:var(--text-primary);white-space:nowrap;text-align:center}.player-controller-trade-button{width:32px;height:32px;border-radius:50%;border:1px solid var(--border-subtle);background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;transition:all .2s}.player-controller-trade-button:hover:not(:disabled){background:#ffffff26;border-color:var(--rift-aqua)}.player-controller-trade-button:disabled{opacity:.5;cursor:not-allowed;background:#ffffff0d}.player-controller-form-group{margin-bottom:1rem}.player-controller-form-label{display:block;margin-bottom:.25rem;font-size:.875rem;color:var(--text-primary);font-weight:500}.player-controller-form-hint{font-size:.85rem;color:var(--text-secondary);margin-bottom:1.5rem;padding:.5rem;background:#ffffff0d;border-radius:4px;border:1px solid var(--border-subtle)}.player-controller-territory-limit-indicator{font-size:.875rem;font-weight:500;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;text-align:center;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);transition:all .3s ease}.player-controller-territory-limit-available{color:var(--rift-aqua);background:#2dd4bf1a;border:1px solid rgba(45,212,191,.3);box-shadow:0 2px 8px #2dd4bf26,inset 0 0 8px #2dd4bf33}.player-controller-territory-limit-maxed{color:var(--rift-orange);background:#ff8a1f26;border:1px solid rgba(255,138,31,.4);box-shadow:0 2px 8px #ff8a1f33,inset 0 0 8px #ff8a1f40}.player-controller-toggle{display:flex;align-items:center;cursor:pointer;position:relative;width:50px;height:28px}.player-controller-toggle input{opacity:0;width:0;height:0}.player-controller-toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--border-subtle);border-radius:28px;transition:background-color .2s}.player-controller-toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:transform .2s}.player-controller-toggle input:checked+.player-controller-toggle-slider{background-color:var(--rift-aqua)}.player-controller-toggle input:checked+.player-controller-toggle-slider:before{transform:translate(22px)}.player-controller-link-button{marginTop:"0.5rem";padding:"0.5rem";background:"none";border:"none";color:"var(--text-secondary)";text-decoration:"underline";cursor:"pointer";font-size:"0.85rem";width:"100%";text-align:"center"}.player-controller-alert{padding:1rem;border-radius:12px;margin-bottom:16px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.player-controller-alert-warning{background:#8b5cf633;border:1px solid var(--rift-purple);color:var(--rift-purple-glow)}.player-controller-alert-error{background:#ff8a1f33;border:1px solid var(--rift-orange);color:var(--rift-orange-glow)}.player-controller-alert p{margin:0;font-weight:500}.player-controller-alert p:first-child{margin-bottom:4px}.player-controller-alert p:not(:first-child){font-size:.875rem;opacity:.9}
