@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap";@media (max-width: 768px){.hidden-on-mobile{display:none!important}}@media (min-width: 769px){.hidden-on-desktop{display:none!important}}.mobile-bottom-panel{position:fixed;bottom:0;left:0;width:100%;background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-top-left-radius:24px;border-top-right-radius:24px;border:1px solid var(--glass-border);padding:10px 16px calc(10px + env(safe-area-inset-bottom));z-index:1000;box-shadow:0 -8px 30px #0006;display:flex;flex-direction:column;gap:4px}.mobile-building-card{position:absolute;bottom:calc(150px + env(safe-area-inset-bottom));left:12px;right:68px;padding:0 18px;height:72px;border-radius:18px;z-index:999;background:#141820f0;backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);border:1px solid rgba(255,255,255,.15);box-shadow:0 10px 35px #00000073;display:flex;align-items:center;justify-content:space-between;animation:slideUpFade .3s cubic-bezier(.2,.8,.2,1)}.bar-info-section{flex:1;display:flex;flex-direction:column;justify-content:center}.bar-info-section .title-text{font-size:1.05rem;font-weight:700;color:#fff;margin:0;max-width:none}.bar-info-section .dim-text{font-size:.75rem;color:#94a3b8;margin:2px 0 0;font-weight:500}.bar-divider{width:1px;height:24px;background:#ffffff1a;margin:0 16px}.bar-hint-section{display:flex;align-items:center;gap:6px;color:#fbbf24;font-size:.8rem;font-weight:600}.hint-icon{opacity:.9}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mobile-analyze-btn{background:linear-gradient(135deg,#f97316,#ea580c);border:none;border-radius:12px;color:#fff;box-shadow:0 4px 15px #ea580c66;width:100%}.mobile-analyze-btn:disabled{opacity:.6}.full-screen-modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0f1115;z-index:9999;display:flex;flex-direction:column;animation:slideInRight .3s cubic-bezier(.25,1,.5,1);box-shadow:-10px 0 30px #00000080}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.glass-header{display:flex;align-items:center;justify-content:space-between;padding:calc(10px + env(safe-area-inset-top)) 16px 10px;background:#141820d9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.08);position:sticky;top:0;z-index:10}.header-title{position:absolute;left:50%;transform:translate(-50%);font-weight:600;font-size:1.1rem;color:#fff;white-space:nowrap}.icon-btn-back{display:flex;align-items:center;background:transparent;border:none;color:#fff;font-size:1rem;padding:8px 0}.icon-btn-back span{font-size:.95rem;margin-left:-2px}.mobile-report-content{flex:1;overflow-y:auto;padding:20px 20px calc(20px + env(safe-area-inset-bottom))}.report-summary-card{background:linear-gradient(135deg,#1e293bcc,#0f172ae6);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:24px;box-shadow:0 10px 30px #0000004d}.report-summary-card h2{font-size:1.3rem;margin-bottom:2px}.report-summary-card h3{font-size:1.05rem;color:#cbd5e1;margin-bottom:20px;opacity:.9}.total-sun-badge{display:flex;align-items:center;gap:10px;background:#f9731626;padding:14px 18px;border-radius:14px;border:1px solid rgba(249,115,22,.3)}.total-sun-badge .sun-text{font-size:1rem;color:#fff}.total-sun-badge strong{font-size:1.2rem}.timeline-title{display:flex;align-items:center;gap:8px;color:#94a3b8;font-size:.95rem;margin-top:32px;margin-bottom:20px;padding-left:4px;text-transform:uppercase;letter-spacing:.05em;opacity:.8}.mobile-timeline{display:flex;flex-direction:column;gap:0;padding-left:8px}.timeline-block{display:flex;gap:20px;min-height:70px}.time-col{display:flex;flex-direction:column;align-items:center;width:50px}.time-col .time{font-size:.9rem;font-weight:500;color:#cbd5e1}.time-col .line{flex:1;width:2px;margin:4px 0}.timeline-block.sun .line{background:linear-gradient(to bottom,#f97316,#f9731666)}.timeline-block.shade .line{background:#ffffff1a}.info-col{flex:1;padding-bottom:24px}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;font-size:.85rem;font-weight:500;margin-bottom:8px}.status-badge.sun{background:#f9731633;color:#fdba74}.status-badge.shade{background:#33415580;color:#94a3b8}.info-col .duration{display:block;font-size:1.1rem;font-weight:600;color:#f8fafc}.empty-state{text-align:center;padding:40px;color:#94a3b8;background:#ffffff08;border-radius:12px}@media (max-width: 768px){.ui-overlay-top-center{width:100%;top:calc(10px + env(safe-area-inset-top));padding:0 16px}.disclaimer-modal{max-height:90vh;border-radius:24px}.modal-header h2{font-size:1.2rem}.modal-body{padding:20px 24px;font-size:.9rem}.modal-body h3{margin:24px 0 10px;font-size:1rem}}.bottom-sheet-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:5000;display:flex;align-items:flex-end;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.bottom-sheet-content{width:100%;max-height:50vh;background:#141820f2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-top-left-radius:24px;border-top-right-radius:24px;border:1px solid rgba(255,255,255,.15);border-bottom:none;display:flex;flex-direction:column;animation:slideInUp .3s cubic-bezier(.2,.8,.2,1);padding-bottom:env(safe-area-inset-bottom)}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.bottom-sheet-header{padding:8px 0 0;display:flex;flex-direction:column;align-items:center}.drag-handle{width:36px;height:4px;background:#fff3;border-radius:2px;margin-bottom:12px}.header-wrapper{width:100%;display:flex;justify-content:space-between;align-items:center;padding:0 20px 12px;border-bottom:1px solid rgba(255,255,255,.08)}.header-wrapper h3{margin:0;font-size:.95rem;font-weight:600;color:#fff}.close-circle-btn{background:#ffffff14;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#fff}.project-list-wrapper{flex:1;overflow-y:auto;padding:12px 16px}.project-item{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;border-radius:12px;margin-bottom:6px;transition:all .2s;background:#ffffff08}.project-item.active{background:#4f46e526;border:1px solid rgba(79,70,229,.3)}.project-item:active{background:#ffffff14;transform:scale(.98)}.project-name{font-size:.9rem;font-weight:500;color:#e2e8f0}.project-item.active .project-name{color:#818cf8}.active-dot{width:8px;height:8px;background:#4f46e5;border-radius:50%;box-shadow:0 0 10px #4f46e5}.mobile-hint-overlay{position:fixed;top:80px;left:50%;transform:translate(-50%);background:#f97316f2;color:#fff;padding:10px 20px;border-radius:30px;font-size:.9rem;font-weight:600;z-index:2000;box-shadow:0 4px 15px #0000004d;white-space:nowrap;animation:fadeInOut 4s forwards}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,-20px)}10%{opacity:1;transform:translate(-50%)}90%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-10px)}}:root{--primary: #4f46e5;--bg-dark: #0f1115;--glass-bg: rgba(20, 24, 32, .75);--glass-border: rgba(255, 255, 255, .1);--text-primary: #f8fafc;--text-secondary: #94a3b8}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px;border:1px solid rgba(255,255,255,.05)}::-webkit-scrollbar-thumb:hover{background:#fff3}.custom-scrollbar::-webkit-scrollbar{width:6px}.custom-scrollbar::-webkit-scrollbar-track{background:#0000001a;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#ffffff40}*{box-sizing:border-box;margin:0;padding:0}.fade-in{animation:fadeIn .3s ease-in-out}.road-label{background:none;color:#444;font-size:11px;font-weight:700;pointer-events:none;white-space:nowrap;-webkit-user-select:none;user-select:none;text-shadow:1px 1px 0 #fff,-1px -1px 0 #fff,1px -1px 0 #fff,-1px 1px 0 #fff,0 0 4px #fff;font-family:Inter,system-ui,sans-serif;transform:translateY(-5px);transition:opacity .2s}.road-label.L1{color:#c96277;font-size:13px}.road-label.L2{color:#b5823c;font-size:12px}.btn-north{position:absolute;bottom:30px;right:30px;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);color:var(--text-primary);padding:10px 16px;border-radius:8px;cursor:pointer;z-index:1000;display:flex;align-items:center;gap:8px;transition:all .2s;font-weight:500;box-shadow:0 8px 32px #0000004d}.ui-overlay-top-center{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:10;pointer-events:auto;display:flex;align-items:center;gap:12px;min-width:300px;justify-content:center}.custom-dropdown-container{position:relative;width:100%}.custom-dropdown-button{display:flex;justify-content:space-between;align-items:center;width:100%;background:var(--glass-bg);border:1px solid var(--glass-border);color:var(--text-primary);padding:12px 18px;border-radius:20px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);outline:none;box-shadow:0 4px 20px #0003}.custom-dropdown-button:hover{background:#1e293b99;border-color:#ffffff40;box-shadow:0 6px 24px #0000004d}.clear-selection-btn-pc{padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#94a3b8;transition:all .2s}.clear-selection-btn-pc:hover{background:#ef444433;color:#f87171}.icon-btn-close-panel{display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.icon-btn-close-panel:hover{background:#ffffff1a;color:#f87171}.clear-selection-btn{padding:8px;margin-right:-4px;border-radius:50%;color:#94a3b8;display:flex;align-items:center;justify-content:center;transition:background .2s}.clear-selection-btn:active{background:#ffffff1a}.custom-dropdown-menu{position:absolute;top:calc(100% + 12px);left:0;width:100%;max-height:350px;overflow-y:auto;border-radius:16px;background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);box-shadow:0 12px 40px #00000080;display:flex;flex-direction:column;padding:8px 0;z-index:20}.custom-dropdown-item{padding:14px 20px;cursor:pointer;transition:background .2s;color:var(--text-primary);font-weight:500;font-size:1.05rem;border-left:3px solid transparent}.custom-dropdown-item:hover{background:#3b82f626;border-left:3px solid var(--primary-color)}.btn-north:hover{background:#1e2430d9;transform:translateY(-2px);box-shadow:0 10px 36px #0006}.btn-north:active{transform:translateY(1px)}body{font-family:Inter,sans-serif;background-color:var(--bg-dark);color:var(--text-primary);overflow:hidden;-webkit-font-smoothing:antialiased}#root{width:100vw;height:100vh;position:relative}.glass-panel{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:12px;padding:20px;box-shadow:0 8px 32px #0000004d}.ui-overlay-top-right{position:absolute;top:24px;right:24px;width:320px;z-index:1000;display:flex;flex-direction:column;gap:12px}.ui-overlay-left-stack{position:absolute;top:24px;left:24px;width:320px;z-index:1000;display:flex;flex-direction:column;gap:12px}.ui-overlay-bottom-left{position:absolute;bottom:24px;left:24px;z-index:1000;display:flex;align-items:center;gap:12px}.glass-panel h2{font-size:1.2rem;font-weight:500;margin-bottom:8px;display:flex;align-items:center;gap:8px}.glass-panel p{font-size:.9rem;color:var(--text-secondary)}.control-group{display:flex;flex-direction:column;gap:8px}.control-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;background:#ffffff1a;border-radius:4px;outline:none}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary);cursor:pointer;transition:transform .1s}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}input[type=date],input[type=time]{background:#ffffff0d;border:1px solid var(--glass-border);color:var(--text-primary);padding:8px 12px;border-radius:6px;font-family:inherit;font-size:.9rem;outline:none}input[type=date]:focus,input[type=time]:focus{border-color:var(--primary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}.disclaimer-modal{width:100%;max-width:600px;max-height:85vh;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 50px #00000080;animation:modalPop .4s cubic-bezier(.16,1,.3,1);will-change:transform;transform:translateZ(0)}@keyframes modalPop{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:24px 24px 16px;border-bottom:1px solid var(--glass-border)}.modal-header h2{font-size:1.4rem;font-weight:600;margin:0;color:var(--text-primary);letter-spacing:-.02em}.modal-header .update-date{font-size:.8rem;color:var(--text-secondary);margin-top:4px}.modal-body{padding:24px 32px;overflow-y:auto;flex:1;font-size:.95rem;line-height:1.7;color:#cbd5e1;text-align:justify;will-change:scroll-position;-webkit-overflow-scrolling:touch}.modal-body h3{font-size:1.1rem;margin:32px 0 12px;color:var(--text-primary);border-left:3px solid var(--primary);padding-left:12px;line-height:1.2}.modal-body p{margin-bottom:18px;opacity:.9}.modal-footer{padding:20px 24px;display:flex;justify-content:flex-end;gap:16px;background:#ffffff05;border-top:1px solid var(--glass-border)}.btn-secondary{background:transparent;border:1px solid var(--glass-border);color:var(--text-secondary);padding:10px 24px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#ffffff0d;color:var(--text-primary)}.btn-primary{background:var(--primary);border:none;color:#fff;padding:10px 32px;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e54d}.btn-primary:hover{background:#4338ca;transform:translateY(-1px);box-shadow:0 6px 16px #4f46e566}.btn-primary:active{transform:translateY(1px)}.restricted-info{text-align:center;padding:48px 32px;max-width:420px;border:1px solid rgba(239,68,68,.2)}.restricted-info h1{font-size:3.5rem;margin-bottom:24px;filter:drop-shadow(0 0 10px rgba(239,68,68,.3))}.restricted-info h2{margin-bottom:12px;color:#ef4444}.restricted-info p{color:var(--text-secondary);margin-bottom:32px}
