*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #131313;--surface: #1c1b1b;--surface2: #201f1f;--surface3: #2a2a2a;--surface4: #353534;--border: #5a403c;--border-sub: #2a2a2a;--border-subtle: #333333;--accent: #8b0000;--accent2: #ffb4a8;--accent-dark: #4a0000;--accent-glow: rgba(139,0,0,.45);--role-mafia: #ff907f;--role-detective: #93c5fd;--role-doctor: #86efac;--role-villager: #c8c6c5;--text: #e5e2e1;--muted: #c8c6c5;--muted2: #aa8984;--night-color: #ffb4a8;--day-color: #eab308;--radius: 0px;--shadow: 10px 10px 40px rgba(0,0,0,.8)}html,body,#root{height:100%;font-family:Inter,sans-serif;color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden}body{background:radial-gradient(ellipse 120% 80% at 50% 0%,#0e0e0ebd,#0e0e0eed 55%,#0c0c0c),url(/img/landing.jpg) center top / cover no-repeat,#0c0c0c;background-attachment:scroll}h1,h2,h3,h4,.noir-headline{font-family:Playfair Display,serif}.icon{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:1.25rem;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;direction:ltr;-webkit-font-smoothing:antialiased;font-variation-settings:"FILL" 0,"wght" 300,"GRAD" 0,"opsz" 24;vertical-align:middle}.icon-filled{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24}input,select,textarea{font-family:Inter,sans-serif;background:linear-gradient(180deg,#00000052,#0000001f);border:1px solid #3a2e2c;color:var(--text);border-radius:0;padding:13px 14px;font-size:1rem;outline:none;width:100%;box-shadow:inset 0 2px 6px #00000073,inset 0 1px #ffffff05;transition:border-color .2s ease,box-shadow .2s ease}input:focus,select:focus,textarea:focus{border-color:var(--accent2);box-shadow:inset 0 2px 6px #00000073,0 0 0 3px #ffb4a821,0 0 18px #ffb4a81a}input::placeholder{color:var(--muted2)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:11px 14px}button{cursor:pointer;font-family:Inter,sans-serif;border:none;outline:none;border-radius:0;transition:all .2s ease;letter-spacing:.06em}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:15px 30px;font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;border-radius:0;font-family:Inter,sans-serif;cursor:pointer;overflow:hidden;border:1px solid transparent;-webkit-tap-highlight-color:transparent;transition:transform .14s cubic-bezier(.2,.7,.3,1),box-shadow .25s ease,border-color .2s ease,filter .2s ease,color .2s ease}.btn:after{content:"";position:absolute;top:0;left:-130%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.16),transparent);transform:skew(-18deg);transition:left .6s ease;pointer-events:none}.btn:hover:after{left:135%}.btn:active{transform:translateY(1px) scale(.985)}.btn:focus-visible{outline:none;box-shadow:0 0 0 2px #0e0e0e,0 0 0 4px var(--accent2)}.btn:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(.3)}.btn:disabled:after{display:none}.btn-primary{background:linear-gradient(180deg,#ffb9aa33,#ffb9aa00 44%),linear-gradient(180deg,#a51414,#6e0707 55%,#470303);color:#fff;border-color:#ffaa9659;border-top-color:#ffcdbe99;text-shadow:0 1px 2px rgba(0,0,0,.55);box-shadow:inset 0 1px #ffd7c880,inset 0 -3px 7px #0000006b,0 6px 18px #8b000073,0 2px 4px #00000080}.btn-primary:hover{filter:brightness(1.09);border-top-color:#ffd7c8c7;box-shadow:inset 0 1px #ffdccd8c,inset 0 -3px 7px #0000006b,0 9px 28px #b4161699,0 0 30px var(--accent-glow)}.btn-primary:active{box-shadow:inset 0 3px 9px #0009,0 2px 6px #00000080}.btn-danger{background:linear-gradient(180deg,#9a1010,#6b0404);color:#fff;border-color:#ffaa964d;border-top-color:#ffc8b973;text-shadow:0 1px 2px rgba(0,0,0,.55);box-shadow:inset 0 1px #ffc8b959,inset 0 -2px 6px #0006,0 5px 14px #00000073}.btn-danger:hover{filter:brightness(1.08);box-shadow:inset 0 1px #ffc8b966,0 6px 18px #00000080,0 0 18px var(--accent-glow)}.btn-danger:active{box-shadow:inset 0 3px 9px #0009}.btn-ghost{background:linear-gradient(180deg,#ffffff0b,#fff0 50%),#1a1817;color:var(--text);border-color:#4a3a38;box-shadow:inset 0 1px #ffffff0d,0 4px 14px #0006}.btn-ghost:hover{color:var(--accent2);border-color:#ffb4a88c;background:linear-gradient(180deg,#ffb4a81a,#ffb4a804 60%),#1a1817;box-shadow:inset 0 1px #ffffff0f,0 6px 18px #00000073,0 0 18px #ffb4a829}.btn-ghost:active{box-shadow:inset 0 3px 8px #00000080}.btn-sm{padding:8px 16px;font-size:.7rem;letter-spacing:.1em}.card{background:var(--surface2);border:1px solid var(--border-sub);border-radius:0;padding:20px;box-shadow:var(--shadow)}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:0;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-family:Inter,sans-serif}.badge-mafia{background:#8b00004d;color:#ffb4a8;border:1px solid rgba(139,0,0,.5)}.badge-detective{background:#3b82f626;color:#93c5fd;border:1px solid rgba(59,130,246,.3)}.badge-doctor{background:#22c55e1f;color:#86efac;border:1px solid rgba(34,197,94,.25)}.badge-villager{background:#c8c6c51a;color:#c8c6c5;border:1px solid #333}.tag-night{background:#8b000026;color:#ffb4a8;border:1px solid rgba(139,0,0,.3)}.tag-day{background:#eab3081f;color:#eab308;border:1px solid rgba(234,179,8,.25)}.noir-label{font-family:Inter,sans-serif;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--muted2)}.pulse{animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.fade-in{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .35s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes redFlash{0%{opacity:.25}to{opacity:0}}.red-flash{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:#8b0000;animation:redFlash .3s ease forwards;pointer-events:none}.smoke-layer{position:fixed;top:-50%;left:-50%;width:200%;height:200%;background-image:radial-gradient(circle at 40% 40%,rgba(255,255,255,.04) 0%,transparent 65%);filter:blur(80px);animation:smokeFlow 28s ease-in-out infinite;pointer-events:none;z-index:0}@keyframes smokeFlow{0%{transform:translate(0) scale(1);opacity:.7}50%{transform:translate(4%,-2%) scale(1.06);opacity:1}to{transform:translate(0) scale(1);opacity:.7}}.grain-texture{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;opacity:.035;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");background-size:180px}.noir-card{position:relative;background:linear-gradient(180deg,#ffaa960d,#fff0 24%),linear-gradient(180deg,#201d1de0,#110f0fed);border:1px solid rgba(139,0,0,.22);border-top-color:#ff826e4d;backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px);box-shadow:inset 0 1px #ff96821a,inset 0 0 55px 8px #00000080,0 12px 36px #0000009e;overflow:hidden}.noir-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;opacity:.08;mix-blend-mode:overlay;background-image:url(/img/textures/card.png),url(/img/textures/grain.png);background-size:280px,200px}.noir-card>*{position:relative;z-index:1}@keyframes kenburns{0%{transform:scale(1.06) translate(0)}50%{transform:scale(1.13) translate(-1.5%,-2%)}to{transform:scale(1.06) translate(0)}}.kenburns{animation:kenburns 20s ease-in-out infinite}@keyframes glowPulse{0%,to{text-shadow:0 0 0 transparent}50%{text-shadow:0 0 18px var(--accent-glow)}}.glow-pulse{animation:glowPulse 1.6s ease-in-out infinite}.phase-tint{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;transition:background 1.4s ease,opacity 1.4s ease}.phase-scene{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;background-size:cover;background-position:center;opacity:.22;filter:saturate(.8) contrast(1.05);transition:background-image .6s ease;mask-image:linear-gradient(180deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.35) 55%,transparent 100%);-webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.9) 0%,rgba(0,0,0,.35) 55%,transparent 100%)}.app-fog{position:fixed;left:-40%;right:-40%;height:70%;pointer-events:none;z-index:0;background:radial-gradient(ellipse at center,rgba(150,150,165,.05) 0%,transparent 70%);filter:blur(28px)}.app-fog-1{top:8%;animation:fogDrift 42s ease-in-out infinite}.app-fog-2{bottom:4%;animation:fogDrift 58s ease-in-out infinite reverse;opacity:.6}.reveal-portrait{animation:revealPortrait .9s cubic-bezier(.2,.7,.2,1) both}@keyframes revealPortrait{0%{opacity:0;transform:scale(1.35);filter:grayscale(1) brightness(.4)}to{opacity:1;transform:scale(1);filter:none}}.stamp-in{animation:stampIn .55s cubic-bezier(.2,.8,.25,1.25) .5s both}@keyframes stampIn{0%{opacity:0;transform:scale(2.6) rotate(-14deg)}65%{opacity:1}to{opacity:1;transform:scale(1) rotate(-9deg)}}.rise-1{opacity:0;animation:heroIn .6s ease .2s forwards}.rise-2{opacity:0;animation:heroIn .6s ease .4s forwards}.rise-3{opacity:0;animation:heroIn .6s ease .65s forwards}.rise-4{opacity:0;animation:heroIn .6s ease .9s forwards}.win-title{animation:winTitle 1.1s cubic-bezier(.2,.7,.2,1) both}@keyframes winTitle{0%{opacity:0;transform:scale(.7);letter-spacing:.5em;filter:blur(8px)}to{opacity:1;transform:scale(1);letter-spacing:normal;filter:blur(0)}}.phase-flash{animation:pfFade .5s ease both}@keyframes pfFade{0%{opacity:0}12%{opacity:1}88%{opacity:1}to{opacity:0}}.pf-scene{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;opacity:.28;animation:pfZoom 2.4s ease-out both;mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,#000 30%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 50%,#000 30%,transparent 80%)}@keyframes pfZoom{0%{transform:scale(1.18)}to{transform:scale(1)}}.pf-title{animation:pfTitle .9s cubic-bezier(.2,.7,.2,1) both}@keyframes pfTitle{0%{opacity:0;transform:translateY(26px);letter-spacing:.4em;filter:blur(6px)}to{opacity:1;transform:translateY(0);letter-spacing:normal;filter:blur(0)}}.pf-rule{animation:pfRule .7s ease .25s both}@keyframes pfRule{0%{width:0;opacity:0}to{width:50px;opacity:1}}.pf-sub{animation:heroIn .6s ease .5s both}.pf-bar{position:absolute;left:0;right:0;height:50%;background:#0a0a0a}.pf-bar-top{top:0;animation:pfBarTop 1s ease both}.pf-bar-bottom{bottom:0;animation:pfBarBottom 1s ease both}@keyframes pfBarTop{0%{transform:translateY(-100%)}30%,60%{transform:translateY(0)}to{transform:translateY(-100%)}}@keyframes pfBarBottom{0%{transform:translateY(100%)}30%,60%{transform:translateY(0)}to{transform:translateY(100%)}}.hero-stage{position:relative;overflow:hidden}.hero-bg{position:absolute;top:-6%;right:-6%;bottom:-6%;left:-6%;background-size:cover;background-position:center;animation:kenburns 26s ease-in-out infinite;will-change:transform}.hero-scrim{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse at 28% 45%,rgba(139,0,0,.18) 0%,transparent 55%),linear-gradient(90deg,#080808f0,#080808b8 42%,#0808084d),linear-gradient(0deg,#0c0c0c 1%,rgba(12,12,12,.2) 32%,transparent 55%)}.hero-scrim-mobile{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:radial-gradient(ellipse at 50% 38%,rgba(139,0,0,.16) 0%,transparent 60%),linear-gradient(180deg,#0c0c0c8c,#0c0c0cc7 58%,#131313)}.fog{position:absolute;left:-50%;right:-50%;height:60%;background:radial-gradient(ellipse at center,rgba(180,180,190,.06) 0%,transparent 70%);filter:blur(22px);pointer-events:none}.fog-1{top:30%;animation:fogDrift 34s ease-in-out infinite}.fog-2{bottom:0;animation:fogDrift 46s ease-in-out infinite reverse;opacity:.7}@keyframes fogDrift{0%{transform:translate(-8%) translateY(0) scale(1)}50%{transform:translate(8%) translateY(-3%) scale(1.12)}to{transform:translate(-8%) translateY(0) scale(1)}}.ember{position:absolute;bottom:-10px;width:3px;height:3px;border-radius:50%;background:#ffb4a8;box-shadow:0 0 6px 2px #ff8c6e8c;animation:emberRise linear infinite;pointer-events:none}@keyframes emberRise{0%{transform:translateY(0) translate(0);opacity:0}12%{opacity:.85}to{transform:translateY(-78vh) translate(36px);opacity:0}}.shadow-figure{position:absolute;bottom:-4%;left:0;width:150px;height:86%;background:radial-gradient(ellipse at 50% 88%,rgba(0,0,0,.9) 0%,rgba(0,0,0,.5) 38%,transparent 72%);filter:blur(7px);pointer-events:none;animation:shadowStalk 26s ease-in-out infinite;animation-delay:5s}@keyframes shadowStalk{0%{transform:translate(-25vw) scaleX(.8);opacity:0}8%{opacity:.55}46%{opacity:.55}56%{opacity:0}to{transform:translate(115vw) scaleX(1.1);opacity:0}}.hero-parallax{transform:translate3d(var(--px, 0),var(--py, 0),0);transition:transform .18s ease-out}.fog-parallax{will-change:transform}.fog-1.fog-parallax{transform:translate3d(calc(var(--px,0) * -1.6),0,0)}.fog-2.fog-parallax{transform:translate3d(calc(var(--px,0) * 1.4),0,0)}.scare-figure{position:absolute;left:50%;top:58%;width:260px;height:480px;margin-left:-130px;background:radial-gradient(ellipse 40% 26% at 50% 16%,rgba(0,0,0,.96) 0%,rgba(0,0,0,.7) 45%,transparent 72%),radial-gradient(ellipse 50% 55% at 50% 70%,rgba(0,0,0,.96) 0%,rgba(0,0,0,.6) 50%,transparent 78%);filter:blur(3px);transform-origin:50% 60%;animation:scareLunge 1.05s cubic-bezier(.2,.7,.3,1) forwards;pointer-events:none;z-index:5}@keyframes scareLunge{0%{transform:scale(.18) translateY(40px);opacity:0}35%{opacity:.5}72%{transform:scale(2.1) translateY(-10px);opacity:.96}to{transform:scale(2.7) translateY(-20px);opacity:0}}.flicker{animation:neonFlicker 6s infinite}@keyframes neonFlicker{0%,18%,22%,25%,53%,57%,to{opacity:1;text-shadow:0 0 24px rgba(255,120,100,.35)}20%,24%,55%{opacity:.45;text-shadow:none}}.hero-in{opacity:0;animation:heroIn .9s ease forwards}.hero-in-1{animation-delay:.15s}.hero-in-2{animation-delay:.35s}.hero-in-3{animation-delay:.55s}.hero-in-4{animation-delay:.75s}@keyframes heroIn{0%{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion: reduce){.hero-bg,.fog-1,.fog-2,.app-fog,.ember,.shadow-figure,.flicker,.hero-in,.kenburns,.scare-figure{animation:none!important}.hero-in{opacity:1!important}.scare-figure{display:none!important}.hero-parallax,.fog-parallax{transform:none!important}.btn:after{display:none!important}}.top-bar{position:fixed;top:0;left:0;right:0;z-index:50;background:var(--surface);border-bottom:1px solid var(--border-sub);height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 16px}.mafia-logo{font-family:Playfair Display,serif;font-weight:900;font-size:1rem;color:var(--accent2);text-transform:uppercase;letter-spacing:.04em}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:50;background:var(--surface);border-top:1px solid var(--border-sub);display:flex;justify-content:space-around;align-items:center;height:60px;padding-bottom:env(safe-area-inset-bottom,0)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;height:100%;font-size:.55rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted2);background:transparent;border:none;cursor:pointer;transition:color .2s;gap:3px;font-family:Inter,sans-serif;padding:0}.bottom-nav-item .icon{font-size:1.1rem}.bottom-nav-item.active{color:var(--accent2)}.bottom-nav-item:hover{color:var(--muted)}.portrait-frame{background:linear-gradient(180deg,#2a2a2a,#0e0e0e);border:1px solid var(--border);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}.portrait-frame:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;box-shadow:inset 0 0 50px 18px #000000eb;pointer-events:none}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-sub);border-radius:0}.toast-container{position:fixed;bottom:72px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{background:var(--surface3);border:1px solid var(--border-subtle);border-radius:0;padding:9px 18px;font-size:.78rem;font-weight:600;color:var(--text);font-family:Inter,sans-serif;letter-spacing:.04em;text-transform:uppercase;animation:fadeIn .3s ease;box-shadow:var(--shadow);white-space:nowrap}.divider{width:100%;height:1px;background:var(--border-sub)}.divider-accent{width:40px;height:2px;background:var(--accent);margin:8px 0}@media (min-width: 768px){.bottom-nav{display:none}.toast-container{bottom:24px}.mobile-only{display:none!important}.desktop-only{display:block!important}}.desktop-only{display:none}@media (max-width: 767px){#root{padding-top:env(safe-area-inset-top,0px)}header{padding-top:env(safe-area-inset-top,0px)!important;height:calc(56px + env(safe-area-inset-top,0px))!important;box-sizing:border-box!important}}
