:root{--bg-dark: #0f172a;--bg-card: rgba(30, 41, 59, .7);--bg-card-hover: rgba(30, 41, 59, .9);--text-main: #f8fafc;--text-muted: #94a3b8;--primary: #3b82f6;--primary-hover: #2563eb;--secondary: #64748b;--secondary-hover: #475569;--success: #10b981;--error: #ef4444;--liberal: #0ea5e9;--fascist: #dc2626;--accent-glow: 0 0 15px rgba(59, 130, 246, .5)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-dark);color:var(--text-main);line-height:1.5;background-image:radial-gradient(circle at 15% 50%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(circle at 85% 30%,rgba(220,38,38,.05) 0%,transparent 50%);background-attachment:fixed;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.btn{padding:.75rem 1.5rem;border-radius:.5rem;border:none;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s ease}.btn-primary{background-color:var(--primary);color:#fff;box-shadow:0 4px 6px #3b82f640}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 12px #3b82f64d}.btn-secondary{background-color:var(--secondary);color:#fff}.btn-secondary:hover:not(:disabled){background-color:var(--secondary-hover)}.btn-success{background-color:var(--success);color:#fff}.btn-success:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px)}.btn:disabled{opacity:.5;cursor:not-allowed}input[type=text]{width:100%;padding:.75rem 1rem;border-radius:.5rem;border:1px solid rgba(255,255,255,.1);background-color:#0f172a99;color:#fff;font-size:1rem;transition:border-color .2s}input[type=text]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #3b82f633}.home-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:1rem}.home-card{background:var(--bg-card);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:3rem;border-radius:1.5rem;border:1px solid rgba(255,255,255,.05);box-shadow:0 25px 50px -12px #00000080;width:100%;max-width:400px;animation:slideUp .5s ease-out}.title{font-size:2.5rem;font-weight:800;text-align:center;margin-bottom:.5rem;background:linear-gradient(135deg,#f8fafc,#cbd5e1);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.subtitle{text-align:center;color:var(--text-muted);margin-bottom:2rem;font-size:.9rem}.error-message{background-color:#ef44441a;color:var(--error);padding:.75rem;border-radius:.5rem;margin-bottom:1.5rem;font-size:.875rem;text-align:center;border:1px solid rgba(239,68,68,.2)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-muted)}.actions{display:flex;flex-direction:column;gap:1.5rem}.actions .btn-primary{width:100%}.divider{display:flex;align-items:center;text-align:center;color:var(--text-muted)}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid rgba(255,255,255,.1)}.divider span{padding:0 1rem;font-size:.875rem;font-weight:500}.join-group{display:flex;gap:.5rem}.join-group input{flex:1;text-transform:uppercase;letter-spacing:2px;font-weight:600}.join-group .btn{white-space:nowrap}.chat-container{display:flex;flex-direction:column;height:100%;background:var(--bg-card);border-radius:1rem;border:1px solid rgba(255,255,255,.05);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.chat-header{padding:1rem;border-bottom:1px solid rgba(255,255,255,.05);background:#0003;border-top-left-radius:1rem;border-top-right-radius:1rem}.chat-header h3{font-size:1.1rem;margin:0}.chat-messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.chat-message{display:flex;flex-direction:column;max-width:85%;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.chat-message.own-message{align-self:flex-end}.chat-message .sender{font-size:.75rem;color:var(--text-muted);margin-bottom:.2rem;margin-left:.5rem}.bubble{padding:.6rem 1rem;border-radius:1rem;background:#ffffff0d;word-break:break-word}.own-message .bubble{background:var(--primary);color:#fff;border-bottom-right-radius:.2rem}.chat-message:not(.own-message) .bubble{border-bottom-left-radius:.2rem}.chat-input-area{padding:1rem;border-top:1px solid rgba(255,255,255,.05);background:#0003;position:relative;border-bottom-left-radius:1rem;border-bottom-right-radius:1rem}.chat-form{display:flex;align-items:center;gap:.5rem;background:#0f172a99;border-radius:2rem;padding:.25rem .5rem;border:1px solid rgba(255,255,255,.1)}.chat-input{flex:1;background:transparent!important;border:none!important;padding:.5rem!important}.chat-input:focus{box-shadow:none!important}.icon-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.5rem;border-radius:50%;transition:all .2s}.icon-btn:hover{color:#fff;background:#ffffff1a}.submit-btn{color:var(--primary)}.submit-btn:disabled{color:var(--text-muted);opacity:.5;cursor:not-allowed;background:transparent}.emoji-picker-container{position:absolute;bottom:100%;right:1rem;margin-bottom:.5rem;z-index:50;box-shadow:0 10px 25px -5px #00000080;border-radius:10px}.game-board{padding:2rem;display:flex;flex-direction:column;align-items:center;height:100%;position:relative}.role-card-container{margin-bottom:2rem;text-align:center}.role-card-container h3{margin-bottom:.5rem;color:var(--text-muted)}.role-card{padding:1.5rem 3rem;border-radius:1rem;border:2px solid rgba(255,255,255,.1);display:inline-block;background:#222;box-shadow:0 10px 20px #00000080;transform:scale(1);transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.role-card:hover{transform:scale(1.05)}.role-card.liberal{border-color:var(--liberal);background:linear-gradient(135deg,#0ea5e933,#000c)}.role-card.fascist{border-color:var(--fascist);background:linear-gradient(135deg,#dc262633,#000c)}.role-title{font-size:2rem;font-weight:800;letter-spacing:2px;text-transform:uppercase}.liberal .role-title{color:var(--liberal);text-shadow:0 0 10px rgba(14,165,233,.5)}.fascist .role-title{color:var(--fascist);text-shadow:0 0 10px rgba(220,38,38,.5)}.role-party{font-size:.9rem;text-transform:uppercase;letter-spacing:1px;opacity:.8;margin-top:.5rem}.boards-container{display:flex;flex-direction:column;gap:2rem;width:100%;max-width:800px;margin-bottom:2rem}.policy-track{background:#0000004d;border-radius:1rem;padding:1.5rem;border:1px solid rgba(255,255,255,.05)}.policy-track h4{margin-bottom:1rem;text-transform:uppercase;letter-spacing:2px;font-size:.9rem}.liberal-track h4{color:var(--liberal)}.fascist-track h4{color:var(--fascist)}.track-slots{display:flex;justify-content:space-between;gap:.5rem}.policy-slot{flex:1;aspect-ratio:2/3;border:2px dashed rgba(255,255,255,.2);border-radius:.5rem;display:flex;align-items:center;justify-content:center;position:relative;transition:all .3s}.slot-inner{font-size:.8rem;text-transform:uppercase;font-weight:700;opacity:.5}.policy-slot.filled{border-style:solid;animation:dropIn .5s cubic-bezier(.175,.885,.32,1.275)}.policy-slot.liberal-filled{background:var(--liberal);border-color:#0ea5e9;box-shadow:0 0 15px #0ea5e966}.policy-slot.liberal-filled .slot-inner{opacity:0}.policy-slot.fascist-filled{background:var(--fascist);border-color:#ef4444;box-shadow:0 0 15px #dc262666}.policy-slot.fascist-filled .slot-inner{opacity:0}@keyframes dropIn{0%{transform:scale(1.5);opacity:0}to{transform:scale(1);opacity:1}}.election-tracker{display:flex;flex-direction:column;align-items:center;background:#0003;padding:1rem 2rem;border-radius:2rem;margin-bottom:2rem}.tracker-slots{display:flex;gap:1rem;margin:.5rem 0}.tracker-slots .marker{width:20px;height:20px;border-radius:50%;background:#ffffff1a;border:2px solid rgba(255,255,255,.2)}.tracker-slots .marker.active{background:var(--primary);border-color:var(--primary);box-shadow:0 0 10px var(--primary)}.tracker-label{font-size:.8rem;color:var(--text-muted)}.players-ring{position:relative;width:300px;height:300px;margin-top:2rem}.player-avatar{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;transition:all .3s}.avatar-circle{width:50px;height:50px;border-radius:50%;background:var(--secondary);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;box-shadow:0 4px 6px #0000004d;border:2px solid transparent}.player-avatar.is-me .avatar-circle{background:var(--primary);border-color:#fff}.policy-slot.filled{animation:popIn .5s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes popIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.1);opacity:1}to{transform:scale(1);opacity:1}}.game-over-overlay{position:absolute;inset:0;background:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn 1s}.game-over-modal{background:var(--bg-card);padding:3rem;border-radius:1rem;text-align:center;border:2px solid rgba(255,255,255,.1);box-shadow:0 20px 50px #00000080;max-width:600px;width:90%}.game-over-modal h2{font-size:2rem;margin-bottom:.5rem}.game-over-modal .win-reason{color:var(--text-muted);font-size:1.1rem;margin-bottom:1.5rem}.game-over-modal h1{font-size:3rem;margin-bottom:2rem;text-transform:uppercase;letter-spacing:2px}.liberal-win{color:var(--liberal);text-shadow:0 0 20px rgba(14,165,233,.5)}.fascist-win{color:var(--fascist);text-shadow:0 0 20px rgba(239,68,68,.5)}.role-reveal{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.reveal-card{background:#0000004d;padding:.5rem 1rem;border-radius:.5rem;display:flex;flex-direction:column;min-width:120px}.reveal-card.liberal{border-bottom:3px solid var(--liberal)}.reveal-card.fascist{border-bottom:3px solid var(--fascist)}.player-avatar.is-acting .avatar-circle{box-shadow:0 0 15px 5px var(--accent);animation:pulse 1.5s infinite}@keyframes pulse{0%{box-shadow:0 0 #eab308b3}70%{box-shadow:0 0 0 15px #eab30800}to{box-shadow:0 0 #eab30800}}.action-bubble{position:absolute;top:-30px;background:#fff;color:#000;padding:.2rem .5rem;border-radius:1rem;font-size:.75rem;font-weight:700;white-space:nowrap;animation:bounce 2s infinite;pointer-events:none}.action-bubble:after{content:"";position:absolute;bottom:-4px;left:50%;transform:translate(-50%);border-width:5px 5px 0;border-style:solid;border-color:white transparent transparent transparent}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.buzz-btn{position:absolute;right:-40px;top:50%;transform:translateY(-50%);background:var(--error);color:#fff;border:none;padding:.2rem .5rem;border-radius:.5rem;font-size:.7rem;font-weight:700;cursor:pointer;box-shadow:0 2px 5px #00000080;transition:all .2s;z-index:10}.buzz-btn:hover{transform:translateY(-50%) scale(1.1);background:#f87171}.avatar-name{margin-top:.5rem;font-size:.8rem;background:#00000080;padding:.2rem .5rem;border-radius:1rem;white-space:nowrap}.action-panel{margin-top:2rem;width:100%;max-width:600px;display:flex;flex-direction:column;align-items:center}.action-box{background:#0f172acc;border:1px solid rgba(255,255,255,.1);box-shadow:0 10px 25px -5px #00000080;border-radius:1rem;padding:2rem;width:100%;text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideUp .3s ease-out}.action-box h4{font-size:1.5rem;margin-bottom:1rem}.action-box p{margin-bottom:1rem;color:var(--text-muted)}.action-box select{width:100%;padding:.75rem;margin-bottom:1rem;background:#0000004d;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:.5rem;font-size:1rem}.action-box select option{background:#111}.vote-buttons{display:flex;justify-content:center;gap:1rem;margin-top:1.5rem}.vote-ja,.vote-nein{font-size:1.25rem;padding:1rem 3rem;border-radius:.5rem;border:none;cursor:pointer;font-weight:700;color:#fff;transition:transform .2s,filter .2s}.vote-ja{background-color:var(--success, #22c55e)}.vote-nein{background-color:var(--error, #ef4444)}.vote-ja:hover,.vote-nein:hover{transform:scale(1.05);filter:brightness(1.1)}.waiting{opacity:.7;font-style:italic;border-style:dashed}.policy-cards{display:flex;justify-content:center;gap:1rem;margin-top:1rem}.policy-card-btn{width:100px;height:150px;border-radius:.5rem;display:flex;align-items:center;justify-content:center;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;-webkit-user-select:none;user-select:none}.policy-card-btn:hover{transform:translateY(-10px);box-shadow:0 10px 15px #0000004d}.policy-card-btn.liberal{background-color:var(--liberal);border:2px solid #0ea5e9;color:#fff}.policy-card-btn.fascist{background-color:var(--fascist);border:2px solid #ef4444;color:#fff}.avatar-role-tag{position:absolute;bottom:-20px;background:var(--primary);color:#fff;font-size:.7rem;padding:.1rem .5rem;border-radius:1rem;font-weight:700;text-transform:uppercase;box-shadow:0 2px 4px #00000080;white-space:nowrap}.player-avatar.is-dead{opacity:.4;filter:grayscale(100%)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.room-container{display:flex;flex-direction:column;height:100vh;max-width:1400px;margin:0 auto;padding:1rem}.room-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-card);border-radius:1rem;margin-bottom:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.05)}.highlight{color:var(--primary);font-family:monospace;letter-spacing:2px;padding:.2rem .6rem;background:#3b82f61a;border-radius:.25rem}.status-badge{background:#ffffff1a;padding:.4rem 1rem;border-radius:2rem;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:1px}.room-content{display:flex;flex:1;gap:1rem}.main-panel{flex:3;background:var(--bg-card);border-radius:1rem;border:1px solid rgba(255,255,255,.05);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow-y:auto}.side-panel{flex:1;min-width:300px;max-width:400px;display:flex;flex-direction:column}.lobby-panel{padding:2rem;height:100%;display:flex;flex-direction:column}.lobby-panel h3{margin-bottom:1.5rem;font-size:1.5rem;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:.5rem}.player-list{list-style:none;flex:1;overflow-y:auto;margin-bottom:1.5rem}.player-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;margin-bottom:.5rem;background:#0003;border-radius:.5rem;transition:transform .2s}.player-item.me{border-left:3px solid var(--primary);background:linear-gradient(90deg,#3b82f61a,#0003)}.player-item:hover{transform:translate(4px);background:#ffffff0d}.player-name{font-weight:500}.ready-status{font-size:.875rem;padding:.25rem .75rem;border-radius:1rem;font-weight:600}.ready-status.ready{background:#10b9811a;color:var(--success)}.ready-status.not-ready{background:#ffffff1a;color:var(--text-muted)}.lobby-actions{display:flex;gap:1rem;justify-content:center;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}@media(max-width:768px){.room-content{flex-direction:column}.side-panel{flex:none;height:300px;max-width:none}}.shake-screen{animation:shake .5s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}
