:root{--primary-gradient: linear-gradient(135deg, #4338ca 0%, #1e40af 100%);--secondary-gradient: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);--accent-gradient: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);--success-gradient: linear-gradient(135deg, #059669 0%, #10b981 100%);--warning-gradient: linear-gradient(135deg, #d97706 0%, #f59e0b 100%);--danger-gradient: linear-gradient(135deg, #dc2626 0%, #ef4444 100%);--bg-page: #f0f4f8;--bg-card: #ffffff;--bg-card-hover: #f1f5f9;--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--border-light: rgba(226, 232, 240, .8);--accent-blue: #2563eb;--accent-indigo: #4f46e5;--accent-green: #10b981;--accent-orange: #f59e0b;--accent-red: #ef4444;--accent-purple: #8b5cf6;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--spacing-xxl: 4rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 2px 4px rgba(0,0,0,.04);--shadow-md: 0 4px 20px -5px rgba(0,0,0,.07), 0 2px 10px -2px rgba(0,0,0,.04);--shadow-lg: 0 10px 25px -5px rgba(0,0,0,.1), 0 8px 10px -6px rgba(0,0,0,.05);--transition-fast: .2s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{overflow-x:hidden;scroll-behavior:smooth;width:100%}body{font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,Noto Sans SC,Poppins,-apple-system,BlinkMacSystemFont,sans-serif;background:#f0f4f8;color:var(--text-primary);line-height:1.6;font-weight:500;overflow-x:hidden;min-height:100vh;width:100%;position:relative}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}@media (max-width: 480px){.container{padding:0 16px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes flash{0%,to{opacity:1}50%{opacity:.3}}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.6}}.app-bar{position:sticky;top:0;left:0;right:0;height:60px;background:#fff;display:flex;align-items:center;justify-content:center;padding:0 16px;z-index:2000;box-shadow:0 2px 10px #0000000d;border-bottom:1px solid var(--border-light)}.app-bar.home-bar{justify-content:center}.app-bar .back-btn{position:absolute;left:16px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;background:var(--bg-card-hover);border:none;border-radius:50%;cursor:pointer}.app-bar .bar-title{position:absolute;width:100%;text-align:center;left:0;font-size:1.25rem;font-weight:800;z-index:-1;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;pointer-events:none}.home-screen{padding:35px 16px;background:#f0f4f8}.home-welcome{text-align:center;margin-bottom:50px;margin-top:30px;padding:20px;animation:fadeInDown .8s ease-out}.main-logo{position:relative;display:block;width:fit-content;margin:0 auto;text-align:center;font-size:5.8rem;font-weight:1000;letter-spacing:-4px;text-transform:uppercase;white-space:nowrap;line-height:1;background:linear-gradient(120deg,#0f172a,#1e293b,#2563eb,#60a5fa,#2563eb,#0f172a);background-size:300% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;animation:wavy-motion 6s ease-in-out infinite}@keyframes wavy-motion{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes pulse-dot{0%,to{opacity:1;transform:translate(-50%) scale(1)}50%{opacity:.3;transform:translate(-50%) scale(.8)}}.home-welcome p{color:var(--text-secondary);font-size:1.05rem;line-height:1.6;max-width:300px;margin:0 auto 20px;font-weight:500;opacity:.9}.feature-request-btn{margin:0 auto;display:inline-flex}.home-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:600px;margin:0 auto}.home-item{background:#fff;border-radius:20px;padding:20px 10px;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 4px 15px #0000000d;border:1px solid rgba(255,255,255,.8);cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);min-height:110px;outline:none;font-family:inherit}.home-item:hover{transform:translateY(-8px);box-shadow:0 12px 25px #0000001a;border-color:var(--accent-blue);background:linear-gradient(135deg,#fff,#f8fafc)}.home-item:hover .item-icon{transform:scale(1.1)}.home-item:active{transform:scale(.95) translateY(-2px)}.item-icon{font-size:2.2rem;margin-bottom:8px;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.item-label{font-size:.95rem;font-weight:800;color:var(--text-primary);text-align:center}.home-item.item-empty,.home-item.item-disabled{background:#fff6;border:1px dashed rgba(0,0,0,.1);box-shadow:none;cursor:default}.home-item.item-disabled{position:relative;opacity:.8;filter:grayscale(.5);pointer-events:none}.coming-soon-badge{position:absolute;top:10px;right:10px;background:#94a3b8;color:#fff;font-size:.55rem;font-weight:900;padding:2px 6px;border-radius:4px;letter-spacing:.5px}.home-grid .home-item.item-reward .coming-soon-badge{opacity:1!important;visibility:visible!important;display:inline-block!important}.app-section{display:none}.app-section.active{display:block;padding-top:24px;animation:simpleFade .4s ease-in-out forwards}@keyframes simpleFade{0%{opacity:0}to{opacity:1}}.section{padding-bottom:40px}.section-header{margin-bottom:30px}.section-header h2{font-size:1.6rem;margin-bottom:5px}.section-subtitle{font-size:.9rem;color:var(--text-muted);font-weight:500}.app-footer{padding:20px 0;background:#f8fafc;border-top:1px solid var(--border-light);margin-top:40px}.footer-grid{display:flex;flex-direction:column;gap:30px}.footer-bottom{text-align:center;padding-top:var(--spacing-md);border-top:1px solid var(--border-light);color:var(--text-muted);font-size:.875rem}.xhs-footer-card{background:#fff;border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}.xhs-qr-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.xhs-info-section h4{font-size:1rem;color:var(--text-primary);margin-bottom:4px}.xhs-info-section .xhs-id{font-size:.95rem;color:#ff2442;font-weight:800;margin-bottom:2px}.xhs-info-section p{font-size:.9rem;color:var(--text-muted);font-weight:500}.xhs-qr-box{width:80px;height:80px;background:#f8fafc;border-radius:8px;padding:4px;border:1px solid var(--border-light)}.xhs-qr-box img{width:100%;height:100%;object-fit:contain}.footer-qr-container{display:flex;justify-content:center;gap:40px;margin:20px auto;padding:10px}.qr-item{text-align:center;transition:transform .3s ease}.qr-item:hover{transform:translateY(-5px)}.qr-img{width:140px;height:140px;border-radius:16px;background:#fff;padding:10px;box-shadow:0 10px 30px #00000014;display:block;margin-bottom:12px;border:1px solid rgba(0,0,0,.03)}.qr-label{font-size:1.05rem;font-weight:800;color:var(--text-primary);background:var(--primary-gradient);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:block}.share-icon-placeholder{width:140px;height:140px;border-radius:16px;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px #00000014;margin-bottom:12px;border:1px solid rgba(0,0,0,.03);transition:all .3s ease}.share-icon-placeholder:hover{background:#f8fafc;transform:scale(1.05)}.share-emoji{font-size:3rem}.share-option-btn{transition:all .2s ease}.share-option-btn:hover{transform:translateY(-5px);box-shadow:0 8px 15px #00000014;border-color:var(--accent-blue)!important}.wechat-btn .share-icon{color:#07c160}.xhs-btn .share-icon{color:#ff2442}.universal-btn .share-icon{color:#3b82f6}.footer-share-top{width:100%;border-bottom:1px solid var(--border-light);padding-bottom:10px;margin-bottom:15px}.share-circles-row{display:flex!important;flex-direction:row!important;justify-content:center!important;align-items:center!important;gap:clamp(10px,4vw,35px)!important;padding:8px 0!important;flex-wrap:nowrap!important;width:100%!important;box-sizing:border-box}.share-circle-item{display:flex!important;flex-direction:column!important;align-items:center!important;width:clamp(60px,15vw,80px)!important;cursor:pointer!important;transition:transform .2s cubic-bezier(.175,.885,.32,1.275)}.share-circle-item:hover{transform:translateY(-5px)}.share-circle{width:clamp(40px,10vw,58px);height:clamp(40px,10vw,58px);border-radius:50%;display:flex!important;align-items:center!important;justify-content:center!important;margin-bottom:clamp(6px,1.5vw,10px);transition:all .3s ease}.xhs-circle{background:#ff2442;box-shadow:0 4px 12px #ff244240}.wechat-circle{background:#07c160;box-shadow:0 4px 12px #07c16040}.url-circle{background:#f1f5f9;box-shadow:0 4px 12px #00000014}.cs-circle{background:#3b82f6;box-shadow:0 4px 12px #3b82f640}.share-group{background:#fff9;border:1px solid #e2e8f0;border-radius:clamp(12px,3vw,20px);padding:clamp(8px,2vw,15px) clamp(6px,1.5vw,10px);position:relative;display:flex;flex-direction:column;align-items:center}.share-group-title{font-size:clamp(9px,2vw,.75rem);font-weight:800;color:#64748b;margin-bottom:clamp(6px,1.5vw,12px);text-transform:uppercase;letter-spacing:.5px}.share-icons-container{display:flex;justify-content:center;gap:clamp(10px,4vw,35px)!important}.share-circle-item span{font-size:clamp(10px,2.2vw,.75rem);font-weight:700;color:var(--text-primary);text-align:center;white-space:nowrap}@media (max-width: 480px){.home-grid{grid-template-columns:repeat(3,1fr);gap:12px}.item-icon{font-size:1.8rem}.item-label{font-size:.9rem}.main-logo{font-size:4.2rem;letter-spacing:-2px}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;border-radius:var(--radius-lg);font-size:.95rem;font-weight:800;cursor:pointer;transition:all var(--transition-normal);border:none;outline:none;font-family:inherit;gap:8px;white-space:nowrap}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 12px #2563eb33}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2563eb4d}.btn-primary:active{transform:scale(.97)}.btn-outline{background:#fff;color:var(--accent-blue);border:1.5px solid var(--accent-blue);box-shadow:0 4px 12px #2563eb1a}.btn-outline:hover{background:var(--primary-gradient);color:#fff;transform:translateY(-2px);box-shadow:0 6px 16px #2563eb4d;border-color:transparent}.btn-outline:active{transform:scale(.97)}.view-toggle-container{display:flex;gap:8px;background:#f1f5f9;padding:6px;border-radius:14px;width:100%;margin-top:10px}.view-toggle-btn{flex:1;border:none;background:transparent;padding:10px;border-radius:10px;font-size:.9rem;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.view-toggle-btn.active{background:#fff;color:var(--accent-blue);box-shadow:0 4px 12px #2563eb26}.badge{padding:4px 10px;border-radius:8px;font-size:.75rem;font-weight:800;color:#fff;display:inline-block;min-width:65px;text-align:center;box-shadow:0 2px 4px #0000001a}.badge-success{background-color:#059669}.badge-warning{background-color:#f59e0b}.badge-danger{background-color:#dc2626}.badge-info{background-color:#2563eb}.status-badge{padding:4px 8px;border-radius:var(--radius-sm);font-size:.72rem;font-weight:600;white-space:nowrap}.status-badge.status-ontime{background:var(--success-gradient);color:#fff}.status-badge.status-delayed{background:var(--warning-gradient);color:#fff}.status-badge.status-cancelled{background:var(--danger-gradient);color:#fff}.status-badge.status-landed,.status-badge.status-departed{background:var(--accent-gradient);color:#fff}.status-badge.status-boarding{background:var(--primary-gradient);color:#fff}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding:40px 10px;overflow-y:auto;animation:fadeIn .3s ease}.modal-content{background:#000;border-radius:var(--radius-xl);width:95%;max-width:1000px;position:relative;padding:2px;box-shadow:0 25px 50px -12px #00000080;animation:modalScaleUp .3s cubic-bezier(.175,.885,.32,1.275);border:1px solid rgba(255,255,255,.1);margin:auto 0}@keyframes modalScaleUp{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.modal-close{position:absolute;top:15px;right:15px;background:#fff3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;color:#fff;width:36px;height:36px;border-radius:50%;font-size:1.2rem;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close:hover{background:#ffffff4d;transform:rotate(90deg)}#feature-request-modal .modal-content,#lost-report-modal .modal-content,#lost-detail-modal .modal-content,#wechat-qr-modal .modal-content{background:#fff;color:var(--text-primary);max-width:500px}#feature-request-modal .modal-close,#lost-report-modal .modal-close,#lost-detail-modal .modal-close,#wechat-qr-modal .modal-close{color:var(--text-primary);background:#0000000d}.cctv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:10px}.cctv-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 12px #0000000d;transition:transform .3s ease;cursor:pointer;border:1px solid var(--border-light)}.cctv-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a}.cctv-video-container{position:relative;width:100%;aspect-ratio:16/9;background:#000;overflow:hidden}.cctv-video-el{width:100%;height:100%;display:block;object-fit:cover}.cctv-modal-body{width:100%;aspect-ratio:16/9;background:#000;display:flex;align-items:center;justify-content:center}.cctv-modal-video{width:100%;height:100%;object-fit:contain}.cctv-modal-info{padding:20px;background:#111}.ad-container{margin:20px auto;width:100%;min-height:90px;background:transparent;text-align:center;overflow:hidden;display:none}#festival .ad-container{display:block;margin-bottom:25px;border-radius:var(--radius-lg);background:#f8fafc;border:1px dashed var(--border-light);position:relative;min-height:100px}#festival .ad-container:before{content:"광고 로드 �?..";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-muted);font-size:.8rem;font-weight:500}#festival .ad-container ins{position:relative;z-index:1}@media (max-width: 768px){.ad-container{margin:15px auto;min-height:50px}}.cctv-tag{position:absolute;top:10px;left:10px;background:#ff2442;color:#fff;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:800;display:flex;align-items:center;gap:4px}.cctv-tag:before{content:"";width:6px;height:6px;background:#fff;border-radius:50%;animation:flash 1s infinite}.cctv-info{padding:12px;display:flex;flex-direction:column;gap:2px}.cctv-name{font-size:.95rem;font-weight:700;color:var(--text-primary)}.cctv-name-cn{font-size:.95rem;font-weight:700;color:var(--text-muted)}.weather-nav-wrapper{width:100%}.location-tabs{display:flex!important;flex-direction:column!important;width:100%!important;padding:2px 0!important;margin-top:5px!important;gap:0!important}.loc-row{display:flex!important;flex-wrap:nowrap!important;align-items:stretch!important;justify-content:space-between!important;gap:4px!important;width:100%!important;overflow-x:hidden!important;padding:16px 2px 2px!important;-webkit-overflow-scrolling:touch!important}.loc-row:nth-child(2){padding-top:2px!important;padding-bottom:12px!important}.loc-row::-webkit-scrollbar{display:none!important}.loc-group-wrapper{display:flex!important;align-items:stretch!important;gap:4px!important;position:relative!important;padding:8px 1px 6px!important;border-radius:var(--radius-lg)!important;border-width:1.5px!important;border-style:solid!important;background:#fff!important;flex:1 1 auto!important;width:auto!important}.group-north{border-color:#8b5cf6!important;background:#8b5cf60d!important}.group-south{border-color:#f59e0b!important;background:#f59e0b0d!important}.group-west{border-color:#4ade80!important;background:#4ade800d!important}.group-east{border-color:#3b82f6!important;background:#3b82f60d!important}.group-mountain{border-color:#94a3b8!important;background:#94a3b80d!important}.group-label{position:absolute!important;top:-12px!important;left:4px!important;background:#fff!important;padding:1px 4px!important;font-size:.65rem!important;font-weight:900!important;line-height:1!important;z-index:20!important;border-radius:4px!important;box-shadow:0 1px 3px #0000001a!important}.loc-row:nth-child(2) .group-label{top:auto!important;bottom:-10px!important}.group-north .group-label{color:#6d28d9!important;border:1.2px solid #8b5cf6!important}.group-south .group-label{color:#b45309!important;border:1.2px solid #f59e0b!important}.group-west .group-label{color:#16a34a!important;border:1.2px solid #4ade80!important}.group-east .group-label{color:#1d4ed8!important;border:1.2px solid #3b82f6!important}.group-mountain .group-label{color:#475569!important;border:1.2px solid #94a3b8!important}.location-tab{flex:1 1 0!important;width:auto!important;min-width:50px!important;max-width:90px!important;background:var(--bg-card);border:1.5px solid var(--border-light);padding:8px 0;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);display:flex!important;flex-direction:column!important;align-items:center!important;gap:3px!important;box-shadow:var(--shadow-sm)}.location-tab:hover{background:var(--bg-card-hover);border-color:var(--accent-purple);transform:translateY(-2px)}.location-tab.active{background:var(--primary-gradient);border-color:transparent!important;box-shadow:0 3px 8px #4338ca4d}.tab-icon{font-size:1.1rem;margin-bottom:2px}.tab-name{font-size:.75rem;font-weight:800;color:var(--text-primary)}.location-tab.active .tab-name{color:#fff!important}.current-weather{background:var(--bg-card);border-radius:24px;padding:20px 16px;margin-bottom:24px;border:1px solid var(--border-light);display:flex;flex-direction:column;align-items:stretch;gap:12px;box-shadow:var(--shadow-md)}.weather-main{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%}.weather-icon{font-size:2.8rem;flex-shrink:0}.weather-temp{display:flex;align-items:baseline;gap:2px;flex-shrink:0}.temp-value{font-size:2.8rem;font-weight:900;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.temp-unit{font-size:1.2rem;font-weight:700;color:var(--text-primary)}.weather-loader,.loading-lost{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 0;width:100%!important;text-align:center;grid-column:1 / -1}.weather-loader{min-height:200px;background:#fff6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;border:1px solid rgba(255,255,255,.3)}.weather-loader img{width:80px;height:80px;margin-bottom:20px;animation:weatherPulse 2s infinite ease-in-out;filter:drop-shadow(0 10px 15px rgba(0,0,0,.1))}.weather-loading-text{font-size:1rem;font-weight:700;color:var(--text-secondary);letter-spacing:-.5px}@keyframes weatherPulse{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.1);opacity:1}}.weather-details{display:flex;flex-direction:column;justify-content:center;flex:1;gap:6px;border-left:1px solid var(--border-light);padding-left:16px;margin-left:4px;min-width:0}.weather-detail-item{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-secondary);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hourly-scroll{display:flex;gap:8px;overflow-x:auto;padding:16px 4px 20px;-webkit-overflow-scrolling:touch}.weather-alerts-container{width:100%;margin-top:10px;margin-bottom:15px;display:flex;justify-content:center;min-height:40px}.alert-type-badge.gray{background:#adb5bd}.alert-more{font-size:.65rem;color:#fa5252;font-weight:700;margin-left:auto}.weather-alert-card{background:#ff244214;border:1.5px solid rgba(255,36,66,.2);border-radius:14px;padding:14px 18px;display:flex;align-items:center;gap:12px;width:100%;box-sizing:border-box;box-shadow:0 4px 15px #ff24420d;cursor:pointer}.weather-alert-card.no-alerts{background:#f8f9fa;border:1px dashed #dee2e6;opacity:1}.alert-type-badge{background:#ff2442;color:#fff;padding:3px 10px;border-radius:6px;font-size:.75rem;font-weight:800;white-space:nowrap;letter-spacing:-.2px}.no-alerts .alert-type-badge{background:#333}.alert-msg{color:#222;font-weight:800;font-size:1.1rem;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.no-alerts .alert-msg{color:#666;font-weight:400;font-size:.88rem}.animate-slide-up{animation:alertSlideUp .6s cubic-bezier(.16,1,.3,1)}@keyframes alertSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hourly-scroll::-webkit-scrollbar{height:4px;display:block}.hourly-scroll::-webkit-scrollbar-track{background:#0000000d;border-radius:10px}.hourly-scroll::-webkit-scrollbar-thumb{background:var(--accent-blue);opacity:.5;border-radius:10px}.hourly-item{background:#fff;border-radius:16px;padding:12px 8px;min-width:80px;text-align:center;border:1px solid var(--border-light);transition:all .2s ease;box-shadow:0 4px 12px #00000008;flex-shrink:0}.hourly-time{font-size:.85rem;font-weight:700;color:var(--text-muted);margin-bottom:2px}.hourly-icon{font-size:1.6rem;margin:4px 0}.hourly-temp{font-size:1.1rem;font-weight:900;color:var(--text-primary);margin-bottom:2px}.hourly-wind{font-size:.72rem;color:var(--text-muted);font-weight:600;margin-bottom:2px}.hourly-precip{font-size:.72rem;font-weight:700;color:var(--text-secondary)}.hourly-precip.precip-blue{color:var(--accent-blue)}.subsection-title-wrap{display:none!important}.weekly-item.active .weekly-day{color:var(--accent-blue)!important;font-weight:900!important}.weather-summary-btn-container{display:flex;justify-content:center;margin:10px 0 20px}.weather-summary-btn.inline{position:static!important;transform:none!important;margin:0 auto!important}.subsection-title-wrap{display:flex;justify-content:center;align-items:center;position:relative;margin:35px 0 20px;padding:0 4px}.subsection-title,.cmp-cur-weather-head{margin:35px 0 20px;font-size:1.15rem;font-weight:800;text-align:center;width:100%}.subsection-title{color:var(--accent-blue);margin:0}.subsection-title-wrap .subsection-title{padding:0 75px;box-sizing:border-box}.weather-summary-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--primary-gradient);color:#fff;font-size:.85rem;font-weight:800;border:none;border-radius:var(--radius-lg);cursor:pointer;white-space:nowrap;box-shadow:0 4px 12px #2563eb33;transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.weather-summary-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2563eb4d}.weather-summary-btn:active{transform:scale(.97)}.bar-title{flex:1;text-align:center;margin-right:40px}.weekly-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px}.weekly-item{background:#fff;border-radius:12px;padding:10px 0;text-align:center;border:1px solid var(--border-light);box-shadow:0 2px 8px #0000000a;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:4px}.weekly-item.active{border-color:var(--accent-blue);background:#2563eb08;transform:translateY(-2px)}.weekly-day{font-size:.9rem;font-weight:800;color:var(--text-muted)}.weekly-icon{font-size:1.3rem;margin:2px 0}.weekly-temps{font-size:.9rem;font-weight:800}.temp-high{color:#ef4444}.temp-low{color:#3b82f6}.weekly-precip{display:flex;flex-direction:column;align-items:center;gap:1px;font-weight:700;font-size:.75rem;line-height:1.2}.weekly-precip .amt{opacity:.8;font-size:.65rem;color:var(--text-muted)}.air-quality-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:15px}.air-quality-item{background:#fff;border-radius:var(--radius-xl);padding:20px 10px;border:1px solid var(--border-light);display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:var(--shadow-md);transition:transform .2s}.air-quality-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.air-label{font-size:.95rem;font-weight:800;color:var(--text-muted);text-transform:uppercase}.air-svg-box{position:relative;width:70px;height:70px;display:flex;align-items:center;justify-content:center}.air-circle-bg{fill:none;stroke:#f1f5f9;stroke-width:6}.air-circle-bar{fill:none;stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset 1.5s cubic-bezier(.4,0,.2,1)}.air-lv1{stroke:#10b981;color:#10b981}.air-lv2{stroke:#f59e0b;color:#f59e0b}.air-lv3{stroke:#ef4444;color:#ef4444}.air-lv4{stroke:#9333ea;color:#9333ea}.air-circle-status{position:absolute;font-size:1.1rem;font-weight:900}.air-lvv-wrap{display:flex;align-items:baseline;gap:2px}.air-lvv{font-size:1.25rem;font-weight:900}.unit{font-size:.65rem;font-weight:700;opacity:.7}.air-quality-error{grid-column:1 / -1;text-align:center;padding:24px;background:#f8fafc;border-radius:16px;border:1px dashed var(--border-light);color:var(--text-muted);font-size:.9rem;line-height:1.6}.status-card{background:#fff;border-radius:20px;padding:2rem;margin-bottom:24px;display:flex;align-items:center;gap:20px;border:2px solid var(--border-light);box-shadow:0 4px 15px #0000000d}.status-card.status-open{border-color:#10b981;background:linear-gradient(135deg,#10b9810d,#10b98105)}.status-card.status-closed{border-color:#ef4444;background:linear-gradient(135deg,#ef44440d,#ef444405)}.trails-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;padding-bottom:30px}@media (min-width: 768px){.trails-grid{grid-template-columns:repeat(3,1fr);gap:12px}}.trail-block{background:#fff;border-radius:12px;border:1px solid var(--border-light);box-shadow:0 4px 12px #00000008;display:flex;flex-direction:column;align-items:center;text-align:center;min-height:100px;transition:transform .2s ease,box-shadow .2s ease;overflow:hidden}.trail-block:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.t-status-line,.t-name-line,.t-info-line{flex:1;display:flex;align-items:center;justify-content:center;width:100%}.t-name-line h4{font-size:.78rem;font-weight:800;color:var(--text-primary);margin:0;line-height:1.2}.t-info-line{border-top:1px dashed #edf2f7;background:#fdfdfd}.t-info-line span{font-size:.62rem;font-weight:800;color:var(--text-muted);white-space:nowrap;display:block}.trail-status-badge{padding:3px 12px;border-radius:6px;font-size:.65rem;font-weight:800;color:#fff;box-shadow:0 2px 4px #0000001a}.trail-status-badge.open{background:var(--success-gradient)}.trail-status-badge.partial{background:var(--warning-gradient)}.trail-status-badge.closed{background:var(--danger-gradient)}.trail-status-badge.info{background:var(--primary-gradient)}.prob-value-large{font-size:1.6rem;font-weight:900;color:#2b6cb0;letter-spacing:-.05em;text-shadow:0 2px 4px rgba(0,0,0,.1);-webkit-text-stroke:.5px #2b6cb0}.probability-block{padding:0!important;overflow:hidden;justify-content:space-between;min-height:100px;background:#fff}.prob-main{flex:2;display:flex;align-items:center;justify-content:center;width:100%}.prob-footer{flex:1;width:100%;background:#f8fafc;display:flex;align-items:center;justify-content:center;border-top:1px solid #edf2f7;padding:2px 0}.prob-label{font-size:.78rem;font-weight:800;color:var(--text-muted);white-space:nowrap;width:100%;text-align:center}.trail-info-compact{display:flex;justify-content:space-between;align-items:center;width:100%;border-top:1px dashed var(--border-light);padding-top:8px;flex-wrap:nowrap;gap:5px}.trail-info-compact span{font-size:.65rem;font-weight:700;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.flight-tabs{display:flex;justify-content:center;background:#e2e8f0;padding:6px;border-radius:30px;margin-bottom:24px}.flight-tab{flex:1;text-align:center;padding:12px 0;font-size:1rem;font-weight:800;color:var(--text-muted);background:transparent;border:none;border-radius:25px;cursor:pointer;transition:all .2s ease}.flight-tab.active{background:#fff;color:var(--accent-blue);box-shadow:0 4px 10px #00000014}.flight-table{background:#fff;border-radius:20px;overflow:hidden;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.flight-row{display:flex;padding:12px 6px;border-bottom:1px solid var(--border-light);align-items:center;font-size:.8rem;cursor:pointer;transition:all .2s ease;border-left:4px solid transparent}.flight-row:hover:not(.flight-header){background-color:#f8fafc}.flight-row.selected{background-color:#eff6ff;border-left-color:var(--accent-blue);color:var(--accent-blue)}.flight-row.selected .flight-col{font-weight:800}.flight-row.flight-header{background:var(--bg-card-hover);font-weight:800;color:var(--text-primary);border-bottom:2px solid var(--border-light);cursor:default}.flight-col{flex:1;text-align:center;min-width:0;display:flex;align-items:center;justify-content:center;font-weight:600}.festival-month-filter{display:flex;gap:10px;overflow-x:auto;padding:10px 4px;margin-bottom:20px;-webkit-overflow-scrolling:touch}.month-tab{padding:8px 20px;border-radius:20px;background:#e2e8f0;color:var(--text-muted);font-size:.95rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all .2s ease}.month-tab.active{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 12px #4338ca4d}.festival-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:24px;padding-bottom:30px}.festival-card.text-only{min-height:140px;background:#fff;border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s ease;overflow:hidden}.festival-card.text-only:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--accent-blue)}.festival-card.text-only .festival-info{padding:20px;display:flex;flex-direction:column;justify-content:flex-start;gap:12px}.festival-header{display:flex;justify-content:space-between;align-items:center;width:100%}.festival-card.text-only .tag{position:static;padding:4px 10px;font-size:.7rem;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.chinese-title{font-size:.95rem;color:var(--accent-blue);font-weight:800}.festival-title{font-size:1.25rem;font-weight:900;color:var(--text-primary);line-height:1.4;margin:0}.festival-date{font-size:.85rem;color:var(--text-muted);font-weight:600;display:flex;align-items:center;gap:6px;margin-top:auto;padding-top:8px;border-top:1px dashed #e2e8f0}.tag.ing{background:#ef4444}.tag.upcoming{background:#3b82f6}.search-filter-box{background:#fff;border-radius:24px;padding:24px;margin-top:15px;margin-bottom:30px;border:1px solid var(--border-light);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:12px}.filter-select,.date-input{width:100%;padding:14px 16px;border-radius:14px;border:1.5px solid #edf2f7;font-size:.95rem;font-weight:600;color:var(--text-primary);outline:none;transition:border-color .2s}.filter-select:focus,.date-input:focus{border-color:var(--accent-blue)}.lost-result-count{text-align:right;margin-bottom:12px;font-size:.85rem;color:var(--text-muted);padding-right:4px}.lost-result-count strong{color:var(--accent-blue);font-weight:800}.search-btn{width:60px;flex-shrink:0;padding:12px;border-radius:var(--radius-lg);border:none;background:var(--primary-gradient);color:#fff;font-weight:800;font-size:1rem;cursor:pointer;transition:transform var(--transition-normal);box-shadow:0 4px 12px #2563eb33;display:flex;align-items:center;justify-content:center}.search-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2563eb4d}.search-btn:active{transform:scale(.97)}.lost-goods-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:15px}.lost-card.gallery-item{aspect-ratio:1 / 1;border-radius:12px;overflow:hidden;background:#f1f5f9;position:relative;cursor:pointer;transition:all .2s ease;border:1px solid var(--border-light)}.lost-card.gallery-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.lost-img-box{width:100%;height:100%;position:relative}.lost-img-box img{width:100%;height:100%;object-fit:cover}.lost-category-badge-overlay{position:absolute;top:8px;left:8px;background:#0009;color:#fff;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:800;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none;z-index:2}.no-lost-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f8fafc;color:#cbd5e1;font-size:2.5rem}.lost-table-container{width:100%;overflow-x:auto;background:#fff;border-radius:20px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.lost-table{width:100%;border-collapse:collapse;min-width:600px}.lost-table th{background:var(--bg-card-hover);padding:14px 10px;text-align:center;border-bottom:2px solid var(--border-light);font-size:.85rem;font-weight:800}.lost-table td{padding:12px 10px;border-bottom:1px solid var(--border-light);font-size:.8rem;font-weight:500;text-align:center;white-space:nowrap}.lost-category-badge{display:inline-block;padding:3px 10px;background:#2563eb1a;color:var(--accent-blue);border-radius:20px;font-size:.72rem;font-weight:800}.lost-table-btn{padding:8px 16px;background:#fff;color:var(--accent-blue);border:1.5px solid var(--accent-blue);border-radius:var(--radius-lg);font-size:.85rem;font-weight:800;cursor:pointer;transition:all var(--transition-normal)}.lost-table-btn:hover{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.location-weather,.flight-content{display:none}.location-weather.active,.flight-content.active{display:block;animation:fadeIn .4s ease-out}.lost-goods-grid{display:none}.lost-goods-grid.active{display:grid;animation:fadeIn .4s ease-out}.lost-table-container{display:none}.lost-table-container.active{display:block;margin-top:15px;animation:fadeIn .4s ease-out}@media (max-width: 480px){.cctv-grid{grid-template-columns:repeat(2,1fr);gap:10px}.trails-grid{grid-template-columns:repeat(3,1fr);gap:4px}.weekly-grid{grid-template-columns:repeat(5,1fr);gap:4px}.weekly-item{padding:8px 1px;min-width:0}.weekly-day,.weekly-temps{font-size:.72rem}.weekly-precip,.weekly-precip .amt{font-size:.58rem}.weather-main{gap:8px}.weather-icon,.temp-value{font-size:2.2rem}.weather-details{padding-left:12px;gap:4px}.weather-detail-item{font-size:.72rem;white-space:nowrap}.hourly-item{min-width:72px;padding:10px 4px}.hourly-precip{font-size:.7rem}.festival-notice-container{padding:30px 10px;display:flex;justify-content:center;width:100%}.festival-notice-card{background:#f8fafc;border-radius:20px;border:1.5px dashed #cbd5e1;padding:40px 20px;text-align:center;width:100%;max-width:500px;box-shadow:0 4px 15px #00000005;transition:all .3s ease}.festival-notice-card:hover{transform:translateY(-3px);border-color:var(--accent-blue);background:#f0f7ff}.notice-icon{font-size:2.5rem;margin-bottom:20px}.notice-title{font-size:1.3rem;font-weight:800;color:var(--text-primary);margin-bottom:12px}.notice-highlight{color:var(--accent-blue);position:relative;display:inline-block}.notice-highlight:after{content:"";position:absolute;bottom:2px;left:0;width:100%;height:8px;background:#2563eb1a;z-index:-1}.notice-subtitle{font-size:.92rem;color:var(--text-muted);line-height:1.6;font-weight:600}.notice-korean{font-size:.8rem;color:#94a3b8;margin-top:20px;border-top:1px solid #e2e8f0;padding-top:15px;font-weight:500}.lost-goods-grid{grid-template-columns:repeat(3,1fr);gap:6px}.flight-row{font-size:.72rem;padding:12px 4px}.flight-col{font-size:.72rem}}.lost-table-img{width:45px;height:45px;object-fit:cover;border-radius:8px;border:1px solid var(--border-light)}.lost-modal-img-container{width:100%;height:250px;background:#f8fafc;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:20px 20px 0 0}.lost-modal-img{width:100%;height:100%;object-fit:contain}.lost-modal-no-img{font-size:3rem;color:#cbd5e1}.lost-modal-info{padding:24px;display:flex;flex-direction:column;gap:16px}.lost-modal-header{display:flex;flex-direction:column;gap:6px}.lost-modal-category{font-size:.8rem;color:var(--accent-blue);font-weight:800}.lost-modal-title{font-size:1.3rem;font-weight:800;color:var(--text-primary);line-height:1.3}.lost-modal-details{display:flex;flex-direction:column;gap:12px;background:#f8fafc;padding:16px;border-radius:16px}.lost-modal-field{display:flex;gap:12px;font-size:.95rem}.lost-modal-label{color:var(--text-muted);font-weight:600;min-width:70px}.lost-modal-value{color:var(--text-primary);font-weight:700}.lost-modal-footer{padding-top:5px;display:flex;gap:12px}.lost-modal-btn{flex:1;padding:14px;border-radius:14px;font-weight:800;text-align:center;border:none;cursor:pointer;font-size:1rem;transition:all .2s ease}.lost-modal-btn.primary{background:var(--primary-gradient);color:#fff}.lost-modal-btn.secondary{background:#f1f5f9;color:var(--text-secondary)}.lost-report-btn{width:100%;padding:16px;border-radius:var(--radius-lg);border:1.5px solid var(--accent-blue);background:#fff;color:var(--accent-blue);font-weight:800;font-size:1.05rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all var(--transition-normal);box-shadow:0 4px 12px #2563eb0d}.lost-report-btn:hover{background:var(--primary-gradient);color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:0 6px 16px #2563eb33}.lost-report-form-content{width:95%;max-width:500px;padding:30px;border-radius:24px}.lost-report-header{text-align:center;margin-bottom:25px}.lost-report-header h3{font-size:1.4rem;color:var(--text-primary);margin-bottom:8px}.lost-report-header p{font-size:.85rem;color:var(--text-muted);line-height:1.5;padding:0 10px}.lost-report-body .form-group{margin-bottom:18px;display:flex;flex-direction:column;gap:6px}.lost-report-body label{font-size:.82rem;font-weight:800;color:var(--text-secondary);margin-left:4px}.lost-report-body input,.lost-report-body textarea{width:100%;padding:12px 15px;border-radius:12px;border:1.5px solid #edf2f7;font-size:.92rem;font-weight:600;font-family:inherit;transition:all .2s;background:#f8fafc}.lost-report-body input:focus,.lost-report-body textarea:focus{border-color:var(--accent-blue);background:#fff;box-shadow:0 0 0 4px #2563eb0d;outline:none}.lost-report-body textarea{height:80px;resize:none;line-height:1.5}.lost-report-body .form-row{display:flex;gap:12px}.lost-report-body .form-row .form-group{flex:1}.form-submit-btn{width:100%;padding:16px;border-radius:16px;border:none;background:var(--primary-gradient);color:#fff;font-weight:800;font-size:1.05rem;cursor:pointer;margin-top:10px;transition:all .2s;box-shadow:0 4px 15px #2563eb40}.form-submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #2563eb59;filter:brightness(1.05)}.form-submit-btn:active{transform:scale(.98)}.photo-preview{margin-top:8px;width:80px;height:80px;border-radius:12px;overflow:hidden;border:2px solid #edf2f7;background:#f8fafc;display:flex;align-items:center;justify-content:center}.photo-preview img{width:100%;height:100%;object-fit:cover}.form-status{margin-top:15px;padding:12px;border-radius:10px;font-size:.85rem;font-weight:700;text-align:center;animation:fadeIn .3s ease}.form-status.success{background:#ecfdf5;color:#059669}.form-status.error{background:#fef2f2;color:#dc2626}@media (max-width: 600px){.lost-report-form-content{padding:20px 15px;border-radius:16px}.lost-report-header h3{font-size:1.2rem}.lost-report-body .form-row{flex-direction:column;gap:0}.lost-report-body input,.lost-report-body textarea{padding:10px 12px;font-size:.88rem}.form-submit-btn{padding:14px;font-size:1rem}}.wsm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:9000;padding:16px;box-sizing:border-box}.wsm-panel{background:#fff;border-radius:20px;width:100%;max-width:480px;max-height:90vh;overflow:hidden;box-shadow:0 10px 40px #00000040;display:flex;flex-direction:column}.wsm-header2{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;background:#fff;border-bottom:5px solid #f8fafc}.wsm-title-bar{display:flex;align-items:center;gap:10px;font-size:1.15rem;font-weight:900;color:#1e293b}.wsm-date-badge{background:#ecfdf5;color:#059669;padding:3px 12px;border-radius:20px;font-size:.82rem;font-weight:800}.wsm-close-btn2{background:#f1f5f9;border:none;color:#64748b;font-size:1.1rem;width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.wsm-body2{overflow-y:auto;padding:20px 14px;scrollbar-width:none;background:#f8fafc}.wsm-body2::-webkit-scrollbar{display:none}.wsm-loc-block{background:#fff;border-radius:16px;padding:20px 12px;margin-bottom:16px;box-shadow:0 2px 8px #00000005;position:relative;overflow:hidden}.wsm-card-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-25deg);font-size:3rem;font-weight:900;color:#0000000a;pointer-events:none;white-space:nowrap;z-index:0;text-transform:uppercase;letter-spacing:2px;-webkit-user-select:none;user-select:none}.wsm-loc-block:last-child{margin-bottom:0}.wsm-loc-title{position:relative;z-index:1;font-size:1.25rem;font-weight:900;color:#0f172a;margin-bottom:24px;display:flex;align-items:baseline;gap:8px}.wsm-loc-sub{font-size:.9rem;color:#94a3b8;font-weight:600}.wsm-hourly-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(6,1fr);gap:20px 4px}.wsm-h-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px}.h-time{font-size:.85rem;color:#64748b;font-weight:700}.h-icon{font-size:1.6rem;line-height:1}.h-temp{font-size:1.15rem;font-weight:900;color:#0f172a}.h-wind{font-size:.72rem;color:#f08c00;font-weight:700}.h-precip{font-size:.72rem;color:#94a3b8;font-weight:700}.h-precip.p-blue{color:#3b82f6;font-weight:900}.wsm-nodata{grid-column:1 / -1;text-align:center;color:#94a3b8;font-size:.9rem;padding:20px}.alert-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:10000;padding:16px;box-sizing:border-box}.alert-modal-panel{background:#fff;border-radius:24px;width:100%;max-width:480px;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 50px #0000004d}.alert-modal-header{padding:20px 24px;border-bottom:1px solid #f1f5f9;display:flex;align-items:center;justify-content:center;position:relative}.alert-modal-title{font-size:1.1rem;font-weight:800;color:#0f172a;text-align:center}.alert-modal-close{position:absolute;right:16px;top:50%;transform:translateY(-50%);background:#f1f5f9;border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b;font-size:1.1rem;transition:all .2s;box-shadow:0 2px 5px #0000000d}.alert-modal-close:hover{background:#e2e8f0;color:#0f172a;transform:translateY(-50%) rotate(90deg)}.alert-modal-body{padding:16px 20px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.alert-history-item{background:#f8fafc;border:1.5px solid #edf2f7;border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:8px;transition:transform .2s;font-size:.9rem}.alert-history-item:hover{transform:scale(1.01)}.alert-history-item.warning{background:#fffbeb;border-color:#fde68a}.alert-history-item.danger{background:#fef2f2;border-color:#fecaca}.alert-history-label{font-weight:800;color:#64748b;flex-shrink:0}.alert-history-item.warning .alert-history-label{color:#d97706}.alert-history-item.danger .alert-history-label{color:#dc2626}.alert-history-time{font-weight:700;color:#94a3b8;font-family:Outfit,sans-serif;flex-shrink:0}.alert-history-text{font-weight:700;color:#1e293b;white-space:normal;word-break:break-all;flex:1}.cctv-marker{cursor:pointer;transition:none!important;transform:none!important}.marker-dot{fill:#ef4444;stroke:#fff;stroke-width:4px;filter:drop-shadow(0 0 10px rgba(239,68,68,.8));transition:none!important}.marker-label{font-family:Outfit,sans-serif;pointer-events:none;opacity:.9;transition:none!important}.jeju-region{pointer-events:auto}.jeju-region.active{filter:url(#region-outline)}.lost-status-tag{display:inline-block;padding:2px 8px;background:#f1f5f9;color:#64748b;border-radius:4px;font-size:.7rem;font-weight:700}.lost-status-tag.active{background:#10b9811a;color:#10b981}.wsm-header-btns{display:flex;gap:8px;align-items:center}.wsm-capture-btn{background:#0000000d;border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.1rem;transition:all .2s}.wsm-capture-btn:hover{background:#0000001a;transform:scale(1.1)}.wsm-capture-btn:active{transform:scale(.9)}.wsm-header2{position:relative!important;display:flex!important;justify-content:flex-end!important}.wsm-title-bar{position:absolute!important;left:50%!important;transform:translate(-50%)!important;pointer-events:none!important}.capture-result-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;z-index:10001;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s ease}.capture-result-container{max-width:100%;max-height:80vh;overflow-y:auto;border-radius:12px;box-shadow:0 10px 40px #00000080;background:#f1f5f9}.capture-result-img{display:block;width:100%;height:auto}.capture-result-info{color:#fff;margin-top:16px;font-size:.95rem;text-align:center;line-height:1.5}.capture-result-close-btn{position:absolute;top:20px;right:20px;width:40px;height:40px;background:#fff;color:#000;border:none;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0003}.capture-gallery-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;z-index:10002;display:flex;flex-direction:column;padding:20px;overflow-y:auto;-webkit-overflow-scrolling:touch;animation:fadeIn .3s ease}.capture-gallery-header{color:#fff;text-align:center;margin-bottom:24px;padding-top:40px}.capture-gallery-header h2{font-size:1.4rem;font-weight:800;margin-bottom:8px}.capture-gallery-header p{font-size:.9rem;opacity:.8}.capture-gallery-grid{display:grid;grid-template-columns:1fr;gap:24px;padding-bottom:60px;max-width:450px;margin:0 auto;width:100%}.capture-gallery-item{background:#f1f5f9;border-radius:16px;overflow:hidden;box-shadow:0 10px 30px #00000080}.capture-gallery-img{display:block;width:100%;height:auto;-webkit-touch-callout:default}.capture-gallery-item-info{padding:12px;text-align:center;font-weight:700;font-size:1rem;color:#1e293b;border-top:1px solid #e2e8f0}.capture-gallery-close{position:fixed;top:20px;right:20px;width:44px;height:44px;background:#fff;color:#000;border:none;border-radius:50%;font-size:1.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 5px 15px #0000004d;z-index:10003}.wsm-overlay.fullscreen{background:#f8fafc!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;padding:0!important}.wsm-panel.fullscreen{max-width:none!important;max-height:100%!important;height:100%!important;border-radius:0!important;box-shadow:none!important}.wsm-fullscreen-hide{display:none!important}.wsm-exit-hint{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#0f172ab3;color:#fff;padding:10px 20px;border-radius:25px;font-size:.9rem;pointer-events:none;opacity:0;transition:opacity .5s;z-index:10000;white-space:nowrap}.wsm-exit-hint.show{opacity:1}.wsm-fullscreen-exit-btn{position:fixed;top:15px;right:15px;width:36px;height:36px;background:#fff6!important;-webkit-backdrop-filter:blur(2px)!important;backdrop-filter:blur(2px)!important;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:#475569;z-index:9999;cursor:pointer;box-shadow:0 2px 10px #00000008;border:1px solid rgba(255,255,255,.2);transition:all .2s}.wsm-fullscreen-exit-btn:hover{background:#fffc!important;transform:scale(1.1)}.wsm-panel.fullscreen .wsm-body2{display:flex!important;overflow-x:auto!important;scroll-snap-type:x mandatory!important;-webkit-overflow-scrolling:touch;padding:0!important;margin:0!important;height:100%!important;width:100%!important;scrollbar-width:none;-ms-overflow-style:none}#weather .subsection-title,[id^=hourly-title-]{display:none!important;visibility:hidden!important;height:0!important;margin:0!important;padding:0!important;overflow:hidden!important}.wsm-watermark{position:fixed!important;bottom:20px!important;right:25px!important;font-size:1.2rem!important;font-weight:900!important;color:#475569!important;opacity:0!important;letter-spacing:.5px!important;text-transform:uppercase!important;pointer-events:none!important;z-index:9999!important;font-family:inherit!important;-webkit-user-select:none!important;user-select:none!important;white-space:nowrap!important;animation:fadeInWatermarkCorner 1s ease-out forwards}@keyframes fadeInWatermarkCorner{0%{opacity:0;transform:translateY(10px)}to{opacity:.3;transform:translateY(0)}}#weather .subsection-title,[id^=hourly-title-]{display:none!important;visibility:hidden!important;height:0!important;scroll-snap-type:x mandatory!important;-webkit-overflow-scrolling:touch;padding:0!important;margin:0!important;height:100%!important;width:100%!important;scrollbar-width:none;-ms-overflow-style:none}.wsm-panel.fullscreen .wsm-loc-block{width:100%!important;min-width:100%!important;flex-shrink:0!important;scroll-snap-align:start!important;margin:0!important;padding:50px 15px 30px!important;box-sizing:border-box!important;display:flex!important;flex-direction:column!important;background:transparent!important;box-shadow:none!important;height:100%!important;overflow-y:hidden!important;justify-content:center}.wsm-page-indicator{position:fixed;top:20px;left:20px;background:#fff9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:4px 12px;border-radius:12px;font-size:.85rem;color:#475569}.wsm-page-indicator{position:fixed;top:20px;left:20px;background:#fff9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:4px 12px;border-radius:12px;font-size:.85rem;color:#475569;font-weight:800;z-index:10000}.wsm-nav-zone{position:fixed;top:60px;bottom:0;width:30%;z-index:9998;cursor:pointer}.wsm-nav-zone.prev{left:0}.wsm-nav-zone.next{right:0}.wsm-panel.fullscreen .wsm-loc-title{font-size:1.1rem!important;margin-bottom:15px!important}.wsm-panel.fullscreen .wsm-hourly-grid{display:grid!important;grid-template-columns:repeat(6,1fr)!important;gap:6px 4px!important;width:100%!important}.wsm-panel.fullscreen .wsm-h-item{padding:6px 2px!important;background:#ffffff0d!important;border-radius:8px!important}.wsm-panel.fullscreen .h-time{font-size:.65rem!important;opacity:.8}.wsm-panel.fullscreen .h-icon{font-size:1.4rem!important;margin:2px 0!important}.wsm-panel.fullscreen .h-temp{font-size:.85rem!important;font-weight:800!important}.wsm-panel.fullscreen .h-wind,.wsm-panel.fullscreen .h-precip{font-size:.6rem!important}@media (max-height: 700px){.wsm-panel.fullscreen .wsm-loc-block{width:100%!important;min-width:100%!important;flex-shrink:0!important;scroll-snap-align:start!important;margin:0!important;padding:50px 15px 30px!important;box-sizing:border-box!important;display:flex!important;flex-direction:column!important;background:transparent!important;box-shadow:none!important;height:100%!important;overflow-y:hidden!important;justify-content:center}.wsm-panel.fullscreen .wsm-hourly-grid{grid-template-columns:repeat(8,1fr)!important;gap:4px 2px!important}.wsm-panel.fullscreen .h-icon{font-size:1.1rem!important}.wsm-panel.fullscreen .wsm-loc-title{font-size:.9rem!important;margin-bottom:8px!important}}.wsm-fs-indicator-header{font-size:.8rem!important;background:#0000000d!important;padding:4px 12px!important;border-radius:20px!important;color:#475569!important;font-weight:800!important;margin-right:12px!important;display:inline-flex!important;align-items:center!important}.wsm-fs-close-btn{background:#0000000d!important;border:1px solid rgba(0,0,0,.1)!important;width:32px!important;height:32px!important;border-radius:50%!important;color:#475569!important;font-size:1.1rem!important;cursor:pointer!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;transition:all .2s!important;padding:0!important;line-height:1!important;z-index:10001!important}.wsm-fs-close-btn:hover{background:#0000001a!important;transform:scale(1.1)}.wsm-header-btns.wsm-fullscreen-hide>button:not(.wsm-fs-close-btn){display:none!important}.wsm-header-btns.wsm-fullscreen-hide{display:flex!important;align-items:center!important;opacity:1!important;visibility:visible!important}.location-weather{display:none;width:100%!important;max-width:100vw!important;box-sizing:border-box!important;overflow-x:hidden!important;clear:both!important}.location-weather.active{display:block!important}#weather .section-alt,#weather .container{display:block!important;width:100%!important;max-width:100%!important;padding:0!important;margin:0!important}#weather .container{padding:0 12px 20px!important;box-sizing:border-box!important}.location-tabs{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:15px;width:100%;padding:5px 0}.location-tabs::-webkit-scrollbar{display:none}.location-tab{background:#fff;border:1px solid #f1f3f5;padding:10px 2px;border-radius:10px;cursor:pointer;transition:all .2s;display:flex;justify-content:center;align-items:center;min-width:0;box-shadow:0 2px 6px #00000008}.location-tab.active{background:#4dabf7;border-color:#4dabf7;color:#fff!important;box-shadow:0 4px 12px #4dabf733}.tab-name{font-size:.72rem;font-weight:800;color:#495057;white-space:nowrap}.location-tab.active .tab-name{color:#fff}.naver-card{background:#fff;border-radius:20px;padding:18px 12px;margin-bottom:12px;box-shadow:0 4px 20px #00000008;border:1px solid #f1f3f5;position:relative;overflow:hidden;width:100%;box-sizing:border-box}.hourly-forecast-card{padding-top:10px!important}.weather-header-container{display:flex;justify-content:space-between;align-items:center;padding:10px 4px 15px}.location-info{display:flex;align-items:center;gap:8px}.location-star{color:#ffd43b;font-size:1.2rem}.location-name{font-size:1.35rem;font-weight:800;color:#212529;margin:0;white-space:nowrap}.header-action-btns{display:flex;gap:8px;align-items:center}.header-cctv-btn{display:flex;align-items:center;gap:4px;background:#f8f9fa;border:1px solid #dee2e6;padding:6px 10px;border-radius:20px;font-size:.78rem;font-weight:800;color:#495057;cursor:pointer;transition:all .2s;white-space:nowrap}.header-summary-btn{display:flex;align-items:center;gap:4px;background:#fff;border:1px solid #dee2e6;padding:6px 10px;border-radius:20px;font-size:.78rem;font-weight:800;color:#495057;cursor:pointer;transition:all .2s;white-space:nowrap}.header-cctv-btn:hover,.header-summary-btn:hover{background:#e9ecef}.current-weather-main{padding:24px;display:flex;justify-content:center;min-height:100px;width:100%;box-sizing:border-box}.current-weather-box{display:flex;justify-content:space-between;align-items:center;width:100%;gap:15px}@media screen and (max-width: 500px){.current-weather-main{padding:20px 10px}.current-weather-box{flex-direction:row;justify-content:space-between;align-items:center;gap:10px}.cw-left{flex:.7;justify-content:flex-start;gap:8px}.cw-left .main-icon{font-size:2.8rem}.cw-left .current-val{font-size:2.5rem}.cw-left .unit{font-size:1.1rem}.cw-right{flex:1.3;padding-left:8px!important;border-left:1px solid #f1f3f5!important;align-items:flex-start!important}.cw-details-list{display:flex;flex-direction:column;width:100%;gap:6px}.cw-details-list li{justify-content:flex-start;font-size:.75rem;white-space:nowrap}}.cw-left{display:flex;align-items:center;gap:15px;flex:1}.cw-left .main-icon{font-size:3.8rem}.cw-left .main-temp{display:flex;flex-direction:column}.cw-left .current-val{font-size:3.5rem;font-weight:500;color:#4c6ef5;line-height:1;display:flex;align-items:flex-start}.cw-left .unit{font-size:1.4rem;font-weight:400;margin-top:8px;margin-left:2px}.cw-right{flex:1.5;padding-left:15px;border-left:1px solid #f1f3f5;display:flex;flex-direction:column;justify-content:center}.cw-details-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;align-items:flex-start}.cw-details-list li{font-size:.85rem;color:#495057;display:flex;align-items:center;gap:6px;font-weight:600}.cw-details-list .cwi{font-size:1rem}.cw-details-list .val{font-weight:700}.weather-details-bar{display:none!important;display:flex;gap:10px;overflow-x:auto;padding:5px 0 20px;scrollbar-width:none}.weather-details-bar::-webkit-scrollbar{display:none}.detail-chip{flex-shrink:0;background:#fff;border:1px solid #f1f3f5;padding:12px 18px;border-radius:14px;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:80px;box-shadow:0 2px 10px #00000005}.chip-label{font-size:.8rem;font-weight:700;color:#868e96}.chip-val{font-size:.95rem;font-weight:800;color:#212529}.chip-status{font-size:.75rem;font-weight:800;padding:2px 8px;border-radius:10px}.status-good{background:#e6fcf5;color:#099268}.status-fair{background:#fff9db;color:#f08c00}.status-poor{background:#fff5f5;color:#e03131}.hourly-forecast-card .card-header{display:flex;gap:20px;margin-bottom:20px;border-bottom:1px solid #f1f3f5;padding-bottom:10px}.day-label{font-size:.95rem;font-weight:700;color:#adb5bd;cursor:pointer;position:relative}.day-label.active{color:#212529;font-weight:900}.day-label.active:after{content:"";position:absolute;bottom:-11px;left:0;width:100%;height:3px;background:#212529}.hourly-table-container{padding:0;overflow:hidden}.hourly-wrapper{display:flex;width:100%;margin-top:5px;border-radius:12px;border:1px solid #f1f3f5;overflow:hidden;box-sizing:border-box}.hourly-legend{width:44px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:10px 0;color:#212529;font-size:.75rem;background:#fff;z-index:10;border-right:1px solid #f1f3f5;position:sticky;left:0}.hourly-table{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;flex:1;scrollbar-width:none;min-width:0;position:relative}.hourly-col{display:flex;flex-direction:column;align-items:center;padding:10px 0;min-width:54px;border-right:1px solid #f8f9fa}.air-quality-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-top:15px}.air-quality-item{background:#fff;border:1px solid #f1f3f5;border-radius:20px;padding:20px 10px;display:flex;flex-direction:column;align-items:center;gap:12px}.air-label{font-size:.85rem;font-weight:700;color:#868e96}.air-circle-wrap{width:60px;height:60px;border-radius:50%;border:3px solid #e9ecef;display:flex;align-items:center;justify-content:center;position:relative}.air-circle{width:100%;height:100%;border-radius:50%;display:flex;align-items:center;justify-content:center;border:3px solid transparent}.air-circle.status-good{border-top-color:#37b24d;border-right-color:#37b24d}.air-circle.status-fair{border-top-color:#f08c00;border-right-color:#f08c00}.air-circle.status-poor{border-top-color:#f03e3e;border-right-color:#f03e3e}.air-text{font-size:1.1rem;font-weight:800}.air-circle.status-good .air-text{color:#2f9e44}.air-circle.status-fair .air-text{color:#e67e22}.air-circle.status-poor .air-text{color:#d63031}.air-val{font-size:1.2rem;font-weight:700;color:#212529}.air-val small{font-size:.65rem;color:#adb5bd;margin-left:2px}.h-top-section{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100px;padding:0 0 5px;box-sizing:border-box}.h-legend-top{height:100px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:5px;position:relative}.h-sticky-date-bar{position:absolute;left:0;top:0;z-index:150;width:max-content;background:#fffffffa;padding:3px 12px;border-radius:20px;font-size:.68rem;font-weight:800;color:#1971c2;border:1px solid #d0ebff;box-shadow:0 2px 8px #00000014;pointer-events:none;white-space:nowrap;height:20px;display:flex;align-items:center;margin-bottom:-20px}.h-date-sub{font-size:.6rem;color:#adb5bd;font-weight:700;margin-bottom:4px}.h-time{font-size:.7rem;color:#868e96;margin-bottom:8px;font-weight:600;line-height:1}.h-icon{font-size:1.3rem;margin-bottom:8px;line-height:1}.h-temp{font-size:.9rem;font-weight:900;color:#212529;margin-bottom:5px;line-height:1}.h-pop{font-size:.65rem;font-weight:800;color:#228be6;margin-bottom:2px;line-height:1}.h-divider{width:100%;height:1px;background:#f1f3f5;margin:8px 0}.h-meta-row{width:100%;display:flex;flex-direction:column;gap:8px;align-items:center}.h-legend-items{align-items:center}.h-legend-item{display:flex;flex-direction:column;justify-content:center;height:26px}.h-legend-title{font-size:.65rem;font-weight:700;color:#868e96;line-height:1.1}.h-legend-unit{font-size:.62rem;color:#adb5bd;line-height:1;margin-top:1px}.h-meta-val{color:#495057;font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center;height:26px}.sun-col{background:#ffa94d0d}.sun-time{color:#fd7e14!important;font-weight:800!important;font-size:.65rem!important}.sun-badge{display:inline-block;padding:2px 8px;background:#ffa94d;color:#fff;border-radius:10px;font-size:.65rem;font-weight:800;margin:4px 0 8px;line-height:1.2}.weekly-forecast-card .card-title{font-size:1.1rem;font-weight:900;color:#212529;margin-bottom:15px}.weekly-grid{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(2,auto);gap:6px 4px;margin-top:10px;width:100%}.weekly-card{background:#fff;border:1px solid #f1f3f5;border-radius:12px;padding:8px 1px;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .2s;min-width:0;cursor:pointer;overflow:hidden}.weekly-card:hover{background:#f8f9fa;border-color:#4dabf7;transform:translateY(-2px)}.weekly-card:active{transform:scale(.95)}.w-date-box{font-size:.65rem;font-weight:700;color:#212529;margin-bottom:-2px}.w-icon{font-size:1.2rem}.w-temps{display:flex;align-items:center;justify-content:center;gap:3px;margin-top:2px;width:100%;letter-spacing:-.2px;font-family:Outfit,sans-serif;font-weight:700;font-size:.85rem}.w-max{color:#fa5252}.w-min{color:#228be6}.w-slash{color:#dee2e6;font-size:.5rem}.w-meta-info{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:.55rem;font-weight:700;color:#868e96;line-height:1}.w-pop{color:#228be6;font-size:.6rem!important}#weather .section-alt{background-color:#f1f3f5}.p-blue{color:#228be6!important;font-weight:800}.weekly-card.active{border-color:#339af0!important;background:#e7f5ff!important;box-shadow:0 4px 12px #339af026!important}.weekly-card.active .w-date{color:#1971c2!important;font-weight:800!important}.hero-status-wrapper{margin-top:25px;margin-bottom:30px;width:100%}.hero-status-card{position:relative;padding:24px;border-radius:24px;border:1px solid rgba(255,255,255,.3);overflow:hidden;display:flex;flex-direction:column;gap:12px;box-shadow:0 10px 30px #00000014;transition:transform .3s ease;background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.hero-status-card.open{border-left:8px solid #10b981;background:linear-gradient(135deg,#10b9810d,#fffc)}.hero-status-card.partial{border-left:8px solid #f59e0b;background:linear-gradient(135deg,#f59e0b0d,#fffc)}.hero-status-card.closed{border-left:8px solid #ef4444;background:linear-gradient(135deg,#ef44440d,#fffc)}.hero-badge{align-self:flex-start;padding:4px 12px;border-radius:8px;font-size:.75rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.5px}.open .hero-badge{background:#10b981}.partial .hero-badge{background:#f59e0b}.closed .hero-badge{background:#ef4444}.hero-title{font-size:1.4rem;font-weight:900;color:var(--text-primary);margin:0}.hero-desc{font-size:.95rem;color:var(--text-secondary);line-height:1.5;margin:0;font-weight:600}.hero-time-tag{font-size:.75rem;color:var(--text-muted);font-weight:700;opacity:.8}#hallasan-dashboard-container{margin-bottom:24px;width:100%}.hallasan-mini-dashboard{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;background:#fff6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-xl);padding:16px;box-shadow:0 4px 15px #00000008}.mini-item{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-card-hover);border-radius:var(--radius-lg);border:1px solid transparent;transition:all .2s ease}.mini-item:hover{border-color:var(--accent-blue);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.mini-icon{font-size:1.8rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.mini-info{display:flex;flex-direction:row;align-items:center;justify-content:space-between;flex:1;gap:12px}.mini-label{font-size:.75rem;font-weight:700;color:var(--text-muted)}.mini-value{font-size:1.2rem;font-weight:900;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-placeholder,.dashboard-error{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:20px;text-align:center}.loader-wrapper{display:flex;flex-direction:column;align-items:center;gap:10px}.loading-spinner{width:24px;height:24px;border:3px solid var(--bg-card-hover);border-top:3px solid var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:.85rem;font-weight:700;color:var(--text-secondary)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 600px){.hallasan-mini-dashboard{grid-template-columns:1fr;gap:8px}.mini-item{padding:10px}}#cctv-hallasan-dashboard{width:100%;animation:fadeIn .4s ease}#cctv-hallasan-weather-info{margin-bottom:20px}#cctv-hallasan-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:4px}.featured-cctv{grid-column:1 / -1!important}.featured-cctv .cctv-video-container{aspect-ratio:16 / 9!important}.featured-cctv .cctv-name{font-size:1.1rem!important}.cctv-repair-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#121622f2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#fff9;font-weight:800;font-size:.9rem;z-index:2}.cctv-tag.offline{background:#64748b!important;box-shadow:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 600px){#cctv-hallasan-grid{grid-template-columns:1fr;gap:12px}}.jeju-region{fill:#333;fill-opacity:.4;stroke:var(--border-light);stroke-width:1;transition:all .3s ease;cursor:pointer}.jeju-region:hover{fill-opacity:.7;filter:drop-shadow(0 0 10px rgba(255,255,255,.2))}.jeju-region.active{fill-opacity:.8!important;stroke:#fff;stroke-width:2}.region-jeju{fill:#4a90e2}.region-seogwipo{fill:#f5a623}.region-east{fill:#50e3c2}.region-west{fill:#9013fe}.region-hallasan{fill:#7ed321}.region-udo{fill:#f8e71c}.cctv-marker{transition:all .3s cubic-bezier(.4,0,.2,1)}.marker-dot{fill:#ff4757;stroke:#ffffffe6;stroke-width:3;filter:drop-shadow(0 0 8px rgba(255,71,87,.6))}.cctv-marker:hover{transform:scale(1.1)}.cctv-marker:hover .marker-dot{fill:#fff;stroke:#ff4757;filter:drop-shadow(0 0 15px rgba(255,71,87,.8))}.cctv-marker text{font-family:Inter,Noto Sans SC,sans-serif;pointer-events:none;-webkit-user-select:none;user-select:none;letter-spacing:-.5px}.cctv-container{position:relative;width:100%}.cctv-detail-card{position:fixed;top:0;left:0;right:0;bottom:0;z-index:5000;display:none;align-items:center;justify-content:center;background:#000000b3;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.cctv-detail-card.show{display:flex}.cctv-detail-inner{width:90%;max-width:440px;background:#121622fa;border:1px solid rgba(255,255,255,.15);border-radius:24px;overflow:hidden;box-shadow:0 40px 80px -20px #000c;animation:cardPopIn .35s cubic-bezier(.34,1.56,.64,1)}@keyframes cardPopIn{0%{transform:scale(.88);opacity:0}to{transform:scale(1);opacity:1}}.detail-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#ffffff08}.detail-header h3{font-size:1rem;font-weight:800;color:#fff!important;margin:0;text-shadow:0 1px 3px rgba(0,0,0,.5)}.detail-close{background:#ffffff26;border:1px solid rgba(255,255,255,.25);color:#fff!important;width:34px;height:34px;border-radius:50%;cursor:pointer;font-size:1rem;font-weight:700;line-height:1;transition:all .2s;display:flex;align-items:center;justify-content:center}.detail-close:hover{background:#ff4757;border-color:#ff4757;transform:rotate(90deg)}.detail-body{position:relative;aspect-ratio:16 / 9;background:#000}.video-wrapper{width:100%;height:100%}#cctv-live-video{width:100%;height:100%;object-fit:cover}.live-indicator{position:absolute;top:15px;left:15px;background:#ef4444;color:#fff;font-size:.65rem;font-weight:900;padding:3px 8px;border-radius:6px;box-shadow:0 2px 10px #ef444466;display:flex;align-items:center;gap:5px}.live-indicator:before{content:"";width:6px;height:6px;background:#fff;border-radius:50%;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}#cctv{padding:0;background:#fff;--color-jeju: #bcac9c;--color-seogwipo: #a49484;--color-east: #81a1c1;--color-west: #a3be8c;--color-hallasan: #eceff4;--color-udo: #fbc531;--color-all: #81a1c1}#cctv .container{max-width:900px;margin:0 auto;padding:10px}.cctv-tabs{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;padding:12px;position:sticky;top:56px;z-index:100;background:#fffffff2;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);width:100%;box-sizing:border-box}.tab-btn{padding:8px 2px;border-radius:10px;background:#f1f2f6cc;border:1px solid rgba(255,255,255,.3);font-size:.72rem;font-weight:700;color:#57606f;cursor:pointer;transition:all .2s ease;white-space:nowrap;text-align:center;display:flex;align-items:center;justify-content:center}.tab-btn:hover{background:#fff;color:#2f3542;transform:translateY(-2px);box-shadow:0 5px 15px #0000000d}.tab-btn.active{background:var(--btn-grad, linear-gradient(135deg, #ff4757, #ff6b81));color:#fff;box-shadow:0 10px 25px var(--glow-color, rgba(255, 71, 87, .4)),inset 0 2px 4px #ffffff4d;font-weight:800;transform:translateY(-4px) scale(1.05);border:none}.tab-btn[data-region=jeju].active{--btn-grad: linear-gradient(135deg, #bcac9c, #dcd0c4);--glow-color: rgba(188, 172, 156, .5)}.tab-btn[data-region=seogwipo].active{--btn-grad: linear-gradient(135deg, #a49484, #c4b4a4);--glow-color: rgba(164, 148, 132, .5)}.tab-btn[data-region=east].active{--btn-grad: linear-gradient(135deg, #81a1c1, #a3be8c);--glow-color: rgba(129, 161, 193, .5)}.tab-btn[data-region=west].active{--btn-grad: linear-gradient(135deg, #a3be8c, #c5d4b5);--glow-color: rgba(163, 190, 140, .5)}.tab-btn[data-region=hallasan].active{--btn-grad: linear-gradient(135deg, #4c566a, #2e3440);--glow-color: rgba(76, 86, 106, .4)}.tab-btn[data-region=udo].active{--btn-grad: linear-gradient(135deg, #fbc531, #f9ca24);--glow-color: rgba(251, 197, 49, .5)}.tab-btn[data-region=all].active{--btn-grad: linear-gradient(135deg, #81a1c1, #5e81ac);--glow-color: rgba(129, 161, 193, .5)}.cctv-map-wrapper{position:relative;width:100%;aspect-ratio:1.8 / 1;background:#fff;border-radius:24px;box-shadow:0 10px 30px #0000000d;margin-bottom:20px;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:20px}.jeju-svg-map{width:100%;height:100%;max-height:500px}.jeju-region{fill-opacity:.25;stroke:#fff;stroke-width:1px;cursor:pointer;vector-effect:non-scaling-stroke}.jeju-region-bg{pointer-events:none;transition:all .3s ease}.jeju-region:hover{fill-opacity:.5}.jeju-region.active{fill-opacity:.8;filter:url(#region-outline);z-index:10}.region-jeju{fill:var(--color-jeju)}.region-seogwipo{fill:var(--color-seogwipo)}.region-east{fill:var(--color-east)}.region-west{fill:var(--color-west)}.region-hallasan{fill:var(--color-hallasan)}.region-udo{fill:var(--color-udo)}.cctv-marker{cursor:pointer;pointer-events:all;transition:none!important;transform:none!important}.cctv-marker circle.marker-dot{fill:#ff4757;stroke:#fff;stroke-width:2px;r:15px;transition:none!important}.cctv-marker:hover circle.marker-dot{filter:none!important}.cctv-marker.marker-jeju{--marker-color: var(--color-jeju)}.cctv-marker.marker-seogwipo{--marker-color: var(--color-seogwipo)}.cctv-marker.marker-east{--marker-color: var(--color-east)}.cctv-marker.marker-west{--marker-color: var(--color-west)}.cctv-marker.marker-hallasan{--marker-color: var(--color-hallasan)}.cctv-marker.marker-udo{--marker-color: var(--color-udo)}.region-label{fill:#fff;font-size:14px;font-weight:700;pointer-events:none;text-shadow:0 1px 3px rgba(0,0,0,.6);dominant-baseline:middle;text-anchor:middle}.cctv-detail-card{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:none;align-items:center;justify-content:center;padding:20px;transition:all .3s ease}.cctv-detail-card.show{display:flex!important}.cctv-detail-inner{background:#1e272e;width:100%;max-width:600px;border-radius:24px;overflow:hidden;box-shadow:0 20px 50px #0000004d;border:1px solid rgba(255,255,255,.1);transform:scale(.9);opacity:0;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.cctv-detail-card.show .cctv-detail-inner{transform:scale(1);opacity:1}.detail-header{padding:16px 20px;background:#ffffff0d;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.detail-header h3{margin:0;color:#fff;font-size:1.1rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.3)}.detail-close{width:32px;height:32px;border-radius:50%;background:#ffffff1a;border:none;color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.detail-close:hover{background:#fff3;transform:rotate(90deg)}.detail-body{position:relative;width:100%}.video-wrapper{width:100%;aspect-ratio:16 / 9;background:#000;position:relative}#cctv-live-video{width:100%;height:100%;object-fit:contain}.live-indicator{position:absolute;top:12px;left:12px;background:#ff4757;color:#fff;padding:4px 10px;border-radius:6px;font-size:.7rem;font-weight:800;display:flex;align-items:center;gap:5px;box-shadow:0 2px 10px #ff475766}.live-indicator:before{content:"";display:block;width:6px;height:6px;background:#fff;border-radius:50%;animation:blink 1s infinite}@keyframes blink{0%{opacity:1}50%{opacity:.3}to{opacity:1}}@media (max-width: 600px){.cctv-map-wrapper{aspect-ratio:1 / 1;padding:10px}.cctv-detail-card{bottom:0;left:0;right:0;border-radius:24px 24px 0 0;max-width:none}}.reward-container{padding-top:10px;padding-bottom:40px}.reward-trust-banner{background:linear-gradient(135deg,#1e293b,#0f172a);border-radius:20px;padding:24px;margin-bottom:30px;display:flex;align-items:center;gap:20px;position:relative;overflow:hidden;box-shadow:0 10px 25px #00000026;border:1px solid rgba(255,255,255,.1)}.reward-trust-banner:after{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 70%);pointer-events:none}.trust-badge-icon{width:64px;height:64px;background:linear-gradient(135deg,#fbbf24,#f59e0b);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;box-shadow:0 0 20px #f59e0b66;animation:badgePulse 2s infinite ease-in-out}@keyframes badgePulse{0%{transform:scale(1);box-shadow:0 0 10px #f59e0b66}50%{transform:scale(1.05);box-shadow:0 0 20px #f59e0b99}to{transform:scale(1);box-shadow:0 0 10px #f59e0b66}}.trust-info{flex:1}.trust-title{color:#fbbf24;font-size:1.25rem;font-weight:900;margin-bottom:4px;letter-spacing:-.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.trust-desc{color:#94a3b8;font-size:1rem;line-height:1.5;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.reward-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;align-items:start}.reward-card{background:#fff;border-radius:16px;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 4px 15px #0000000d;border:1.5px solid var(--border-light);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative;text-align:center}.reward-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a;border-color:var(--accent-blue)}.reward-img-top{width:100%;aspect-ratio:1 / 1;background:#f8fafc;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-light)}.reward-img-top img{width:100%;height:100%;object-fit:contain;padding:12px;transition:transform .5s ease}.reward-info{padding:12px;display:flex;flex-direction:column;gap:6px;background:#fff;align-items:center}.reward-item-name{font-size:.95rem;font-weight:800;color:var(--text-primary);line-height:1.3;margin:0;word-break:break-all}.reward-amount{font-size:1rem;font-weight:900;color:#ef4444}.reward-amount small{font-size:.65rem;font-weight:700;color:#64748b}.wechat-qr-content{max-width:340px;padding:30px;text-align:center}.wechat-title{font-size:1.2rem;font-weight:800;color:var(--text-primary);margin-bottom:10px}.wechat-desc{font-size:.85rem;color:#64748b;margin-bottom:20px;line-height:1.4}.wechat-qr-box{background:#fff;padding:15px;border-radius:12px;box-shadow:0 4px 15px #0000000d;margin-bottom:20px}.wechat-qr-box img{width:100%;height:auto;border-radius:8px}.copy-btn{width:100%;padding:12px 24px;background:var(--primary-gradient);color:#fff;border:none;border-radius:var(--radius-lg);font-size:.95rem;font-weight:800;cursor:pointer;box-shadow:0 4px 12px #2563eb33;transition:all var(--transition-normal)}.copy-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #2563eb4d}.copy-btn:active{transform:scale(.97)}@media (max-width: 480px){.reward-trust-banner{padding:16px;gap:12px}.trust-badge-icon{width:48px;height:48px;font-size:1.5rem}.trust-title{font-size:.95rem}.trust-desc{font-size:.75rem}.reward-grid{grid-template-columns:repeat(2,1fr);gap:8px}.reward-item-name{font-size:.85rem}.reward-amount{font-size:.9rem}}.header-action-btn{position:absolute;right:16px;padding:8px 16px;background:var(--primary-gradient);color:#fff;border:none;border-radius:var(--radius-lg);font-size:.95rem;font-weight:800;cursor:pointer;box-shadow:0 4px 12px #2563eb33;transition:all var(--transition-normal);z-index:2001}.header-action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 15px #2563eb4d}.header-action-btn:active{transform:scale(.95);opacity:.9}
