.map-wrap{width:100%;height:100vh;position:relative;overflow:hidden}.map{width:100%;height:100%;position:absolute;inset:0}.calculation-box{color:rgb(var(--foreground));-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #0000000f;border-radius:12px;padding:12px 16px;font-size:14px;line-height:1.4;transition:all .3s;position:absolute;bottom:120px;left:12px;box-shadow:0 4px 20px #00000026}.calculation-box:hover{transform:translateY(-2px);box-shadow:0 6px 25px #0003}.toolbar{z-index:1;flex-direction:column;gap:8px;max-width:220px;display:flex;position:absolute;top:258px;left:10px}.toolbar button{color:rgb(var(--foreground));cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap;text-align:center;background:#fffffff2;border:1px solid #0000000f;border-radius:10px;padding:8px 12px;font-size:13px;font-weight:600;transition:all .3s;box-shadow:0 2px 10px #0000001a}.toolbar button:hover{background:#fff;transform:translateY(-1px);box-shadow:0 4px 15px #00000026}.form-panel{width:390px;height:100%;color:rgb(var(--foreground));-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffffa;border-left:1px solid #0000000f;padding:20px;position:absolute;top:0;right:0;overflow-y:auto;box-shadow:-4px 0 20px #0000001a}.logo-container{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);border:1px solid #0000000f;border-radius:12px;justify-content:center;align-items:center;margin-bottom:18px;padding:14px;display:flex;box-shadow:0 2px 10px #0000000d}.logo-container img{object-fit:contain;filter:drop-shadow(0 2px 4px #0000001f);max-width:220px;max-height:64px}.stepper{align-items:center;gap:12px;margin-bottom:18px;display:flex}.stepper .step{color:#6b7280;background:linear-gradient(135deg,#e5e7eb 0%,#d1d5db 100%);border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:800;transition:all .35s;display:flex;position:relative;overflow:hidden}.stepper .step.active{background:linear-gradient(135deg,rgb(var(--brand))0%,rgb(var(--brand-hover))100%);color:#fff;transform:scale(1.08);box-shadow:0 4px 15px #00000024}.stepper .step.completed{background:linear-gradient(135deg,rgb(var(--brand))0%,rgb(var(--brand-hover))100%);color:#0000}.stepper .step.completed:after{content:"✓";color:#fff;place-items:center;font-size:18px;font-weight:800;display:grid;position:absolute;inset:0}.step-content{flex-direction:column;gap:16px;display:flex}.step-content h3{letter-spacing:-.02em;margin:0 0 8px;font-size:22px;font-weight:800}.search-section{margin-bottom:10px}.form-search-container{width:100%;position:relative}.form-search-container .mapboxgl-ctrl-geocoder{border:2px solid rgb(var(--border))!important;-webkit-backdrop-filter:blur(10px)!important;backdrop-filter:blur(10px)!important;background:#ffffffe6!important;border-radius:10px!important;width:100%!important;box-shadow:0 2px 10px #0000001a!important}.form-search-container .mapboxgl-ctrl-geocoder:hover{border-color:rgb(var(--brand))!important;box-shadow:0 4px 15px #0000001f!important}.form-search-container .mapboxgl-ctrl-geocoder input{background:0 0!important;border:none!important;border-radius:10px!important;margin-left:0!important;padding:12px 14px!important;font-size:16px!important}.form-search-container .mapboxgl-ctrl-geocoder .suggestions{-webkit-backdrop-filter:blur(20px)!important;backdrop-filter:blur(20px)!important;z-index:1001!important;background:#fffffffa!important;border:1px solid #0000000f!important;border-radius:10px!important;max-height:250px!important;margin-top:4px!important;overflow-y:auto!important;box-shadow:0 8px 30px #0003!important}.form-search-container .mapboxgl-ctrl-geocoder .suggestions .suggestion{color:#374151!important;border-bottom:1px solid #0000000d!important;padding:12px 16px!important;font-size:14px!important;transition:all .2s!important}.form-search-container .mapboxgl-ctrl-geocoder .suggestions .suggestion:hover,.form-search-container .mapboxgl-ctrl-geocoder .suggestions .suggestion.active{border-left:3px solid rgb(var(--brand))!important;background:#0000000a!important}.form-action-buttons{gap:8px;margin-bottom:10px;display:flex}.form-action-button{cursor:pointer;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;padding:9px 10px;font-size:12px;font-weight:800;transition:all .25s;display:flex}.form-action-button.primary{background:linear-gradient(135deg,rgb(var(--brand))0%,rgb(var(--brand-hover))100%);color:#fff;box-shadow:0 2px 8px #00000024}.form-action-button.secondary{color:#fff;background:linear-gradient(135deg,#54595f 0%,#3f4247 100%);box-shadow:0 2px 8px #00000024}.form-action-button.primary:hover,.form-action-button.secondary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000002e}.summary{background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);border:1px solid #0000000f;border-radius:12px;grid-template-columns:120px 1fr;gap:12px;padding:14px;display:grid}.actions{gap:12px;margin-top:12px;display:flex}.actions .primary{background:linear-gradient(135deg,rgb(var(--brand))0%,rgb(var(--brand-hover))100%);color:#fff;text-transform:uppercase;letter-spacing:.5px;border:none;border-radius:999px;padding:12px 24px;font-weight:800;transition:all .25s;box-shadow:0 4px 15px #00000024}.actions button{border:2px solid rgb(var(--border));color:#374151;cursor:pointer;background:#ffffffe6;border-radius:999px;padding:12px 24px;font-size:14px;font-weight:800;transition:all .25s}.actions button:hover:not(:disabled),.actions .primary:hover:not(:disabled){transform:translateY(-1px)}.actions button:disabled,.actions .primary:disabled{opacity:.55;cursor:not-allowed!important;box-shadow:none!important;transform:none!important}.error-message,.error{color:#b91c1c;font-size:12px}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;margin:4px 0;padding:6px 8px}.drawing-mode-indicator{color:#92400e;background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;align-items:center;gap:8px;margin:8px 0;padding:8px 12px;font-size:14px;display:flex}.pulse-dot{background:#f59e0b;border-radius:50%;width:8px;height:8px;animation:2s infinite pulse}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #f59e0bb3}70%{transform:scale(1);box-shadow:0 0 0 10px #f59e0b00}to{transform:scale(.95);box-shadow:0 0 #f59e0b00}}.detection-indicator{border:1px solid rgb(var(--brand));color:rgb(var(--foreground));background:#0000000a;border-radius:8px;align-items:center;gap:8px;margin:8px 0;padding:8px 12px;font-size:14px;display:flex}.detection-indicator .pulse-dot{background:rgb(var(--brand));animation:2s infinite pulse-brand}@keyframes pulse-brand{0%{transform:scale(.95);box-shadow:0 0 #16a34a80}70%{transform:scale(1);box-shadow:0 0 0 10px #16a34a00}to{transform:scale(.95);box-shadow:0 0 #16a34a00}}.auto-add-message{border:1px solid rgb(var(--brand));color:rgb(var(--foreground));background:#0000000a;border-radius:10px;align-items:center;gap:8px;margin:8px 0;padding:12px 14px;font-size:14px;font-weight:700;display:flex;box-shadow:0 4px 15px #00000014}.detected-roofs{background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 100%);border:1px solid #0ea5e9;border-radius:12px;margin:16px 0;padding:16px;box-shadow:0 4px 15px #0ea5e91a}.detected-header{border-bottom:1px solid #bae6fd;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;padding-bottom:8px;display:flex}.detected-actions{gap:6px;display:flex}.add-all-btn,.clear-all-btn{cursor:pointer;border:1px solid;border-radius:8px;padding:4px 8px;font-size:12px;font-weight:800}.add-all-btn{color:#fff;background:#0ea5e9;border-color:#0ea5e9}.clear-all-btn{color:#fff;background:#ef4444;border-color:#ef4444}.detected-roof-item{background:#fff;border:1px solid #bae6fd;border-radius:10px;justify-content:space-between;align-items:center;gap:10px;margin:8px 0;padding:10px;display:flex}.roof-info{flex-direction:column;flex:1;gap:2px;display:flex}.roof-name{color:#0c4a6e;font-size:14px;font-weight:800}.roof-area{color:#64748b;font-size:12px}.roof-actions{align-items:center;gap:6px;display:flex}.add-roof-btn,.delete-roof-btn{cursor:pointer;border:1px solid;border-radius:8px;font-weight:900}.add-roof-btn{background:rgb(var(--brand));color:#fff;border-color:rgb(var(--brand));padding:4px 10px;font-size:12px}.delete-roof-btn{color:#fff;background:#ef4444;border-color:#ef4444;place-items:center;width:28px;height:28px;font-size:16px;display:grid}.slope-options,.stories-options{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px;display:grid}.slope-option,.stories-option{cursor:pointer;text-align:center;background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);border:2px solid #e5e7eb;border-radius:12px;flex-direction:column;align-items:center;padding:14px 12px;transition:all .25s;display:flex;position:relative;box-shadow:0 2px 8px #0000000d}.slope-option.selected,.stories-option.selected{border-color:rgb(var(--brand));background:#00000008;transform:translateY(-1px);box-shadow:0 4px 15px #0000001f}.slope-icon{margin-bottom:8px;font-size:28px}.slope-label{color:#374151;font-size:15px;font-weight:800}.slope-description{color:#6b7280;font-size:12px;font-weight:600}.stories-icon{color:#374151;margin-bottom:8px;font-size:22px;font-weight:900}.section-divider{background:linear-gradient(90deg,transparent 0%,rgb(var(--brand))50%,transparent 100%);border:none;height:2px;margin:24px 0 16px}.success-message{text-align:center;border:1px solid rgb(var(--border));background:#f8fafc;border-radius:12px;margin-bottom:20px;padding:16px 20px}.sites-list{flex-direction:column;gap:8px;margin-top:10px;display:flex}.sites-header{border-bottom:1px solid rgb(var(--border));flex-direction:column;gap:4px;padding:6px 0;display:flex}.total-area{color:rgb(var(--muted));font-size:12px;font-weight:600}.site-item{border:1px solid rgb(var(--border));background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);border-radius:12px;justify-content:space-between;align-items:center;gap:10px;padding:12px;transition:all .25s;display:flex;box-shadow:0 2px 8px #0000000d}.site-item:hover{transform:translateY(-1px);box-shadow:0 4px 15px #0000001a}.site-main{flex-direction:column;gap:2px;display:flex}.site-address{font-size:13px;font-weight:800}.site-area{color:#374151;font-size:12px;font-weight:700}.site-actions button{color:#ef4444;cursor:pointer;background:0 0;border:2px solid #ef4444;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:900}.site-actions button:hover{background:#ef444414}.how-it-works-map-btn{border:2px solid rgb(var(--brand));width:44px;height:44px;color:rgb(var(--brand));cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:2;background:#fffffff2;border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:all .25s;display:flex;position:absolute;bottom:20px;right:410px;box-shadow:0 4px 15px #00000026}.how-it-works-map-btn:hover{background:rgb(var(--brand));color:#fff;transform:translateY(-2px)scale(1.05);box-shadow:0 6px 20px #0003}.modal-overlay{z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:16px;width:92%;max-width:520px;max-height:80vh;padding:0;overflow:hidden;box-shadow:0 20px 60px #0000004d}.modal-header{border-bottom:1px solid rgb(var(--border));background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);justify-content:space-between;align-items:center;padding:20px;display:flex}.modal-header h3{margin:0;font-size:18px;font-weight:900}.modal-close-btn{color:#6b7280;cursor:pointer;background:0 0;border:none;border-radius:999px;place-items:center;width:40px;height:40px;font-size:30px;transition:all .2s;display:grid}.modal-close-btn:hover{color:rgb(var(--foreground));background:#0000000f}.modal-body{max-height:calc(80vh - 84px);padding:20px;overflow-y:auto}.instruction-step{border-left:4px solid rgb(var(--brand));background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);border-radius:12px;align-items:flex-start;gap:12px;margin:12px 0;padding:14px;font-size:14px;display:flex}.instruction-step .step-number{background:linear-gradient(135deg,rgb(var(--brand))0%,rgb(var(--brand-hover))100%);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:28px;height:28px;font-size:14px;font-weight:900;display:grid}@media (max-width:900px){.form-panel{width:100%;height:48%;top:auto;bottom:0}.how-it-works-map-btn{bottom:52%;right:15px}.toolbar{max-width:180px;top:130px}.actions{gap:10px}}@media (max-width:768px){.actions{flex-direction:column;gap:8px}.actions button{width:100%}.form-action-buttons{flex-direction:column}}@media (max-width:600px){.toolbar{max-width:160px;top:110px;left:8px}.toolbar button{padding:6px 10px;font-size:12px}.calculation-box{font-size:13px;bottom:20px;left:8px}.how-it-works-map-btn{width:40px;height:40px;font-size:18px;bottom:15px;right:15px}}
