*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #0D4E8C;--primary-light: #1A6BB5;--primary-lighter: #E3F2FD;--secondary-color: #4FC3F7;--accent-color: #FFD54F;--success-color: #66BB6A;--background-gradient: linear-gradient(135deg, #E3F2FD 0%, #BBDEFB 50%, #90CAF9 100%)}body{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-x:hidden;background:var(--background-gradient)}.navbar{position:fixed;top:0;left:0;right:0;height:70px;background:#fff;box-shadow:0 2px 15px #0d4e8c1a;display:flex;justify-content:space-between;align-items:center;padding:0 30px;z-index:100}.nav-logo{font-size:1.5rem;font-weight:800;color:var(--primary-color);cursor:pointer;display:flex;align-items:center;gap:10px}.nav-logo-icon{font-size:2rem}.nav-menu{display:flex;gap:30px;align-items:center}.nav-item{font-size:1rem;font-weight:600;color:#4a5568;cursor:pointer;transition:all .3s ease;padding:8px 16px;border-radius:8px}.nav-item:hover,.nav-item.active{color:var(--primary-color);background:var(--primary-lighter)}.nav-user{display:flex;align-items:center;gap:15px}.user-info{display:flex;flex-direction:column;align-items:flex-end}.user-name{font-size:.9rem;font-weight:600;color:#2d3748}.user-stamps{font-size:.8rem;color:var(--primary-color);font-weight:600}.user-avatar{width:45px;height:45px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);display:flex;justify-content:center;align-items:center;color:#fff;font-weight:700;cursor:pointer;font-size:1.2rem}.login-button{padding:10px 25px;background:var(--primary-color);color:#fff;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease}.login-button:hover{background:var(--primary-light);transform:translateY(-2px);box-shadow:0 5px 15px #0d4e8c4d}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:70px;background:#fff;box-shadow:0 -2px 15px #0d4e8c1a;display:none;justify-content:space-around;align-items:center;z-index:100}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;transition:all .3s ease;padding:10px 20px;border-radius:10px}.bottom-nav-item.active{background:var(--primary-lighter)}.bottom-nav-icon{font-size:1.5rem}.bottom-nav-label{font-size:.75rem;font-weight:600;color:#4a5568}.bottom-nav-item.active .bottom-nav-label{color:var(--primary-color)}.hero-section{position:relative;width:100%;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;background:var(--background-gradient);overflow:hidden;margin-top:70px;padding:40px 20px}.hero-content{width:100%;max-width:1200px;display:flex;flex-direction:column;align-items:center;z-index:2}.hero-title-section{text-align:center;margin-bottom:40px;animation:fadeInDown 1s ease-out}.hero-logo{width:150px;height:150px;margin:0 auto 20px;background:#fff;border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 10px 40px #0d4e8c33}.hero-logo-text{font-size:2rem;font-weight:800;color:var(--primary-color)}.hero-main-title{font-size:3rem;font-weight:800;color:var(--primary-color);margin-bottom:15px;text-shadow:2px 2px 4px rgba(255,255,255,.5)}.hero-subtitle{font-size:1.3rem;color:#2d3748;font-weight:500}.hero-image-container{width:100%;max-width:900px;border-radius:30px;overflow:hidden;box-shadow:0 30px 60px #0d4e8c4d;background:#fff;padding:20px;animation:fadeInUp 1s ease-out}.hero-image{width:100%;height:auto;border-radius:20px}.scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--primary-color);animation:bounce 2s infinite;cursor:pointer;z-index:3;font-weight:600}.scroll-arrow{width:30px;height:30px;border:3px solid var(--primary-color);border-top:none;border-left:none;transform:rotate(45deg)}.deco-circle:nth-child(1){width:100px;height:100px;top:10%;left:5%;animation-delay:0s}.deco-circle:nth-child(2){width:150px;height:150px;top:60%;right:10%;animation-delay:2s}.deco-circle:nth-child(3){width:80px;height:80px;bottom:15%;left:15%;animation-delay:4s}.deco-circle:nth-child(4){width:120px;height:120px;top:30%;right:20%;animation-delay:6s}.stamp-section{min-height:100vh;background:linear-gradient(180deg,#e3f2fd,#fff);padding:80px 20px 100px}.stamp-container{max-width:1200px;width:100%;margin:0 auto}.stamp-header{text-align:center;margin-bottom:60px;animation:fadeInUp 1s ease-out}.stamp-header-bg{background:#fff;border-radius:30px;padding:40px;box-shadow:0 10px 40px #0d4e8c1a;margin-bottom:40px}.stamp-title{font-size:2.5rem;font-weight:800;color:var(--primary-color);margin-bottom:15px}.stamp-subtitle{color:#718096;font-size:1.2rem}.progress-section{background:#fff;padding:30px;border-radius:20px;box-shadow:0 10px 30px #0d4e8c1a;margin-bottom:50px}.progress-bar-container{width:100%;height:50px;background:var(--primary-lighter);border-radius:25px;overflow:hidden;position:relative;margin-bottom:20px;border:3px solid var(--primary-color)}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-color) 0%,var(--primary-light) 100%);transition:width .5s ease;display:flex;justify-content:flex-end;align-items:center;padding-right:20px;color:#fff;font-weight:800;font-size:1.1rem}.progress-text{text-align:center;font-size:1.3rem;font-weight:800;color:#2d3748}.progress-count{color:var(--primary-color);font-size:1.5rem}.stamp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))!important;max-width:1500px;margin:0 auto 50px;gap:25px}.stamp-card{background:#fff;border-radius:25px;padding:30px;box-shadow:0 10px 30px #0d4e8c1a;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden;border:4px solid transparent}.stamp-card:hover{transform:translateY(-10px);box-shadow:0 20px 50px #0d4e8c33}.stamp-card.collected{border-color:var(--primary-color);background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%)}.main-map-section{background:#fff;padding:40px;border-radius:30px;box-shadow:0 20px 60px #0d4e8c26;margin-bottom:50px}.map-header{text-align:center;margin-bottom:25px}.map-title{font-size:1.8rem;font-weight:800;color:var(--primary-color);margin-bottom:10px}.map-subtitle{font-size:1rem;color:#718096}.main-map-container{width:100%;height:500px;border-radius:20px;overflow:hidden;border:4px solid var(--primary-color);box-shadow:0 10px 30px #0d4e8c33}.map-legend{display:flex;justify-content:center;gap:30px;margin-top:20px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:10px;padding:10px 20px;background:var(--primary-lighter);border-radius:12px;font-weight:600;color:var(--primary-color)}.legend-marker{width:20px;height:20px;border-radius:50%}.legend-marker.collected{background:var(--primary-color)}.legend-marker.uncollected{background:#cbd5e0}.legend-marker.current{background:#f56565}.stamp-icon-wrapper{width:120px;height:120px;margin:0 auto 20px;position:relative}.stamp-circle{width:100%;height:100%;border-radius:50%;border:5px solid #cbd5e0;background:#fff;display:flex;flex-direction:column;justify-content:center;align-items:center;transition:all .4s ease;position:relative;box-shadow:0 4px 15px #0000001a}.stamp-card.collected .stamp-circle{border-color:var(--primary-color);background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);animation:stampPulse .6s ease-out;box-shadow:0 8px 25px #0d4e8c66}.stamp-icon{font-size:3rem;margin-bottom:5px;opacity:.3;transition:all .3s ease}.stamp-card.collected .stamp-icon{opacity:1;filter:brightness(0) invert(1)}.stamp-logo-text{font-size:.75rem;font-weight:800;color:#718096;text-align:center;line-height:1.3}.stamp-card.collected .stamp-logo-text{color:#fff}.stamp-location{font-size:1.3rem;font-weight:800;color:var(--primary-color);text-align:center;margin-bottom:8px}.stamp-card.collected .stamp-location{color:#fff}.stamp-building{font-size:.95rem;color:#718096;text-align:center;font-weight:600}.stamp-card.collected .stamp-building{color:#fffffff2}.stamp-check-badge{position:absolute;top:15px;right:15px;width:40px;height:40px;background:var(--success-color);border-radius:50%;display:none;justify-content:center;align-items:center;color:#fff;font-weight:800;font-size:1.3rem;box-shadow:0 4px 15px #66bb6a66}.stamp-card.collected .stamp-check-badge{display:flex;animation:checkPop .5s ease-out}.submit-form-section{background:#fff;padding:50px;border-radius:30px;box-shadow:0 20px 60px #0d4e8c26}.submit-form{display:flex;flex-direction:column;gap:30px}.form-group{display:flex;flex-direction:column;gap:12px}.form-label{font-size:1.1rem;font-weight:700;color:var(--primary-color)}.form-input{padding:18px 25px;border:3px solid var(--primary-lighter);border-radius:15px;font-size:1.1rem;transition:all .3s ease;font-weight:600}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #0d4e8c1a}.submit-button{padding:20px;background:var(--primary-color);color:#fff;border:none;border-radius:15px;font-size:1.3rem;font-weight:800;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 30px #0d4e8c4d}.submit-button:hover{background:var(--primary-light);transform:translateY(-3px);box-shadow:0 15px 40px #0d4e8c66}.submit-button:disabled{background:#cbd5e0;cursor:not-allowed;box-shadow:none;transform:none}.modal-overlay{position:fixed;inset:0;background:#0d4e8cb3;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:#fff;padding:60px 50px;border-radius:30px;text-align:center;max-width:500px;width:90%;animation:scaleIn .3s ease-out;box-shadow:0 30px 80px #0d4e8c66}.modal-icon{font-size:5rem;margin-bottom:25px}.modal-title{font-size:2.2rem;font-weight:800;margin-bottom:20px;color:var(--primary-color)}.modal-text{font-size:1.2rem;color:#4a5568;margin-bottom:35px;line-height:1.8}.modal-button{padding:18px 50px;background:var(--primary-color);color:#fff;border:none;border-radius:15px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease}.modal-button:hover{background:var(--primary-light);transform:translateY(-3px);box-shadow:0 10px 30px #0d4e8c4d}.login-form{display:flex;flex-direction:column;gap:20px;margin-top:30px}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-40px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-15px)}}@keyframes stampPulse{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}@keyframes checkPop{0%{transform:scale(0) rotate(-180deg)}50%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0)}}@media(max-width:768px){.navbar{display:none}.bottom-nav{display:flex}.hero-section{margin-top:0;min-height:auto;padding:60px 15px}.hero-main-title{font-size:2rem}.hero-subtitle{font-size:1rem}.stamp-section{padding:60px 15px 100px}.stamp-title{font-size:1.8rem}.stamp-grid{grid-template-columns:repeat(2,1fr);gap:15px}.stamp-card{padding:20px}.stamp-icon-wrapper{width:90px;height:90px}.stamp-location{font-size:1.1rem}.stamp-building{font-size:.85rem}.submit-form-section{padding:30px 20px}.modal-content{padding:40px 30px}}.login-actions{margin-top:20px;display:flex;justify-content:center;align-items:center;font-size:.9rem;color:#718096}.login-action-link{background:none;border:none;color:#718096;cursor:pointer;padding:5px 10px;font-size:inherit;transition:color .2s}.login-action-link:hover{color:#0d4e8c;text-decoration:underline}.divider{margin:0 5px;color:#cbd5e0;font-size:.8rem}.stamp-image-wrapper-large{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:20px;background:#fff;border-radius:16px;overflow:visible;z-index:5}.stamp-image-large{max-width:140%;max-height:140%;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 6px 16px rgba(0,0,0,.2));animation:stampAppearLarge .6s ease-out;position:relative;z-index:6}@keyframes stampAppearLarge{0%{opacity:0;transform:scale(.5) rotate(-15deg)}50%{transform:scale(1.15) rotate(5deg)}to{opacity:1;transform:scale(1) rotate(0)}}.stamp-card.collected{position:relative;background:#fff;border:4px solid #0D4E8C;box-shadow:0 12px 32px #0d4e8c59;transform:translateY(-6px)}.stamp-card.collected:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 16px 40px #0d4e8c73}.stamp-card{position:relative;overflow:visible!important}.stamp-card.collected .stamp-location,.stamp-card.collected .stamp-building{position:relative;z-index:10;background:#fff;padding:4px 8px;border-radius:6px;margin-top:8px}.stamp-card.collected .stamp-check-badge{display:flex;align-items:center;justify-content:center;position:absolute;top:-8px;right:-8px;width:48px;height:48px;background:#0d4e8c;color:#fff;border-radius:50%;font-size:1.5rem;font-weight:700;box-shadow:0 6px 20px #0d4e8c80;z-index:15;border:4px solid white}.stamp-card:not(.collected) .stamp-check-badge{display:none}@media(max-width:768px){.stamp-image-large{max-width:130%;max-height:130%}.stamp-card.collected .stamp-check-badge{width:40px;height:40px;font-size:1.3rem}}.stamp-card.collected{background:#fff!important;border:4px solid #0D4E8C!important;box-shadow:0 12px 35px #0d4e8c40;overflow:visible}.stamp-card.collected:hover{transform:translateY(-8px);box-shadow:0 18px 45px #0d4e8c59}.stamp-collected-content{width:100%;display:flex;justify-content:center;align-items:center;padding:10px;min-height:140px}.stamp-image-collected{max-width:120px;max-height:120px;width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(13,78,140,.3));animation:stampBounce .5s ease-out}.stamp-info-collected{text-align:center;margin-top:10px}.stamp-info-collected .stamp-location{color:#0d4e8c!important;font-size:1.2rem;font-weight:700}.stamp-info-collected .stamp-building{color:#4a5568!important;font-size:.9rem}.stamp-card.collected .stamp-check-badge{display:flex!important;position:absolute;top:-10px;right:-10px;width:42px;height:42px;background:#0d4e8c;color:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;font-weight:700;box-shadow:0 4px 15px #0d4e8c80;border:3px solid white;z-index:10;animation:checkPop .4s ease-out}@keyframes stampBounce{0%{opacity:0;transform:scale(.3) rotate(-10deg)}60%{transform:scale(1.1) rotate(3deg)}to{opacity:1;transform:scale(1) rotate(0)}}@media(max-width:768px){.stamp-collected-content{min-height:100px}.stamp-image-collected{max-width:90px;max-height:90px}.stamp-info-collected .stamp-location{font-size:1rem}.stamp-card.collected .stamp-check-badge{width:36px;height:36px;font-size:1.2rem;top:-8px;right:-8px}}.map-section{margin-top:60px;padding-top:40px;border-top:3px solid #E3F2FD}.map-header-box{text-align:center;margin-bottom:20px}.map-title{font-size:2rem;font-weight:800;color:#0d4e8c;margin-bottom:10px}.map-subtitle{font-size:1.1rem;color:#718096}.congestion-legend{display:flex;justify-content:center;gap:20px;margin-bottom:20px;padding:12px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 10px #00000014}.selected-booth-panel{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:20px 25px;border-radius:15px;box-shadow:0 4px 20px #0d4e8c26;margin-bottom:20px;border:3px solid #0D4E8C;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.selected-booth-info{display:flex;align-items:center;gap:15px}.booth-icon{width:50px;height:50px;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:1.5rem}.booth-details{display:flex;flex-direction:column}.booth-name{font-size:1.2rem;font-weight:700;color:#2d3748}.booth-building{font-size:.9rem;color:#718096}.close-panel-btn{width:36px;height:36px;background:#edf2f7;border:none;border-radius:50%;font-size:1.1rem;cursor:pointer;color:#718096;transition:all .2s}.close-panel-btn:hover{background:#e2e8f0;color:#2d3748}@media(max-width:768px){.map-section{margin-top:40px;padding-top:30px}.map-title{font-size:1.5rem}.map-subtitle{font-size:1rem}.congestion-legend{flex-wrap:wrap;gap:12px;padding:10px 15px}.legend-item{font-size:.8rem}.selected-booth-panel{padding:15px 20px}.booth-icon{width:40px;height:40px;font-size:1.2rem}.booth-name{font-size:1rem}}.profile-dropdown-container{position:relative;display:flex;align-items:center;gap:12px}.user-avatar{cursor:pointer;transition:transform .2s,box-shadow .2s}.user-avatar:hover{transform:scale(1.05);box-shadow:0 4px 12px #0d4e8c4d}.profile-dropdown-menu{position:absolute;top:calc(100% + 10px);right:0;background:#fff;border-radius:16px;box-shadow:0 10px 40px #00000026;min-width:220px;z-index:1000;overflow:hidden;animation:dropdownFadeIn .2s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{padding:16px 20px;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);color:#fff}.dropdown-user-name{font-size:1.1rem;font-weight:700}.dropdown-user-id{font-size:.85rem;opacity:.85;margin-top:4px}.dropdown-divider{height:1px;background:#e2e8f0}.dropdown-item{display:flex;align-items:center;gap:12px;padding:14px 20px;cursor:pointer;transition:background .2s;font-size:.95rem;color:#2d3748}.dropdown-item:hover{background:#f7fafc}.dropdown-item.admin{color:#0d4e8c;font-weight:600}.dropdown-item.admin:hover{background:#ebf8ff}.dropdown-item.logout{color:#e53e3e}.dropdown-item.logout:hover{background:#fff5f5}.dropdown-icon{font-size:1.2rem}.mobile-profile-overlay{position:fixed;inset:0;background:#00000080;z-index:2000;animation:overlayFadeIn .2s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.mobile-profile-menu{position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:24px 24px 0 0;padding-bottom:30px;animation:slideUpMenu .3s ease-out}@keyframes slideUpMenu{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-menu-header{display:flex;align-items:center;gap:15px;padding:25px 20px;border-bottom:1px solid #E2E8F0}.mobile-user-avatar{width:55px;height:55px;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700}.mobile-user-info{flex:1}.mobile-user-name{font-size:1.2rem;font-weight:700;color:#2d3748}.mobile-user-id{font-size:.9rem;color:#718096;margin-top:4px}.mobile-menu-close{width:36px;height:36px;background:#edf2f7;border:none;border-radius:50%;font-size:1.1rem;cursor:pointer;color:#718096}.mobile-menu-stats{display:flex;padding:20px;gap:20px}.mobile-stat{flex:1;text-align:center;padding:15px;background:#f7fafc;border-radius:12px}.mobile-stat-value{font-size:1.8rem;font-weight:800;color:#0d4e8c}.mobile-stat-label{font-size:.85rem;color:#718096;margin-top:5px}.mobile-menu-items{padding:0 15px}.mobile-menu-item{display:flex;align-items:center;gap:15px;padding:18px 15px;border-radius:12px;cursor:pointer;transition:background .2s;font-size:1rem;color:#2d3748}.mobile-menu-item:hover{background:#f7fafc}.mobile-menu-item.admin{color:#0d4e8c;font-weight:600}.mobile-menu-item.admin:hover{background:#ebf8ff}.mobile-menu-item.logout{color:#e53e3e}.mobile-menu-item.logout:hover{background:#fff5f5}.mobile-menu-icon{font-size:1.3rem}.mobile-menu-arrow{margin-left:auto;font-size:1.2rem;color:#cbd5e0}@media(min-width:769px){.mobile-profile-overlay{display:none}}@media(max-width:768px){.profile-dropdown-menu{display:none}}.completion-banner{background:linear-gradient(135deg,gold,orange,#ff8c00);border-radius:20px;padding:25px 30px;margin-bottom:30px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 8px 32px #ffa5004d;animation:celebrationPulse 2s ease-in-out infinite}@keyframes celebrationPulse{0%,to{transform:scale(1)}50%{transform:scale(1.01)}}.completion-banner-content{display:flex;align-items:center;gap:20px}.completion-trophy{font-size:3.5rem;animation:trophyBounce 1s ease-in-out infinite}@keyframes trophyBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.completion-text{color:#fff}.completion-title{font-size:1.5rem;font-weight:700;margin:0 0 5px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.completion-date{font-size:1rem;margin:0;opacity:.9}.certificate-button{background:#fff;color:#ff8c00;border:none;padding:14px 28px;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #00000026}.certificate-button:hover{transform:translateY(-3px);box-shadow:0 6px 20px #0003}.progress-bar-container.completed{border:2px solid #FFD700}.progress-bar-fill.completed{background:linear-gradient(90deg,gold,orange,#ff8c00)}.progress-count.completed{color:#ff8c00;font-weight:700}.completed-badge{background:linear-gradient(135deg,gold,orange);color:#fff;padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:600;margin-left:12px;animation:badgeGlow 1.5s ease-in-out infinite}@keyframes badgeGlow{0%,to{box-shadow:0 0 5px #ffa50080}50%{box-shadow:0 0 15px #ffa500cc}}.stamp-grid.completed{position:relative}.stamp-card.all-completed{border:2px solid #FFD700;box-shadow:0 4px 15px #ffd7004d}.completion-buttons{display:flex;flex-direction:column;gap:15px;align-items:center}.submit-button.completed{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;cursor:default;opacity:1!important}.submit-button.completed:hover{transform:none}.certificate-download-button{background:linear-gradient(135deg,gold,orange);color:#fff;border:none;padding:18px 50px;border-radius:16px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 20px #ffa50066}.certificate-download-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #ffa50080}@media(max-width:768px){.completion-banner{flex-direction:column;text-align:center;gap:20px;padding:20px}.completion-banner-content{flex-direction:column}.completion-trophy{font-size:3rem}.completion-title{font-size:1.2rem}.certificate-button{width:100%;padding:12px 20px}.completion-buttons{width:100%}.certificate-download-button{width:100%;padding:16px 30px;font-size:1.1rem}}.kakao-map-container{position:relative;width:100%;border-radius:20px;overflow:hidden;box-shadow:0 10px 40px #0d4e8c33}.kakao-map{width:100%;border-radius:20px}.kakao-map-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-radius:20px;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid #E3F2FD;border-top:4px solid #0D4E8C;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{color:#0d4e8c;font-weight:600;font-size:1.1rem}.kakao-map-error{display:flex;flex-direction:column;justify-content:center;align-items:center;background:#fee2e2;border-radius:20px;gap:15px;padding:40px}.error-icon{font-size:3rem}.error-message{color:#c53030;font-weight:700;font-size:1.2rem;text-align:center}.error-hint{color:#742a2a;font-size:.9rem;text-align:center}.custom-marker{display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:transform .2s ease}.custom-marker:hover{transform:scale(1.1)}.marker-icon{width:50px;height:50px;background:var(--marker-color, #0D4E8C);border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:1.5rem;box-shadow:0 4px 15px #0000004d;border:3px solid white}.marker-label{background:#fff;padding:6px 12px;border-radius:8px;font-size:.85rem;font-weight:700;color:#2d3748;margin-top:8px;box-shadow:0 2px 10px #00000026;white-space:nowrap;max-width:120px;overflow:hidden;text-overflow:ellipsis}.congestion-badge{position:absolute;top:-5px;right:-5px;padding:3px 8px;border-radius:10px;font-size:.7rem;font-weight:800;color:#fff;box-shadow:0 2px 8px #0003}.current-location-marker{position:relative;width:20px;height:20px}.current-location-marker .dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:#4285f4;border-radius:50%;border:3px solid white;box-shadow:0 2px 10px #4285f480;z-index:2}.current-location-marker .pulse{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;background:#4285f44d;border-radius:50%;animation:pulse 2s infinite;z-index:1}@keyframes pulse{0%{transform:translate(-50%,-50%) scale(.5);opacity:1}to{transform:translate(-50%,-50%) scale(1.5);opacity:0}}.route-marker{padding:8px 14px;border-radius:20px;font-size:.85rem;font-weight:700;color:#fff;box-shadow:0 3px 10px #0003}.route-marker.start{background:#48bb78}.route-marker.end{background:#e53e3e}.route-info-panel{position:absolute;top:15px;left:15px;background:#fff;padding:15px 20px;border-radius:15px;box-shadow:0 4px 20px #00000026;z-index:10;min-width:200px}.route-destination{font-size:1.1rem;font-weight:800;color:#0d4e8c;margin-bottom:10px;padding-bottom:10px;border-bottom:2px solid #E3F2FD}.route-details{display:flex;gap:20px}.route-distance,.route-time{font-size:.95rem;font-weight:600;color:#4a5568}.current-location-btn{position:absolute;bottom:20px;right:20px;width:50px;height:50px;background:#fff;border:none;border-radius:50%;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 15px #0003;transition:all .3s ease;z-index:10;display:flex;justify-content:center;align-items:center}.current-location-btn:hover{transform:scale(1.1);box-shadow:0 6px 20px #00000040}.current-location-btn:active{transform:scale(.95)}@media(max-width:768px){.kakao-map-container,.kakao-map{border-radius:15px}.route-info-panel{top:10px;left:10px;right:10px;min-width:auto;padding:12px 15px}.route-destination{font-size:1rem}.route-details{gap:15px}.route-distance,.route-time{font-size:.9rem}.marker-icon{width:40px;height:40px;font-size:1.2rem}.marker-label{font-size:.75rem;padding:4px 10px}.current-location-btn{width:45px;height:45px;font-size:1.3rem;bottom:15px;right:15px}}:root{--primary-color: #0D4E8C;--primary-light: #1A6BB5;--primary-lighter: #E3F2FD;--success-color: #66BB6A}.modal-overlay{position:fixed;inset:0;background:#0d4e8ccc;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-content{background:#fff;padding:60px 50px;border-radius:30px;text-align:center;max-width:500px;width:90%;animation:scaleIn .3s ease-out;box-shadow:0 30px 80px #0d4e8c66;position:relative;max-height:90vh;overflow-y:auto}.modal-close{position:absolute;top:20px;right:20px;width:40px;height:40px;border-radius:50%;background:var(--primary-lighter);border:none;cursor:pointer;display:flex;justify-content:center;align-items:center;font-size:1.5rem;color:var(--primary-color);transition:all .3s ease}.modal-close:hover{background:var(--primary-color);color:#fff;transform:rotate(90deg)}.signup-modal-content{max-width:550px}.signup-steps{display:flex;justify-content:space-between;margin-bottom:40px;position:relative}.signup-steps:before{content:"";position:absolute;top:20px;left:0;right:0;height:3px;background:#e2e8f0;z-index:0}.signup-step{width:40px;height:40px;border-radius:50%;background:#e2e8f0;color:#cbd5e0;display:flex;justify-content:center;align-items:center;font-weight:800;font-size:1rem;position:relative;z-index:1;transition:all .3s ease}.signup-step.active{background:var(--primary-color);color:#fff;transform:scale(1.2);box-shadow:0 5px 15px #0d4e8c4d}.signup-step.completed{background:var(--success-color);color:#fff}.signup-step-label{position:absolute;bottom:-25px;left:50%;transform:translate(-50%);font-size:.75rem;white-space:nowrap;color:#718096;font-weight:600}.signup-step.active .signup-step-label{color:var(--primary-color)}.signup-form-section{min-height:350px;animation:fadeInUp .4s ease-out}.signup-title{font-size:1.5rem;font-weight:800;color:var(--primary-color);margin-bottom:10px;text-align:center}.signup-subtitle{font-size:.95rem;color:#718096;margin-bottom:30px;text-align:center}.login-label{display:block;font-size:.9rem;font-weight:600;color:var(--primary-color);margin-bottom:8px;padding-left:5px}.login-input-icon{position:absolute;left:18px;bottom:18px;font-size:1.3rem;color:var(--primary-color);z-index:1}.input-with-button{display:flex;gap:10px}.input-with-button input{flex:1}.check-button{padding:16px 24px;background:var(--primary-color);color:#fff;border:none;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s ease;white-space:nowrap;font-size:.95rem}.check-button:hover{background:var(--primary-light);transform:translateY(-2px)}.check-button:disabled{background:#cbd5e0;cursor:not-allowed;transform:none}.check-button.verified{background:var(--success-color)}.password-strength{margin-top:10px;padding:10px;border-radius:8px;font-size:.85rem;font-weight:600}.password-strength.weak{background:#fed7d7;color:#c53030}.password-strength.medium{background:#feebc8;color:#c05621}.password-strength.strong{background:#c6f6d5;color:#2f855a}.verification-info{background:var(--primary-lighter);padding:15px;border-radius:12px;margin-top:10px;font-size:.9rem;color:var(--primary-color);font-weight:600}.radio-group{display:flex;gap:15px;margin-top:10px}.radio-option{flex:1;position:relative}.radio-option input[type=radio]{position:absolute;opacity:0}.radio-label{display:block;padding:15px;border:3px solid var(--primary-lighter);border-radius:12px;text-align:center;font-weight:700;color:#4a5568;cursor:pointer;transition:all .3s ease}.radio-option input[type=radio]:checked+.radio-label{border-color:var(--primary-color);background:var(--primary-lighter);color:var(--primary-color)}select.login-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%230D4E8C' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 20px center;padding-right:50px}.signup-nav-buttons{display:flex;gap:15px;margin-top:40px}.signup-nav-button{flex:1;padding:16px;border:none;border-radius:12px;font-weight:700;font-size:1.05rem;cursor:pointer;transition:all .3s ease}.signup-nav-button.prev{background:#fff;color:var(--primary-color);border:2px solid var(--primary-color)}.signup-nav-button.prev:hover{background:var(--primary-lighter)}.signup-nav-button.next{background:var(--primary-color);color:#fff}.signup-nav-button.next:hover{background:var(--primary-light);transform:translateY(-2px)}.signup-nav-button:disabled{background:#cbd5e0;color:#fff;cursor:not-allowed;transform:none;border:none}.success-animation{text-align:center;padding:40px 0}.success-checkmark{width:100px;height:100px;margin:0 auto 30px;border-radius:50%;background:var(--success-color);display:flex;justify-content:center;align-items:center;font-size:3rem;color:#fff;animation:bounceIn .6s ease-out}@keyframes scaleIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}@media(max-width:768px){.modal-content{padding:40px 25px;max-width:95%}.form-row{grid-template-columns:1fr}.signup-steps{margin-bottom:50px}.signup-step-label{font-size:.7rem}.login-input{font-size:1rem;padding:14px 18px 14px 45px}.check-button{padding:14px 18px;font-size:.85rem}}:root{--primary-color: #0D4E8C;--primary-light: #1A6BB5;--primary-lighter: #E3F2FD;--success-color: #66BB6A;--warning-color: #FFA726}.forgot-password-modal{max-width:500px;padding:50px 40px}.forgot-password-steps{display:flex;justify-content:center;align-items:center;margin-bottom:40px;gap:0}.forgot-password-step{width:50px;height:50px;border-radius:50%;background:#e2e8f0;color:#cbd5e0;display:flex;justify-content:center;align-items:center;font-weight:800;font-size:1.2rem;transition:all .3s ease;z-index:2}.forgot-password-step.active{background:var(--primary-color);color:#fff;transform:scale(1.1);box-shadow:0 5px 20px #0d4e8c66}.forgot-password-step.completed{background:var(--success-color);color:#fff}.forgot-password-line{width:80px;height:3px;background:#e2e8f0;z-index:1}.forgot-password-header{text-align:center;margin-bottom:35px}.forgot-password-icon{width:80px;height:80px;margin:0 auto 20px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:2.5rem;box-shadow:0 10px 30px #0d4e8c4d;animation:bounceIn .6s ease-out}.forgot-password-title{font-size:1.8rem;font-weight:800;color:var(--primary-color);margin-bottom:12px}.forgot-password-subtitle{font-size:1rem;color:#718096;line-height:1.6}.forgot-password-section{animation:fadeInUp .4s ease-out}.forgot-password-form{margin-bottom:25px}.login-input-group{margin-bottom:20px;text-align:left}.login-label{display:block;font-size:.95rem;font-weight:600;color:var(--primary-color);margin-bottom:8px;padding-left:5px}.login-input-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);font-size:1.3rem;color:var(--primary-color);z-index:1;margin-top:18px}.forgot-password-button{width:100%;padding:18px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);color:#fff;border:none;border-radius:15px;font-size:1.15rem;font-weight:800;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 30px #0d4e8c4d;margin-bottom:12px}.forgot-password-button:hover{transform:translateY(-3px);box-shadow:0 15px 40px #0d4e8c66}.forgot-password-button:disabled{background:#cbd5e0;cursor:not-allowed;transform:none;box-shadow:none}.forgot-password-button-secondary{width:100%;padding:16px;background:#fff;color:var(--primary-color);border:2px solid var(--primary-color);border-radius:15px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .3s ease}.forgot-password-button-secondary:hover{background:var(--primary-lighter);transform:translateY(-2px)}.forgot-password-back{width:100%;padding:14px;background:transparent;color:#718096;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:15px}.forgot-password-back:hover{background:#f7fafc;color:var(--primary-color)}.forgot-password-info{background:var(--primary-lighter);padding:18px;border-radius:15px;margin-top:20px}.forgot-password-info p{font-size:.9rem;color:var(--primary-color);font-weight:600;margin:8px 0;line-height:1.5}.forgot-password-success{text-align:center;padding:20px 0}.success-checkmark{width:100px;height:100px;margin:0 auto 30px;border-radius:50%;background:var(--success-color);display:flex;justify-content:center;align-items:center;font-size:3.5rem;color:#fff;animation:bounceIn .6s ease-out;box-shadow:0 15px 40px #66bb6a66}.forgot-password-notice{background:#fff8e1;border:2px solid var(--warning-color);border-radius:15px;padding:25px;margin:30px 0;text-align:left}.forgot-password-notice h4{font-size:1.1rem;font-weight:800;color:#f57c00;margin-bottom:15px}.forgot-password-notice ol{margin:0;padding-left:20px;color:#4a5568;font-weight:600}.forgot-password-notice li{margin-bottom:10px;line-height:1.6}@keyframes bounceIn{0%{transform:scale(.3);opacity:0}50%{transform:scale(1.05)}70%{transform:scale(.9)}to{transform:scale(1);opacity:1}}@media(max-width:768px){.forgot-password-modal{padding:40px 25px;max-width:95%}.forgot-password-icon{width:70px;height:70px;font-size:2rem}.forgot-password-title{font-size:1.5rem}.forgot-password-subtitle{font-size:.95rem}.forgot-password-line{width:50px}.login-input{font-size:1rem;padding:14px 18px 14px 45px}.forgot-password-button{font-size:1.05rem;padding:16px}.forgot-password-notice{padding:20px}.forgot-password-notice h4{font-size:1rem}.forgot-password-notice ol{font-size:.9rem}}:root{--primary-color: #0D4E8C;--primary-light: #1A6BB5;--primary-lighter: #E3F2FD}.login-page{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#e3f2fd,#bbdefb,#90caf9);padding:20px}.login-container{width:100%;max-width:450px}.login-card{background:#fff;border-radius:30px;padding:50px 40px;box-shadow:0 30px 80px #0d4e8c4d;animation:fadeInUp .6s ease-out}.login-header{text-align:center;margin-bottom:40px}.login-logo{width:100px;height:100px;margin:0 auto 20px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:3rem;box-shadow:0 10px 30px #0d4e8c4d}.login-title{font-size:1.8rem;font-weight:800;color:var(--primary-color);margin-bottom:8px}.login-subtitle{font-size:1.1rem;color:#718096;font-weight:600}.error-banner{background:#fed7d7;border:2px solid #fc8181;border-radius:15px;padding:15px 20px;margin-bottom:25px;color:#c53030;font-weight:600;font-size:.95rem;animation:shake .5s ease-in-out}.login-form{display:flex;flex-direction:column;gap:20px;margin-bottom:25px}.login-input-group{text-align:left}.login-label{display:block;font-size:.95rem;font-weight:700;color:var(--primary-color);margin-bottom:10px;padding-left:5px}.login-input{width:100%;padding:16px 20px 16px 50px;border:3px solid var(--primary-lighter);border-radius:15px;font-size:1.1rem;transition:all .3s ease;font-weight:600;background:#fff;box-sizing:border-box}.login-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #0d4e8c1a}.login-input-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);font-size:1.3rem;color:var(--primary-color);z-index:1}.login-button-submit{width:100%;padding:18px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);color:#fff;border:none;border-radius:15px;font-size:1.2rem;font-weight:800;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 30px #0d4e8c4d;margin-top:10px}.login-button-submit:hover{transform:translateY(-3px);box-shadow:0 15px 40px #0d4e8c66}.login-button-submit:disabled{background:#cbd5e0;cursor:not-allowed;transform:none;box-shadow:none}.login-actions{display:flex;justify-content:center;align-items:center;gap:10px;margin-top:20px}.login-action-link{background:none;border:none;color:#718096;font-size:.95rem;font-weight:600;cursor:pointer;padding:8px 12px;border-radius:8px;transition:all .3s ease}.login-action-link:hover{color:var(--primary-color);background:var(--primary-lighter)}.divider{color:#cbd5e0;font-size:.9rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.login-page{padding:15px}.login-card{padding:40px 30px}.login-logo{width:80px;height:80px;font-size:2.5rem}.login-title{font-size:1.5rem}.login-subtitle{font-size:1rem}.login-input{padding:14px 18px 14px 45px;font-size:1rem}.login-button-submit{font-size:1.1rem;padding:16px}}:root{--primary-color: #0D4E8C;--primary-light: #1A6BB5;--primary-lighter: #E3F2FD;--background-gradient: linear-gradient(135deg, #E3F2FD 0%, #BBDEFB 50%, #90CAF9 100%)}.notfound-container{min-height:100vh;display:flex;justify-content:center;align-items:center;background:var(--background-gradient);position:relative;overflow:hidden;padding:40px 20px}.notfound-content{max-width:600px;width:100%;text-align:center;z-index:2;animation:fadeInUp .8s ease-out}.notfound-number{display:flex;justify-content:center;gap:20px;margin-bottom:30px}.notfound-number span{font-size:8rem;font-weight:900;background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:bounce 1s ease-in-out infinite}.notfound-number .four:first-child{animation-delay:0s}.notfound-number .zero{animation-delay:.2s}.notfound-number .four:last-child{animation-delay:.4s}.notfound-icon{font-size:5rem;margin-bottom:30px;animation:rotate 3s ease-in-out infinite}.notfound-title{font-size:2.5rem;font-weight:800;color:var(--primary-color);margin-bottom:20px;text-shadow:2px 2px 4px rgba(255,255,255,.5)}.notfound-message{font-size:1.2rem;color:#2d3748;margin-bottom:40px;line-height:1.8;font-weight:500}.notfound-buttons{display:flex;gap:15px;justify-content:center;margin-bottom:50px;flex-wrap:wrap}.home-button,.back-button{padding:18px 40px;border:none;border-radius:15px;font-size:1.1rem;font-weight:800;cursor:pointer;transition:all .3s ease}.home-button{background:linear-gradient(135deg,var(--primary-color) 0%,var(--primary-light) 100%);color:#fff;box-shadow:0 10px 30px #0d4e8c4d}.home-button:hover{transform:translateY(-3px);box-shadow:0 15px 40px #0d4e8c66}.back-button{background:#fff;color:var(--primary-color);border:3px solid var(--primary-color)}.back-button:hover{background:var(--primary-lighter);transform:translateY(-3px)}.notfound-suggestions{background:#fff;padding:30px;border-radius:20px;box-shadow:0 10px 30px #0d4e8c1a}.suggestions-title{font-size:1.1rem;font-weight:700;color:#2d3748;margin-bottom:20px}.suggestion-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.suggestion-link{padding:12px 24px;background:var(--primary-lighter);color:var(--primary-color);border:none;border-radius:12px;font-weight:700;font-size:.95rem;cursor:pointer;transition:all .3s ease}.suggestion-link:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px)}.notfound-bg{position:absolute;inset:0;z-index:1;pointer-events:none}.deco-circle{position:absolute;border-radius:50%;background:#ffffff4d;animation:float 8s infinite ease-in-out}.deco-circle:nth-child(1){width:150px;height:150px;top:10%;left:10%;animation-delay:0s}.deco-circle:nth-child(2){width:200px;height:200px;bottom:10%;right:10%;animation-delay:2s}.deco-circle:nth-child(3){width:100px;height:100px;top:50%;left:5%;animation-delay:4s}@keyframes fadeInUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes rotate{0%,to{transform:rotate(0)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}@keyframes float{0%,to{transform:translateY(0) scale(1);opacity:.3}50%{transform:translateY(-30px) scale(1.1);opacity:.5}}@media(max-width:768px){.notfound-number span{font-size:5rem}.notfound-icon{font-size:4rem}.notfound-title{font-size:2rem}.notfound-message{font-size:1rem}.notfound-buttons{flex-direction:column;align-items:center}.home-button,.back-button{width:100%;max-width:300px}.suggestion-links{flex-direction:column}.suggestion-link{width:100%}.notfound-suggestions{padding:25px 20px}}@media(max-width:480px){.notfound-number span{font-size:4rem}.notfound-number{gap:10px}.notfound-title{font-size:1.5rem}.home-button,.back-button{padding:16px 30px;font-size:1rem}}.pin-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.pin-modal{background:#fff;border-radius:20px;padding:30px;max-width:360px;width:100%;position:relative;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.pin-modal-close{position:absolute;top:15px;right:15px;background:none;border:none;font-size:1.5rem;color:#a0aec0;cursor:pointer;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.pin-modal-close:hover{background:#edf2f7;color:#4a5568}.pin-modal-header{text-align:center;margin-bottom:25px}.pin-icon{font-size:3rem;display:block;margin-bottom:10px}.pin-modal-header h2{font-size:1.4rem;font-weight:800;color:#2d3748;margin:0 0 8px}.pin-modal-header p{color:#718096;font-size:.95rem;margin:0}.pin-form{display:flex;flex-direction:column;gap:15px}.pin-input-container{position:relative}.pin-input{width:100%;padding:16px 20px;font-size:1.5rem;font-weight:700;text-align:center;letter-spacing:8px;border:3px solid #E2E8F0;border-radius:12px;outline:none;transition:border-color .2s;box-sizing:border-box}.pin-input:focus{border-color:#0d4e8c}.pin-input::placeholder{letter-spacing:normal;font-weight:400;font-size:1rem;color:#a0aec0}.pin-error{background:#fed7d7;color:#c53030;padding:12px;border-radius:8px;font-size:.9rem;text-align:center}.pin-submit-btn{padding:16px;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s}.pin-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 15px #0d4e8c66}.pin-submit-btn:disabled{background:#cbd5e0;cursor:not-allowed}.pin-help{margin-top:20px;padding-top:20px;border-top:1px solid #E2E8F0;text-align:center}.pin-help p{color:#718096;font-size:.9rem;margin:0}.qr-scan-page{min-height:100vh;background:#f7fafc}.qr-scan-header{display:flex;align-items:center;gap:15px;padding:15px 20px;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);color:#fff}.back-button{background:#fff3;border:none;color:#fff;padding:8px 16px;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .2s}.back-button:hover{background:#ffffff4d}.qr-scan-header h1{font-size:1.3rem;font-weight:700;margin:0}.qr-scan-container{padding:20px;max-width:500px;margin:0 auto}.scan-info{text-align:center;margin-bottom:20px}.scan-info p{color:#4a5568;margin:0}.scan-hint{color:#718096!important;font-size:.9rem;margin-top:5px!important}.qr-reader{border-radius:16px;overflow:hidden;margin-bottom:20px}#qr-reader{width:100%!important}#qr-reader video{border-radius:16px}.scanning-overlay{position:fixed;inset:0;background:#000000b3;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:20px;z-index:100}.scanning-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.scanning-overlay p{color:#fff;font-size:1.1rem;font-weight:600}.error-box{background:#fed7d7;border:2px solid #FC8181;border-radius:12px;padding:15px;margin-bottom:20px;text-align:center}.error-box p{color:#c53030;margin:0;font-weight:600}.scan-help{text-align:center;margin-bottom:20px}.pin-fallback-button{background:#edf2f7;border:none;padding:12px 24px;border-radius:10px;font-size:.95rem;color:#4a5568;cursor:pointer;transition:all .2s}.pin-fallback-button:hover{background:#e2e8f0}.scan-tips{background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 10px #00000014}.scan-tips h3{font-size:1rem;color:#2d3748;margin:0 0 15px}.scan-tips ul{list-style:none;padding:0;margin:0}.scan-tips li{padding:8px 0;color:#718096;font-size:.9rem;border-bottom:1px solid #EDF2F7}.scan-tips li:last-child{border-bottom:none}.scan-success{text-align:center;padding:30px 20px}.success-icon{font-size:4rem;animation:celebrate .6s ease-out}.scan-success h2{font-size:1.8rem;color:#2d3748;margin:15px 0}.success-booth{background:linear-gradient(135deg,#0d4e8c,#1a6bb5);color:#fff;padding:15px 30px;border-radius:12px;font-size:1.2rem;font-weight:700;margin:20px 0}.success-total{font-size:1.1rem;color:#4a5568}.success-total strong{color:#0d4e8c;font-size:1.5rem}.success-progress{margin:20px 0}.success-progress span{color:#718096;font-weight:600}.completion-badge{background:linear-gradient(135deg,#f6e05e,#ecc94b);color:#744210;padding:12px 24px;border-radius:30px;font-size:1.1rem;font-weight:700;margin:15px 0;display:inline-block}.success-actions{display:flex;flex-direction:column;gap:12px;margin-top:25px}@media(max-width:480px){.qr-scan-container{padding:15px}.scan-success h2{font-size:1.5rem}.success-booth{font-size:1rem;padding:12px 20px}}.stamp-collect-page{min-height:100vh;background:linear-gradient(135deg,#0d4e8c,#1a6bb5,#2e8bc0);display:flex;justify-content:center;align-items:center;padding:20px}.stamp-collect-container{background:#fff;border-radius:24px;padding:40px;max-width:400px;width:100%;box-shadow:0 20px 60px #0000004d;text-align:center}.stamp-status{display:flex;flex-direction:column;align-items:center;gap:20px}.stamp-status h2{font-size:1.5rem;font-weight:800;color:#2d3748;margin:0}.stamp-status p{color:#718096;margin:0;line-height:1.6}.stamp-spinner{width:60px;height:60px;border:5px solid #E2E8F0;border-top-color:#0d4e8c;border-radius:50%;animation:spin 1s linear infinite}.stamp-icon{font-size:4rem;animation:bounce .5s ease-out}@keyframes bounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.stamp-icon.success-icon{animation:celebrate .6s ease-out}@keyframes celebrate{0%{transform:scale(0) rotate(-180deg)}50%{transform:scale(1.3) rotate(10deg)}to{transform:scale(1) rotate(0)}}.stamp-icon.error-icon{animation:shake .5s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.booth-info{background:linear-gradient(135deg,#0d4e8c,#1a6bb5);padding:15px 30px;border-radius:12px;margin:10px 0}.booth-name{color:#fff;font-size:1.3rem;font-weight:700}.total-stamps{font-size:1.1rem;color:#4a5568}.total-stamps strong{color:#0d4e8c;font-size:1.5rem}.stamp-progress{width:100%;margin-top:10px}.progress-bar{height:12px;background:#e2e8f0;border-radius:6px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#48bb78,#38a169);border-radius:6px;transition:width .5s ease-out}.progress-text{font-size:.9rem;color:#718096;font-weight:600}.completion-badge{background:linear-gradient(135deg,#f6e05e,#ecc94b);color:#744210;padding:12px 24px;border-radius:30px;font-size:1.1rem;font-weight:700;margin-top:10px;animation:glow 1.5s ease-in-out infinite alternate}@keyframes glow{0%{box-shadow:0 0 10px #ecc94b80}to{box-shadow:0 0 20px #ecc94bcc}}.error-message{color:#e53e3e;font-weight:600}.error-detail{color:#718096;font-size:.9rem}.stamp-actions{display:flex;flex-direction:column;gap:12px;width:100%;margin-top:20px}.primary-btn,.secondary-btn{padding:14px 24px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;border:none}.primary-btn{background:linear-gradient(135deg,#0d4e8c,#1a6bb5);color:#fff}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #0d4e8c66}.secondary-btn{background:#edf2f7;color:#4a5568}.secondary-btn:hover{background:#e2e8f0}.need-login h2{color:#0d4e8c}@media(max-width:480px){.stamp-collect-container{padding:30px 20px;margin:10px}.stamp-icon{font-size:3rem}.stamp-status h2{font-size:1.3rem}}.admin-dashboard{min-height:100vh;background:#f7fafc}.admin-content{max-width:1400px;margin:0 auto;padding:30px}.admin-header{display:flex;align-items:center;gap:20px;margin-bottom:30px}.admin-title{font-size:2rem;font-weight:800;color:#2d3748;margin:0}.admin-subtitle{color:#718096;margin:0;flex:1}.refresh-btn{padding:12px 24px;background:#0d4e8c;color:#fff;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s}.refresh-btn:hover{background:#1a6bb5;transform:translateY(-2px)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:30px}.stat-card{display:flex;align-items:center;gap:20px;background:#fff;padding:25px;border-radius:16px;box-shadow:0 4px 15px #00000014;transition:transform .2s}.stat-card:hover{transform:translateY(-5px)}.stat-icon{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.8rem}.stat-card.blue .stat-icon{background:#ebf8ff}.stat-card.green .stat-icon{background:#f0fff4}.stat-card.purple .stat-icon{background:#faf5ff}.stat-card.orange .stat-icon{background:#fffaf0}.stat-info{flex:1}.stat-label{font-size:.9rem;color:#718096;margin-bottom:5px}.stat-value{font-size:1.8rem;font-weight:800;color:#2d3748}.stat-sub{font-size:.85rem;color:#a0aec0;margin-top:3px}.section-card{background:#fff;border-radius:20px;padding:25px;margin-bottom:25px;box-shadow:0 4px 15px #00000014}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #E2E8F0}.section-title{font-size:1.4rem;font-weight:700;color:#2d3748;margin:0}.congestion-legend{display:flex;gap:20px}.legend-item{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#4a5568}.legend-dot{width:12px;height:12px;border-radius:50%}.legend-dot.green{background:#48bb78}.legend-dot.orange{background:#f6ad55}.legend-dot.red{background:#e53e3e}.map-container{border-radius:16px;overflow:hidden;margin-bottom:20px;border:2px solid #E2E8F0}.congestion-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;max-height:200px;overflow-y:auto;padding:10px 0}.congestion-item{display:flex;align-items:center;gap:10px;padding:12px 15px;background:#f7fafc;border-radius:12px;border-left:4px solid}.congestion-item.low{border-left-color:#48bb78}.congestion-item.medium{border-left-color:#f6ad55}.congestion-item.high{border-left-color:#e53e3e}.congestion-item .booth-icon{font-size:1.2rem}.congestion-item .booth-name{flex:1;font-weight:600;color:#2d3748;font-size:.9rem}.congestion-badge{padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600}.congestion-badge.low{background:#c6f6d5;color:#276749}.congestion-badge.medium{background:#feebc8;color:#c05621}.congestion-badge.high{background:#fed7d7;color:#c53030}.collection-stats{display:grid;grid-template-columns:1fr 1.5fr;gap:40px;align-items:center}.collection-chart{display:flex;justify-content:center}.collection-bars{display:flex;flex-direction:column;gap:20px}.collection-bar-item{display:flex;flex-direction:column;gap:8px}.bar-label{display:flex;align-items:center;gap:10px}.bar-icon{font-size:1.2rem}.bar-label span:nth-child(2){flex:1;font-weight:600;color:#2d3748}.bar-value{font-weight:700;color:#0d4e8c}.bar-track{height:12px;background:#e2e8f0;border-radius:6px;overflow:hidden}.bar-fill{height:100%;border-radius:6px;transition:width .5s ease}.bar-fill.qr{background:linear-gradient(90deg,#0d4e8c,#1a6bb5)}.bar-fill.pin{background:linear-gradient(90deg,#dd6b20,#f6ad55)}.bar-fill.admin{background:linear-gradient(90deg,#c53030,#e53e3e)}.record-count{background:#fed7d7;color:#c53030;padding:6px 14px;border-radius:20px;font-size:.9rem;font-weight:600}.suspicious-table-wrapper{overflow-x:auto}.suspicious-table{width:100%;border-collapse:collapse}.suspicious-table th,.suspicious-table td{padding:15px;text-align:left;border-bottom:1px solid #E2E8F0}.suspicious-table th{background:#f7fafc;font-weight:700;color:#4a5568;font-size:.9rem}.suspicious-table tbody tr:hover{background:#f7fafc}.suspicious-table .student-id{font-family:monospace;color:#4a5568}.suspicious-table .name{font-weight:600;color:#2d3748}.suspicious-table .booth{color:#0d4e8c}.suspicious-table .time{color:#718096;font-size:.9rem}.reason-badge{display:inline-block;padding:5px 12px;background:#fed7d7;color:#c53030;border-radius:8px;font-size:.85rem;font-weight:500}.suspicious-table .action{display:flex;gap:8px}.action-btn{padding:8px 14px;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.action-btn.view{background:#ebf8ff;color:#0d4e8c}.action-btn.view:hover{background:#bee3f8}.action-btn.dismiss{background:#e2e8f0;color:#718096}.action-btn.dismiss:hover{background:#cbd5e0}.no-records{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#a0aec0}.no-records-icon{font-size:3rem;margin-bottom:15px}.no-records p{font-size:1.1rem}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.collection-stats{grid-template-columns:1fr}}@media(max-width:768px){.admin-nav{flex-direction:column;gap:15px;padding:15px}.admin-nav-menu{flex-wrap:wrap;justify-content:center}.admin-nav-item{padding:8px 12px;font-size:.9rem}.admin-content{padding:20px 15px}.admin-header{flex-direction:column;align-items:flex-start}.admin-title{font-size:1.5rem}.stats-grid{grid-template-columns:1fr}.stat-card{padding:20px}.congestion-list{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:10px}.congestion-legend{flex-wrap:wrap;gap:10px}.suspicious-table th,.suspicious-table td{padding:10px 8px;font-size:.85rem}}.qr-manage-page{min-height:100vh;background:#f7fafc}.qr-manage-container{max-width:1400px;margin:0 auto;padding:30px}.error-banner{background:#fed7d7;color:#c53030;padding:15px 20px;border-radius:12px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;font-weight:600}.error-banner button{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#c53030}.qr-manage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;background:#fff;padding:25px 30px;border-radius:20px;box-shadow:0 4px 15px #00000014}.page-title{font-size:1.8rem;font-weight:800;color:#2d3748;margin:0 0 5px}.page-subtitle{color:#718096;font-size:1rem;margin:0}.header-right{display:flex;gap:12px}.create-booth-button,.download-all-button{padding:14px 24px;border:none;border-radius:12px;font-weight:700;cursor:pointer;transition:all .2s;font-size:.95rem}.create-booth-button{background:#0d4e8c;color:#fff}.create-booth-button:hover{background:#1a6bb5;transform:translateY(-2px)}.download-all-button{background:#48bb78;color:#fff}.download-all-button:hover{background:#38a169;transform:translateY(-2px)}.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:25px}.qr-card{background:#fff;border-radius:20px;padding:25px;box-shadow:0 4px 15px #00000014;transition:all .2s}.qr-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.qr-card-header{display:flex;align-items:center;gap:15px;margin-bottom:20px}.booth-icon{width:55px;height:55px;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);border-radius:15px;display:flex;justify-content:center;align-items:center;font-size:1.8rem}.booth-info{flex:1}.booth-name{font-size:1.15rem;font-weight:700;color:#2d3748;margin:0 0 3px}.booth-building{font-size:.9rem;color:#718096;margin:0}.qr-preview{aspect-ratio:1;background:#f7fafc;border-radius:15px;display:flex;justify-content:center;align-items:center;margin-bottom:20px;cursor:pointer;transition:all .2s;border:3px dashed #CBD5E0}.qr-preview:hover{background:#ebf8ff;border-color:#0d4e8c}.qr-placeholder{text-align:center}.qr-icon{font-size:3rem;display:block;margin-bottom:10px}.qr-placeholder p{color:#718096;font-weight:600;font-size:.9rem;margin:0}.qr-info{background:#f7fafc;padding:15px;border-radius:12px;margin-bottom:15px}.info-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.info-item:last-child{margin-bottom:0}.info-label{font-size:.85rem;color:#718096;font-weight:600}.info-value{font-size:.85rem;color:#2d3748;font-weight:700}.qr-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.action-button{padding:10px;border:none;border-radius:10px;font-weight:700;font-size:.85rem;cursor:pointer;transition:all .2s}.action-button.generate{background:#ebf8ff;color:#0d4e8c}.action-button.generate:hover{background:#0d4e8c;color:#fff}.action-button.download{background:#c6f6d5;color:#276749}.action-button.download:hover{background:#48bb78;color:#fff}.action-button.delete{background:#fed7d7;color:#c53030}.action-button.delete:hover{background:#e53e3e;color:#fff}.qr-preview-modal{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.qr-preview-content{background:#fff;padding:40px;border-radius:24px;max-width:450px;width:90%;position:relative;animation:scaleIn .3s ease}.close-modal{position:absolute;top:15px;right:15px;width:40px;height:40px;border-radius:50%;background:#f7fafc;border:none;cursor:pointer;font-size:1.5rem;color:#718096;transition:all .2s}.close-modal:hover{background:#e53e3e;color:#fff}.preview-title{font-size:1.5rem;font-weight:800;color:#2d3748;text-align:center;margin:0 0 5px}.preview-subtitle{font-size:1rem;color:#718096;text-align:center;margin:0 0 25px}.qr-preview-image{background:#fff;padding:20px;border-radius:16px;border:3px solid #0D4E8C;margin-bottom:20px;display:flex;justify-content:center}.qr-preview-image img{width:100%;max-width:280px;border-radius:10px}.preview-info{background:#f7fafc;padding:18px;border-radius:12px;margin-bottom:20px}.preview-info-item{margin-bottom:10px;color:#4a5568;font-size:.95rem}.preview-info-item:last-child{margin-bottom:0}.preview-info-item strong{color:#0d4e8c}.download-button-large{width:100%;padding:16px;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);color:#fff;border:none;border-radius:14px;font-weight:700;font-size:1.1rem;cursor:pointer;transition:all .2s}.download-button-large:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0d4e8c66}.create-booth-modal{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:20px}.create-booth-content{background:#fff;padding:35px;border-radius:24px;max-width:550px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:scaleIn .3s ease}.modal-title{font-size:1.5rem;font-weight:800;color:#2d3748;margin:0 0 25px;text-align:center}.create-booth-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.95rem;font-weight:700;color:#2d3748}.form-input{padding:14px 16px;border:2px solid #E2E8F0;border-radius:12px;font-size:1rem;transition:all .2s}.form-input:focus{outline:none;border-color:#0d4e8c;box-shadow:0 0 0 3px #0d4e8c1a}.icon-selector{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.icon-option{aspect-ratio:1;background:#f7fafc;border:2px solid #E2E8F0;border-radius:12px;display:flex;justify-content:center;align-items:center;font-size:1.6rem;cursor:pointer;transition:all .2s}.icon-option:hover{background:#ebf8ff;border-color:#0d4e8c;transform:scale(1.1)}.icon-option.selected{background:#0d4e8c;border-color:#0d4e8c;transform:scale(1.1)}.submit-button{padding:16px;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);color:#fff;border:none;border-radius:14px;font-weight:700;font-size:1.1rem;cursor:pointer;transition:all .2s;margin-top:10px}.submit-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #0d4e8c66}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@media(max-width:768px){.admin-nav{flex-direction:column;gap:15px;padding:15px}.admin-nav-menu{flex-wrap:wrap;justify-content:center}.admin-nav-item{padding:8px 12px;font-size:.85rem}.qr-manage-container{padding:20px 15px}.qr-manage-header{flex-direction:column;gap:20px;align-items:flex-start;padding:20px}.header-right{width:100%}.create-booth-button,.download-all-button{flex:1;text-align:center}.qr-grid,.form-row{grid-template-columns:1fr}.icon-selector{grid-template-columns:repeat(5,1fr)}.create-booth-content,.qr-preview-content{padding:25px 20px}}.user-manage{min-height:100vh;background:#f7fafc}.admin-loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:20px}.user-manage-content{max-width:1400px;margin:0 auto;padding:30px}.csv-btn{padding:14px 28px;background:#48bb78;color:#fff;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:pointer;transition:all .2s}.csv-btn:hover{background:#38a169;transform:translateY(-2px)}.search-section{background:#fff;padding:25px;border-radius:16px;box-shadow:0 4px 15px #00000014;margin-bottom:25px;display:flex;gap:20px;flex-wrap:wrap;justify-content:space-between}.search-box{display:flex;flex:1;min-width:300px;gap:10px}.search-type{padding:12px 15px;border:2px solid #E2E8F0;border-radius:10px;font-size:.95rem;background:#fff;cursor:pointer}.search-type:focus{border-color:#0d4e8c;outline:none}.search-input{flex:1;padding:12px 18px;border:2px solid #E2E8F0;border-radius:10px;font-size:1rem;transition:border-color .2s}.search-input:focus{border-color:#0d4e8c;outline:none}.search-btn{padding:12px 20px;background:#0d4e8c;color:#fff;border:none;border-radius:10px;font-size:1.1rem;cursor:pointer;transition:background .2s}.search-btn:hover{background:#1a6bb5}.filter-box{display:flex;gap:10px}.filter-btn{padding:12px 20px;background:#edf2f7;color:#4a5568;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s}.filter-btn:hover{background:#e2e8f0}.filter-btn.active{background:#0d4e8c;color:#fff}.users-section{background:#fff;border-radius:16px;box-shadow:0 4px 15px #00000014;overflow:hidden}.users-header{padding:20px 25px;border-bottom:2px solid #E2E8F0}.users-count{font-weight:600;color:#4a5568}.users-table-wrapper{overflow-x:auto}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:16px 20px;text-align:left;border-bottom:1px solid #E2E8F0}.users-table th{background:#f7fafc;font-weight:700;color:#4a5568;font-size:.9rem;white-space:nowrap}.users-table tbody tr{cursor:pointer;transition:background .2s}.users-table tbody tr:hover{background:#f7fafc}.users-table tbody tr.selected{background:#ebf8ff}.users-table .student-id{font-family:monospace;font-weight:600;color:#0d4e8c}.users-table .name{font-weight:600;color:#2d3748}.users-table .dept{color:#4a5568}.users-table .grade{color:#718096}.users-table .date{color:#718096;font-size:.9rem}.stamp-progress{display:flex;align-items:center;gap:10px}.stamp-bar{width:100px;height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.stamp-fill{height:100%;background:linear-gradient(90deg,#0d4e8c,#48bb78);border-radius:4px;transition:width .3s}.stamp-count{font-weight:600;color:#2d3748;font-size:.9rem;white-space:nowrap}.status-badge{display:inline-block;padding:6px 12px;border-radius:20px;font-size:.85rem;font-weight:600}.status-badge.completed{background:#c6f6d5;color:#276749}.status-badge.progress{background:#feebc8;color:#c05621}.users-table .actions{white-space:nowrap}.action-btn{padding:8px 16px;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.action-btn.stamp{background:#ebf8ff;color:#0d4e8c}.action-btn.stamp:hover{background:#bee3f8}.detail-row td{padding:0!important;background:#f7fafc}.user-detail{padding:25px}.detail-info{display:flex;gap:30px;margin-bottom:20px}.detail-item{display:flex;align-items:center;gap:10px}.detail-label{font-weight:600;color:#4a5568}.detail-value{color:#2d3748}.detail-stamps h4{font-size:1rem;color:#2d3748;margin:0 0 15px}.stamp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.stamp-item{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#fff;border:2px solid #E2E8F0;border-radius:10px;font-size:.85rem;position:relative}.stamp-item.collected{background:#c6f6d5;border-color:#48bb78}.stamp-item .stamp-icon{font-size:1.1rem}.stamp-item .stamp-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stamp-item .check{color:#276749;font-weight:700}.no-users{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:#a0aec0}.no-users-icon{font-size:4rem;margin-bottom:15px}.no-users p{font-size:1.2rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.stamp-modal{background:#fff;border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;position:relative;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:15px;right:15px;width:36px;height:36px;background:#edf2f7;border:none;border-radius:50%;font-size:1.5rem;cursor:pointer;color:#718096;transition:all .2s}.modal-close:hover{background:#e2e8f0;color:#2d3748}.modal-title{font-size:1.5rem;font-weight:700;color:#2d3748;margin:0;padding:25px 25px 10px}.modal-subtitle{color:#718096;margin:0;padding:0 25px 20px;border-bottom:2px solid #E2E8F0}.modal-content{padding:25px}.form-group{margin-bottom:25px}.form-label{display:block;font-weight:600;color:#2d3748;margin-bottom:10px}.booth-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;max-height:250px;overflow-y:auto;padding:5px}.booth-select-item{display:flex;flex-direction:column;align-items:center;gap:5px;padding:15px 10px;background:#f7fafc;border:2px solid #E2E8F0;border-radius:12px;cursor:pointer;transition:all .2s;text-align:center;position:relative}.booth-select-item:hover:not(.disabled){border-color:#0d4e8c;background:#ebf8ff}.booth-select-item.selected{border-color:#0d4e8c;background:#0d4e8c;color:#fff}.booth-select-item.disabled{opacity:.5;cursor:not-allowed}.booth-select-item .booth-icon{font-size:1.5rem}.booth-select-item .booth-name{font-size:.85rem;font-weight:600}.already-badge{position:absolute;top:5px;right:5px;background:#48bb78;color:#fff;font-size:.65rem;padding:2px 6px;border-radius:10px}.form-textarea{width:100%;padding:15px;border:2px solid #E2E8F0;border-radius:12px;font-size:1rem;resize:vertical;transition:border-color .2s;font-family:inherit}.form-textarea:focus{border-color:#0d4e8c;outline:none}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:10px}.cancel-btn{padding:14px 28px;background:#edf2f7;color:#4a5568;border:none;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#e2e8f0}.submit-btn{padding:14px 28px;background:#0d4e8c;color:#fff;border:none;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.submit-btn:hover:not(:disabled){background:#1a6bb5}.submit-btn:disabled{background:#cbd5e0;cursor:not-allowed}@media(max-width:1200px){.search-section{flex-direction:column}.search-box{width:100%}.filter-box{width:100%;justify-content:center}}@media(max-width:768px){.admin-nav{flex-direction:column;gap:15px;padding:15px}.admin-nav-menu{flex-wrap:wrap;justify-content:center}.admin-nav-item{padding:8px 12px;font-size:.85rem}.user-manage-content{padding:20px 15px}.page-header{flex-direction:column;align-items:flex-start;gap:15px}.page-title{font-size:1.5rem}.csv-btn{width:100%}.search-box{flex-direction:column}.filter-box{flex-wrap:wrap}.filter-btn{flex:1;min-width:100px;text-align:center}.users-table th,.users-table td{padding:12px 10px;font-size:.85rem}.stamp-bar{width:60px}.stamp-grid,.booth-select-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.settings-page{min-height:100vh;background:#f7fafc}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid #E2E8F0;border-top-color:#0d4e8c;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.settings-content{max-width:1200px;margin:0 auto;padding:30px}.save-btn{padding:14px 28px;background:#cbd5e0;color:#4a5568;border:none;border-radius:12px;font-weight:700;font-size:1rem;cursor:not-allowed;transition:all .2s}.save-btn.active{background:linear-gradient(135deg,#0d4e8c,#1a6bb5);color:#fff;cursor:pointer;box-shadow:0 4px 15px #0d4e8c4d}.save-btn.active:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0d4e8c66}.save-btn:disabled{opacity:.6}.settings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:25px;margin-bottom:25px}.settings-card{background:#fff;border-radius:20px;box-shadow:0 4px 15px #00000014;overflow:hidden}.settings-card.full-width{grid-column:1 / -1}.card-header{padding:20px 25px;border-bottom:2px solid #E2E8F0}.card-title{font-size:1.2rem;font-weight:700;color:#2d3748;margin:0}.card-subtitle{font-size:.9rem;color:#718096;margin:5px 0 0}.card-body{padding:25px}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:.95rem;font-weight:600;color:#4a5568;margin-bottom:8px}.form-input{width:100%;padding:12px 16px;border:2px solid #E2E8F0;border-radius:10px;font-size:1rem;transition:border-color .2s;box-sizing:border-box}.form-input:focus{border-color:#0d4e8c;outline:none}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}.form-hint{font-size:.85rem;color:#718096;margin-top:8px}.stamp-counter{display:flex;align-items:center;gap:15px}.counter-btn{width:45px;height:45px;border:none;border-radius:12px;background:#edf2f7;color:#2d3748;font-size:1.5rem;font-weight:700;cursor:pointer;transition:all .2s}.counter-btn:hover:not(:disabled){background:#0d4e8c;color:#fff}.counter-btn:disabled{opacity:.4;cursor:not-allowed}.counter-value{font-size:1.5rem;font-weight:800;color:#0d4e8c;min-width:80px;text-align:center}.toggle-switch{display:flex;align-items:center;gap:12px}.toggle-switch input{display:none}.toggle-label{position:relative;width:56px;height:30px;background:#cbd5e0;border-radius:15px;cursor:pointer;transition:background .3s}.toggle-switch input:checked+.toggle-label{background:#48bb78}.toggle-switch-btn{position:absolute;top:3px;left:3px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 2px 5px #0003}.toggle-switch input:checked+.toggle-label .toggle-switch-btn{transform:translate(26px)}.toggle-text{font-size:.95rem;font-weight:600;color:#718096}.toggle-text.active{color:#48bb78}.form-range{width:100%;height:8px;border-radius:4px;background:#e2e8f0;outline:none;appearance:none;-webkit-appearance:none}.form-range::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:#0d4e8c;cursor:pointer;box-shadow:0 2px 6px #0d4e8c66}.form-range::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#0d4e8c;cursor:pointer;border:none}.range-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:.85rem;color:#718096}.pin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:15px}.pin-item{display:flex;justify-content:space-between;align-items:center;padding:15px 18px;background:#f7fafc;border-radius:12px;transition:all .2s}.pin-item:hover{background:#edf2f7}.pin-info{display:flex;align-items:center;gap:12px}.pin-icon{font-size:1.5rem}.pin-details{display:flex;flex-direction:column}.pin-name{font-weight:600;color:#2d3748;font-size:.95rem}.pin-location{font-size:.8rem;color:#718096}.pin-value{display:flex;align-items:center}.pin-display{display:flex;align-items:center;gap:10px}.pin-code{font-family:Courier New,monospace;font-size:1.1rem;font-weight:700;color:#0d4e8c;background:#fff;padding:6px 12px;border-radius:8px;border:2px solid #E2E8F0}.pin-edit-btn{background:none;border:none;font-size:1.1rem;cursor:pointer;padding:5px;transition:transform .2s}.pin-edit-btn:hover{transform:scale(1.2)}.pin-edit{display:flex;align-items:center;gap:8px}.pin-input{width:80px;padding:8px 12px;border:2px solid #0D4E8C;border-radius:8px;font-family:Courier New,monospace;font-size:1rem;font-weight:700;text-align:center}.pin-input:focus{outline:none}.pin-save-btn,.pin-cancel-btn{width:32px;height:32px;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .2s}.pin-save-btn{background:#48bb78;color:#fff}.pin-save-btn:hover{background:#38a169}.pin-cancel-btn{background:#e53e3e;color:#fff}.pin-cancel-btn:hover{background:#c53030}@media(max-width:1024px){.settings-grid{grid-template-columns:1fr}}@media(max-width:768px){.admin-nav{flex-direction:column;gap:15px;padding:15px}.admin-nav-menu{flex-wrap:wrap;justify-content:center}.admin-nav-item{padding:8px 12px;font-size:.85rem}.settings-content{padding:20px 15px}.page-header{flex-direction:column;align-items:flex-start;gap:15px}.page-title{font-size:1.5rem}.save-btn{width:100%}.form-row,.pin-grid{grid-template-columns:1fr}.pin-item{flex-direction:column;align-items:flex-start;gap:12px}.pin-value{width:100%;justify-content:flex-end}}.data-export-page{min-height:100vh;background:#f7fafc}.admin-nav{display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);padding:15px 30px;box-shadow:0 4px 20px #0d4e8c4d;position:sticky;top:0;z-index:100}.admin-nav-left{display:flex;align-items:center}.admin-logo{display:flex;align-items:center;gap:10px;color:#fff}.admin-logo-icon{font-size:1.8rem}.admin-logo-text{font-size:1.3rem;font-weight:700}.admin-nav-menu{display:flex;gap:5px}.admin-nav-item{padding:10px 18px;color:#fffc;border-radius:10px;cursor:pointer;transition:all .2s;font-weight:500}.admin-nav-item:hover{background:#ffffff26;color:#fff}.admin-nav-item.active{background:#ffffff40;color:#fff}.admin-nav-right{display:flex;gap:10px}.admin-nav-btn{padding:10px 18px;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s}.admin-nav-btn.home{background:#fff3;color:#fff}.admin-nav-btn.home:hover{background:#ffffff4d}.admin-nav-btn.logout{background:#e53e3e;color:#fff}.admin-nav-btn.logout:hover{background:#c53030}.export-content{max-width:1200px;margin:0 auto;padding:30px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.page-title{font-size:2rem;font-weight:800;color:#2d3748;margin:0}.page-subtitle{color:#718096;margin:5px 0 0}.download-all-btn{padding:16px 32px;background:linear-gradient(135deg,#0d4e8c,#1a6bb5);color:#fff;border:none;border-radius:14px;font-weight:700;font-size:1.1rem;cursor:pointer;transition:all .2s;box-shadow:0 4px 15px #0d4e8c4d}.download-all-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 6px 20px #0d4e8c66}.download-all-btn:disabled{background:#cbd5e0;cursor:not-allowed;box-shadow:none}.date-range-card{background:#fff;border-radius:20px;box-shadow:0 4px 15px #00000014;margin-bottom:30px;overflow:hidden}.date-range-header{padding:20px 25px;border-bottom:2px solid #E2E8F0}.date-range-title{font-size:1.2rem;font-weight:700;color:#2d3748;margin:0}.date-range-content{padding:25px;display:flex;align-items:flex-end;gap:20px;flex-wrap:wrap}.date-input-group{display:flex;flex-direction:column;gap:8px}.date-label{font-size:.9rem;font-weight:600;color:#4a5568}.date-input{padding:12px 16px;border:2px solid #E2E8F0;border-radius:10px;font-size:1rem;transition:border-color .2s;min-width:160px}.date-input:focus{border-color:#0d4e8c;outline:none}.date-separator{font-size:1.5rem;color:#a0aec0;padding-bottom:10px}.quick-date-btns{display:flex;gap:10px;margin-left:auto}.quick-btn{padding:10px 18px;background:#edf2f7;color:#4a5568;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s}.quick-btn:hover{background:#0d4e8c;color:#fff}.download-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:25px;margin-bottom:30px}.download-card{background:#fff;border-radius:20px;box-shadow:0 4px 15px #00000014;overflow:hidden;transition:transform .2s,box-shadow .2s}.download-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001f}.download-card-header{display:flex;align-items:flex-start;gap:15px;padding:25px 25px 15px}.download-icon{font-size:2.5rem;flex-shrink:0}.download-info{flex:1}.download-title{font-size:1.2rem;font-weight:700;color:#2d3748;margin:0 0 5px}.download-desc{font-size:.9rem;color:#718096;margin:0;line-height:1.4}.download-card-body{padding:0 25px 20px}.download-columns{background:#f7fafc;padding:12px 15px;border-radius:10px;margin-bottom:15px}.columns-label{display:block;font-size:.8rem;color:#718096;margin-bottom:5px}.columns-value{font-size:.85rem;color:#4a5568;line-height:1.5}.download-count{display:flex;align-items:baseline;gap:8px}.count-value{font-size:2rem;font-weight:800;color:#0d4e8c}.count-unit{font-size:1rem;color:#718096}.download-card-footer{padding:15px 25px 25px;display:flex;gap:10px}.download-btn{flex:1;padding:14px 20px;border:none;border-radius:12px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s}.download-btn.csv{background:#48bb78;color:#fff}.download-btn.csv:hover:not(:disabled){background:#38a169}.download-btn:disabled{background:#cbd5e0;cursor:not-allowed}.export-notice{background:#ebf8ff;border:2px solid #BEE3F8;border-radius:16px;padding:25px}.notice-title{font-size:1.1rem;font-weight:700;color:#2c5282;margin:0 0 15px}.notice-list{margin:0;padding-left:20px}.notice-list li{color:#2c5282;font-size:.95rem;line-height:1.8}@media(max-width:1024px){.download-grid{grid-template-columns:1fr}}@media(max-width:768px){.admin-nav{flex-direction:column;gap:15px;padding:15px}.admin-nav-menu{flex-wrap:wrap;justify-content:center}.admin-nav-item{padding:8px 12px;font-size:.85rem}.export-content{padding:20px 15px}.page-header{flex-direction:column;align-items:flex-start;gap:15px}.page-title{font-size:1.5rem}.download-all-btn{width:100%}.date-range-content{flex-direction:column;align-items:stretch}.date-separator{display:none}.date-input{width:100%}.quick-date-btns{margin-left:0;flex-wrap:wrap}.quick-btn{flex:1;min-width:80px;text-align:center}.download-card-header{padding:20px 20px 10px}.download-icon{font-size:2rem}.download-card-body{padding:0 20px 15px}.download-card-footer{padding:10px 20px 20px}.count-value{font-size:1.5rem}}
