@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;700&display=swap";.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:30px 40px;border-radius:8px;text-align:center;box-shadow:0 4px 8px #00000026;min-width:300px;max-width:90%}.modal-content p{margin:0 0 20px;font-size:16px;color:#333;white-space:pre-line}.modal-content button{padding:10px 25px;border:none;background-color:#003d7e;color:#fff;border-radius:5px;cursor:pointer;font-size:16px;transition:background-color .2s}.modal-content button:hover{background-color:#002a5c}.auth-container{display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:var(--background-color);min-height:80vh}.auth-card{background:var(--light-color);padding:40px 30px;border-radius:12px;box-shadow:var(--box-shadow);text-align:center;width:100%;max-width:380px;margin:20px;border:1px solid var(--border-color)}.auth-logo{max-width:400px;width:90%;margin:40px auto 20px}.auth-description{color:var(--dark-color);margin-bottom:30px;font-size:1rem}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-input{width:100%;padding:12px 15px;border:1px solid var(--border-color);border-radius:8px;font-size:1rem;box-sizing:border-box;background-color:var(--white-color);color:var(--dark-color)}.auth-button{width:100%;padding:12px 15px;border:none;border-radius:8px;background-color:var(--primary-color);color:var(--white-color);font-size:1rem;font-weight:700;cursor:pointer;transition:background-color .2s}.auth-button:hover:not(:disabled){background-color:var(--primary-hover-color)}.auth-button:disabled{background-color:#ccc;cursor:not-allowed}.admin-nav{display:flex;justify-content:center;gap:10px;margin-bottom:20px}.admin-nav-button{padding:8px 16px;border:1px solid #ccc;border-radius:20px;background-color:#f0f0f0;color:#333;text-decoration:none;font-size:14px;transition:all .2s ease-in-out}.admin-nav-button.active,.admin-nav-button:hover{background-color:#007bff;color:#fff;border-color:#007bff}.confirm-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.confirm-modal-content{background:#fff;padding:30px 40px;border-radius:8px;text-align:center;box-shadow:0 4px 8px #00000026;min-width:320px;max-width:90%}.confirm-modal-content p{margin:0 0 25px;font-size:16px;color:#333;white-space:pre-line}.confirm-modal-buttons{display:flex;justify-content:center;gap:15px}.confirm-modal-buttons button{padding:10px 25px;border:none;border-radius:5px;cursor:pointer;font-size:16px;font-weight:500;transition:background-color .2s,box-shadow .2s}.confirm-btn-confirm{background-color:#d32f2f;color:#fff}.confirm-btn-confirm:hover{background-color:#b71c1c;box-shadow:0 2px 4px #0003}.confirm-btn-cancel{background-color:#f0f0f0;color:#333;border:1px solid #ddd}.confirm-btn-cancel:hover{background-color:#e0e0e0}.spinner-container{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000;color:#fff}.spinner{border:8px solid #f3f3f3;border-top:8px solid #3498db;border-radius:50%;width:60px;height:60px;animation:spin 1.5s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.results-page-container{padding:20px 0}.results-container{max-width:800px;margin:0 auto;padding:0 25px}.podium{display:flex;justify-content:center;align-items:flex-end;min-height:380px;margin-bottom:40px;position:relative}.podium-item{display:flex;flex-direction:column;align-items:center;width:130px;margin:0 5px;position:relative}.podium-rank-1{order:2}.podium-rank-2{order:1}.podium-rank-3{order:3}.podium-pedestal{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:60px 15px 15px;box-sizing:border-box;width:100%;border-radius:8px 8px 0 0;box-shadow:0 4px 10px #00000026;animation:riseUp .6s cubic-bezier(.25,.46,.45,.94) forwards;margin-top:-50px;z-index:1}.podium-rank-1 .podium-pedestal{height:220px;background-color:gold;animation-delay:.1s}.podium-rank-2 .podium-pedestal{height:160px;background-color:silver}.podium-rank-3 .podium-pedestal{height:120px;background-color:#cd7f32;animation-delay:.2s}.podium-name,.podium-stats,.podium-percentage{opacity:0;animation:fadeInContent .5s ease-out .7s forwards}.podium-rank-badge{font-size:24px;font-weight:700;border-radius:50%;width:40px;height:40px;display:flex;justify-content:center;align-items:center;border:3px solid white;position:relative;z-index:3;box-shadow:0 2px 6px #00000040;margin-bottom:15px;animation:flipIn .6s ease-out .4s forwards,spin3D 4s linear 1.2s infinite}.podium-rank-1 .podium-rank-badge{background-color:gold;color:#8c6d00}.podium-rank-2 .podium-rank-badge{background-color:silver;color:#5a5a5a}.podium-rank-3 .podium-rank-badge{background-color:#cd7f32;color:#70461c}.podium-image{width:100px;height:100px;border-radius:50%;object-fit:cover;border:4px solid #fff;box-shadow:0 4px 8px #0003;position:relative;z-index:2}.podium-name{font-weight:700;font-size:1.2em;color:var(--dark-color)}[data-theme=dark] .podium-name{color:#fff}.podium-stats{font-size:1em;color:var(--secondary-color);font-weight:500;margin-top:4px}.podium-percentage{font-size:.9em;color:var(--secondary-color)}.others-title{text-align:center;margin-top:40px;margin-bottom:20px;color:var(--dark-color);font-size:1.5em;font-weight:600}.others-list{display:flex;flex-direction:column;gap:7px}.result-item-new{display:flex;align-items:center;background-color:var(--light-color);border-radius:10px;padding:12px 15px;box-shadow:0 2px 5px #00000012;transition:transform .2s ease,box-shadow .2s ease;animation:fadeIn .5s ease-out forwards;border:1px solid var(--border-color)}.result-item-new:hover{transform:translateY(-3px);box-shadow:0 5px 12px #0000001a}.result-rank{font-size:1.3em;font-weight:700;color:var(--secondary-color);width:40px;text-align:center;flex-shrink:0}.result-image{width:50px;height:50px;border-radius:50%;object-fit:cover;margin:0 15px;border:2px solid var(--border-color);flex-shrink:0}.result-info{flex-grow:1;display:flex;flex-direction:column;justify-content:center;min-width:0}.result-name{font-size:1.1em;font-weight:600;color:var(--dark-color);margin-bottom:5px}.result-bar-container{width:100%;height:8px;background-color:var(--border-color);border-radius:4px;overflow:hidden}.result-bar{height:100%;background:linear-gradient(90deg,#4facfe,#00f2fe);border-radius:4px;transition:width .5s ease-in-out}.result-votes{font-size:1.1em;font-weight:700;color:var(--dark-color);min-width:60px;text-align:right;margin-left:15px;flex-shrink:0}.info-box{width:98%;padding:10px 0;margin:20px 0 10px;background-color:var(--light-color);border-left:4px solid var(--primary-color);border-right:4px solid var(--primary-color);color:var(--dark-color);font-size:.9rem;border-radius:4px;text-align:center;font-weight:700}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes flipIn{0%{transform:perspective(400px) rotateY(90deg);opacity:0}to{transform:perspective(400px) rotateY(0);opacity:1}}@keyframes spin3D{0%{transform:perspective(400px) rotateY(0)}to{transform:perspective(400px) rotateY(360deg)}}@keyframes riseUp{0%{height:0}}@keyframes fadeInContent{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}:root{--primary-color: #007bff;--primary-hover-color: #0056b3;--secondary-color: #6c757d;--success-color: #28a745;--danger-color: #dc3545;--warning-color: #ffc107;--light-color: #f8f9fa;--dark-color: #343a40;--background-color: #f4f7f9;--white-color: #ffffff;--border-color: #dee2e6;--font-family: "Noto Sans KR", sans-serif;--border-radius: 8px;--box-shadow: 0 4px 12px rgba(0, 0, 0, .08);--selected-bg-color: #f0f8ff;--selected-shadow-color: rgba(0, 123, 255, .25)}[data-theme=holiday]{--primary-color: #e62e2e;--primary-hover-color: #c00f0f;--secondary-color: #1b5e20;--success-color: #2e7d32;--danger-color: #d32f2f;--warning-color: #ffb300;--light-color: #fff0f0;--dark-color: #2d1a1a;--background-color: #ebf5ee;--white-color: #ffffff;--border-color: #ffCDD2;--box-shadow: 0 4px 16px rgba(211, 47, 47, .25);--selected-bg-color: #fff0f0;--selected-shadow-color: rgba(230, 46, 46, .2)}[data-theme=dark]{--primary-color: #3f9eff;--primary-hover-color: #0078d4;--secondary-color: #aeb9be;--success-color: #4caf50;--danger-color: #f44336;--warning-color: #ffca28;--light-color: #2d2d2d;--dark-color: #e0e0e0;--background-color: #121212;--white-color: #1e1e1e;--border-color: #444444;--box-shadow: 0 4px 12px rgba(0, 0, 0, .4);--selected-bg-color: #383838;--selected-shadow-color: rgba(63, 158, 255, .3)}body{font-family:var(--font-family);background-color:var(--background-color);color:var(--dark-color);line-height:1.6;margin:0}#root{max-width:960px;margin:0 auto;padding:20px}header{background:var(--white-color);padding:20px 30px;border-radius:var(--border-radius);box-shadow:var(--box-shadow);margin-bottom:30px}header h1{text-align:center;color:var(--primary-color);margin:0 0 15px;font-weight:700}.header-logo{text-align:center;margin-bottom:15px}.header-logo img{max-width:100%;height:auto;max-height:80px}nav ul{list-style:none;padding:0;display:flex;justify-content:center;gap:15px;margin:0}nav a{text-decoration:none;color:var(--primary-color);font-weight:500;padding:8px 15px;border-radius:20px;transition:background-color .3s,color .3s}nav a:hover{background-color:var(--primary-color);color:var(--white-color)}main{background:var(--white-color);padding:30px;border-radius:var(--border-radius);box-shadow:var(--box-shadow)}.candidate-image{width:100px;height:100px;border-radius:var(--border-radius);object-fit:cover;margin-right:20px;border:2px solid var(--border-color)}.candidate-image.small{width:60px;height:60px}.candidate-list{list-style:none;padding:0;display:grid;gap:20px}.candidate-item{position:relative;display:flex;align-items:center;padding:15px;border:1px solid var(--border-color);border-radius:var(--border-radius);transition:all .3s ease;cursor:pointer;overflow:hidden}.candidate-item:hover{transform:translateY(-3px);box-shadow:0 6px 16px #0000001a;background-color:var(--light-color)}.candidate-item.selected{border-color:var(--primary-color);box-shadow:0 0 0 3px var(--selected-shadow-color);background-color:var(--selected-bg-color)}.candidate-info{flex-grow:1}.candidate-info h3{margin:0 0 5px}.candidate-info p{margin:0;color:var(--secondary-color)}button{background-color:var(--primary-color);color:var(--white-color);border:none;padding:12px 25px;border-radius:25px;cursor:pointer;font-size:1em;font-weight:500;transition:background-color .3s,box-shadow .3s;font-family:var(--font-family)}button:hover{background-color:var(--primary-hover-color);box-shadow:0 4px 8px #007bff4d}button:disabled{background-color:#ced4da;cursor:not-allowed;box-shadow:none}button.final-submit{background-color:var(--danger-color)}button.final-submit:hover{background-color:#c82333;box-shadow:0 4px 8px #dc35454d}.vote-actions{text-align:center;margin-bottom:30px;padding:20px;background-color:var(--light-color);border-radius:var(--border-radius);border:1px solid var(--border-color)}.admin-section{text-align:center;margin-top:30px}.selected-candidate{margin:0 0 15px;font-size:1.2em;font-weight:500;color:var(--dark-color)}.live-status{text-align:center;margin-top:20px;padding:10px;border-radius:var(--border-radius)}.live-status.visible{background-color:#e9f7ef;color:#155724}.live-status.hidden{background-color:#f8d7da;color:#721c24}.final-submitted-message{text-align:center;font-weight:700;color:var(--success-color);font-size:1.2em}.checkmark{position:absolute;top:-1px;right:-1px;width:30px;height:30px;background-color:var(--primary-color);color:var(--white-color);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;border-bottom-left-radius:var(--border-radius);box-shadow:-2px 2px 5px #0000001a}.result-item{display:flex;align-items:center;padding:15px;background-color:var(--light-color);border-radius:var(--border-radius)}.rank{font-size:1.8em;font-weight:700;color:var(--secondary-color);width:50px;text-align:center}.progress-bar-container{flex-grow:1;height:28px;background-color:#e9ecef;border-radius:14px;overflow:hidden}.progress-bar{height:100%;background-color:var(--success-color);color:#fff;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;font-weight:500;white-space:nowrap;transition:width .6s ease-in-out}.result-item h3{margin:0 0 8px}.admin-section button{background-color:var(--warning-color);color:var(--dark-color)}.admin-section button:hover{background-color:#e0a800;box-shadow:0 4px 8px #ffc1074d}@media (max-width: 768px){body,#root{padding:0}header,main{margin:0;border-radius:0;padding:20px;box-shadow:none;border-bottom:1px solid var(--border-color)}header h1{font-size:1.8em}nav ul{gap:10px}nav a{padding:6px 12px}.candidate-list{grid-template-columns:repeat(2,1fr);gap:15px}.candidate-item{flex-direction:column;text-align:center;padding:10px}.candidate-image{margin-right:0;margin-bottom:10px;width:100%;height:auto;aspect-ratio:4 / 3;object-fit:cover}.candidate-item .vote-actions{margin-top:15px}.result-item{flex-direction:column;align-items:flex-start}.rank{align-self:flex-end;order:1}.result-item .candidate-image.small{order:2;align-self:center;margin-bottom:10px}.result-item div:nth-of-type(1){order:3;width:100%}.result-item span:nth-of-type(2){order:4;align-self:flex-end;margin-top:5px}}.admin-nav{display:flex;justify-content:center;gap:10px;margin-bottom:30px}.admin-nav-button{padding:10px 20px;border:1px solid #0033a0;background-color:#fff;color:#0033a0;border-radius:5px;text-decoration:none;font-weight:700}.vote-info-box{width:100%;padding:10px 15px;margin:20px 0 10px;background-color:#eef2f7;border-left:4px solid #4a90e2;border-right:4px solid #4a90e2;color:#333;font-size:.9rem;border-radius:4px;text-align:center;font-weight:700}
