*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: #818cf8;--secondary: #10b981;--secondary-hover: #059669;--accent: #f59e0b;--bg-dark: #0f172a;--bg-card: #1e293b;--bg-card-light: #334155;--bg-input: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--border: #475569;--danger: #ef4444;--sidebar-width: 400px;--scrollbar-bg: rgba(30, 41, 59, .5);--scrollbar-thumb: rgba(99, 102, 241, .5);--scrollbar-thumb-hover: rgba(99, 102, 241, .8);--glow-primary: rgba(99, 102, 241, .3);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .3), 0 4px 6px -2px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 10px 10px -5px rgba(0, 0, 0, .3)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--scrollbar-bg);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:4px;transition:background .2s ease}::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}::-webkit-scrollbar-corner{background:var(--scrollbar-bg)}*{scrollbar-width:thin;scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-bg)}.thin-scrollbar::-webkit-scrollbar{width:5px;height:5px}.hide-scrollbar::-webkit-scrollbar{display:none}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg-dark);color:var(--text);overflow:hidden}#app{display:flex;height:100vh;width:100vw;overflow:hidden}#sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);flex-shrink:0;background:linear-gradient(180deg,#1e293b,#0f172a);display:flex;flex-direction:column;border-right:1px solid rgba(99,102,241,.2);position:relative;overflow-y:auto;overflow-x:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 24px #0006}#sidebar.collapsed{width:0;min-width:0;margin-left:0;border-right:none;overflow:hidden}.sidebar-toggle-btn .toggle-icon{font-size:1.2rem;display:inline-block;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));font-weight:700;line-height:1}.sidebar-toggle-btn:hover .toggle-icon{transform:scale(1.15);filter:drop-shadow(0 0 8px rgba(255,255,255,.8))}.sidebar-content{flex:1;display:flex;flex-direction:column}.sidebar-toggle-btn{position:fixed;left:var(--sidebar-width);top:50%;transform:translateY(-50%);width:40px;height:100px;background:#0f172af2;border:none;border-radius:0 16px 16px 0;color:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .4s cubic-bezier(.4,0,.2,1);z-index:150;box-shadow:4px 0 24px #0006,inset 0 0 0 1px #6366f14d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);overflow:hidden}.sidebar-toggle-btn:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#6366f199,#8b5cf699);opacity:0;transition:opacity .4s ease}.sidebar-toggle-btn:hover:before{opacity:1}.sidebar-toggle-btn:hover{width:48px;box-shadow:4px 0 32px #6366f180,inset 0 0 0 2px #6366f199;transform:translateY(-50%) translate(2px)}.sidebar-toggle-btn:active{transform:translateY(-50%) scale(.95)}@keyframes togglePulse{0%,to{box-shadow:4px 0 24px #0006,inset 0 0 0 1px #6366f14d}50%{box-shadow:4px 0 28px #6366f166,inset 0 0 0 1px #6366f180}}.sidebar-toggle-btn{animation:togglePulse 3s ease-in-out infinite}.sidebar-toggle-btn:hover{animation:none}.sidebar-header{padding:2rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6,#ec4899);text-align:center;position:relative;overflow:hidden;box-shadow:0 4px 20px #6366f14d}.sidebar-header:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:pulse 4s ease-in-out infinite}@keyframes pulse{0%,to{transform:translate(0) scale(1);opacity:.5}50%{transform:translate(10px,10px) scale(1.1);opacity:.8}}.header-logo{width:200px;height:200px;margin:0 auto 1rem;display:block;position:relative;z-index:1;border-radius:50%;box-shadow:0 4px 12px #0000004d}.sidebar-header h1{font-size:1.75rem;margin-bottom:.5rem;font-weight:700;position:relative;z-index:1;text-shadow:0 2px 10px rgba(0,0,0,.3);background:linear-gradient(to right,#fff,#e0e7ff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-header p{font-size:.9rem;opacity:.95;position:relative;z-index:1;font-weight:500;letter-spacing:.5px}.form-section{padding:1.5rem;border-bottom:1px solid rgba(71,85,105,.3);position:relative;transition:background .3s ease}.form-section:hover{background:#3341554d}.form-section h3{font-size:.9rem;font-weight:700;color:var(--text);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.form-section h3:before{content:"";width:4px;height:16px;background:linear-gradient(to bottom,var(--primary),var(--primary-light));border-radius:2px;box-shadow:0 0 10px var(--glow-primary)}.shape-selector{display:flex;gap:1rem}.shape-option{flex:1;display:flex;flex-direction:column;align-items:center;padding:1rem;background:#33415580;border:2px solid rgba(71,85,105,.5);border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.shape-option:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent,rgba(99,102,241,.1));opacity:0;transition:opacity .3s ease}.shape-option:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 16px #6366f133}.shape-option:hover:before{opacity:1}.shape-option.active{border-color:var(--primary);background:#6366f126;box-shadow:0 0 20px var(--glow-primary),inset 0 0 20px #6366f11a}.shape-option.active:after{content:"✓";position:absolute;top:8px;right:8px;width:20px;height:20px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#fff;animation:checkmark .3s ease}@keyframes checkmark{0%{transform:scale(0) rotate(-45deg)}50%{transform:scale(1.2) rotate(10deg)}to{transform:scale(1) rotate(0)}}.shape-option input{display:none}.shape-icon{font-size:2.5rem;margin-bottom:.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:transform .3s ease}.shape-option:hover .shape-icon{transform:scale(1.1)}.input-group{margin-bottom:1rem}.input-group label{display:block;font-size:.85rem;color:var(--text);margin-bottom:.5rem;font-weight:600;letter-spacing:.3px}.input-group input,.input-group select{width:100%;padding:.75rem 1rem;background:#33415599;border:2px solid rgba(71,85,105,.5);border-radius:8px;color:var(--text);font-size:.95rem;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.input-group input:hover,.input-group select:hover{border-color:#6366f180;background:#334155cc}.input-group input:focus,.input-group select:focus{outline:none;border-color:var(--primary);background:#334155e6;box-shadow:0 0 0 3px var(--glow-primary),0 4px 12px #6366f133;transform:translateY(-1px)}.input-row{display:flex;gap:.5rem}.input-group.small{flex:1}.door-entry,.window-entry{background:#0f172a99;border:1px solid rgba(71,85,105,.4);border-radius:12px;padding:1rem;margin-bottom:.75rem;transition:all .3s ease;position:relative;overflow:hidden}.door-entry:before,.window-entry:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--primary),var(--primary-light));opacity:0;transition:opacity .3s ease}.door-entry:hover,.window-entry:hover{background:#0f172acc;border-color:#6366f166;transform:translate(2px)}.door-entry:hover:before,.window-entry:hover:before{opacity:1}.color-palette{display:flex;gap:.75rem;margin-bottom:1rem}.color-palette .input-group{flex:1;margin-bottom:0}.color-palette input[type=color]{width:100%;height:48px;padding:4px;border:2px solid rgba(71,85,105,.5);border-radius:10px;background:#33415599;cursor:pointer;transition:all .3s ease}.color-palette input[type=color]:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.color-palette input[type=color]::-webkit-color-swatch-wrapper{padding:4px}.color-palette input[type=color]::-webkit-color-swatch{border-radius:6px;border:none;box-shadow:inset 0 2px 4px #0003}.style-presets{display:flex;flex-wrap:wrap;gap:.75rem}.preset-btn{flex:1;min-width:calc(50% - .375rem);padding:.75rem 1rem;background:#33415580;border:2px solid rgba(71,85,105,.5);border-radius:10px;color:var(--text);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.preset-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent,rgba(99,102,241,.2));opacity:0;transition:opacity .3s ease}.preset-btn:hover{border-color:var(--primary);background:#6366f126;transform:translateY(-2px);box-shadow:0 4px 12px #6366f133}.preset-btn:hover:before{opacity:1}.preset-btn.active{border-color:var(--primary);background:#6366f140;box-shadow:0 0 20px var(--glow-primary)}.preset-btn.active:after{content:"✓";position:absolute;top:4px;right:4px;width:18px;height:18px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#fff}.entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;font-size:.9rem;font-weight:600;color:var(--text)}.btn-remove{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;width:26px;height:26px;border-radius:6px;cursor:pointer;font-size:1.1rem;line-height:1;transition:all .2s ease;box-shadow:0 2px 8px #ef44444d}.btn-remove:hover{transform:scale(1.1) rotate(90deg);box-shadow:0 4px 12px #ef444480}.btn-remove:active{transform:scale(.95) rotate(90deg)}.btn-add{width:100%;padding:.75rem;background:transparent;border:2px dashed rgba(99,102,241,.4);border-radius:10px;color:var(--text-muted);cursor:pointer;font-size:.9rem;font-weight:600;transition:all .3s ease;position:relative;overflow:hidden}.btn-add:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent,rgba(99,102,241,.1));opacity:0;transition:opacity .3s ease}.btn-add:hover{border-color:var(--primary);border-style:solid;color:var(--primary);background:#6366f10d}.btn-add:hover:before{opacity:1}.actions{display:flex;flex-direction:column;gap:1rem}.btn-primary,.btn-secondary{padding:1rem 1.5rem;border:none;border-radius:12px;font-size:1.05rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;letter-spacing:.3px}.btn-primary:before,.btn-secondary:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#fff3;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-primary:hover:before,.btn-secondary:hover:before{width:300px;height:300px}.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);color:#fff;box-shadow:0 4px 20px #6366f166}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px #6366f199}.btn-primary:active{transform:translateY(-1px);box-shadow:0 4px 20px #6366f166}.btn-secondary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 4px 20px #10b98166}.btn-secondary:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 30px #10b98199}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}#json-preview{background:#0f172acc;padding:1rem;border-radius:10px;border:1px solid rgba(71,85,105,.4);font-family:Fira Code,Consolas,monospace;font-size:.75rem;line-height:1.6;overflow-x:auto;max-height:220px;overflow-y:auto;color:#10b981;box-shadow:inset 0 2px 8px #0000004d;position:relative}#json-preview:before{content:"JSON Output";position:absolute;top:.5rem;right:.5rem;font-size:.65rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;opacity:.5}#viewer{flex:1 1 auto;min-width:0;position:relative;background:linear-gradient(180deg,#1a1a2e,#16213e);overflow:hidden}#canvas{position:absolute;top:0;left:0;width:100%!important;height:100%!important;display:block}#controls-overlay{position:absolute;bottom:1rem;left:1rem;display:flex;gap:1rem}.control-hint{background:#0009;padding:.5rem .75rem;border-radius:6px;font-size:.75rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.control-hint span{font-weight:600;color:var(--primary)}#view-mode{position:absolute;top:1rem;right:1rem;display:flex;background:#0009;border-radius:8px;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:10}.mode-btn{padding:.5rem .85rem;background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem;transition:all .2s;display:flex;align-items:center;gap:.3rem}.mode-btn:hover{color:var(--text);background:#ffffff1a}.mode-btn.active{background:var(--primary);color:#fff}body.pan-mode{cursor:grab!important}body.pan-mode:active{cursor:grabbing!important}body.pan-mode #canvas{cursor:grab!important}body.pan-mode #canvas:active{cursor:grabbing!important}#sidebar::-webkit-scrollbar{width:6px}#sidebar::-webkit-scrollbar-track{background:var(--bg-dark)}#sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}#sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 768px){#app{flex-direction:column}#sidebar{width:100%;min-width:unset;max-height:50vh;border-right:none;border-bottom:1px solid var(--border)}#viewer{height:50vh}}.generating{pointer-events:none;opacity:.7}.generating:after{content:"⏳";animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.wall-context-menu{position:fixed;display:none;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 32px #0006;z-index:1000;min-width:180px;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:menuFadeIn .15s ease-out}@keyframes menuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.menu-header{padding:.75rem 1rem;background:linear-gradient(135deg,var(--primary),#8b5cf6);font-weight:600;font-size:.9rem;border-bottom:1px solid var(--border)}.menu-items{padding:.5rem 0}.menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.6rem 1rem;background:transparent;border:none;color:var(--text);font-size:.85rem;text-align:left;cursor:pointer;transition:background .15s}.menu-item:hover{background:#6366f133}.menu-item:active{background:#6366f14d}.menu-divider{border:none;border-top:1px solid var(--border);margin:.25rem 0}.wall-hint{position:absolute;top:1rem;left:50%;transform:translate(-50%);background:#000000b3;padding:.5rem 1rem;border-radius:6px;font-size:.8rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);pointer-events:none;opacity:0;transition:opacity .3s}.wall-hint.visible{opacity:1}#tools-panel{position:absolute;top:0;right:0;bottom:0;width:260px;background:#0f172af2;border-left:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;flex-direction:column;transition:transform .3s ease,width .3s ease;z-index:100}#tools-panel.collapsed{transform:translate(100%)}#tools-panel.collapsed .tools-toggle-btn{left:-40px}#tools-panel.collapsed .tools-panel-content{opacity:0;pointer-events:none}#tools-panel.collapsed .tools-toggle-btn .toggle-icon{transform:rotate(180deg)}.tools-toggle-btn{position:absolute;left:-40px;top:50%;transform:translateY(-50%);width:40px;height:100px;background:#0f172af2;border:none;border-radius:16px 0 0 16px;color:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .4s cubic-bezier(.4,0,.2,1);z-index:101;box-shadow:-4px 0 24px #0006,inset 0 0 0 1px #6366f14d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);overflow:hidden}.tools-toggle-btn:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,#6366f199,#8b5cf699);opacity:0;transition:opacity .4s ease}.tools-toggle-btn:hover:before{opacity:1}.tools-toggle-btn:hover{width:48px;left:-48px;box-shadow:-4px 0 32px #6366f180,inset 0 0 0 2px #6366f199;transform:translateY(-50%) translate(-2px)}.tools-toggle-btn:active{transform:translateY(-50%) scale(.95)}@keyframes togglePulseRight{0%,to{box-shadow:-4px 0 24px #0006,inset 0 0 0 1px #6366f14d}50%{box-shadow:-4px 0 28px #6366f166,inset 0 0 0 1px #6366f180}}.tools-toggle-btn{animation:togglePulseRight 3s ease-in-out infinite}.tools-toggle-btn:hover{animation:none}.toggle-icon{font-size:1.2rem;display:inline-block;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));font-weight:700;line-height:1}.tools-toggle-btn:hover .toggle-icon{transform:scale(1.15);filter:drop-shadow(0 0 8px rgba(255,255,255,.8))}.tools-panel-content{flex:1;overflow-y:auto;transition:opacity .2s ease}.undo-redo-bar{display:flex;gap:.5rem;padding:.5rem;background:#0000004d;border-bottom:1px solid var(--border)}.btn-undo-redo{flex:1;padding:.5rem .75rem;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.75rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.3rem}.btn-undo-redo:hover:not(:disabled){background:var(--primary);border-color:var(--primary)}.btn-undo-redo:disabled{opacity:.4;cursor:not-allowed}.btn-undo-redo:active:not(:disabled){transform:scale(.95)}.accordion-section{border-bottom:1px solid var(--border)}.accordion-header{display:flex;align-items:center;gap:.5rem;padding:.6rem .75rem;background:#1e293bcc;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s}.accordion-header:hover{background:#334155cc}.accordion-icon{font-size:.6rem;transition:transform .2s ease;color:var(--text-muted)}.accordion-section:not(.expanded) .accordion-icon{transform:rotate(-90deg)}.accordion-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;flex:1}.accordion-content{padding:.5rem;max-height:300px;overflow-y:auto;display:none}.accordion-section.expanded .accordion-content{display:block}.selected-header-active{background:#10b9814d!important}.btn-deselect{background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.2rem .4rem;font-size:.8rem;border-radius:4px;transition:all .2s}.btn-deselect:hover{background:var(--danger);color:#fff}.quick-actions,.selected-actions{display:flex;flex-wrap:wrap;gap:.35rem}.btn-tool{flex:1;min-width:calc(50% - .35rem);padding:.4rem .5rem;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.7rem;cursor:pointer;transition:all .2s;text-align:center}.btn-tool:hover{background:var(--primary);border-color:var(--primary)}.btn-tool.danger{color:var(--danger);border-color:#ef44444d}.btn-tool.danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}.hint-text{font-size:.65rem;color:var(--text-muted);text-align:center;margin-top:.5rem;padding:.25rem;background:#6366f11a;border-radius:4px}.lighting-controls{display:flex;flex-direction:column;gap:.6rem}.control-row{display:flex;align-items:center;gap:.5rem}.control-row label{font-size:.7rem;color:var(--text-muted);min-width:55px;flex-shrink:0}.control-row input[type=range]{flex:1;height:4px;background:var(--bg-input);border-radius:2px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.control-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:var(--primary);border-radius:50%;cursor:pointer;transition:transform .2s,background .2s}.control-row input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);background:var(--primary-hover)}.slider-with-value{flex:1;display:flex;align-items:center;gap:.5rem}.slider-with-value input[type=range]{flex:1}.slider-with-value span{font-size:.65rem;color:var(--secondary);font-weight:600;min-width:40px;text-align:right}.toggle-row{justify-content:space-between}.lighting-presets{display:flex;gap:.3rem;justify-content:center;padding:.25rem 0}.preset-btn-small{width:36px;height:32px;padding:0;background:var(--bg-input);border:1px solid transparent;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s}.preset-btn-small:hover{background:var(--bg-dark);border-color:var(--primary);transform:scale(1.1)}.preset-btn-small.active{background:var(--primary);border-color:var(--primary)}.postprocessing-controls{display:flex;flex-direction:column;gap:.5rem}.effect-group{border-left:2px solid var(--border);padding-left:.5rem;margin-left:.25rem}.sub-control{padding-left:.5rem;opacity:.9}.sub-control label{font-size:.65rem}.panel-placeholder{color:var(--text-muted);font-size:.75rem;text-align:center;padding:1rem .5rem}.furniture-categories{display:flex;flex-wrap:wrap;gap:.25rem;padding-bottom:.5rem;border-bottom:1px solid var(--border);margin-bottom:.5rem}.category-btn{flex:1;min-width:calc(16.66% - .25rem);padding:.4rem;background:var(--bg-input);border:1px solid transparent;border-radius:6px;color:var(--text);font-size:.9rem;cursor:pointer;transition:all .2s;text-align:center}.furniture-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.4rem;max-height:180px;overflow-y:auto}.openings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;max-height:200px;overflow-y:auto}.opening-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.75rem .5rem;background:var(--bg-dark);border:2px solid var(--border);border-radius:8px;cursor:grab;transition:all .2s;text-align:center;min-height:70px}.opening-item:hover{border-color:var(--primary);background:#6366f126;transform:translateY(-2px)}.opening-item:active{cursor:grabbing;transform:scale(.95)}.opening-item.dragging{opacity:.5;cursor:grabbing}.opening-icon{font-size:1.5rem;margin-bottom:.25rem}.opening-label{font-size:.7rem;color:var(--text);margin-bottom:.15rem;font-weight:500}.opening-size{font-size:.6rem;color:var(--text-muted)}.furniture-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .25rem;background:var(--bg-dark);border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;text-align:center;min-height:60px}.furniture-item-icon{font-size:1.3rem;margin-bottom:.15rem}.furniture-item-name{font-size:.6rem;color:var(--text-muted);line-height:1.1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.wall-toggle-item{display:flex;align-items:center;justify-content:space-between;padding:.35rem .5rem;margin-bottom:.25rem;background:var(--bg-dark);border-radius:6px;font-size:.75rem;transition:background .2s}.wall-toggle-item:hover{background:var(--bg-input)}.wall-toggle-item.surface-item{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(99,102,241,.1) 100%)}.panel-section-label{color:var(--primary);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.4rem .25rem .2rem;margin-top:.4rem;border-bottom:1px solid rgba(99,102,241,.2)}.panel-section-label:first-child{margin-top:0}.panel-section-label.room-indicator{background:linear-gradient(135deg,#6366f133,#6366f11a);color:var(--accent);padding:.5rem;border-radius:4px;margin-bottom:.5rem;border:1px solid rgba(99,102,241,.3);font-size:.75rem}@media (max-width: 768px){#app{flex-direction:column}#sidebar{width:100%;min-width:unset;max-height:40vh;border-right:none;border-bottom:1px solid var(--border)}#viewer{height:60vh}#tools-panel{width:220px}#tools-panel.collapsed{transform:translate(calc(100% - 36px))}.tools-toggle-btn{left:-36px;width:36px;height:60px}#controls-overlay{display:none}#view-mode{bottom:auto;top:.5rem;left:.5rem}.furniture-grid{max-height:120px}.accordion-content{max-height:200px}}@media (max-width: 480px){#sidebar{max-height:35vh}#viewer{height:65vh}#tools-panel{width:180px}.furniture-grid{grid-template-columns:repeat(2,1fr)}.category-btn{font-size:.8rem;padding:.3rem}.btn-tool{font-size:.65rem;padding:.35rem}}#wall-panel,#furniture-panel{display:none!important}.wall-toggle-item.surface-item{background:linear-gradient(135deg,var(--bg-dark) 0%,rgba(var(--primary-rgb),.1) 100%)}.wall-toggle-item:hover{background:#6366f126}.wall-toggle-item .wall-info{display:flex;align-items:center;justify-content:space-between;width:100%;gap:.5rem}.wall-toggle-item .wall-name{display:flex;flex-direction:column;gap:.1rem}.wall-toggle-item .wall-name span:first-child{font-weight:500}.wall-toggle-item .wall-status{font-size:.65rem;color:var(--text-muted)}.wall-toggle-item .wall-controls{display:flex;align-items:center;gap:.4rem}.wall-color-picker{width:24px;height:24px;padding:0;border:2px solid var(--border);border-radius:4px;cursor:pointer;background:transparent}.wall-color-picker::-webkit-color-swatch-wrapper{padding:1px}.wall-color-picker::-webkit-color-swatch{border-radius:2px;border:none}.wall-color-picker:hover{border-color:var(--primary)}.wall-toggle-item.hidden-wall{opacity:.5}.wall-toggle-item.hidden-wall .wall-status{color:var(--danger)}.toggle-switch{position:relative;width:36px;height:20px;min-width:36px;background:var(--bg-input);border-radius:10px;cursor:pointer;transition:background .3s}.toggle-switch.active{background:var(--primary)}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .3s}.toggle-switch.active:after{transform:translate(16px)}.panel-actions{display:flex;flex-wrap:wrap;gap:.25rem;padding:.25rem;background:#0003}.btn-panel-action{flex:1;min-width:calc(50% - .25rem);padding:.4rem .3rem;background:var(--secondary);border:none;color:#fff;font-size:.65rem;font-weight:500;cursor:pointer;transition:background .2s;border-radius:4px;white-space:nowrap}.btn-panel-action:hover{background:#0d9668}.btn-panel-action.secondary{background:var(--primary)}.btn-panel-action.secondary:hover{background:var(--primary-hover)}.btn-show-all{width:100%;padding:.5rem;background:var(--secondary);border:none;color:#fff;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .2s}.btn-show-all:hover{background:#0d9668}#furniture-panel{position:absolute;top:1rem;right:1rem;background:#1e293bf2;border:1px solid var(--border);border-radius:10px;width:240px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;transition:all .3s ease}#furniture-panel.collapsed .panel-content{display:none}#furniture-panel.collapsed .panel-toggle{transform:rotate(-90deg)}.furniture-categories{display:flex;flex-wrap:wrap;gap:.25rem;padding:.5rem;border-bottom:1px solid var(--border)}.category-btn{flex:1;min-width:calc(33% - .25rem);padding:.35rem .5rem;background:var(--bg-input);border:1px solid transparent;border-radius:4px;color:var(--text);font-size:.65rem;cursor:pointer;transition:all .2s;white-space:nowrap}.category-btn:hover{background:var(--bg-dark);border-color:var(--primary)}.category-btn.active{background:var(--primary);border-color:var(--primary)}.furniture-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;padding:.5rem;max-height:200px;overflow-y:auto}.furniture-item{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem;background:var(--bg-dark);border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;text-align:center;position:relative}.furniture-item:hover{border-color:var(--primary);background:#6366f126}.furniture-item.selected{border-color:var(--secondary);background:#10b98126}.furniture-item-icon{font-size:1.5rem;margin-bottom:.25rem}.furniture-item-name{font-size:.65rem;color:var(--text-muted);line-height:1.2}.furniture-selected{padding:.5rem;border-top:1px solid var(--border);background:#10b9811a}.selected-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.8rem;font-weight:600}.selected-actions{display:flex;gap:.25rem;flex-wrap:wrap}.btn-small{padding:.3rem .5rem;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:.65rem;cursor:pointer;transition:all .2s}.btn-small:hover{background:var(--primary);border-color:var(--primary)}.btn-small.danger{color:var(--danger)}.btn-small.danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}.placement-mode-indicator{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);background:#10b981f2;color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;font-weight:500;display:none;animation:pulse 2s infinite}.placement-mode-indicator.active{display:block}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.furniture-highlight{box-shadow:0 0 20px #10b981cc}.furniture-item[draggable=true]{cursor:grab}.furniture-item[draggable=true]:active{cursor:grabbing}.furniture-item.dragging{opacity:.5;transform:scale(.95)}#canvas.drag-over{box-shadow:inset 0 0 30px #10b98180}.furniture-item.external{border:1px solid rgba(139,92,246,.3);background:linear-gradient(135deg,rgba(139,92,246,.1) 0%,transparent 100%)}.furniture-item.external:hover{border-color:#8b5cf680;background:linear-gradient(135deg,rgba(139,92,246,.2) 0%,transparent 100%)}.gltf-badge{position:absolute;top:2px;right:2px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;font-size:.5rem;font-weight:700;padding:1px 4px;border-radius:3px;text-transform:uppercase}.furniture-thumbnail{width:32px;height:32px;object-fit:cover;border-radius:4px}.furniture-item-icon.fallback{font-size:1.5rem}.glb-preview-container{width:40px;height:40px;border-radius:6px;overflow:hidden;background:var(--bg-dark);display:flex;align-items:center;justify-content:center;margin-bottom:.15rem}.glb-preview-container canvas{width:100%!important;height:100%!important;border-radius:6px}.glb-preview-loading{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.drag-hint{font-size:.6rem;color:var(--text-muted);text-align:center;padding:.25rem;border-top:1px solid var(--border);margin-top:.25rem}.ai-section{background:linear-gradient(135deg,#6366f126,#8b5cf626);border:2px solid rgba(99,102,241,.4);border-radius:16px;margin:1rem;padding:1.5rem!important;position:relative;overflow:hidden;box-shadow:0 8px 32px #6366f133}.ai-section:before{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);animation:rotate 20s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ai-section h3{color:var(--primary-light);display:flex;align-items:center;gap:.75rem;position:relative;z-index:1;font-size:1.1rem;text-shadow:0 2px 8px rgba(99,102,241,.3)}.ai-hint{font-size:.85rem;color:var(--text);margin:.75rem 0;line-height:1.5;position:relative;z-index:1;opacity:.9}.ai-input-container{display:flex;flex-direction:column;gap:1rem;position:relative;z-index:1}#ai-prompt{width:100%;min-height:120px;padding:1rem;background:#334155b3;border:2px solid rgba(71,85,105,.5);border-radius:12px;color:var(--text);font-family:inherit;font-size:.95rem;resize:vertical;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}#ai-prompt:hover{border-color:#6366f180;background:#334155d9}#ai-prompt:focus{outline:none;border-color:var(--primary);background:#334155f2;box-shadow:0 0 0 4px #6366f133,0 8px 24px #6366f14d;transform:translateY(-2px)}#ai-prompt::placeholder{color:var(--text-muted);font-size:.9rem}.btn-ai{width:100%;padding:1rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border:none;border-radius:12px;color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 4px 20px #6366f166;letter-spacing:.5px}.btn-ai:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.btn-ai:hover:not(:disabled):before{width:300px;height:300px}.btn-ai:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 30px #6366f199}.btn-ai:active:not(:disabled){transform:translateY(-1px)}.btn-ai:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-ai .btn-loading{display:flex;align-items:center;justify-content:center;gap:.5rem}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.ai-status{font-size:.8rem;padding:.5rem;border-radius:6px;margin-top:.5rem;display:none}.ai-status.success{display:block;background:#10b98133;color:var(--secondary);border:1px solid rgba(16,185,129,.3)}.ai-status.error{display:block;background:#ef444433;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.ai-status.loading{display:block;background:#6366f133;color:var(--primary);border:1px solid rgba(99,102,241,.3)}.ai-status.info{display:block;background:#3b82f633;color:#60a5fa;border:1px solid rgba(59,130,246,.3)}.ai-chat-history{max-height:280px;overflow-y:auto;overflow-x:hidden;margin-bottom:1rem;padding:1rem;background:#0f172a99;border:1px solid rgba(71,85,105,.3);border-radius:16px;display:flex;flex-direction:column;position:relative;z-index:1}.ai-chat-history:empty{display:none}.chat-message{display:flex;gap:.75rem;margin-bottom:1rem;animation:slideIn .4s cubic-bezier(.4,0,.2,1);position:relative}@keyframes slideIn{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-user{flex-direction:row-reverse;justify-content:flex-start}.chat-user .chat-content{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-radius:18px 18px 4px;padding:.75rem 1rem;max-width:75%;box-shadow:0 2px 8px #6366f14d;font-size:.9rem;line-height:1.5;word-break:break-word;position:relative}.chat-assistant{flex-direction:row}.chat-assistant .chat-content{background:#334155cc;color:var(--text);border:1px solid rgba(71,85,105,.4);border-radius:18px 18px 18px 4px;padding:.75rem 1rem;max-width:75%;box-shadow:0 2px 8px #0003;font-size:.9rem;line-height:1.5;word-break:break-word;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.chat-icon{flex-shrink:0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 2px 8px #0003}.chat-user .chat-icon{background:linear-gradient(135deg,#ec4899,#f97316)}.chat-assistant .chat-icon{background:linear-gradient(135deg,#10b981,#059669)}.typing-indicator{display:flex;gap:.75rem;margin-bottom:1rem;animation:slideIn .3s ease}.typing-indicator .chat-icon{background:linear-gradient(135deg,#10b981,#059669)}.typing-indicator .typing-dots{background:#334155cc;border:1px solid rgba(71,85,105,.4);border-radius:18px;padding:.75rem 1.25rem;display:flex;gap:.4rem;align-items:center;box-shadow:0 2px 8px #0003}.typing-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);animation:typingBounce 1.4s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.6}30%{transform:translateY(-8px);opacity:1}}.ai-buttons{display:flex;gap:.75rem}.ai-buttons .btn-ai{flex:1}.btn-ai-clear{padding:1rem;background:#33415599;border:2px solid rgba(71,85,105,.5);border-radius:12px;color:var(--text-muted);font-size:1.2rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:56px;display:flex;align-items:center;justify-content:center}.btn-ai-clear:hover{background:#ef444433;border-color:var(--danger);color:var(--danger);transform:translateY(-2px) rotate(10deg);box-shadow:0 4px 16px #ef44444d}.btn-ai-clear:active{transform:translateY(0) rotate(10deg) scale(.95)}.section-divider{display:flex;align-items:center;text-align:center;margin:2rem 1.5rem;color:var(--text);font-size:.8rem;position:relative}.section-divider:before,.section-divider:after{content:"";flex:1;height:2px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.5),transparent)}.section-divider:before{margin-right:1rem}.section-divider:after{margin-left:1rem}.section-divider span{padding:.5rem 1rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;background:#6366f11a;border:1px solid rgba(99,102,241,.3);border-radius:20px;box-shadow:0 0 20px #6366f133}.floorplan-container{display:flex;flex-direction:column;gap:.5rem}.floorplan-toolbar{display:flex;align-items:center;gap:.25rem;padding:.35rem;background:var(--bg-dark);border-radius:6px}.floorplan-tool,.floorplan-action{width:32px;height:32px;border:1px solid transparent;border-radius:4px;background:transparent;color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .2s}.floorplan-tool:hover,.floorplan-action:hover{background:var(--bg-input);border-color:var(--border)}.floorplan-tool.active{background:var(--primary);border-color:var(--primary)}.toolbar-divider{width:1px;height:24px;background:var(--border);margin:0 .25rem}#floorplan-canvas-container{position:relative;background:var(--bg-dark);border-radius:6px;overflow:hidden;height:200px;border:1px solid var(--border)}#floorplan-canvas{width:100%;height:100%;cursor:crosshair}.floorplan-room-info{display:flex;align-items:center;justify-content:space-between;padding:.35rem .5rem;background:var(--bg-dark);border-radius:4px;font-size:.7rem;color:var(--text-muted)}.room-info-label{display:flex;align-items:center;gap:.35rem}.room-info-dimensions{color:var(--secondary);font-weight:500}.floorplan-actions{display:flex;gap:.35rem}.floorplan-actions .btn-tool{flex:1}.floorplan-legend{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.25rem;font-size:.65rem}.legend-item{display:flex;align-items:center;gap:.25rem}.legend-color{width:12px;height:12px;border-radius:2px;border:1px solid rgba(255,255,255,.2)}#floorplan-canvas.tool-select{cursor:default}#floorplan-canvas.tool-draw{cursor:crosshair}#floorplan-canvas.tool-doorway{cursor:pointer}#floorplan-canvas.dragging{cursor:grabbing!important}#floorplan-canvas.resizing-nw,#floorplan-canvas.resizing-se{cursor:nwse-resize!important}#floorplan-canvas.resizing-ne,#floorplan-canvas.resizing-sw{cursor:nesw-resize!important}.floorplan-room-list{margin-top:.5rem;background:var(--bg-dark);border-radius:6px;overflow:hidden}.room-list-header{display:flex;justify-content:space-between;align-items:center;padding:.4rem .6rem;background:#ffffff0d;font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.room-count{background:var(--primary);color:#fff;padding:.1rem .4rem;border-radius:10px;font-size:.65rem}.room-list-items{max-height:120px;overflow-y:auto}.room-list-items .empty-hint{padding:.6rem;text-align:center;color:var(--text-muted);font-size:.7rem;font-style:italic}.room-list-item{display:flex;align-items:center;gap:.5rem;padding:.4rem .6rem;cursor:pointer;transition:background .15s;border-bottom:1px solid rgba(255,255,255,.05)}.room-list-item:hover{background:#ffffff0d}.room-list-item.selected{background:#6366f133}.room-list-item.active{border-left:3px solid var(--secondary)}.room-color-dot,.room-item-color{width:10px;height:10px;border-radius:2px;flex-shrink:0}.room-item-info{flex:1;display:flex;flex-direction:column;overflow:hidden}.room-item-name{flex:1;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-item-size{font-size:.65rem;color:var(--text-muted)}.material-picker{display:flex;flex-direction:column;gap:.75rem;padding:.5rem}.material-categories{display:flex;flex-wrap:wrap;gap:.25rem}.category-btn{display:flex;flex-direction:column;align-items:center;padding:.4rem .6rem;border:1px solid var(--border);border-radius:6px;background:var(--bg-input);color:var(--text-muted);cursor:pointer;transition:all .2s;flex:1;min-width:50px}.category-btn:hover{background:var(--bg-card);color:var(--text);border-color:var(--primary)}.category-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.category-icon{font-size:1.1rem}.category-name{font-size:.6rem;margin-top:.15rem}.material-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;max-height:220px;overflow-y:auto;padding-right:.25rem}.material-item{display:flex;flex-direction:column;align-items:center;padding:.4rem;background:var(--bg-input);border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s}.material-item:hover{background:var(--bg-card);border-color:var(--border);transform:translateY(-2px)}.material-item.selected{border-color:var(--primary);background:#6366f126}.material-item.dragging{opacity:.5;transform:scale(.95)}.material-swatch{width:40px;height:40px;border-radius:6px;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 1px 3px #0000004d}.material-emoji{font-size:1.2rem;filter:drop-shadow(0 1px 1px rgba(0,0,0,.3))}.material-name{font-size:.65rem;margin-top:.3rem;text-align:center;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.material-props{display:flex;gap:.3rem;margin-top:.2rem}.material-props .prop{font-size:.5rem;color:var(--text-muted);background:#ffffff0d;padding:.1rem .25rem;border-radius:3px}.material-preview{background:var(--bg-input);border-radius:8px;padding:.75rem;min-height:80px}.preview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60px;color:var(--text-muted);font-size:.75rem}.preview-placeholder span{font-size:1.5rem;margin-bottom:.25rem}.preview-content{display:flex;gap:.75rem}.preview-swatch-large{width:60px;height:60px;border-radius:8px;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 2px 4px #0000004d;flex-shrink:0}.preview-emoji{font-size:1.8rem}.preview-info{flex:1;overflow:hidden}.preview-info h4{font-size:.85rem;margin-bottom:.15rem}.preview-category{font-size:.65rem;color:var(--text-muted);margin-bottom:.4rem}.preview-properties{display:flex;flex-direction:column;gap:.25rem}.prop-row{display:flex;align-items:center;gap:.4rem;font-size:.6rem}.prop-label{width:55px;color:var(--text-muted)}.prop-bar{flex:1;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.prop-fill{height:100%;background:var(--primary);border-radius:2px}.prop-fill.metal{background:linear-gradient(90deg,silver,gold)}.prop-value{width:30px;text-align:right;color:var(--text)}.prop-row.pattern{margin-top:.15rem}.prop-row.pattern .prop-value{width:auto;text-transform:capitalize}.material-actions{display:flex;gap:.5rem}.material-actions .action-btn{flex:1;padding:.5rem .75rem;border:none;border-radius:6px;font-size:.7rem;cursor:pointer;transition:all .2s;background:var(--bg-input);color:var(--text)}.material-actions .action-btn:hover:not(:disabled){background:var(--bg-card)}.material-actions .action-btn:disabled{opacity:.5;cursor:not-allowed}.material-actions .action-btn.primary{background:var(--primary);color:#fff}.material-actions .action-btn.primary:hover:not(:disabled){background:var(--primary-hover)}.material-actions .action-btn.cancel{background:var(--danger)}.material-tip{display:flex;align-items:center;gap:.4rem;padding:.4rem .6rem;background:#6366f11a;border-radius:6px;border:1px solid rgba(99,102,241,.2)}.tip-icon{font-size:.9rem}.tip-text{font-size:.6rem;color:var(--text-muted)}.material-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%) translateY(100px);background:var(--bg-card);border:1px solid var(--border);padding:.75rem 1.25rem;border-radius:8px;display:flex;align-items:center;gap:.5rem;box-shadow:0 4px 20px #0000004d;z-index:9999;opacity:0;transition:all .3s ease}.material-toast.show{transform:translate(-50%) translateY(0);opacity:1}.material-toast.success{border-color:var(--secondary)}.material-toast.warning{border-color:#f59e0b}.toast-icon{font-size:1rem}.toast-message{font-size:.8rem;color:var(--text)}.room-indicator{background:#6366f126;border-left:3px solid var(--primary);padding-left:.6rem!important;margin-bottom:.5rem}#dimension-labels{z-index:100;pointer-events:none}.dimension-label{background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#0ff;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:600;font-family:Monaco,Courier New,monospace;border:1px solid rgba(0,255,255,.3);box-shadow:0 2px 8px #00ffff40,0 0 15px #00ffff26;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;text-shadow:0 0 5px rgba(0,255,255,.5);letter-spacing:.5px}.dimension-label.wall{color:#ffc800;border-color:#ffc8004d;box-shadow:0 2px 8px #ffc80040,0 0 15px #ffc80026;text-shadow:0 0 5px rgba(255,200,0,.5)}.dimension-label.height{color:#00ff96;border-color:#00ff964d;box-shadow:0 2px 8px #00ff9640,0 0 15px #00ff9626;text-shadow:0 0 5px rgba(0,255,150,.5)}.dimension-label.furniture{color:#ff64c8;border-color:#ff64c84d;box-shadow:0 2px 8px #ff64c840,0 0 15px #ff64c826;text-shadow:0 0 5px rgba(255,100,200,.5)}.dimension-label:hover{transform:scale(1.05);transition:transform .2s ease}.shortcuts-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-xl),0 0 40px #00000080;z-index:10000;min-width:450px;max-width:90vw;max-height:85vh;overflow:hidden;animation:panelSlideIn .2s ease-out}@keyframes panelSlideIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.shortcuts-panel.hidden{display:none}.shortcuts-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);border-bottom:1px solid var(--border)}.shortcuts-header h2{margin:0;font-size:1.2rem;color:#fff}.shortcuts-close{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:1.2rem;cursor:pointer;transition:all .2s}.shortcuts-close:hover{background:#ffffff4d;transform:scale(1.1)}.shortcuts-content{padding:20px;max-height:60vh;overflow-y:auto;display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.shortcuts-group{background:var(--bg-card-light);padding:15px;border-radius:10px}.shortcuts-group h3{margin:0 0 12px;font-size:.9rem;color:var(--primary-light);text-transform:uppercase;letter-spacing:.5px}.shortcut-row{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:.85rem;color:var(--text-muted)}.shortcut-row span{margin-left:auto;color:var(--text)}kbd{background:var(--bg-dark);border:1px solid var(--border);border-radius:4px;padding:3px 8px;font-family:monospace;font-size:.8rem;color:var(--text);box-shadow:0 2px 0 var(--border)}.context-menu{position:fixed;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-lg);z-index:10001;min-width:180px;padding:6px 0;animation:contextMenuFadeIn .15s ease-out}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu.hidden{display:none}.context-menu-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;transition:background .15s;color:var(--text);font-size:.9rem}.context-menu-item:hover{background:var(--primary)}.context-menu-item.danger:hover{background:var(--danger)}.context-icon{font-size:1rem;width:20px;text-align:center}.context-menu-divider{height:1px;background:var(--border);margin:6px 10px}.drag-preview{position:fixed;pointer-events:none;z-index:9999;background:var(--bg-card);border:2px solid var(--primary);border-radius:10px;padding:10px 15px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);opacity:.9;transform:translate(-50%,-50%)}.drag-preview.hidden{display:none}.drag-preview-icon{font-size:1.5rem}.drag-preview-name{font-size:.9rem;color:var(--text);white-space:nowrap}.help-btn{position:fixed;bottom:20px;right:20px;width:48px;height:48px;border-radius:50%;background:var(--primary);border:none;color:#fff;font-size:1.5rem;font-weight:700;cursor:pointer;box-shadow:var(--shadow-lg);transition:all .2s;z-index:1000}.help-btn:hover{background:var(--primary-hover);transform:scale(1.1);box-shadow:var(--shadow-xl),0 0 20px var(--glow-primary)}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:var(--bg-dark);color:var(--text);padding:6px 12px;border-radius:6px;font-size:.8rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s;pointer-events:none;z-index:10000;box-shadow:var(--shadow-md);border:1px solid var(--border)}[data-tooltip]:hover:after{opacity:1;visibility:visible;bottom:calc(100% + 8px)}.ai-progress{position:relative;width:100%;height:4px;background:var(--bg-card-light);border-radius:2px;overflow:hidden;margin-top:10px}.ai-progress-bar{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary),var(--primary));background-size:200% 100%;animation:progressShimmer 1.5s ease-in-out infinite;border-radius:2px}@keyframes progressShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ai-progress-text{text-align:center;font-size:.8rem;color:var(--text-muted);margin-top:8px}.ai-progress-steps{display:flex;justify-content:space-between;margin-top:10px;padding:0 5px}.ai-step{display:flex;flex-direction:column;align-items:center;gap:4px;font-size:.75rem;color:var(--text-muted);opacity:.5;transition:all .3s}.ai-step.active{opacity:1;color:var(--primary-light)}.ai-step.completed{opacity:1;color:var(--secondary)}.ai-step-icon{width:24px;height:24px;border-radius:50%;background:var(--bg-card-light);display:flex;align-items:center;justify-content:center;font-size:.8rem;transition:all .3s}.ai-step.active .ai-step-icon{background:var(--primary);box-shadow:0 0 10px var(--glow-primary)}.ai-step.completed .ai-step-icon{background:var(--secondary)}.furniture-item{position:relative}.furniture-item:before{content:attr(data-name);position:absolute;bottom:-30px;left:50%;transform:translate(-50%);background:var(--bg-dark);color:var(--text);padding:4px 10px;border-radius:4px;font-size:.75rem;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s;pointer-events:none;z-index:100}.furniture-item:hover:before{opacity:1;visibility:visible;bottom:-35px}
