:root{color-scheme:light dark;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background-color:#0f172a;color:#e2e8f0}body{margin:0;min-height:100vh;background:linear-gradient(140deg,#0f172a,#1f2937 45%,#111827)}#root{min-height:100vh;display:flex;align-items:stretch}*{box-sizing:border-box}.app-shell{display:grid;grid-template-columns:340px 1fr;width:100%;min-height:100vh;flex:1}.sidebar{padding:32px 28px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0f172ab8;border-right:1px solid rgba(148,163,184,.12);display:flex;flex-direction:column;gap:24px;overflow-y:auto}.viewport{position:relative;display:flex;flex-direction:column;align-items:stretch;justify-content:center;min-height:100vh;background:radial-gradient(circle at top,rgba(59,130,246,.18),transparent 55%)}.viewport-content{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.layout-form{display:flex;flex-direction:column;gap:12px}.layout-form h1{margin:0;font-size:1.4rem;font-weight:600}.layout-form .muted{margin:0 0 8px}.layout-form label{display:flex;flex-direction:column;gap:6px;font-size:.95rem}.layout-form input[type=number],.layout-form select,.layout-form input[type=tel]{padding:10px 12px;border-radius:10px;border:1px solid rgba(148,163,184,.2);background:#0f172ab3;color:inherit;font-size:1rem}.layout-form input:focus-visible,.layout-form select:focus-visible,.quote-form input:focus-visible{outline:2px solid rgba(96,165,250,.7);outline-offset:3px}.checkbox{flex-direction:row;align-items:center;gap:10px;font-size:.95rem}.form-actions{display:flex;gap:12px;margin-top:12px}button{border:none;border-radius:10px;padding:10px 14px;font-size:1rem;cursor:pointer;background:#94a3b829;color:inherit;transition:background .16s ease,transform .16s ease}button:hover{background:#94a3b847}button:disabled{opacity:.5;cursor:not-allowed}.primary{background:linear-gradient(135deg,#38bdf8,#6366f1);color:#0f172a;font-weight:600}.primary:hover{background:linear-gradient(135deg,#0ea5e9,#4f46e5)}.accent{background:linear-gradient(135deg,#f472b6,#fb7185);color:#0f172a;font-weight:600}.muted{color:#94a3b8cc}.scene-canvas{width:100%;height:100%;flex:1 1 auto;min-height:0}.quote-panel-floating{position:static;margin:16px 16px 0}.quote-panel-floating .quote-panel{width:100%}@media (min-width: 1024px){.quote-panel-floating{position:absolute;bottom:24px;right:24px;margin:0;width:320px;max-width:calc(100% - 48px);max-height:calc(100vh - 48px);overflow-y:auto;z-index:30}body{overflow:hidden}.app-shell{height:100vh}.sidebar,.viewport{height:100%}}.empty-state{text-align:center;max-width:360px}.empty-state h2{margin-bottom:12px}.quote-panel{padding:20px;border-radius:12px;background:#1e293bb3;border:1px solid rgba(148,163,184,.12);display:flex;flex-direction:column;gap:14px}.summary{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.quote-form{display:flex;flex-direction:column;gap:10px}.quote-form label{display:flex;flex-direction:column;gap:6px;font-size:.95rem}.quote-form input[type=tel]{padding:10px 12px;border-radius:10px;border:1px solid rgba(148,163,184,.25);background:#0f172abf;color:inherit;font-size:1rem;transition:border-color .16s ease,box-shadow .16s ease}.quote-form input[type=tel]::placeholder{color:#94a3b899}.quote-form input[type=tel]:hover{border-color:#94a3b859}.quote-form input[type=tel]:focus-visible{outline:none;border-color:#60a5fab3;box-shadow:0 0 0 3px #60a5fa40}.footprint{padding:18px 20px;border-radius:12px;background:#1e293b99;border:1px solid rgba(148,163,184,.1)}.floor-select,.wall-select,.front-select{display:flex;flex-direction:column;gap:6px;margin-top:16px;font-size:.95rem}.floor-select select,.wall-select select,.front-select select{padding:10px 12px;border-radius:10px;border:1px solid rgba(148,163,184,.2);background:#0f172ab3;color:inherit;font-size:1rem}.floor-select select:focus-visible,.wall-select select:focus-visible,.front-select select:focus-visible{outline:2px solid rgba(96,165,250,.7);outline-offset:3px}.layout-form .hidden,.hidden{display:none}.viewport canvas{box-shadow:0 25px 60px #0f172a73}.viewport-controls{position:absolute;top:16px;right:16px;display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;z-index:10}.loader-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0f172ad6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .24s ease,visibility .24s ease}.loader-overlay.visible{opacity:1;visibility:visible;pointer-events:auto}.loader-content{display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center}.loader-spinner{position:relative;width:92px;height:92px}.loader-spinner:before,.loader-spinner:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;border:4px solid transparent;border-top-color:#38bdf8;border-right-color:#6366f1;animation:loader-spin 1.1s linear infinite;filter:drop-shadow(0 0 10px rgba(99,102,241,.45))}.loader-spinner:after{top:10px;right:10px;bottom:10px;left:10px;border-top-color:transparent;border-right-color:transparent;border-bottom-color:#f472b6;border-left-color:#38bdf8a6;animation:loader-spin-reverse 1.4s linear infinite;opacity:.8}.loader-glow{position:absolute;top:24px;right:24px;bottom:24px;left:24px;border-radius:50%;background:radial-gradient(circle at center,#38bdf880,#3b82f600 70%);animation:loader-pulse 1.8s ease-in-out infinite}.loader-content p{margin:0;font-size:1rem;letter-spacing:.02em;color:#e2e8f0d9}@media (max-width: 1024px){.app-shell{display:flex;flex-direction:column}.viewport{order:-1;flex:1;min-height:55vh;padding:24px 24px 88px}.scene-canvas{min-height:clamp(320px,55vh,560px);align-self:stretch;flex:1}.sidebar{padding:24px 20px 36px;border-right:none;border-top:1px solid rgba(148,163,184,.12);-webkit-backdrop-filter:none;backdrop-filter:none;background:#0f172ae6;overflow-y:visible}.viewport-controls{top:auto;right:auto;bottom:28px;left:50%;transform:translate(-50%);justify-content:center}.form-actions{flex-wrap:wrap}.quote-panel{padding:18px}.empty-state{padding:0 8px}}@media (max-width: 640px){.viewport{padding:16px 16px 140px;min-height:360px}.viewport-controls{bottom:32px;flex-direction:column;width:min(100%,220px);gap:10px}.sidebar{padding:20px 16px 36px;gap:20px}.layout-form h1{font-size:1.2rem}.layout-form .muted,.layout-form label,.quote-form label{font-size:.9rem}.layout-form input[type=number],.layout-form select,.layout-form input[type=tel],.quote-form input[type=tel]{padding:12px 14px}.floor-select,.wall-select{margin-top:14px}.floor-select select,.wall-select select{padding:12px 14px}.form-actions{flex-direction:column;gap:10px}.form-actions button,.quote-form button{width:100%}.quote-panel{padding:16px}}@keyframes loader-spin{to{transform:rotate(360deg)}}@keyframes loader-spin-reverse{to{transform:rotate(-360deg)}}@keyframes loader-pulse{0%,to{transform:scale(.95);opacity:.65}50%{transform:scale(1.1);opacity:1}}
