:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;color-scheme:light dark;--bg-primary: #0a0a0a;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a;--text-primary: #ffffff;--text-secondary: #a0a0a0;--border-color: #333333;--accent-color: #0066cc;--accent-hover: #0052a3;--danger-color: #dc3545;--danger-hover: #c82333;--shadow: rgba(0, 0, 0, .3);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media(prefers-color-scheme:light){:root{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--bg-tertiary: #e8e8e8;--text-primary: #1a1a1a;--text-secondary: #666666;--border-color: #d0d0d0;--accent-color: #0066cc;--accent-hover: #0052a3;--danger-color: #dc3545;--danger-hover: #c82333;--shadow: rgba(0, 0, 0, .1)}}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg-primary);color:var(--text-primary)}h1,h2,h3{margin:0;font-weight:600}button{border-radius:8px;border:1px solid var(--border-color);padding:.75em 1.5em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease}button:hover:not(:disabled){background-color:var(--bg-tertiary);transform:translateY(-1px)}button:disabled{opacity:.5;cursor:not-allowed}button:focus-visible{outline:2px solid var(--accent-color);outline-offset:2px}.code-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-primary);padding:20px}.code-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:40px 30px;box-shadow:0 4px 12px var(--shadow);text-align:center;max-width:400px;width:100%}.title{font-size:32px;margin:0 0 8px;color:var(--text-primary);font-weight:600}.subtitle{font-size:14px;color:var(--text-secondary);margin:0 0 32px;font-weight:400}.code-form{display:flex;flex-direction:column;gap:16px}.code-input{padding:16px;font-size:24px;text-align:center;background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;font-weight:600;letter-spacing:4px;transition:all .2s ease}.code-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #0066cc1a}.submit-button{padding:14px;font-size:16px;font-weight:500;color:#fff;background:var(--accent-color);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.submit-button:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.submit-button:disabled{opacity:.5;cursor:not-allowed}.game-code-display{font-size:3rem;font-weight:700;letter-spacing:.5rem;margin:2rem 0;color:var(--accent-color);text-align:center}.waiting-room-section{margin-top:2rem}.waiting-room-title{margin-bottom:1rem;color:var(--text-primary);font-size:18px;font-weight:600}.players-list-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:1rem;max-height:200px;overflow-y:auto}.players-list-empty{color:var(--text-secondary);text-align:center;margin:0}.players-list{list-style:none;padding:0;margin:0}.player-item{padding:.5rem;color:var(--text-primary);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.player-item:last-child{border-bottom:none}.remove-player-button{background:none;border:none;font-size:1.2rem;cursor:pointer;padding:.25rem .5rem;opacity:.6;transition:all .2s ease;line-height:1}.remove-player-button:hover:not(:disabled){opacity:1;transform:scale(1.2)}.remove-player-button:disabled{cursor:not-allowed;opacity:.3}.start-game-button{margin-top:2rem;padding:1rem 2rem;font-size:1.2rem;font-weight:700;background:var(--accent-color);color:#fff;border:none;border-radius:8px;cursor:pointer;width:100%;transition:all .2s ease}.start-game-button:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.start-game-button:disabled{background:var(--border-color);cursor:not-allowed;opacity:.6}.error-message{color:var(--danger-color);background:var(--bg-secondary);border:1px solid var(--danger-color);padding:.75rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.voting-modal-overlay{position:fixed;inset:0;background:#000000f2;z-index:9999;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease-in-out}.voting-modal-content{width:100%;max-width:600px;display:flex;flex-direction:column;align-items:center;gap:20px}.voting-header{text-align:center;color:#fff}.voting-header h2{font-size:28px;margin:0 0 10px;color:#ff4757;text-shadow:0 0 10px rgba(255,71,87,.5)}.voting-header p{font-size:16px;margin:0;color:#fffc}.voting-header .killer-name{color:#ff4757;font-weight:700}.voting-header .victim-name{color:#ffa502;font-weight:700}.kill-photo-container{width:100%;max-height:60vh;border-radius:12px;overflow:hidden;box-shadow:0 10px 40px #00000080;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.kill-photo{width:100%;height:100%;object-fit:contain;background:#1a1a1a}.voting-stats{display:flex;gap:20px;padding:15px;background:#ffffff1a;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.stat-item{text-align:center;color:#fff}.stat-item .stat-value{font-size:24px;font-weight:700;display:block;margin-bottom:5px}.stat-item.valid .stat-value{color:#2ed573}.stat-item.invalid .stat-value{color:#ff4757}.stat-item.total .stat-value{color:#ffa502}.stat-item .stat-label{font-size:12px;color:#ffffffb3;text-transform:uppercase;letter-spacing:1px}.voting-buttons{display:flex;gap:15px;width:100%}.vote-btn{flex:1;padding:18px 30px;font-size:18px;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;box-shadow:0 4px 15px #0000004d}.vote-btn:active{transform:scale(.95)}.vote-btn.valid{background:linear-gradient(135deg,#2ed573,#26d063);color:#fff}.vote-btn.valid:hover{background:linear-gradient(135deg,#26d063,#1fb956);box-shadow:0 6px 20px #2ed57366}.vote-btn.invalid{background:linear-gradient(135deg,#ff4757,#ff3838);color:#fff}.vote-btn.invalid:hover{background:linear-gradient(135deg,#ff3838,#ff1e1e);box-shadow:0 6px 20px #ff475766}.vote-btn:disabled{opacity:.5;cursor:not-allowed}.voting-info{text-align:center;color:#ffffffb3;font-size:14px;margin-top:-10px}.voting-deadline{margin-top:10px;padding:10px;background:#ffa50233;border-radius:8px;color:#ffa502;font-size:14px;text-align:center}.special-voting-notice{padding:12px 20px;background:#8a2be233;border:2px solid rgba(138,43,226,.5);border-radius:8px;color:#e0b3ff;font-size:14px;text-align:center;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.already-voted{text-align:center;padding:20px;background:#2ed57333;border-radius:8px;color:#2ed573;font-size:16px}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#ff4757;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.voting-modal-content{max-width:100%}.voting-header h2{font-size:22px}.kill-photo-container{max-height:50vh}.vote-btn{padding:15px 20px;font-size:16px}}.players-list-modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.players-list-modal-content{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;padding:25px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.players-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.players-list-header h2{margin:0;color:#fff;font-size:24px;font-weight:700}.close-button{background:#fff3;border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-button:hover{background:#ffffff4d;transform:rotate(90deg)}.loading-players{text-align:center;padding:40px;color:#fff;font-size:18px}.players-lists{display:flex;flex-direction:column;gap:20px}.players-section{background:#ffffff1a;border-radius:15px;padding:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.section-title{margin:0 0 15px;font-size:18px;font-weight:700;padding-bottom:10px;border-bottom:2px solid rgba(255,255,255,.2)}.alive-title{color:#4ade80}.eliminated-title{color:#ef4444}.players-list{display:flex;flex-direction:column;gap:10px}.no-players{text-align:center;color:#fff9;padding:20px;font-style:italic;margin:0}.player-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;transition:all .2s}.player-item.alive{background:#4ade8033;border:2px solid rgba(74,222,128,.3)}.player-item.eliminated{background:#ef444433;border:2px solid rgba(239,68,68,.3);opacity:.7}.player-avatar{width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff}.alive-avatar{background:linear-gradient(135deg,#4ade80,#22c55e);box-shadow:0 2px 10px #4ade8066}.eliminated-avatar{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 2px 10px #ef444466}.player-info{display:flex;flex-direction:column;gap:4px;flex:1}.player-name{color:#fff;font-weight:600;font-size:16px}.player-kills{color:#ffffffb3;font-size:13px}.gallery-modal-overlay{position:fixed;inset:0;background-color:#000000e6;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px;overflow-y:auto}.gallery-modal-content{background:linear-gradient(135deg,#1e1e1e,#2d2d2d);border-radius:20px;padding:25px;max-width:1000px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #00000080}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;flex-wrap:wrap;gap:15px}.gallery-header h2{margin:0;color:#fff;font-size:24px;font-weight:700}.gallery-header-actions{display:flex;gap:10px;align-items:center}.download-all-button{background:linear-gradient(135deg,#10b981,#059669);border:none;color:#fff;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #10b9814d}.download-all-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.close-button{background:#ffffff1a;border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-button:hover{background:#fff3;transform:rotate(90deg)}.loading-gallery,.no-kills{text-align:center;padding:60px 20px;color:#fff;font-size:18px}.no-kills p{margin:0;font-size:20px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.gallery-item{background:#ffffff0d;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s;border:2px solid transparent}.gallery-item:hover{transform:translateY(-4px);border-color:#667eea80;box-shadow:0 8px 20px #667eea4d}.gallery-thumbnail{width:100%;height:200px;object-fit:cover;display:block}.gallery-item-info{padding:12px;display:flex;flex-direction:column;gap:8px}.kill-info{display:flex;align-items:center;gap:8px;font-size:13px;color:#fff;flex-wrap:wrap}.killer{color:#ef4444;font-weight:600}.arrow{color:#ffffff80}.victim{color:#fffc;font-weight:600}.kill-date{font-size:11px;color:#ffffff80}.image-preview-overlay{position:fixed;inset:0;background-color:#000000f2;display:flex;justify-content:center;align-items:center;z-index:2000;padding:20px}.image-preview-content{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:20px}.preview-close{position:absolute;top:-50px;right:0;background:#ffffff1a;border:none;color:#fff;width:40px;height:40px;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.preview-close:hover{background:#fff3;transform:rotate(90deg)}.preview-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:12px;box-shadow:0 10px 40px #00000080}.preview-info{background:#000c;padding:20px;border-radius:12px;display:flex;flex-direction:column;gap:12px;align-items:center;min-width:300px}.preview-players{display:flex;align-items:center;gap:12px;font-size:16px}.preview-killer{color:#ef4444;font-weight:700}.preview-arrow{color:#ffffff80;font-size:20px}.preview-victim{color:#fff;font-weight:700}.preview-date{color:#fff9;font-size:14px}.preview-download{background:linear-gradient(135deg,#10b981,#059669);border:none;color:#fff;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;width:100%}.preview-download:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}@media(max-width:768px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px}.gallery-thumbnail{height:150px}.gallery-header{flex-direction:column;align-items:stretch}.gallery-header-actions{width:100%;justify-content:space-between}.preview-image{max-height:60vh}}.game-page{min-height:100vh;background-color:var(--bg-primary)}.game-container{min-height:100vh;display:flex;flex-direction:column;padding:20px;max-width:600px;margin:0 auto}.header{text-align:center;margin-bottom:24px;padding-top:20px}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.header-actions{display:flex;align-items:center;gap:12px}.refresh-indicator{font-size:18px;animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.title{font-size:24px;color:var(--text-primary);margin:0;font-weight:600}.logout-button{padding:8px 16px;background:var(--danger-color);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.logout-button:hover{background:var(--danger-hover);transform:translateY(-1px)}.game-info-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:0 2px 8px var(--shadow)}.game-info-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;color:var(--text-primary)}.game-info-row:not(:last-child){border-bottom:1px solid var(--border-color)}.info-label{font-size:14px;color:var(--text-secondary)}.info-value{font-size:14px;font-weight:600;color:var(--text-primary)}.game-code{font-size:18px;font-weight:700;color:var(--accent-color);letter-spacing:2px}.creator-notice{background:var(--bg-secondary);border:2px solid var(--accent-color);border-radius:12px;padding:16px;margin-bottom:16px;text-align:left}.creator-notice strong{display:block;color:var(--text-primary);font-size:16px;margin-bottom:8px}.creator-notice-text{margin:0 0 12px;font-size:14px;color:var(--text-secondary);line-height:1.5}.back-to-lobby-button{width:100%;padding:12px;background:var(--accent-color);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.back-to-lobby-button:hover{background:var(--accent-hover);transform:translateY(-1px)}.target-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:32px 24px;text-align:center;box-shadow:0 4px 12px var(--shadow);margin-bottom:24px}.target-avatar{width:80px;height:80px;border-radius:50%;background:var(--accent-color);color:#fff;font-size:32px;font-weight:600;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.target-name{font-size:20px;color:var(--text-primary);margin:0 0 8px;font-weight:600}.target-instruction{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.gun-button{width:100%;padding:16px;background:var(--danger-color);border:none;border-radius:8px;color:#fff;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;transition:all .2s ease;margin-bottom:24px}.gun-button:hover{background:var(--danger-hover);transform:translateY(-1px)}.gun-button:active{transform:translateY(0)}.gun-icon{font-size:20px}.gun-text{letter-spacing:.5px}.info-section{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:16px}.info-item{display:flex;align-items:flex-start;gap:12px;padding:12px 0;color:var(--text-primary)}.info-item:not(:last-child){border-bottom:1px solid var(--border-color)}.info-icon{font-size:18px;flex-shrink:0;margin-top:2px;color:var(--text-secondary)}.info-text{font-size:13px;line-height:1.6;color:var(--text-secondary)}.camera-modal{position:fixed;top:0;left:0;width:100%;height:100dvh;background:#000000fa;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.camera-modal-content{width:100%;height:100%;background:#000;display:flex;align-items:center;justify-content:center}.camera-video{width:100%;height:100%;object-fit:cover;background:#000}.camera-controls{position:fixed;bottom:0;left:0;right:0;display:flex;gap:12px;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));background:#000000f2;z-index:10000;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@supports (-webkit-touch-callout: none){.camera-controls{padding:16px;padding-bottom:calc(24px + env(safe-area-inset-bottom,0px))}}.camera-button{flex:1;padding:14px;border:1px solid rgba(255,255,255,.2);border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.cancel-button{background:#ffffff1a;color:#fff}.cancel-button:hover{background:#ffffff26}.capture-button{background:var(--danger-color);color:#fff;border-color:var(--danger-color)}.capture-button:hover{background:var(--danger-hover);border-color:var(--danger-hover)}.game-info-card.player-eliminated{background:#ef44441a;border:2px solid rgba(239,68,68,.5)}.status-alive{color:#4ade80!important;text-shadow:0 0 8px rgba(74,222,128,.4)}.status-dead{color:#ef4444!important;text-shadow:0 0 8px rgba(239,68,68,.4)}.target-card.dead-player{background:#ef44441a;border:2px solid rgba(239,68,68,.5)}.target-card.dead-player .target-avatar{background:linear-gradient(135deg,#ef4444,#dc2626);font-size:48px}.players-list-button{width:100%;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;margin-bottom:16px;box-shadow:0 2px 8px #667eea4d}.players-list-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.players-list-button:active{transform:translateY(0)}.gallery-button{width:100%;padding:12px;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;margin-bottom:16px;box-shadow:0 2px 8px #f59e0b4d}.gallery-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b66}.gallery-button:active{transform:translateY(0)}.victory-screen{flex:1;display:flex;align-items:center;justify-content:center;padding:20px 0}.victory-card{background:linear-gradient(135deg,#f59e0b1a,#d977061a);border:2px solid rgba(245,158,11,.5);border-radius:20px;padding:40px 32px;text-align:center;box-shadow:0 10px 40px #f59e0b33;max-width:500px;width:100%}.victory-trophy{font-size:80px;margin-bottom:20px;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-20px)}60%{transform:translateY(-10px)}}.victory-title{font-size:28px;color:var(--text-primary);margin:0 0 24px;font-weight:700}.winner-info{display:flex;align-items:center;gap:20px;background:#ffffff0d;border-radius:16px;padding:20px;margin-bottom:20px;border:2px solid rgba(245,158,11,.3)}.winner-avatar{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;font-size:32px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #f59e0b66;flex-shrink:0}.winner-details{display:flex;flex-direction:column;gap:6px;text-align:left;flex:1}.winner-label{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.winner-name{font-size:22px;color:var(--text-primary);font-weight:700}.winner-kills{font-size:14px;color:var(--text-secondary);font-weight:600}.victory-message{display:flex;align-items:center;justify-content:center;gap:12px;background:linear-gradient(135deg,#10b981,#059669);padding:16px;border-radius:12px;margin-bottom:20px;animation:pulse 2s infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.congrats-emoji{font-size:24px}.congrats-text{font-size:15px;color:#fff;font-weight:600}.victory-description{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.6}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;min-height:100vh}
