body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.building{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.building-main{border-radius:4px;box-shadow:0 4px 6px #0000001a,inset 0 0 20px #0000001a;overflow:hidden;position:absolute}.building-window{background:linear-gradient(135deg,#fff,#e6e6e6);border:1px solid #0003;border-radius:2px;box-shadow:inset 0 0 4px #0000001a;position:absolute}.building-roof{background-color:#0003;clip-path:polygon(0 100%,50% 0,100% 100%);height:15px;left:0;position:absolute;right:0;top:-10px}.building-roof.sloped{clip-path:polygon(0 100%,20% 0,80% 0,100% 100%)}.building-entrance{bottom:0;height:45px;left:50%;position:absolute;transform:translateX(-50%);width:30px}.entrance-door{background:linear-gradient(90deg,#0000004d,#0003);border-radius:4px 4px 0 0;bottom:0;height:35px;position:absolute;width:100%}.entrance-steps{background-color:#0003;bottom:-5px;height:5px;left:-5px;position:absolute;right:-5px}.helipad{height:40px;position:absolute;right:10px;top:10px;width:40px}.helipad-circle{align-items:center;background-color:#ff0000b3;border:2px solid #fff;border-radius:50%;color:#fff;display:flex;font-weight:700;height:100%;justify-content:center;position:absolute;width:100%}.playground{background-color:#90ee90;border-radius:4px;bottom:10px;height:30px;overflow:hidden;position:absolute;right:10px;width:50px}.playground-surface{background:repeating-linear-gradient(45deg,#85c285,#85c285 5px,#90ee90 0,#90ee90 10px);bottom:0;height:5px;position:absolute;width:100%}.loading-bay{background-color:#666;border-radius:4px 4px 0 0;bottom:0;height:20px;position:absolute;right:20%;width:60px}.loading-ramp{background:repeating-linear-gradient(45deg,#555,#555 5px,#666 0,#666 10px);bottom:-5px;height:5px;position:absolute;width:100%}.property-badges{display:flex;font-size:12px;gap:5px;justify-content:center;left:0;position:absolute;right:0;top:-25px}.property-badge{background-color:#ffffffe6;border-radius:4px;box-shadow:0 1px 2px #0000001a;padding:2px 4px}.setback{box-sizing:border-box;height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%}.garden{border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;position:relative}.garden:hover{filter:brightness(1.05)}.grass-base{filter:url(#noise)}.tree-crown{fill:#228b22;filter:drop-shadow(0 2px 2px rgba(0,0,0,.2))}.tree-trunk{fill:#8b4513}.water-body{fill:#4169e1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.water-pattern{animation:waterFlow 10s linear infinite}.walkways .path{stroke:#deb887;stroke-width:4;fill:none;stroke-linecap:round}.walkways .path-border{stroke:#0000001a;stroke-width:6;fill:none;stroke-linecap:round}.art-installation .art-base{fill:#f0f0f0;stroke:#ddd}.art-installation .art-sculpture{stroke:#ff69b4;stroke-linecap:round}.garden-label{background-color:#ffffffe6;border-radius:4px;box-shadow:0 2px 4px #0000001a;font-size:12px;left:50%;padding:4px 8px;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%)}.garden-type{font-weight:500}.protected-badge{margin-left:4px}@keyframes waterFlow{0%{transform:translateX(0)}to{transform:translateX(20px)}}.drawing-area-container{background-color:#f0f0f0;background-image:linear-gradient(90deg,#e0e0e0 1px,#0000 0),linear-gradient(180deg,#e0e0e0 1px,#0000 0);background-size:40px 40px;border:1px solid #ddd;height:80vh;margin-bottom:1rem;min-height:600px;min-width:100%;overflow:auto;position:relative;scroll-behavior:smooth;width:100%}.drawing-area-container::-webkit-scrollbar{height:12px;width:12px}.drawing-area-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:6px}.drawing-area-container::-webkit-scrollbar-thumb{background:#888;border:3px solid #f1f1f1;border-radius:6px}.drawing-area-container::-webkit-scrollbar-thumb:hover{background:#666}.drawing-area{background-image:linear-gradient(90deg,#e0e0e0 1px,#0000 0),linear-gradient(180deg,#e0e0e0 1px,#0000 0);background-size:40px 40px;border:2px solid #ccc;box-shadow:0 0 10px #0000001a;min-height:100%;min-width:100%;transform-origin:0 0;transition:width .3s ease,height .3s ease;will-change:transform}.drawing-area:before{border:1px solid #0000001a;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.zoom-controls{border-radius:8px;bottom:20px;box-shadow:0 2px 6px #0000001a;gap:8px;padding:8px;position:fixed;right:20px;z-index:1000}.zoom-controls,.zoom-controls button{align-items:center;background:#fff;display:flex}.zoom-controls button{border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:16px;height:28px;justify-content:center;transition:background-color .2s;width:28px}.zoom-controls button:hover{background-color:#f5f5f5}.zoom-controls span{color:#666;font-size:14px;min-width:60px;text-align:center}.drawing-area-container.panning{cursor:grab}.drawing-area-container.panning:active{cursor:grabbing}.drawing-area,.drawing-area-container{user-select:none;-webkit-user-select:none}.ghost-element{pointer-events:none;position:absolute}.drawing-area.active{box-shadow:0 0 0 2px #4a90e2}.raw-response-display{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;margin-top:20px;overflow:hidden}.response-header{background-color:#e9ecef;cursor:pointer;padding:10px 15px;-webkit-user-select:none;user-select:none}.response-header h4{color:#333;font-size:16px;margin:0}.response-content{background-color:#fff;padding:15px}.response-content pre{word-wrap:break-word;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;font-size:14px;line-height:1.5;margin:0;overflow-x:auto;padding:15px;white-space:pre-wrap}.copy-button{background-color:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;margin-top:10px;padding:6px 12px}.copy-button:hover{background-color:#0056b3}.raw-response-section{border:1px solid #e5e7eb;border-radius:8px}.response-header{border-bottom:1px solid #e5e7eb}.response-body{padding:16px}.response-body pre{word-wrap:break-word;font-family:monospace;margin:0;white-space:pre-wrap}.response-body button{margin-top:12px}.zone-category{margin-bottom:1.5rem}.category-title{border-bottom:1px solid #eee;color:#666;font-size:.9rem;margin:.5rem 0;padding-bottom:.25rem}.checkbox-group{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.checkbox-label{align-items:center;border-radius:4px;display:flex;font-size:.9rem;gap:.5rem;padding:.25rem;transition:background-color .2s}.checkbox-label:hover{background-color:#f5f5f5}.checkbox-label input[type=checkbox]{height:16px;width:16px}.size-inputs{display:flex;gap:1rem}.size-inputs input{width:100px}.modal-content{max-width:800px}@media (max-width:600px){.checkbox-group{grid-template-columns:1fr}.size-inputs{flex-direction:column}.size-inputs input{width:100%}}.eco-score-board{background-color:#f9fafb;border-radius:.75rem;box-shadow:0 5px 15px #0000001a;font-size:14px;padding:1.5rem;transition:all .3s ease}.score-card{background:#fff;border-radius:.5rem;box-shadow:0 2px 10px #0000000d;padding:1rem;transition:transform .3s ease}.score-card:hover{transform:translateY(-3px)}.progress-bar{background-color:#e5e7eb;border-radius:.25rem;height:6px;overflow:hidden}.suggestions-alert{background-color:#fef3c7;border-left:4px solid #f59e0b;border-radius:.375rem}.suggestions-list{font-size:.875rem;margin-top:.25rem}.badge{background-color:#f3f4f6;border-radius:9999px;color:#374151;font-weight:500;padding:.25rem .5rem}.text-green-600{color:#10b981}.text-blue-600{color:#3b82f6}.text-purple-600{color:#8b5cf6}.text-emerald-600{color:#059669}.text-red-500{color:#ef4444}.text-yellow-500{color:#f59e0b}@media (prefers-color-scheme:dark){.eco-score-board{background-color:#1f2937}.score-card{background-color:#374151}.badge{background-color:#4b5563;color:#e5e7eb}}.floor-plan-container{display:flex;flex-direction:column;gap:1rem;height:100%;padding:1rem}.top-controls{align-items:center;display:flex;justify-content:space-between}.main-layout{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 300px;height:calc(100vh - 200px)}.drawing-section{display:flex;flex-direction:column;gap:1rem}.scoreboard-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;height:fit-content;padding:1rem;position:sticky;top:1rem}@media (max-width:1200px){.main-layout{grid-template-columns:1fr}.scoreboard-section{position:static}}.app-container{background-color:#f5f5f5;display:flex;flex-direction:column;min-height:100vh}.app-header{background-color:#2c3e50;box-shadow:0 2px 4px #0000001a;color:#fff;padding:1rem;text-align:center}.app-header h1{font-size:2rem;margin:0}.app-main{display:flex;flex:1 1;justify-content:center;padding:2rem}.app-footer{background-color:#2c3e50;color:#fff;padding:1rem;text-align:center}.floor-plan-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:1200px;padding:1.5rem;width:100%}.toolbar{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.element-buttons{flex-wrap:wrap}.action-buttons,.element-buttons{display:flex;gap:.5rem}.action-button,.element-button{border-radius:4px;cursor:pointer;padding:.5rem 1rem;transition:all .2s ease}.element-button{background-color:#fff;border:1px solid #ddd}.action-button{background-color:#3498db;border:none;color:#fff}.action-button:hover{background-color:#2980b9}.action-button.clear{background-color:#e74c3c}.action-button.clear:hover{background-color:#c0392b}.drawing-area{background-image:linear-gradient(#ddd 1px,#0000 0),linear-gradient(90deg,#ddd 1px,#0000 0);background-size:20px 20px;border:1px solid #ddd;margin-bottom:1rem}.building{cursor:move;position:absolute;transition:transform .2s}.building:hover{transform:scale(1.02)}.building-label{color:#000000b3;font-size:12px;padding:4px;text-align:center}.garden{cursor:move;position:absolute;transition:filter .2s}.garden:hover{filter:brightness(1.1)}.delete-button,.rotate-button{align-items:center;border-radius:50%;cursor:pointer;display:flex;height:24px;justify-content:center;opacity:0;position:absolute;transition:opacity .2s,transform .2s;width:24px}.delete-button{background-color:#e74c3ccc;border:none;color:#fff;right:4px;top:4px}.rotate-button{background-color:#fff;border:1px solid #ddd;left:50%;top:-20px;transform:translateX(-50%)}.building:hover .delete-button,.building:hover .rotate-button,.garden:hover .delete-button{opacity:1}.instructions{background-color:#f8f9fa;border-radius:4px;padding:1rem}.instructions h3{color:#2c3e50;margin-top:0}.instructions ol{margin:0;padding-left:1.5rem}.instructions li{color:#2c3e50;margin-bottom:.5rem}.view-toggle-container{align-items:center;display:flex;gap:1rem;justify-content:center;margin-top:1rem}.view-label{color:#fff;opacity:.7;transition:opacity .3s}.view-label.active{opacity:1}.toggle-switch{height:30px;position:relative;width:60px}.toggle-input{display:none}.toggle-label{background-color:#34495e;border-radius:15px;cursor:pointer;height:100%;position:absolute;width:100%}.toggle-button{background-color:#fff;border-radius:50%;height:26px;left:2px;position:absolute;top:2px;transition:transform .3s;width:26px}.toggle-input:checked+.toggle-label .toggle-button{transform:translateX(30px)}@media (max-width:768px){.app-main,.floor-plan-container{padding:1rem}.element-buttons{gap:.25rem}.element-button{font-size:.8rem;padding:.25rem .5rem}.drawing-area{height:400px}}.modal{align-items:center;background-color:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;max-width:500px;padding:2rem;width:90%}.input-group{margin-bottom:1rem}.input-group label{display:block;font-weight:700;margin-bottom:.5rem}.input-group input[type=number],.input-group input[type=password],.input-group textarea{border:1px solid #ddd;border-radius:4px;margin-bottom:.5rem;padding:.5rem;width:100%}.input-group textarea{height:100px;resize:vertical}.checkbox-group{display:flex;flex-wrap:wrap;gap:1rem;margin-top:.5rem}.checkbox-group label{align-items:center;display:flex;font-weight:400;gap:.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.api-key-input{font-family:monospace}.api-key-info{color:#666;font-size:.9rem;margin-top:1rem}.api-key-info a{color:#3498db;text-decoration:none}.api-key-info a:hover{text-decoration:underline}.error-message{background-color:#fee2e2;border:1px solid #ef4444;border-radius:4px;color:#dc2626;margin-bottom:1rem;padding:.75rem}.modal-content{max-height:90vh}pre{word-wrap:break-word;white-space:pre-wrap}.bg-gray-50{background-color:#f9fafb}.rounded-lg{border-radius:.5rem}.p-4{padding:1rem}.mt-4{margin-top:1rem}.mt-2{margin-top:.5rem}.font-medium{font-weight:500}.text-sm{font-size:.875rem}.max-h-60{max-height:15rem}.overflow-x-auto{overflow-x:auto}button.hover\:bg-gray-50:hover{background-color:#f9fafb}.drawing-area{background-color:#fff;height:600px;overflow:hidden;position:relative;-webkit-user-select:none;user-select:none;width:100%}.road-layer{pointer-events:none;z-index:1}.elements-layer,.road-layer{height:100%;left:0;position:absolute;top:0;width:100%}.elements-layer{z-index:2}.ghost-element{border:2px dashed #0000004d;border-radius:4px;transition:transform .1s ease-out}.drawing-area *{box-sizing:border-box}.drawing-area[data-tool=select]{cursor:default}.drawing-area[data-tool=draw]{cursor:crosshair}.drawing-area .draggable{cursor:move}@keyframes elementPlace{0%{opacity:.7;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.element-placed{animation:elementPlace .2s ease-out}.snap-indicator{background-color:#2196f3;border-radius:50%;height:6px;pointer-events:none;position:absolute;transform:translate(-50%,-50%);width:6px;z-index:3}.road-intersection{background-color:grey;position:absolute;z-index:1}.road-intersection:after{background-color:#fff;border-radius:50%;content:"";height:12px;left:50%;opacity:.6;position:absolute;top:50%;transform:translate(-50%,-50%);width:12px}.modal-content{max-height:80vh;overflow-y:auto;padding:20px}.raw-response-section{border-top:1px solid #dee2e6;margin:20px 0;padding-top:20px}.view-toggle{display:flex;justify-content:flex-end;margin-bottom:1rem}.switch{display:inline-block;height:34px;margin-left:10px;position:relative;width:60px}.switch input{height:0;opacity:0;width:0}.slider{background-color:#ccc;border-radius:34px;bottom:0;cursor:pointer;left:0;right:0;top:0}.slider,.slider:before{position:absolute;transition:.4s}.slider:before{background-color:#fff;border-radius:50%;bottom:4px;content:"";height:26px;left:4px;width:26px}input:checked+.slider{background-color:#2196f3}input:checked+.slider:before{transform:translateX(26px)}.toggle-label{color:#333;font-weight:500;line-height:34px;margin-left:70px}.content-wrapper{display:flex;gap:1.5rem;margin-bottom:1.5rem}.main-content{flex:1 1;min-width:0}.side-panel{flex-shrink:0;width:300px}@media (max-width:1024px){.content-wrapper{flex-direction:column}.side-panel{width:100%}}@media (max-width:768px){.content-wrapper{gap:1rem}}.eco-score-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:1rem 0;padding:1rem}.drawing-container{margin-top:1rem}@media (max-width:768px){.eco-score-container{margin:.5rem 0;padding:.5rem}}
/*# sourceMappingURL=main.986a661e.css.map*/