body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.name-uploader{display:flex;flex-direction:column;gap:1.5rem}.text-input-container{display:flex;flex-direction:column;gap:1rem}.name-textarea{border:1px solid #ddd;border-radius:var(--border-radius);box-sizing:border-box;font-family:inherit;font-size:14px;min-height:120px;padding:12px;resize:vertical;transition:var(--transition);width:100%}.name-textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #3498db33;outline:none}.name-textarea::placeholder{color:#aaa}.submit-button{align-self:flex-start;background-color:var(--primary-color);border:none;border-radius:var(--border-radius);color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 15px;transition:var(--transition)}.submit-button:hover:not(:disabled){background-color:var(--primary-dark);transform:translateY(-2px)}.submit-button:active:not(:disabled){transform:translateY(0)}.submit-button:disabled{background-color:#ccc;cursor:not-allowed;opacity:.7}.file-drop-area{background-color:#f9f9f9;border:2px dashed #ddd;border-radius:var(--border-radius);cursor:pointer;padding:20px;text-align:center;transition:var(--transition)}.file-drop-area.dragging{background-color:#3498db0d;border-color:var(--primary-color)}.file-drop-area p{color:#666;margin:5px 0}.file-upload-button{background-color:var(--primary-color);border-radius:var(--border-radius);color:#fff;cursor:pointer;display:inline-block;font-size:14px;margin-top:10px;padding:8px 16px;transition:var(--transition)}.file-upload-button:hover{background-color:var(--primary-dark)}.hidden-input{display:none}.spin-controller{display:flex;flex-direction:column;gap:1.5rem}.spin-mode{margin-bottom:.5rem}.toggle-switch{align-items:center;cursor:pointer;display:inline-flex;position:relative}.toggle-switch input{height:0;opacity:0;width:0}.slider{background-color:#ccc;border-radius:34px;display:inline-block;height:24px;position:relative;width:50px}.slider,.slider:before{transition:var(--transition)}.slider:before{background-color:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;position:absolute;width:18px}input:checked+.slider{background-color:var(--primary-color)}input:focus+.slider{box-shadow:0 0 1px var(--primary-color)}input:checked+.slider:before{transform:translateX(26px)}.toggle-label{font-weight:500;margin-left:10px}.mode-description{color:#666;font-size:.85rem;margin-top:6px;padding-left:60px}.spin-buttons{display:flex;gap:10px}.spin-button,.stop-button{border:none;border-radius:var(--border-radius);cursor:pointer;flex:1 1;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 20px;text-transform:uppercase;transition:var(--transition)}.spin-button{background-color:var(--primary-color);color:#fff}.spin-button:hover{background-color:var(--primary-dark);box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.spin-button:active{box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.stop-button{background-color:var(--secondary-color);color:#fff}.stop-button:hover{background-color:var(--secondary-dark);box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.stop-button:active{box-shadow:0 2px 4px #0000001a;transform:translateY(0)}.winner-popup-overlay{align-items:center;background-color:#000000b3;bottom:0;display:flex;justify-content:center;left:0;opacity:0;position:fixed;right:0;top:0;transition:opacity .3s ease;z-index:1000}.popup-enter{opacity:1}.popup-exit{opacity:0}.winner-popup-content{background-color:#fff;border-radius:12px;box-shadow:0 5px 30px #0000004d;max-width:400px;padding:30px;position:relative;text-align:center;transform:scale(.9);transition:transform .3s cubic-bezier(.18,.89,.32,1.28);width:90%}.popup-enter .winner-popup-content{transform:scale(1)}.popup-exit .winner-popup-content{transform:scale(.9)}.winner-popup-content h2{color:var(--primary-color);font-size:1.8rem;margin-top:0}.winner-name{animation:pulse 1.5s infinite;color:var(--secondary-color);font-size:2.5rem;font-weight:700;margin:20px 0;text-shadow:0 2px 4px #0000001a}.close-button{background-color:var(--primary-color);border:none;border-radius:var(--border-radius);color:#fff;cursor:pointer;font-size:1rem;margin-top:20px;padding:10px 25px;transition:all .2s ease}.close-button:hover{background-color:var(--primary-dark);transform:translateY(-2px)}.close-button:active{transform:translateY(0)}.winner-crown{background-color:gold;clip-path:polygon(50% 0,80% 30%,100% 0,100% 40%,80% 25%,60% 40%,40% 40%,20% 25%,0 40%,0 0,20% 30%);height:40px;left:50%;position:absolute;top:-30px;transform:translateX(-50%);width:60px}.winner-celebration{height:100%;left:0;overflow:hidden;pointer-events:none;position:absolute;top:0;width:100%}.confetti-piece{animation:confetti-fall 3s ease-in-out infinite;background-color:var(--primary-color);height:20px;opacity:.8;position:absolute;width:10px}.confetti-piece:first-child{animation-delay:0s;background-color:#f44336;left:10%;top:-20px}.confetti-piece:nth-child(2){animation-delay:.5s;background-color:#2196f3;left:30%;top:-20px}.confetti-piece:nth-child(3){animation-delay:1s;background-color:#ffeb3b;left:50%;top:-20px}.confetti-piece:nth-child(4){animation-delay:1.5s;background-color:#4caf50;left:70%;top:-20px}.confetti-piece:nth-child(5){animation-delay:2s;background-color:#9c27b0;left:90%;top:-20px}.confetti-piece:nth-child(6){animation-delay:2.5s;background-color:#ff9800;left:20%;top:-20px}.confetti-piece:nth-child(7){animation-delay:.7s;background-color:#00bcd4;left:80%;top:-20px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0) rotate(0deg)}to{opacity:0;transform:translateY(400px) rotate(1turn)}}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}:root{--primary-color:#3498db;--primary-dark:#2980b9;--secondary-color:#e74c3c;--secondary-dark:#c0392b;--bg-color:#f8f9fa;--panel-bg:#fff;--text-color:#333;--border-radius:8px;--box-shadow:0 4px 6px #0000001a;--transition:all 0.3s ease}body{background-color:#f8f9fa;background-color:var(--bg-color);color:#333;color:var(--text-color);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0;padding:0}.app-container{display:flex;flex-direction:column;margin:0 auto;max-width:1200px;min-height:100vh;padding:1rem}.app-header{border-bottom:1px solid #eaeaea;margin-bottom:2rem;padding-bottom:1rem;text-align:center}.app-header h1{color:#3498db;color:var(--primary-color);font-size:2.5rem;margin:0}.app-subtitle{color:#666;margin-top:.5rem}.app-content{display:flex;flex:1 1;flex-direction:row;gap:2rem}@media (max-width:768px){.app-content{flex-direction:column}}.sidebar{display:flex;flex:0 0 300px;flex-direction:column;gap:1.5rem}.wheel-container{align-items:center;display:flex;flex:1 1;justify-content:center}.panel{background-color:#fff;background-color:var(--panel-bg);border-radius:8px;border-radius:var(--border-radius);box-shadow:0 4px 6px #0000001a;box-shadow:var(--box-shadow);padding:1.5rem}.panel h2{border-bottom:1px solid #eee;color:#3498db;color:var(--primary-color);font-size:1.5rem;margin-bottom:1rem;margin-top:0;padding-bottom:.5rem}.keyboard-key{background-color:#f1f1f1;border:1px solid #ccc;border-radius:4px;box-shadow:0 1px 1px #0003;display:inline-block;font-family:monospace;font-size:.9rem;margin:0 4px;padding:2px 6px}.controls-info{margin-bottom:1rem}.app-footer{border-top:1px solid #eaeaea;color:#666;margin-top:2rem;padding-top:1rem;text-align:center}.wheel-canvas{border-radius:50%;box-shadow:0 4px 6px #0000001a;box-shadow:var(--box-shadow);display:block;margin:0 auto}
/*# sourceMappingURL=main.35ed2afa.css.map*/