@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Cinzel:wght@400;600;700&display=swap";:root{--bg-base:#070714;--bg-surface:#0d0d24;--bg-card:#ffffff0a;--bg-card-hover:#ffffff14;--border:#ffffff14;--border-glow:#8b5cf666;--purple:#8b5cf6;--purple-dark:#6d28d9;--purple-glow:#8b5cf640;--amber:#f59e0b;--amber-glow:#f59e0b40;--red:#ef4444;--red-glow:#ef444440;--cyan:#06b6d4;--green:#10b981;--text-primary:#f1f0ff;--text-secondary:#9ca3af;--text-muted:#6b7280;--role-werewolf:#ef4444;--role-villager:#10b981;--role-seer:#a855f7;--role-doctor:#06b6d4;--night-bg:#070714;--night-accent:#8b5cf6;--day-bg:#14100a;--day-accent:#f59e0b;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--shadow-sm:0 2px 12px #0006;--shadow-md:0 8px 32px #00000080;--shadow-lg:0 20px 60px #0009;--glow-purple:0 0 30px #8b5cf64d;--glow-amber:0 0 30px #f59e0b4d;--glow-red:0 0 30px #ef44444d}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Outfit,sans-serif;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--purple-dark);border-radius:3px}h1,h2,h3{letter-spacing:.03em;font-family:Cinzel,serif}.glass{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(16px)}.glass-hover{transition:background .2s,border-color .2s,transform .2s}.glass-hover:hover{background:var(--bg-card-hover);border-color:var(--border-glow);transform:translateY(-2px)}.btn{border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-family:Outfit,sans-serif;font-size:.95rem;font-weight:600;transition:all .2s;display:inline-flex;position:relative;overflow:hidden}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.btn-primary{background:linear-gradient(135deg, var(--purple), var(--purple-dark));color:#fff;box-shadow:0 4px 20px #8b5cf659}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 28px #8b5cf68c}.btn-danger{color:#fff;background:linear-gradient(135deg,#ef4444,#b91c1c);box-shadow:0 4px 20px #ef44444d}.btn-danger:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 28px #ef444480}.btn-amber{color:#1a1000;background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 20px #f59e0b4d}.btn-amber:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 28px #f59e0b80}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-ghost:hover:not(:disabled){border-color:var(--border-glow);color:var(--text-primary)}.btn-sm{border-radius:var(--radius-sm);padding:8px 16px;font-size:.85rem}.btn-lg{padding:16px 36px;font-size:1.1rem}.btn-full{width:100%}.input{border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);background:#ffffff0d;outline:none;padding:13px 16px;font-family:Outfit,sans-serif;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.input:focus{border-color:var(--purple);box-shadow:0 0 0 3px var(--purple-glow)}.input::placeholder{color:var(--text-muted)}.starfield{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.star{animation:twinkle var(--dur,3s) var(--delay,0s) infinite;background:#fff;border-radius:50%;position:absolute}@keyframes twinkle{0%,to{opacity:.2;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}.bg-orb{filter:blur(80px);pointer-events:none;z-index:0;border-radius:50%;animation:8s ease-in-out infinite float;position:fixed}@keyframes float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-20px)scale(1.05)}}.phase-night{--phase-primary:var(--purple);--phase-glow:var(--purple-glow)}.phase-day{--phase-primary:var(--amber);--phase-glow:var(--amber-glow)}.badge{letter-spacing:.03em;border-radius:999px;align-items:center;gap:5px;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-werewolf{color:#f87171;background:#ef444426;border:1px solid #ef44444d}.badge-villager{color:#34d399;background:#10b98126;border:1px solid #10b9814d}.badge-seer{color:#c084fc;background:#a855f726;border:1px solid #a855f74d}.badge-doctor{color:#22d3ee;background:#06b6d426;border:1px solid #06b6d44d}.badge-dead{color:#9ca3af;background:#64646426;border:1px solid #6464644d;text-decoration:line-through}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;top:20px;right:20px}.toast{border:1px solid var(--border);border-radius:var(--radius-md);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);min-width:280px;max-width:360px;box-shadow:var(--shadow-md);pointer-events:auto;background:#0f0f23f2;padding:14px 18px;animation:.3s slideIn,.3s 3.7s forwards fadeOut}.toast.info{border-left:3px solid var(--purple)}.toast.success{border-left:3px solid var(--green)}.toast.warning{border-left:3px solid var(--amber)}.toast.error{border-left:3px solid var(--red)}.toast.death{border-left:3px solid #6b7280}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0;transform:translate(20px)}}.avatar{background:linear-gradient(135deg, var(--purple), var(--purple-dark));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1rem;font-weight:700;display:flex}.avatar-lg{width:56px;height:56px;font-size:1.3rem}.avatar-sm{width:30px;height:30px;font-size:.8rem}.divider{color:var(--text-muted);align-items:center;gap:12px;font-size:.8rem;display:flex}.divider:before,.divider:after{content:"";background:var(--border);flex:1;height:1px}.spinner{border:3px solid var(--border);border-top-color:var(--purple);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.pulse-dot{background:var(--green);border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}@keyframes pulse{0%,to{box-shadow:0 0 #10b98180}50%{box-shadow:0 0 0 6px #10b98100}}.page-center{z-index:1;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative}@media (width<=480px){.btn-lg{padding:14px 28px;font-size:1rem}h1{font-size:1.6rem}}.auth-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.auth-card{z-index:1;width:100%;max-width:420px;padding:40px 36px;animation:.5s cardIn;position:relative}@keyframes cardIn{0%{opacity:0;transform:translateY(24px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo-icon{margin-bottom:12px;font-size:3.5rem;line-height:1;animation:3s ease-in-out infinite wolfFloat}@keyframes wolfFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.auth-title{background:linear-gradient(135deg,#c4b5fd,#8b5cf6,#6d28d9);-webkit-text-fill-color:transparent;letter-spacing:.1em;-webkit-background-clip:text;background-clip:text;margin-bottom:6px;font-size:2rem}.auth-subtitle{color:var(--text-muted);letter-spacing:.03em;font-size:.82rem}.auth-tabs{border-radius:var(--radius-md);border:1px solid var(--border);background:#ffffff0a;grid-template-columns:1fr 1fr;margin-bottom:28px;padding:4px;display:grid}.auth-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:10px;padding:10px;font-family:Outfit,sans-serif;font-size:.9rem;font-weight:600;transition:all .2s}.auth-tab.active{background:linear-gradient(135deg, var(--purple), var(--purple-dark));color:#fff;box-shadow:0 2px 12px #8b5cf64d}.auth-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;font-size:.82rem;font-weight:600}.auth-error{color:#fca5a5;border-radius:var(--radius-sm);background:#ef44441f;border:1px solid #ef444440;padding:10px 14px;font-size:.88rem}.auth-footer{text-align:center;color:var(--text-muted);margin-top:28px;font-size:.8rem}.auth-roles{justify-content:center;gap:12px;margin-bottom:8px;font-size:1.4rem;display:flex}.lobby-page{z-index:1;min-height:100vh;padding:24px 20px;position:relative}.lobby-header{justify-content:space-between;align-items:center;max-width:520px;margin:0 auto 32px;display:flex}.lobby-brand{align-items:center;gap:10px;display:flex}.lobby-brand .wolf-icon{font-size:1.8rem}.lobby-brand h2{background:linear-gradient(135deg,#c4b5fd,#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.2rem}.user-pill{background:var(--bg-card);border:1px solid var(--border);border-radius:999px;align-items:center;gap:10px;padding:6px 14px 6px 8px;display:flex}.user-pill .avatar{width:28px;height:28px;font-size:.75rem}.user-pill .username{color:var(--text-secondary);font-size:.85rem;font-weight:600}.lobby-content{flex-direction:column;gap:16px;max-width:520px;margin:0 auto;display:flex}.lobby-card{padding:28px}.lobby-card h3{color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:18px;font-size:1rem;display:flex}.room-code-display{text-align:center;border-radius:var(--radius-md);background:#8b5cf614;border:1px dashed #8b5cf64d;margin-bottom:16px;padding:24px}.room-code-display .code{letter-spacing:.2em;color:#c4b5fd;font-family:Cinzel,serif;font-size:2.5rem;font-weight:700}.room-code-display .copy-hint{color:var(--text-muted);margin-top:6px;font-size:.78rem}.room-code-input{text-align:center;letter-spacing:.3em;text-transform:uppercase;font-family:Cinzel,serif;font-size:1.5rem}.lobby-error{color:#fca5a5;border-radius:var(--radius-sm);text-align:center;background:#ef44441a;border:1px solid #ef444433;padding:10px 14px;font-size:.88rem}.divider-or{color:var(--text-muted);align-items:center;gap:12px;margin:4px 0;font-size:.8rem;display:flex}.divider-or:before,.divider-or:after{content:"";background:var(--border);flex:1;height:1px}.waiting-room{justify-content:center;min-height:100vh;padding:24px 16px;display:flex;position:relative;overflow:hidden}.waiting-inner{z-index:1;flex-direction:column;gap:14px;width:100%;max-width:520px;display:flex;position:relative}.waiting-header{justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.waiting-title{background:linear-gradient(135deg,#c4b5fd,#8b5cf6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.1rem}.waiting-sub{color:var(--text-muted);margin-top:2px;font-size:.78rem}.room-code-box{text-align:center;cursor:pointer;padding:24px;transition:all .2s}.room-code-box:hover{border-color:var(--border-glow);background:#ffffff12}.rc-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:8px;font-size:.72rem}.rc-code{letter-spacing:.2em;color:#c4b5fd;font-family:Cinzel,serif;font-size:2.8rem;font-weight:700}.rc-hint{color:var(--text-muted);margin-top:8px;font-size:.75rem}.waiting-players{padding:20px}.wp-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.wp-header h3{font-size:.9rem}.min-note{color:var(--text-muted);font-size:.75rem}.wp-list{flex-direction:column;gap:8px;max-height:300px;display:flex;overflow-y:auto}.wp-item{border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff08;align-items:center;gap:12px;padding:10px 12px;display:flex}.wp-name{align-items:center;gap:8px;font-size:.9rem;font-weight:500;display:flex}.host-badge{background:linear-gradient(135deg, var(--amber), #d97706);color:#1a1000;letter-spacing:.05em;border-radius:999px;padding:2px 7px;font-size:.65rem;font-weight:700}.you-badge{color:#c4b5fd;background:#8b5cf633;border-radius:999px;padding:2px 7px;font-size:.65rem;font-weight:700}.role-preview{padding:16px 20px}.role-preview h4{color:var(--text-muted);margin-bottom:12px;font-size:.8rem}.role-icons{flex-wrap:wrap;gap:12px;display:flex}.role-icon-item{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);background:#ffffff0a;flex-direction:column;flex:1;align-items:center;gap:4px;min-width:70px;padding:10px 16px;font-size:.78rem;display:flex}.role-icon-item span:first-child{font-size:1.4rem}.waiting-host-msg{color:var(--text-secondary);align-items:center;gap:12px;padding:16px 20px;font-size:.9rem;display:flex}.gameboard{flex-direction:column;gap:14px;min-height:100vh;padding:16px;transition:background 1s;display:flex}.gameboard.phase-night{background:radial-gradient(ellipse at 50% 0%, #8b5cf61f 0%, var(--bg-base) 70%)}.gameboard.phase-day{background:radial-gradient(ellipse at 50% 0%, #f59e0b1a 0%, var(--bg-base) 70%)}.gameboard__topbar{z-index:10;justify-content:space-between;align-items:center;padding:12px 20px;display:flex;position:sticky;top:0}.topbar-phase{align-items:center;gap:12px;display:flex}.phase-icon{font-size:1.8rem}.phase-name{font-size:1rem;font-weight:700}.phase-round{color:var(--text-muted);font-size:.75rem}.phase-timer{justify-content:center;align-items:center;display:flex;position:relative}.timer-text{font-family:Cinzel,serif;font-size:.78rem;font-weight:700;position:absolute}.timer-ring{transform:rotate(-90deg)}.role-section{flex-direction:column;align-items:center;gap:10px;display:flex}.role-card{border:1px solid rgba(var(--role-color,139,92,246), .3);border-radius:var(--radius-lg);text-align:center;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0000004d;width:100%;max-width:360px;padding:20px 28px;position:relative;overflow:hidden}.role-card__glow{pointer-events:none;background:radial-gradient(circle at 50% 0,#ffffff12,#0000 60%);position:absolute;inset:0}.role-card__icon{margin-bottom:4px;font-size:2.5rem}.role-card__label{letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted);font-size:.65rem}.role-card__name{color:var(--role-color,#c4b5fd);margin:4px 0;font-family:Cinzel,serif;font-size:1.3rem;font-weight:700}.role-card__desc{color:var(--text-secondary);font-size:.8rem;line-height:1.5}.role-card--hidden{border-color:var(--border)}.role-card--werewolf{--role-color:#ef4444;background:#ef44440f;border-color:#ef444466}.role-card--villager{--role-color:#10b981;background:#10b9810f;border-color:#10b98166}.role-card--seer{--role-color:#a855f7;background:#a855f70f;border-color:#a855f766}.role-card--doctor{--role-color:#06b6d4;background:#06b6d40f;border-color:#06b6d466}.dead-banner{border-radius:var(--radius-md);color:var(--text-muted);text-align:center;background:#6464641f;border:1px solid #64646440;padding:10px 16px;font-size:.85rem}.gameboard__main{grid-template-columns:1fr 380px;gap:14px;display:grid}@media (width<=768px){.gameboard__main{grid-template-columns:1fr}}.gameboard__left,.gameboard__right{flex-direction:column;gap:12px;display:flex}.chatbox{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;height:400px;display:flex;overflow:hidden}.chat-header{border-bottom:1px solid var(--border);background:#0003;align-items:center;gap:8px;padding:12px 16px;font-size:.85rem;font-weight:600;display:flex}.chat-messages{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.chat-empty{text-align:center;color:var(--text-muted);margin-top:20px;font-size:.82rem}.chat-msg{align-items:flex-end;gap:8px;display:flex}.chat-msg.mine{flex-direction:row-reverse}.chat-avatar{background:linear-gradient(135deg, var(--purple), var(--purple-dark));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:.7rem;font-weight:700;display:flex}.chat-bubble-wrap{flex-direction:column;gap:2px;max-width:70%;display:flex}.chat-sender{color:var(--text-muted);padding:0 8px;font-size:.7rem}.chat-bubble{border:1px solid var(--border);word-break:break-word;background:#ffffff12;border-radius:12px;padding:8px 12px;font-size:.88rem;line-height:1.4}.chat-msg.mine .chat-bubble{background:linear-gradient(135deg,#8b5cf64d,#6d28d940);border-color:#8b5cf64d}.chat-input-row{border-top:1px solid var(--border);gap:8px;padding:10px;display:flex}.chat-input{border-radius:999px;padding:8px 16px;font-size:.85rem}.chat-send{border-radius:999px;flex-shrink:0;width:36px;height:36px;padding:0}.player-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.player-list__title{color:var(--text-muted);letter-spacing:.05em;text-transform:uppercase;margin-bottom:12px;font-size:.82rem}.player-list__grid{flex-direction:column;gap:6px;display:flex}.player-item{border-radius:var(--radius-sm);border:1px solid #0000;align-items:center;gap:10px;padding:8px 12px;transition:all .15s;display:flex}.player-item:hover{border-color:var(--border);background:#ffffff0a}.player-item--dead{opacity:.45}.player-item--selected,.player-item--targeted{border-color:var(--purple)!important;background:#8b5cf61a!important}.player-item--targetable:hover{background:#ef444412!important;border-color:#ef444466!important}.player-info{flex-direction:column;flex:1;gap:2px;display:flex}.player-name{align-items:center;gap:6px;font-size:.88rem;font-weight:600;display:flex}.dead-label{color:var(--text-muted);font-size:.7rem}.target-indicator{font-size:1rem}.night-actions,.night-wait,.night-done{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:14px;padding:20px;display:flex}.night-title{font-size:1rem}.night-hint{color:var(--text-muted);font-size:.85rem}.night-wait{text-align:center;align-items:center;padding:32px 20px}.night-wait__icon{margin-bottom:8px;font-size:3rem;animation:2s infinite pulse}.night-done{text-align:center;align-items:center}.done-icon{font-size:2.5rem}.voted-wait{color:var(--text-muted);font-size:.8rem}.wolf-allies{flex-wrap:wrap;align-items:center;gap:8px;padding:8px 0;font-size:.85rem;display:flex}.seer-reveal{flex-direction:column;align-items:center;gap:8px;margin-top:8px;display:flex}.voting-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;gap:14px;padding:20px;display:flex}.voting-panel__header{justify-content:space-between;align-items:center;display:flex}.vote-count{color:var(--text-muted);font-size:.8rem}.voting-hint{color:var(--text-secondary);font-size:.85rem}.voted-confirm{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:12px 0;display:flex}.voted-icon{font-size:2.5rem}.vote-tally{border-top:1px solid var(--border);flex-direction:column;gap:8px;padding-top:14px;display:flex}.vote-tally h4{color:var(--text-muted);font-size:.8rem}.tally-row{align-items:center;gap:10px;display:flex}.tally-name{width:80px;font-size:.82rem}.tally-bar-wrap{background:#ffffff0f;border-radius:3px;flex:1;height:6px;overflow:hidden}.tally-bar{background:linear-gradient(90deg, var(--red), #dc2626);border-radius:3px;height:100%;transition:width .5s}.tally-count{color:var(--text-muted);text-align:right;width:50px;font-size:.75rem}.phase-result{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:28px 20px;display:flex}.result-icon{font-size:2.5rem}.discussion-banner{text-align:center;flex-direction:column;gap:8px;padding:20px;display:flex}.discussion-banner h3{font-size:1rem}.discussion-banner p{color:var(--text-muted);font-size:.85rem}.gameover{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;padding:40px 20px;display:flex}.gameover__icon{font-size:5rem;animation:2s ease-in-out infinite wolfFloat}.gameover__title{font-size:2rem}.gameover__you{background:#ffffff12;border-radius:999px;padding:10px 24px;font-size:1.2rem;font-weight:700}.gameover__roles{margin-top:16px}.gameover__roles h4{color:var(--text-muted);margin-bottom:14px;font-size:.85rem}.role-reveal-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;max-width:600px;display:grid}.role-reveal-item{border:1px solid var(--border);border-radius:var(--radius-md);background:#ffffff0a;flex-direction:column;align-items:center;gap:6px;padding:12px;display:flex}.role-reveal-emoji{font-size:1.5rem}.role-reveal-name{font-size:.82rem;font-weight:600}
