*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#0f172a;color:#e2e8f0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}.app-container{background:#0f172a;display:flex;flex-direction:column;height:100vh}.app-body{display:flex;flex:1 1}.top-bar{background:#1e293b;border-bottom:1px solid #334155;box-shadow:0 1px 3px #0000004d;height:60px;justify-content:space-between;padding:0 20px}.top-bar,.top-bar-left{align-items:center;display:flex}.top-bar-left{gap:20px}.top-bar-center,.top-bar-right{align-items:center;display:flex;gap:15px}.logo{align-items:center;color:#38bdf8;display:flex;font-size:18px;font-weight:600;gap:10px}.mode-toggle{background:#334155;border-radius:6px;display:flex;padding:2px}.mode-toggle button{background:#0000;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.mode-toggle button.active{background:#1e40af;color:#fff}.cost-display{background:#1e293b;border:1px solid #334155;border-radius:6px;font-size:14px;padding:8px 12px}.sidebar{background:#1e293b;border-right:1px solid #334155;display:flex;flex-direction:column;height:calc(100vh - 60px);max-height:calc(100vh - 60px);overflow:hidden;width:300px}.sidebar-header{border-bottom:1px solid #334155;padding:20px}.sidebar-content{-webkit-overflow-scrolling:touch;flex:1 1;max-height:calc(100vh - 140px);min-height:0;overflow-x:hidden;overflow-y:scroll!important;padding:20px;scrollbar-color:#4b5563 #1e293b;scrollbar-width:auto}.sidebar-content::-webkit-scrollbar{width:8px}.sidebar-content::-webkit-scrollbar-track{background:#1e293b}.sidebar-content::-webkit-scrollbar-thumb{background:#4b5563;border-radius:4px}.sidebar-content::-webkit-scrollbar-thumb:hover{background:#6b7280}.category-section{margin-bottom:30px}.category-title{align-items:center;border-bottom:1px solid #334155;color:#e2e8f0;display:flex;font-size:16px;font-weight:600;gap:10px;margin-bottom:15px;padding:10px 0}.component-item{align-items:center;background:#0f172a;border:1px solid #334155;border-radius:8px;cursor:pointer;display:flex;gap:12px;margin-bottom:8px;padding:12px;transition:all .2s}.component-item:hover{background:#1e293b;border-color:#4f46e5;transform:translateY(-1px)}.component-icon{align-items:center;background:#374151;border-radius:6px;display:flex;height:40px;justify-content:center;width:40px}.component-info{flex:1 1}.component-price{color:#94a3b8;font-size:12px}.canvas-container{flex:1 1}.canvas-container,.coop-layout-canvas{background:#0f172a;overflow:hidden;position:relative}.coop-layout-canvas{align-items:flex-start;display:flex;height:100%;justify-content:center;padding:20px;width:100%}.coop-layout{background:url(/static/media/coop-background.12b857410e211b977305.jpg) 50%/cover no-repeat;background-color:#8b5a3c;border:3px solid #654321;border-radius:12px;box-shadow:0 10px 30px #00000080,inset 0 2px 4px #ffffff1a;height:500px;max-width:900px;position:relative;width:100%}.coop-floor{background:#0000;border-radius:8px;bottom:10px;left:10px;opacity:0;position:absolute;right:10px;top:10px}.coop-structure{height:100%;position:relative;width:100%}.coop-area{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#8b5a3c4d;border:2px solid #654321;border-radius:8px;display:flex;justify-content:center;position:absolute;text-align:center}.nesting-boxes{background:#daa52066!important}.roosting-area{background:#a0522d66!important}.feeding-area{background:#228b2266!important}.water-area{background:#1e90ff66!important}.area-label{background:#0000004d;border-radius:4px;color:#fff;font-size:12px;font-weight:600;padding:4px 8px;text-shadow:1px 1px 2px #000000b3}.coop-door{align-items:center;display:flex;justify-content:center;position:absolute}.door-frame{background:linear-gradient(180deg,#8b4513 0,#654321);border:2px solid #4a4a4a;border-radius:6px;height:100%;position:relative;width:100%}.door-frame:before{background:gold;border-radius:50%;box-shadow:0 0 4px #ffd70099;content:"";height:4px;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:4px}.coop-feature-indicator{align-items:center;cursor:pointer;display:flex;justify-content:center;position:absolute;transition:all .3s ease;z-index:10}.coop-feature-indicator:hover{transform:translate(-50%,-50%) scale(1.1)}.coop-feature-indicator.selected{transform:translate(-50%,-50%) scale(1.2)}.coop-feature-indicator.dragging{cursor:grabbing;opacity:.8;transform:translate(-50%,-50%) scale(1);z-index:1000}.coop-feature-indicator.dragging .feature-indicator-icon{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#fbbf24;box-shadow:0 6px 20px #f59e0b99,0 0 0 4px #fbbf2466}.custom-position-badge{background:#f59e0b;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000004d;font-size:8px;height:16px;position:absolute;right:-8px;top:-8px;width:16px;z-index:3}.custom-position-badge,.feature-indicator-icon{align-items:center;display:flex;justify-content:center}.feature-indicator-icon{background:linear-gradient(135deg,#4f46e5,#7c3aed);border:3px solid #fff;border-radius:50%;box-shadow:0 4px 15px #4f46e566,0 2px 4px #0000004d;font-size:18px;height:40px;position:relative;width:40px;z-index:2}.coop-feature-indicator.selected .feature-indicator-icon{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#fbbf24;box-shadow:0 6px 20px #22c55e80,0 0 0 4px #fbbf244d}.feature-indicator-pulse{animation:pulse 2s infinite;border:2px solid #4f46e5;border-radius:50%;height:40px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:40px;z-index:1}.coop-feature-indicator.selected .feature-indicator-pulse{animation:selectedPulse 1.5s infinite;border-color:#22c55e}@keyframes pulse{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:.5;transform:translate(-50%,-50%) scale(1.5)}to{opacity:0;transform:translate(-50%,-50%) scale(2)}}@keyframes selectedPulse{0%{border-color:#22c55e;opacity:1;transform:translate(-50%,-50%) scale(1)}50%{border-color:#fbbf24;opacity:.3;transform:translate(-50%,-50%) scale(1.8)}to{border-color:#fbbf24;opacity:0;transform:translate(-50%,-50%) scale(2.5)}}.drop-indicator{animation:dropBounce .6s ease-out;background:#4f46e5e6;border:2px dashed #fff;border-radius:12px;color:#fff;font-weight:600;left:50%;padding:20px;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:1000}@keyframes dropBounce{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}50%{transform:translate(-50%,-50%) scale(1.05)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.drop-indicator-content{align-items:center;display:flex;flex-direction:column;gap:8px}.coop-instructions{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172ae6;border:1px solid #334155;border-radius:12px;bottom:20px;box-shadow:0 4px 20px #0000004d;left:50%;padding:20px;position:absolute;text-align:center;transform:translateX(-50%);z-index:5}.properties-panel{background:#1e293b;border-left:1px solid #334155;display:flex;flex-direction:column;overflow:hidden;width:320px}.properties-header{border-bottom:1px solid #334155;padding:20px}.properties-content{flex:1 1;overflow-y:auto;padding:20px}.properties-section{margin-bottom:25px}.properties-section h4{border-bottom:1px solid #334155;color:#e2e8f0;font-size:14px;font-weight:600;margin-bottom:12px;padding-bottom:8px}.property-row{border-bottom:1px solid #1e293b;padding:8px 0}.property-label{color:#94a3b8;font-size:13px}.property-value{color:#e2e8f0;font-size:13px;font-weight:500}input,select,textarea{background:#0f172a;border:1px solid #334155;border-radius:6px;color:#e2e8f0;font-size:14px;margin-bottom:12px;padding:8px 12px;width:100%}input:focus,select:focus,textarea:focus{border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e54d;outline:none}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:8px 16px;text-decoration:none;transition:all .2s}.btn-primary{background:#4f46e5;color:#fff}.btn-primary:hover{background:#4338ca}.btn-secondary{background:#374151;border:1px solid #4b5563;color:#e2e8f0}.btn-secondary:hover{background:#4b5563}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover{background:#b91c1c}.btn-sm{font-size:12px;padding:6px 12px}.coop-outline{background:#4f46e51a;border:2px dashed #4f46e5;border-radius:8px}.connection-line,.coop-outline{pointer-events:none;position:absolute}.connection-line{background:#22c55e;height:2px;z-index:1}.connection-line:after,.connection-line:before{background:#22c55e;border-radius:50%;content:"";height:6px;position:absolute;top:-2px;width:6px}.connection-line:before{left:-3px}.connection-line:after{right:-3px}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1e293b}::-webkit-scrollbar-thumb{background:#4b5563;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6b7280}.fade-in{animation:fadeIn .3s ease-out}.components-panel{background:#1e293b;border-left:1px solid #334155;color:#e2e8f0;display:flex;flex-direction:column;height:100vh;overflow-y:auto;width:320px}.components-header{background:#1e293b;border-bottom:1px solid #334155;padding:20px 20px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.components-header h3{color:#e2e8f0;font-size:18px;font-weight:600;margin:0 0 4px}.components-list{flex:1 1;padding:0}.components-empty{align-items:center;display:flex;flex:1 1;justify-content:center}.component-item-panel{background:#1e293b;border-bottom:1px solid #334155;transition:all .2s ease}.component-item-panel.selected{background:#0f172a;border-left:3px solid #3b82f6}.component-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:16px 20px;transition:background .2s ease}.component-header:hover{background:#3b82f61a}.component-header-left{align-items:center;display:flex;flex:1 1;gap:12px}.component-header-right{align-items:center;display:flex;gap:8px}.component-icon{font-size:20px;text-align:center;width:24px}.component-title{flex:1 1}.component-name{color:#e2e8f0;font-size:14px;font-weight:500;margin-bottom:2px}.component-status{margin-top:2px}.status-badge{align-items:center;border-radius:4px;display:inline-flex;font-size:11px;gap:4px;padding:2px 6px}.status-badge.active{background:#22c55e33;color:#86efac}.status-badge.inactive{background:#ef444433;color:#fca5a5}.status-badge.maintenance{background:#fbbf2433;color:#fcd34d}.quantity-badge{background:#3b82f633;border:1px solid #3b82f6;border-radius:4px;color:#60a5fa;font-size:11px;font-weight:500;margin-right:8px;padding:2px 6px}.property-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.property-row .solution-select{max-width:60%}.remove-btn{background:#ef444433;border:none;border-radius:4px;color:#ef4444;cursor:pointer;font-size:12px;padding:4px 6px;transition:all .2s ease}.remove-btn:hover{background:#ef44444d;transform:scale(1.1)}.expand-icon{color:#94a3b8;font-size:12px;margin-left:8px;transition:transform .2s ease}.component-details{animation:slideDown .2s ease;background:#0f172a;border-top:1px solid #334155;padding:0 20px 16px}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:500px;opacity:1}}.detail-section{border-bottom:1px solid #374151;margin-bottom:20px;padding-bottom:16px}.detail-section:last-child{border-bottom:none;margin-bottom:0}.detail-section h4{color:#60a5fa;font-size:13px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.components-panel .property-row{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:8px}.components-panel .property-label{color:#94a3b8;font-size:12px;font-weight:500;min-width:80px}.components-panel .property-value{color:#e2e8f0;flex:1 1;font-size:12px;text-align:right;word-break:break-word}.components-panel .solution-select,.components-panel .status-select{background:#374151;border:1px solid #4b5563;border-radius:4px;color:#e2e8f0;font-size:12px;margin-top:4px;padding:6px 8px;width:100%}.components-panel .solution-select:focus,.components-panel .status-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633;outline:none}.solution-details{border-top:1px solid #374151;margin-top:12px;padding-top:12px}.no-solutions{color:#6b7280;font-size:12px;font-style:italic}.dependency-item{align-items:center;display:flex;font-size:12px;gap:8px;margin-bottom:6px}.dependency-status{font-size:14px}.dependency-name{color:#e2e8f0;flex:1 1}.dependency-warning{color:#ef4444;font-size:10px;font-style:italic}@media (max-width:1024px){.sidebar{width:250px}.components-panel,.properties-panel{width:280px}}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:0 1rem}.min-h-screen{min-height:100vh}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}@media (min-width:768px){.md\\:grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.lg\\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.lg\\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.lg\\:col-span-1{grid-column:span 1/span 1}.lg\\:col-span-2{grid-column:span 2/span 2}}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.space-y-8>*+*{margin-top:2rem}.space-x-2>*+*{margin-left:.5rem}.space-x-3>*+*{margin-left:.75rem}.space-x-4>*+*{margin-left:1rem}.flex{display:flex}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-1{flex:1 1}.flex-shrink-0{flex-shrink:0}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.py-8{padding-bottom:2rem;padding-top:2rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pb-10{padding-bottom:2.5rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-4{margin-top:1rem}.bg-white{background-color:#fff}.bg-gray-50{background-color:#f9fafb}.bg-gray-100{background-color:#f3f4f6}.bg-primary-50{background-color:#fef2f2}.bg-primary-500{background-color:#ef4444}.bg-secondary-500{background-color:#22c55e}.bg-blue-100{background-color:#dbeafe}.bg-yellow-100{background-color:#fef3c7}.bg-green-100{background-color:#dcfce7}.text-white{color:#fff}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-900{color:#111827}.text-primary-500{color:#ef4444}.text-primary-600{color:#dc2626}.text-blue-800{color:#1e40af}.text-yellow-800{color:#92400e}.text-green-800{color:#166534}.text-amber-600{color:#d97706}.border{border-style:solid;border-width:1px}.border-2{border-width:2px}.border-t{border-style:solid;border-top-width:1px}.border-b{border-bottom-width:1px;border-style:solid}.border-gray-100{border-color:#f3f4f6}.border-gray-200{border-color:#e5e7eb}.border-gray-300{border-color:#d1d5db}.border-primary-500{border-color:#ef4444}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px 0 #0000000d}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-lg{font-size:1.125rem}.text-lg,.text-xl{line-height:1.75rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.uppercase{text-transform:uppercase}.tracking-wide{letter-spacing:.025em}.leading-tight{line-height:1.25}.text-center{text-align:center}.relative{position:relative}.absolute{position:absolute}.top-3{top:.75rem}.right-3{right:.75rem}.top-0\.5{top:.125rem}.left-0\.5{left:.125rem}.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-full{width:100%}.h-3{height:.75rem}.h-4{height:1rem}.h-5{height:1.25rem}.min-w-0{min-width:0}.cursor-pointer{cursor:pointer}.hover\\:border-gray-300:hover{border-color:#d1d5db}.hover\\:shadow-sm:hover{box-shadow:0 1px 2px 0 #0000000d}.hover\\:bg-primary-600:hover{background-color:#dc2626}.hover\\:bg-secondary-600:hover{background-color:#16a34a}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.transform{transform:var(--tw-transform)}.scale-105{transform:scale(1.05)}.animate-fade-in{animation:fadeIn .5s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}button{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-weight:500;justify-content:center;transition:all .2s}button:focus{outline:2px solid #3b82f6;outline-offset:2px}@media (max-width:767px){.hidden.md\\:flex{display:none}}@media (min-width:768px){.hidden.md\\:flex{display:flex}}.line-clamp-2{-webkit-box-orient:vertical;-webkit-line-clamp:2;display:-webkit-box;overflow:hidden}.custom-scrollbar::-webkit-scrollbar{height:12px;width:12px}.custom-scrollbar::-webkit-scrollbar-track{background:#374151;border-radius:6px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#6b7280;border:2px solid #374151;border-radius:6px}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background:#9ca3af}.custom-scrollbar::-webkit-scrollbar-corner{background:#374151}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.f70498b6.css.map*/