:root{font-family:Outfit,Inter,"Source Sans 3",system-ui,sans-serif;--bg-color: #0a0a0a;--text-color: #f5f5f5;--card-bg: #171717;--border-color: #262626;--subtext: #a3a3a3;--header-bg: #0a0a0a;--accent-color: #3b82f6;--glass-bg: rgba(23, 23, 23, .7);--glass-border: rgba(255, 255, 255, .1);--app-max-width: 1800px;--app-padding: clamp(1rem, 2.2vw, 2.5rem);--section-gap: clamp(1rem, 2vw, 2rem);color:var(--text-color);background:var(--bg-color);color-scheme:dark}*{box-sizing:border-box}html{overflow-x:hidden}body{margin:0;min-height:100vh;background-color:var(--bg-color);color:var(--text-color);transition:background-color .3s ease,color .3s ease;overflow-x:hidden}.app{width:min(calc(100% - clamp(1rem,3vw,3rem)),var(--app-max-width));max-width:var(--app-max-width);margin:clamp(.75rem,2.5vw,2.5rem) auto clamp(2rem,4vw,4rem);padding:var(--app-padding);background:var(--card-bg);border-radius:clamp(12px,1.4vw,20px);border:1px solid var(--border-color);box-shadow:0 20px 50px #00000080;min-width:0}h1{margin:0;font-size:clamp(1.45rem,2.2vw,2rem);font-weight:800;letter-spacing:-.025em;color:#fff;background:linear-gradient(to right,#fff,#a3a3a3);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.app-header{display:flex;justify-content:space-between;align-items:center;gap:var(--section-gap);margin-bottom:var(--section-gap);flex-wrap:wrap;min-width:0}.header-left{min-width:min(100%,14rem)}.header-controls{display:flex;align-items:center;justify-content:flex-end;gap:clamp(.55rem,1.2vw,1.5rem);padding:clamp(.5rem,1vw,.75rem) clamp(.75rem,1.6vw,1.5rem);background:#0000004d;border:1px solid var(--border-color);border-radius:999px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex:1 1 36rem;flex-wrap:wrap;min-width:0}.compact-coords{display:flex;gap:clamp(.45rem,1vw,1rem);font-family:inherit;font-size:.85rem;flex-wrap:wrap;min-width:0}.coord-item{color:var(--text-color);font-weight:600}.coord-label{color:var(--subtext);margin-right:.25rem}.header-analyze-btn{margin-top:0!important;font-size:.9rem!important;padding:.6rem 1.25rem!important;background:var(--accent-color)!important;color:#fff!important}.header-analyze-btn:hover:not(:disabled){background:#2563eb!important}.hidden-file-input{display:none}.header-privacy-link{color:var(--subtext);font-size:.86rem;font-weight:700;text-decoration:none;white-space:nowrap;transition:color .2s}.header-privacy-link:hover{color:#fff}.map-card{margin-top:var(--section-gap);border:1px solid var(--border-color);border-radius:16px;padding:clamp(.75rem,1.6vw,1.25rem);background:#000;box-shadow:inset 0 2px 4px #0000004d;min-width:0}.search-input{width:100%;min-width:0;padding:clamp(.78rem,1.3vw,1rem) clamp(.9rem,1.5vw,1.25rem);border-radius:12px;border:1px solid var(--border-color);background:#1a1a1a;color:#fff;font-size:1rem;margin-bottom:1.25rem;transition:border-color .2s,box-shadow .2s}.search-input::placeholder{color:#737373}.search-input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f633}.status{margin-top:1rem;font-weight:500;display:flex;align-items:center;gap:.75rem;color:var(--subtext);flex-wrap:wrap;min-width:0}.status.loading{color:var(--accent-color)}.loading-spinner{display:inline-block;width:1.25rem;height:1.25rem;border:2px solid rgba(255,255,255,.1);border-top-color:var(--accent-color);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.results{margin-top:clamp(.75rem,1.5vw,1rem);background:#0f0f0f;padding:clamp(.85rem,1.8vw,1.5rem);border-radius:12px;border:1px solid var(--border-color);min-width:0}.results-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:clamp(1rem,2vw,1.5rem);flex-wrap:wrap;min-width:0}.results-heading{min-width:min(100%,22rem);flex:1 1 24rem}.results-heading h2{margin:0;font-size:clamp(1.25rem,2vw,1.8rem)}.primary-button{margin-top:1rem;padding:.85rem clamp(1rem,1.8vw,1.75rem);border-radius:999px;border:none;background:#fff;color:#000;font-size:1rem;font-weight:700;cursor:pointer;transition:transform .2s,background .2s,box-shadow .2s;min-height:2.5rem;max-width:100%;white-space:normal}.primary-button:hover:not(:disabled){background:#f5f5f5;transform:translateY(-1px);box-shadow:0 4px 12px #ffffff26}.primary-button:active:not(:disabled){transform:translateY(0)}.primary-button:disabled{opacity:.3;cursor:not-allowed}.summary{font-size:1.1rem;color:var(--subtext);margin:.5rem 0}.clusters-container{display:grid;gap:clamp(.85rem,1.6vw,1rem);margin-top:0rem;min-width:0}.comparison-card{display:flex;flex-direction:column;gap:clamp(1.1rem,2vw,2rem);position:relative;background:#121212;border:1px solid var(--border-color);border-radius:clamp(12px,1.4vw,20px);padding:clamp(.85rem,1.5vw,1.25rem);box-shadow:0 4px 20px #0006;transition:border-color .3s,opacity .2s ease;min-width:0}.comparison-card:hover{border-color:#404040}.location-header{display:flex;justify-content:space-between;align-items:flex-start;gap:clamp(.8rem,1.5vw,1.5rem);margin-bottom:1rem;flex-wrap:wrap;min-width:0}.view-header{border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1rem;margin-bottom:1rem}.view-actions{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;flex-wrap:wrap;min-width:0}.view-toggle-button,.view-analyze-button{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;margin:0;min-height:2.35rem;padding:.5rem clamp(.75rem,1.4vw,1.2rem);border-radius:999px;border:none;cursor:pointer;font-size:.85rem;font-weight:700;line-height:1.2;text-align:center;max-width:100%;transition:background .2s,opacity .2s,transform .2s}.view-toggle-button:hover:not(:disabled),.view-analyze-button:hover:not(:disabled){transform:translateY(-1px)}.view-analyze-button:disabled,.view-toggle-button:disabled{cursor:not-allowed;opacity:.55}.view-block-separated{padding-top:clamp(1.25rem,2.5vw,2rem);border-top:2px dashed rgba(255,255,255,.1)}.gemini-summary-box{margin-top:.5rem;margin-bottom:1.5rem;padding:clamp(1rem,1.8vw,1.5rem);background-color:#6366f11a;border:1px solid rgba(99,102,241,.3);border-radius:12px;min-width:0}.gemini-summary-title{margin:0 0 1rem;display:flex;align-items:center;gap:.5rem;color:#a5b4fc;font-size:clamp(1rem,1.4vw,1.1rem)}.summary-actions{display:flex;gap:1rem;align-items:center;margin-top:.5rem;flex-wrap:wrap}.comparison-card-footer{border-top:1px solid rgba(255,255,255,.1);padding-top:1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.street-group{margin-bottom:1rem}.street-header{font-size:clamp(1.2rem,2vw,1.75rem);font-weight:800;color:#fff;margin:0 0 .5rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:1rem}.street-header:after{content:"";height:2px;background:var(--accent-color);flex:1;border-radius:2px}.location-title{margin:0 0 .5rem;font-size:clamp(1.05rem,1.6vw,1.35rem);font-weight:700;color:#fff}.location-coords{margin:0;font-size:.9rem;color:var(--subtext)}.history-button.compact{margin-top:0!important;padding:.5rem 1rem!important;font-size:.85rem!important;background:#ffffff0d!important;border:1px solid rgba(255,255,255,.1)!important;color:#fff!important;white-space:nowrap}.history-button.compact:hover{background:#ffffff1f!important;border-color:#fff3!important}.camera-shift-info{margin:1rem 0 0;font-size:.85rem;color:#fcd34d;background:#fbbf241a;border-left:3px solid #f59e0b;padding:.65rem 1rem;border-radius:6px;display:inline-block}.warning-badge{color:#f59e0b;font-weight:700;margin-left:.5rem}.no-history-badge{display:inline-block;background:#ffffff0d;color:#a3a3a3;padding:.35rem 1rem;border-radius:999px;font-size:.85rem;font-weight:600;border:1px solid rgba(255,255,255,.1);margin-top:.75rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.comparison-images{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1rem,2vw,2rem);margin-bottom:clamp(1rem,2vw,2rem);min-width:0}.comparison-images-single{grid-template-columns:1fr}@media (max-width: 1024px){.comparison-images{grid-template-columns:1fr}}.facade-comparison{display:flex;flex-direction:column;gap:1rem;padding:clamp(.75rem,1.3vw,1rem);background:#0a0a0a;border-radius:12px;border:1px solid var(--border-color)}.facade-comparison-label{font-size:.85rem;font-weight:800;color:var(--subtext);text-transform:uppercase;letter-spacing:.1em;padding:0 .5rem}.facade-pair{display:flex;align-items:center;gap:1rem;min-width:0}.year-column{flex:1;display:flex;flex-direction:column;align-items:stretch;min-width:0}.year-label{font-size:clamp(.85rem,1.2vw,1rem);font-weight:700;color:#fff;margin-bottom:.75rem;display:flex;justify-content:space-between;align-items:center;gap:.5rem;flex-wrap:wrap}.capture-date{font-size:.8rem;color:var(--subtext);text-align:right;margin-top:.5rem;font-family:monospace;word-break:break-word}.image-metadata-line{margin-top:.5rem;color:var(--subtext);font-family:monospace;font-size:clamp(.62rem,.72vw,.78rem);line-height:1.35;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.image-container{position:relative;width:100%;aspect-ratio:1 / 1;min-height:260px;background:#000;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.05);box-shadow:0 10px 30px #00000080}.image-loading{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#171717 25%,#262626,#171717 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;z-index:1}.image-loading:after{content:"Loading Street View image...";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#a3a3a3;font-size:.85rem;font-weight:700;letter-spacing:.02em}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.comparison-image{width:100%;height:100%;display:block;object-fit:cover;border-radius:0}.image-placeholder{width:100%;aspect-ratio:1;background:#0f0f0f;border:1px dashed #404040;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#525252}.placeholder-text{font-size:.85rem;text-align:center;font-weight:500}.history-image-placeholder{width:100%;aspect-ratio:1;background:#0f0f0f;border:1px dashed #404040;border-radius:8px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;color:#737373;padding:1rem;text-align:center}.arrow-separator{font-size:1.5rem;color:#404040;font-weight:300;flex-shrink:0}.no-results{text-align:center;padding:4rem 2rem;color:var(--subtext)}.hint{font-size:.9rem;color:#525252;font-style:italic;margin-top:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:clamp(.75rem,2vw,2rem)}.modal-content{background:#171717;border-radius:24px;width:100%;max-width:1600px;max-height:min(90vh,980px);box-shadow:0 30px 100px #000c;display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--border-color)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:clamp(1rem,2vw,1.5rem) clamp(1rem,3vw,2.5rem);border-bottom:1px solid var(--border-color);background:#0a0a0a}.modal-header h3{margin:0;color:#fff;font-size:clamp(1.05rem,2vw,1.5rem);font-weight:800}.modal-close{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);font-size:1.25rem;color:#fff;cursor:pointer;padding:.5rem;width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;border-radius:12px;transition:background .2s}.modal-close:hover{background:#ffffff1f}.history-tabs{display:flex;gap:.75rem;padding:clamp(.9rem,1.8vw,1.25rem) clamp(1rem,3vw,2.5rem);background:#0a0a0a;border-bottom:1px solid var(--border-color);overflow-x:auto}.history-tab-button{padding:.65rem 1.25rem;border:1px solid var(--border-color);background:#171717;border-radius:99px;font-size:.9rem;font-weight:700;color:var(--subtext);cursor:pointer;white-space:nowrap;transition:all .2s}.history-tab-button:hover{border-color:#525252;color:#fff}.history-tab-button.active{background:#fff;border-color:#fff;color:#000}.modal-body{padding:clamp(1rem,3vw,2.5rem);overflow-y:auto;flex:1}.capture-info{margin:0 0 2rem;color:#fff;font-weight:800;font-size:1.2rem;display:flex;align-items:center;gap:.75rem}.capture-info:before{content:"📅"}.history-modal-content{max-width:95vw}.timeline-scroll-container{overflow-x:auto;padding-bottom:2rem}.timeline-grid{display:flex;gap:clamp(1rem,2vw,2rem);min-width:min-content}.timeline-item{display:flex;flex-direction:column;gap:1rem;width:clamp(260px,34vw,350px);flex-shrink:0}.timeline-header{display:flex;justify-content:space-between;align-items:flex-end;border-bottom:1px solid var(--border-color);padding-bottom:.75rem}.timeline-year-label{font-size:1.5rem;font-weight:800;color:#fff}.timeline-date-label{font-size:.9rem;color:var(--subtext);font-family:monospace}.results-map-container{margin:1rem 0;padding:clamp(.85rem,1.6vw,1.25rem);background:var(--card-bg);border:1px solid var(--border-color);border-radius:20px;box-shadow:0 10px 30px #0006}.results-map-container h3{margin:0 0 .5rem;font-size:clamp(1.1rem,1.8vw,1.5rem);font-weight:800;color:#fff}.results-map{margin-top:1.5rem;height:clamp(420px,52vh,720px);border-radius:12px;overflow:hidden;border:1px solid var(--border-color);background:#fff}.highlight-flash{animation:flash-border 2s ease-out}@keyframes flash-border{0%{border-color:var(--accent-color);box-shadow:0 0 0 4px #3b82f666;transform:scale(1.02)}to{border-color:var(--border-color);box-shadow:0 4px 20px #0006;transform:scale(1)}}html{scroll-behavior:smooth}.gm-style-iw-c{background-color:#1c1c21!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:8px!important;box-shadow:0 8px 24px #000c!important;padding:6px 12px!important;max-width:calc(100vw - 32px)!important}.gm-style-iw-c button[title=Close]{display:none!important}.gm-style-iw-d{overflow:hidden!important;max-width:calc(100vw - 48px)!important}.floating-action-button{position:fixed;bottom:2rem;right:2rem;background-color:var(--surface-light);color:var(--text-primary);border:1px solid var(--border-color);border-radius:9999px;padding:.75rem 1.5rem;font-weight:600;font-size:1rem;box-shadow:0 4px 6px -1px #00000080,0 2px 4px -1px #0000004d;cursor:pointer;z-index:1000;transition:all .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.floating-action-button:hover{background-color:var(--surface-hover);transform:translateY(-2px);box-shadow:0 10px 15px -3px #00000080,0 4px 6px -2px #0000004d;border-color:var(--text-secondary)}.floating-action-button:active{transform:translateY(0)}.custom-map-tooltip{color:#fff;font-weight:600;font-size:.85rem;text-align:center;line-height:1.2;white-space:nowrap}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:var(--bg-color);padding:clamp(1rem,4vw,2rem)}.login-box{background:var(--card-bg);border:1px solid var(--border-color);border-radius:20px;padding:clamp(1.5rem,5vw,3rem) clamp(1.1rem,6vw,4rem);width:100%;max-width:500px;text-align:center;box-shadow:0 20px 50px #00000080;animation:fadeIn .5s ease-out}.login-subtitle{color:var(--subtext);margin-top:.5rem;margin-bottom:2.5rem;font-size:1.1rem}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-form .search-input{margin-bottom:0;text-align:center}.login-btn{width:100%}.login-error{color:#ef4444;background:#ef44441a;border:1px solid rgba(239,68,68,.3);padding:.75rem;border-radius:8px;font-size:.9rem;font-weight:500}.api-setup-app{max-width:1200px}.api-setup-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(.9rem,1.8vw,1.25rem)}.api-setup-panel{display:flex;flex-direction:column;gap:.8rem;padding:clamp(1rem,2vw,1.35rem);border:1px solid rgba(148,163,184,.16);border-radius:12px;background:#101216;min-width:0}.api-setup-panel h2{margin:0;font-size:1.1rem;color:#fff}.api-setup-panel p{margin:0;color:var(--subtext);line-height:1.55}.api-setup-panel a{color:#93c5fd;font-weight:700;text-decoration:none}.api-setup-admin{display:flex;flex-direction:column;align-items:flex-end;gap:.65rem;min-width:min(100%,280px)}.api-setup-admin-toggle{padding:.45rem .75rem;font-size:.78rem}.api-setup-admin-form{display:grid;gap:.55rem;width:min(280px,100%);padding:.8rem;border:1px solid rgba(148,163,184,.18);border-radius:8px;background:#101216}.api-setup-admin-form .search-input{margin-bottom:0}.api-setup-form label{display:grid;gap:.45rem;color:#d1d5db;font-size:.88rem;font-weight:700}.api-setup-form .search-input{margin-bottom:0}.api-setup-actions{display:flex;gap:.75rem;flex-wrap:wrap}.api-setup-message{color:#fbbf24;font-size:.86rem}.api-setup-warning,.usage-summary{color:var(--subtext);font-size:.82rem;line-height:1.45}.api-setup-warning{margin-top:1rem;padding:.85rem 1rem;border:1px solid rgba(251,191,36,.25);border-radius:10px;background:#fbbf2414}.usage-summary{margin:.6rem 0 0}@media (max-width: 1024px){.api-setup-grid{grid-template-columns:1fr}}.summary-container table{width:100%;min-width:760px;border-collapse:collapse;margin:1.5rem 0;background:#ffffff05;border-radius:12px;overflow:hidden;border:1px solid var(--border-color);font-size:.95rem}.summary-container th{background:#ffffff0d;color:#fff;font-weight:800;text-align:left;padding:1rem;border-bottom:2px solid var(--border-color);text-transform:uppercase;letter-spacing:.05em}.summary-container td{padding:.85rem 1rem;border-bottom:1px solid rgba(255,255,255,.05);color:var(--subtext)}.summary-container tr:last-child td{border-bottom:none}.summary-container tr:hover td{background:#ffffff08;color:#fff}.summary-container strong{color:var(--accent-color);font-weight:700}.summary-container h3{margin-top:2rem;margin-bottom:1rem;font-size:1.25rem;color:#fff;border-left:4px solid var(--accent-color);padding-left:1rem}.summary-container hr{border:none;border-top:1px solid var(--border-color);margin:2rem 0}.summary-container p{margin-bottom:1rem;color:#d1d5db}.composite-score-group{display:grid;gap:.45rem;margin:1.25rem 0}.composite-score-line{display:flex;align-items:baseline;gap:.45rem;color:var(--accent-color);font-weight:800}.composite-score-label{color:var(--accent-color)}.composite-score-separator{color:#c4b5fd}.composite-score-value{color:#34d399;font-family:monospace;font-size:1.05em}.summary-container table th:last-child,.summary-container table td:last-child{text-align:center;font-weight:700;color:#fff;background:#ffffff08;border-left:1px solid var(--border-color);min-width:60px}.summary-container td.score-improved{color:#34d399;font-weight:800}.summary-container td.score-declined{color:#f87171;font-weight:800}.summary-container td.score-unchanged{color:#d1d5db;font-weight:700}.summary-container{position:relative;transition:max-height .4s ease;overflow-x:auto;-webkit-overflow-scrolling:touch}.summary-container.collapsed{max-height:240px;overflow:hidden;mask-image:linear-gradient(to bottom,black 60%,transparent 100%);-webkit-mask-image:linear-gradient(to bottom,black 60%,transparent 100%)}.analysis-progress{display:grid;gap:.7rem;padding:.9rem 1rem;border:1px solid rgba(129,140,248,.22);border-radius:10px;background:#0f172a52}.analysis-progress-topline{display:flex;justify-content:space-between;align-items:center;gap:1rem;color:#dbeafe;font-size:.88rem;font-weight:700}.analysis-progress-topline span:last-child{color:#93c5fd;font-family:monospace;word-break:break-word}.analysis-progress-track{height:.65rem;overflow:hidden;border-radius:999px;background:#0f172ad9;border:1px solid rgba(148,163,184,.12)}.analysis-progress-bar{height:100%;border-radius:inherit;background:linear-gradient(90deg,#38bdf8,#6366f1);transition:width .45s ease}.study-sidebar{max-width:100%;min-width:0}.study-sidebar-summary{min-width:0;flex-wrap:wrap}.study-sidebar-button{min-height:2.4rem;max-width:100%;white-space:normal!important;text-align:center;justify-content:center}.study-sidebar-status,.study-sidebar-status-row{min-width:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.alignment-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2;display:flex;align-items:center;justify-content:center;opacity:.3;transition:opacity .2s ease}.crosshair-h{position:absolute;width:100%;height:1px;background:#fff6;box-shadow:0 0 3px #0009}.crosshair-v{position:absolute;width:1px;height:100%;background:#fff6;box-shadow:0 0 3px #0009}.image-container:hover .alignment-overlay{opacity:.8}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:10000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.criteria-overlay{align-items:flex-start;padding:clamp(.75rem,2vw,1.5rem) 0;overflow-y:auto}.modal-content{background:#1e1e1e;border:1px solid #333;border-radius:20px;width:min(90%,1600px);max-width:900px;max-height:min(85vh,980px);overflow-y:auto;padding:clamp(1rem,3vw,2.5rem);box-shadow:0 25px 50px -12px #00000080}.criteria-modal-content{background:#15171c;border:1px solid rgba(148,163,184,.2);border-radius:16px;max-width:1120px;width:min(94vw,1120px);padding:clamp(.75rem,1.6vw,1rem);box-shadow:0 28px 70px #0000008c}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;border-bottom:1px solid #333;padding-bottom:1rem}.criteria-modal-header{margin-bottom:0;padding:clamp(.75rem,1.5vw,.9rem) clamp(.75rem,1.8vw,1rem);border:1px solid rgba(148,163,184,.14);border-radius:12px;background:linear-gradient(135deg,#1e293bb8,#0f172a57)}.criteria-header-actions{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap;justify-content:flex-end}.criteria-title-block{display:flex;flex-direction:column;gap:.25rem}.criteria-kicker{color:#93c5fd;font-size:.72rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase}.modal-header h2{margin:0;color:#818cf8;font-size:clamp(1.25rem,2vw,1.8rem)}.criteria-modal-header h2{color:#f8fafc;font-size:clamp(1.05rem,1.5vw,1.28rem);line-height:1.2;letter-spacing:0}.close-button{background:#ffffff0d;border:1px solid rgba(148,163,184,.16);color:#cbd5e1;font-size:1.35rem;cursor:pointer;transition:color .2s,border-color .2s,background .2s;width:2.25rem;height:2.25rem;border-radius:8px;display:inline-flex;align-items:center;justify-content:center}.close-button:hover{color:#f87171;background:#f8717114;border-color:#f8717152}.criteria-edit-button,.criteria-save-button,.criteria-cancel-button,.criteria-reset-button{border:1px solid rgba(148,163,184,.18);border-radius:9px;cursor:pointer;font-weight:700;font-size:.8rem;min-height:2.35rem;padding:.55rem .85rem;transition:background .2s,border-color .2s,color .2s,transform .2s}.criteria-edit-button,.criteria-save-button{color:#fff;background:linear-gradient(135deg,#4f46e5,#2563eb);border-color:#818cf86b}.criteria-edit-button:hover,.criteria-save-button:hover{border-color:#bfdbfeb3;transform:translateY(-1px)}.criteria-cancel-button,.criteria-reset-button{color:#dbeafe;background:#0f172a8c}.criteria-cancel-button:hover,.criteria-reset-button:hover{background:#1e293bd9;border-color:#94a3b857}.criteria-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem;margin-top:.85rem}.criteria-category{background:#1d2027;padding:.95rem;border-radius:10px;border:1px solid rgba(148,163,184,.14);box-shadow:inset 3px 0 #60a5fac7}.category-title{font-weight:700;color:#f8fafc;margin-bottom:.65rem;display:block;font-size:.88rem;text-transform:uppercase;letter-spacing:.08em}.criteria-list{list-style:none;padding:0;margin:0}.criteria-subcategory{display:block;margin:.75rem 0 .2rem;color:#93c5fd;font-size:.74rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.criteria-item{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.48rem 0;border-bottom:1px solid rgba(148,163,184,.1);color:#cbd5e1;font-size:.88rem;line-height:1.25}.criteria-item-editing{align-items:flex-start;flex-direction:column;gap:.5rem}.criteria-item:last-child{border-bottom:none}.item-weight{color:#818cf8;font-family:monospace;font-weight:700;flex-shrink:0;background:#818cf81a;border:1px solid rgba(129,140,248,.16);border-radius:999px;padding:.05rem .4rem}.criteria-edit-toolbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:.8rem;padding:.75rem .8rem;border:1px solid rgba(59,130,246,.22);border-radius:8px;background:#2563eb14;color:#c7d2fe;font-size:.84rem}.criteria-edit-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:flex-end}.weight-editor{display:grid;grid-template-columns:minmax(140px,1fr) auto;align-items:center;gap:.75rem;width:100%}.weight-editor input[type=range]{width:100%;accent-color:#60a5fa;cursor:pointer}@media (max-width: 860px){.criteria-modal-content{width:94%;padding:1rem}.criteria-modal-header{align-items:stretch;flex-direction:column;gap:.8rem}.criteria-header-actions{justify-content:space-between}.criteria-grid{grid-template-columns:1fr}.criteria-edit-toolbar{align-items:stretch;flex-direction:column}.criteria-edit-actions{justify-content:flex-start}}.secondary-button{background:#2d2e32;color:#e2e8f0;border:1px solid #3f3f46;padding:.6rem clamp(.85rem,1.4vw,1.2rem);border-radius:9999px;cursor:pointer;font-weight:500;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s;margin-right:.5rem;min-height:2.4rem;max-width:100%;white-space:normal;text-align:center}.secondary-button:hover{background:#3f3f46;border-color:#818cf8}@media (min-width: 1920px){:root{--app-max-width: 1800px}.results-map{height:min(56vh,680px)}}@media (max-width: 1024px){.app{width:calc(100% - 1.5rem)}.app-header{align-items:stretch}.header-controls{flex:1 1 100%;justify-content:flex-start;border-radius:18px}.compact-coords{width:100%}.results-toolbar{align-items:stretch}.study-sidebar{width:100%}.study-sidebar-button-auto{margin-left:0!important}.location-header,.view-header{align-items:stretch}.view-actions{width:100%;justify-content:flex-start}.summary-container table{min-width:720px}}@media (max-width: 640px){.app{width:100%;margin:0;border-radius:0;border-left:none;border-right:none;padding:1rem}h1{font-size:1.45rem}.header-left{width:100%}.header-controls{width:100%;padding:.75rem;gap:.55rem}.header-controls>button,.header-controls .primary-button,.header-controls .secondary-button{flex:1 1 100%;width:100%;margin-right:0}.compact-coords{display:grid;grid-template-columns:repeat(2,minmax(0,1fr))}.map-card,.results{border-radius:12px}.results-map{height:320px}.results-toolbar,.comparison-card-footer{gap:.85rem}.study-sidebar{align-items:stretch!important;gap:.55rem!important;padding:.65rem!important}.study-sidebar-summary{width:100%;padding-right:0!important;border-right:none!important;padding-bottom:.55rem;border-bottom:1px solid rgba(255,255,255,.1)}.study-sidebar-button{flex:1 1 calc(50% - .55rem);min-width:0}.study-sidebar-button:last-of-type,.study-sidebar-button:nth-last-of-type(2){flex-basis:100%}.location-header,.view-header{gap:.75rem}.view-actions{display:grid;grid-template-columns:1fr}.view-toggle-button,.view-analyze-button,.history-button.compact{width:100%}.facade-pair{flex-direction:column;align-items:stretch}.arrow-separator{transform:rotate(90deg);align-self:center;line-height:1}.year-label,.capture-date,.image-metadata-line{text-align:left}.summary-container table{min-width:640px;font-size:.85rem}.summary-container th,.summary-container td{padding:.7rem .75rem}.modal-overlay{padding:.5rem;align-items:stretch}.modal-content,.criteria-modal-content{width:100%;max-width:none;max-height:calc(100vh - 1rem);border-radius:14px}.modal-header,.criteria-modal-header{align-items:stretch;flex-direction:column;gap:.75rem}.criteria-header-actions{justify-content:space-between}.timeline-item{width:calc(100vw - 3rem)}.floating-action-button{right:1rem;bottom:1rem;width:calc(100% - 2rem);justify-content:center}}
