.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;box-sizing:border-box}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:600px;width:90%;max-height:calc(100vh - 40px);overflow-y:auto;margin:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 20px 0;border-bottom:1px solid #E5E7EB;margin-bottom:16px}.modal-header h2{font-size:20px;font-weight:600;color:#111827;margin:0}.modal-close{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background-color:#f3f4f6;color:#374151}.modal-body{padding:0 20px 16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:500;color:#374151;margin-bottom:8px;font-size:14px}.room-name-input{width:100%;padding:12px 16px;border:2px solid #E5E7EB;border-radius:8px;font-size:16px;transition:border-color .2s}.room-name-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.dimensions-inputs{display:grid;grid-template-columns:1fr 1fr;gap:16px}.dimension-input{display:flex;flex-direction:column}.dimension-field{padding:12px 16px;border:2px solid #E5E7EB;border-radius:8px;font-size:16px;transition:border-color .2s}.dimension-field:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.floor-select{width:100%;padding:12px 16px;border:2px solid #E5E7EB;border-radius:8px;font-size:16px;background-color:#fff;cursor:pointer;transition:border-color .2s}.floor-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.template-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}.template-btn{display:flex;flex-direction:column;align-items:center;padding:12px 8px;border:2px solid #E5E7EB;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;text-align:center}.template-btn:hover{border-color:#d1d5db;background-color:#f9fafb}.template-btn.selected{border-color:#3b82f6;background-color:#eff6ff;box-shadow:0 0 0 3px #3b82f61a}.template-icon{font-size:16px;margin-bottom:4px}.template-size{font-weight:500;color:#374151;font-size:12px}.custom-size-section{margin-top:12px}.custom-size-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:10px 12px;border:2px solid #E5E7EB;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;font-weight:500;color:#374151;font-size:14px}.custom-size-btn:hover{border-color:#d1d5db;background-color:#f9fafb}.custom-size-btn.active{border-color:#3b82f6;background-color:#eff6ff;box-shadow:0 0 0 3px #3b82f61a}.btn-icon{margin-right:8px;font-size:16px}.custom-size-inputs{margin-top:12px;padding:12px;background-color:#f9fafb;border-radius:8px;border:1px solid #E5E7EB}.floor-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.floor-option{display:flex;flex-direction:column;align-items:center;padding:8px 6px;border:2px solid #E5E7EB;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;text-align:center}.floor-option:hover{border-color:#d1d5db;background-color:#f9fafb}.floor-option.selected{border-color:#3b82f6;background-color:#eff6ff;box-shadow:0 0 0 3px #3b82f61a}.floor-preview{width:32px;height:32px;border-radius:4px;overflow:hidden;margin-bottom:4px;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6}.floor-image{width:100%;height:100%;object-fit:cover}.no-floor{background-color:#f3f4f6}.no-floor-icon{font-size:16px;color:#9ca3af}.floor-label{font-weight:500;color:#374151;font-size:10px;line-height:1.2}.room-preview{margin-top:16px;padding:12px;background-color:#f9fafb;border-radius:8px;border:2px solid #E5E7EB}.preview-label{font-weight:500;color:#374151;margin-bottom:12px;font-size:14px}.preview-room{background:linear-gradient(45deg,#E5E7EB 25%,transparent 25%),linear-gradient(-45deg,#E5E7EB 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#E5E7EB 75%),linear-gradient(-45deg,transparent 75%,#E5E7EB 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;border:2px solid #D1D5DB;border-radius:6px;position:relative;margin:0 auto;display:flex;align-items:center;justify-content:center;min-height:80px}.preview-dimensions{background:#ffffffe6;padding:8px 12px;border-radius:4px;font-weight:600;color:#374151;font-size:14px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid #E5E7EB;background-color:#f9fafb;border-radius:0 0 12px 12px}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:8px;font-weight:500;font-size:14px;cursor:pointer;transition:all .2s;border:none}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.btn-secondary{background-color:#fff;color:#374151;border:2px solid #E5E7EB}.btn-secondary:hover{background-color:#f9fafb;border-color:#d1d5db}.empty-canvas-state{display:flex;align-items:center;justify-content:center;height:100%;background-color:#f9fafb}.empty-canvas-content{text-align:center;max-width:400px;padding:40px}.empty-canvas-icon{font-size:64px;margin-bottom:24px}.empty-canvas-content h3{font-size:24px;font-weight:600;color:#111827;margin-bottom:12px}.empty-canvas-content p{font-size:16px;color:#6b7280;margin-bottom:32px;line-height:1.5}.create-first-room-btn{font-size:16px;padding:16px 32px;border-radius:12px;font-weight:600}.rooms-tabs{display:flex;gap:8px;overflow-x:auto;padding:4px 0}.room-tab{display:flex;align-items:center;background:#fff;border:2px solid #E5E7EB;border-radius:8px;padding:3px 12px;cursor:pointer;transition:all .2s;min-width:120px;position:relative;white-space:nowrap}.room-tab:hover{border-color:#d1d5db;background-color:#f9fafb}.room-tab.active{border-color:#3b82f6;background-color:#eff6ff;box-shadow:0 0 0 3px #3b82f61a}.room-tab-content{flex:1;min-width:0}.room-tab-name{font-weight:500;color:#374151;font-size:12px;margin-bottom:0;overflow:hidden;text-overflow:ellipsis}.room-tab-objects{font-size:10px;color:#6b7280}.room-tab-delete{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:16px;font-weight:700;padding:2px 6px;margin-left:8px;border-radius:4px;transition:all .2s;line-height:1}.room-tab-delete:hover{background-color:#fee2e2;color:#dc2626}.new-project-section{margin-bottom:16px}.new-project-btn{width:100%;padding:12px 16px;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #10b98133}.new-project-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 4px 8px #10b9814d}.new-project-btn:active{transform:translateY(0);box-shadow:0 2px 4px #10b98133}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.6;color:#333;background-color:#f9fafb;overflow:hidden}:root{--bg-primary: #F9FAFB;--bg-secondary: #FFFFFF;--text-primary: #333333;--text-secondary: #6B7280;--border-color: #E5E7EB;--accent-blue: #3B82F6;--accent-blue-hover: #2563EB;--success-green: #10B981;--error-red: #EF4444;--warning-orange: #F59E0B;--grid-line: #E5E7EB;--grid-line-thick: #D1D5DB}[data-theme=dark]{--bg-primary: #1F2937;--bg-secondary: #374151;--text-primary: #F9FAFB;--text-secondary: #D1D5DB;--border-color: #4B5563;--grid-line: #4B5563;--grid-line-thick: #6B7280}.app{height:100vh;display:flex;flex-direction:column}.header{width:100%;display:flex;justify-content:center;align-items:center;padding:0;margin:0;overflow:hidden;background-color:#fff;border-bottom:1px solid #E5E7EB;box-shadow:0 2px 4px #0000001a}.banner-container{background-color:#fff;border-bottom:1px solid #E5E7EB;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:center;align-items:center;width:100%}.banner-image{width:100%;height:auto;max-height:12vh;min-height:6vh;object-fit:contain;object-position:center center;display:block;margin:0;padding:.8vh 0;transition:all .3s ease}@media (max-width: 1400px){.banner-image{max-height:10vh;padding:.6vh 0}}@media (max-width: 1200px){.banner-image{max-height:8vh;padding:.5vh 0}}@media (max-width: 1000px){.banner-image{max-height:6vh;padding:.4vh 0}}@media (max-width: 768px){.banner-image{max-height:5vh;padding:.3vh 0}}@media (max-width: 480px){.banner-image{max-height:50px;min-height:40px;padding:3px 0}}.main-content{flex:1;display:flex;overflow:hidden}.left-panel{width:480px;min-width:400px;max-width:520px;height:100%;background-color:var(--bg-secondary);border-right:.5px solid var(--border-color);scroll-behavior:smooth;position:relative;z-index:10;overflow-y:auto;-webkit-overflow-scrolling:touch;scroll-padding-top:20px;scroll-snap-type:y proximity;padding:18px;display:flex;flex-direction:column;gap:16px}.section{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:14px}.project-info.section{padding:10px}.panel{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-bottom:16px}.panel-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:0;margin:0 0 12px;border:none;background:none;font-size:16px;font-weight:600;color:var(--text-primary)}.panel-header:hover{color:var(--accent-blue)}.section h2{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:8px}.section h3{font-size:14px;font-weight:500;color:var(--text-secondary);margin-bottom:8px}.collapsible-section{transition:all .3s ease}.collapsible-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s ease;margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--border-color);font-size:14px}.collapsible-header:hover{color:var(--accent-blue)}.collapse-arrow{font-size:12px;transition:transform .3s ease;color:var(--text-secondary)}.collapsible-section.collapsed .collapse-arrow{transform:rotate(-90deg)}.collapsible-content{overflow:visible;transition:max-height .3s ease,opacity .3s ease;max-height:2000px;opacity:1}.collapsible-section.collapsed .collapsible-content{max-height:0;opacity:0;padding-top:0;padding-bottom:0}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:6px 10px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;color:var(--text-primary);background-color:var(--bg-secondary);transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:50px}.left-panel-content{display:grid;grid-template-columns:1fr 1fr;gap:16px;height:100%}.client-panel{min-width:0}.tools-panel{min-width:0;overflow-y:auto;max-height:100vh;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.compact-section{padding:12px!important}.compact-section h2{font-size:14px!important;margin-bottom:8px!important}.template-buttons{display:flex;gap:8px;margin-bottom:16px}.template-buttons.compact{gap:4px;margin-bottom:8px;flex-direction:column}.template-btn{flex:1;padding:12px 8px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:4px}.template-btn:hover{background-color:var(--border-color);border-color:var(--accent-blue)}.template-btn.active{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.template-btn.compact{padding:8px 6px;font-size:12px}.template-btn.compact .template-icon{font-size:16px}.template-presets{margin-top:16px}.preset-buttons{display:flex;gap:8px;margin-bottom:12px}.preset-buttons.compact{gap:4px;margin-bottom:6px}.preset-btn{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;font-size:13px;transition:all .2s ease}.preset-btn:hover{background-color:var(--border-color)}.preset-btn.compact{padding:6px 8px;font-size:11px}.furniture-dropdowns{display:flex;flex-direction:column;gap:16px}.furniture-select{width:100%;padding:12px 40px 12px 12px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-family:inherit;cursor:pointer;transition:all .2s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:16px}.furniture-select:hover{border-color:var(--accent-blue);background-color:var(--border-color)}.furniture-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.furniture-select option{padding:8px;background-color:var(--bg-secondary);color:var(--text-primary)}.furniture-name{flex:1;font-weight:600;color:var(--text-primary)}.furniture-size{font-size:12px;color:var(--text-secondary)}.layer-controls{display:flex;flex-direction:column;gap:8px}.layer-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .2s ease}.layer-btn:hover{background-color:var(--border-color)}.layer-btn:disabled{opacity:.5;cursor:not-allowed}.layer-info{margin-top:8px;padding:8px;background-color:var(--bg-tertiary);border-radius:4px;font-size:12px;color:var(--text-secondary)}.layer-text{display:block}.helpers-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:16px}.helper-btn{padding:12px 8px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:12px}.helper-btn:hover{background-color:var(--border-color);border-color:var(--accent-blue)}.helper-btn.active{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.helper-icon{font-size:16px}.helper-name{font-weight:500}.constraint-status{background-color:#fef2f2;border:1px solid #FECACA;border-radius:6px;padding:12px;margin-top:16px}.constraint-status h3{font-size:14px;font-weight:600;color:#dc2626;margin-bottom:8px}.violations-list{display:flex;flex-direction:column;gap:4px}.violation-item{font-size:12px;color:#dc2626;padding:4px 8px;background-color:#fee2e2;border-radius:4px}.export-btn{padding:12px 16px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500}.export-btn:hover{background-color:var(--border-color)}.export-btn.primary{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.export-btn.primary:hover{background-color:var(--accent-blue-hover)}.export-btn svg{width:16px;height:16px}.right-panel{flex:1;display:flex;flex-direction:column;background-color:var(--bg-primary);padding-left:0}.canvas-header{padding:16px 24px;background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;justify-content:flex-end}.canvas-container{flex:1;position:relative;overflow:hidden;margin-left:-150px;margin-top:-20px;min-height:880px;max-height:calc(88vh - 80px)}#roomCanvas{display:block;cursor:crosshair;background-color:#fff}.room-dimensions{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none}.footer{background-color:var(--bg-secondary);border-top:1px solid var(--border-color);padding:12px 24px}.keyboard-shortcuts{display:flex;gap:24px;flex-wrap:wrap}.shortcut{font-size:12px;color:var(--text-secondary);font-weight:500}@media (max-width: 1200px){.left-panel{width:600px}}@media (max-width: 768px){.main-content{flex-direction:column}.left-panel{width:100%;height:300px;overflow-y:auto}.right-panel{height:calc(100vh - 412px)}}.left-panel::-webkit-scrollbar{width:6px}.left-panel::-webkit-scrollbar-track{background:var(--bg-primary)}.left-panel::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.left-panel::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.fade-in{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}.hidden{display:none!important}.text-center{text-align:center}.text-right{text-align:right}.mb-0{margin-bottom:0}.mt-16{margin-top:16px}.p-16{padding:16px}.border-radius-8{border-radius:8px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.form-row:last-child{margin-bottom:0}@media (max-width: 1200px){.form-row{grid-template-columns:1fr;gap:8px}}.template-buttons{display:flex;gap:6px;margin-bottom:10px}.template-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:11px;font-weight:500}.template-btn:hover{border-color:var(--accent-blue);background:#f8faff}.template-btn.active{border-color:var(--accent-blue);background:#eff6ff;color:var(--accent-blue)}.template-icon{font-size:20px}.template-label{font-weight:500}.dimension-presets{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.dimension-preset-btn{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500;text-align:center;min-height:36px;display:flex;align-items:center;justify-content:center}.dimension-preset-btn:hover{background-color:var(--border-color);border-color:var(--accent-blue);transform:translateY(-1px)}.dimension-preset-btn:active{transform:translateY(0);background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.bed-selection{display:flex;flex-direction:column;gap:12px}.bed-style-select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer}.bed-style-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.bed-size-buttons{display:flex;gap:8px}.bed-size-btn{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500}.bed-size-btn:hover:not(:disabled){background-color:var(--border-color);border-color:var(--accent-blue)}.bed-size-btn:disabled{opacity:.5;cursor:not-allowed;background-color:#f5f5f5}.bed-size-btn:not(:disabled):active{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.rug-selection{display:flex;flex-direction:column;gap:12px;overflow:visible;position:relative}.rug-type-select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer}.rug-type-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.rug-size-buttons{display:flex;flex-direction:column;gap:8px}.rug-size-btn{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500;text-align:left}.rug-size-btn:hover{background-color:var(--border-color);border-color:var(--accent-blue)}.rug-size-btn:active{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.sofa-selection{display:flex;flex-direction:column;gap:12px}.sofa-type-select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer}.sofa-type-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.sofa-size-buttons{display:flex;flex-direction:column;gap:8px}.sofa-size-btn{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500;text-align:left}.sofa-size-btn:hover{background-color:var(--border-color);border-color:var(--accent-blue)}.sofa-size-btn:active{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.custom-dropdown{position:relative;width:100%}.dropdown-trigger{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;text-align:left}.dropdown-trigger:hover{border-color:var(--accent-blue)}.dropdown-trigger:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.dropdown-arrow{font-size:10px;transition:transform .2s ease}.dropdown-menu{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 6px #0000001a;z-index:9999;margin-top:2px;max-height:200px!important;overflow-y:auto!important;overflow-x:hidden;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.dropdown-option{padding:8px 12px;cursor:pointer;display:flex;align-items:center;transition:background-color .2s ease}.dropdown-option:hover{background-color:var(--border-color)}.dropdown-option-with-image{display:flex;align-items:center;gap:8px}.dropdown-image{width:20px;height:20px;object-fit:contain;border-radius:2px}.dining-selection{display:flex;flex-direction:column;gap:12px}.dining-size-buttons{display:flex;flex-direction:column;gap:8px}.dining-size-btn{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500;text-align:left}.dining-size-btn:hover{background-color:var(--border-color);border-color:var(--accent-blue)}.dining-size-btn:active{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.coffee-selection{display:flex;flex-direction:column;gap:12px}.coffee-size-buttons{display:flex;flex-direction:column;gap:8px}.coffee-size-btn{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500;text-align:left}.coffee-size-btn:hover{background-color:var(--border-color);border-color:var(--accent-blue)}.coffee-size-btn:active{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.bedside-selection{display:flex;flex-direction:column;gap:12px}.bedside-size-buttons{display:flex;flex-direction:column;gap:8px}.bedside-size-btn{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500;text-align:left}.bedside-size-btn:hover{background-color:var(--border-color);border-color:var(--accent-blue)}.bedside-size-btn:active{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.door-selection{display:flex;flex-direction:column;gap:12px}.door-width-select{padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-secondary);color:var(--text-primary);font-size:12px;font-weight:500;cursor:pointer}.door-width-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f61a}.door-add-btn{padding:8px 12px;border:1px solid var(--accent-blue);border-radius:6px;background-color:var(--accent-blue);color:#fff;cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500;text-align:center}.door-add-btn:hover{background-color:#2563eb;border-color:#2563eb}.door-add-btn:active{background-color:#1d4ed8;border-color:#1d4ed8}.door-direction-selector{margin-bottom:12px}.door-direction-label{display:block;font-size:12px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.door-direction-options{display:flex;gap:16px}.door-direction-option{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-primary);cursor:pointer}.door-direction-option input[type=radio]{margin:0;cursor:pointer}.door-direction-option span{font-weight:500}.preset-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}.preset-btn{padding:6px 8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:5px;cursor:pointer;transition:all .2s ease;font-size:11px;font-weight:500;text-align:center}.preset-btn:hover{border-color:var(--accent-blue);background:#f8faff;color:var(--accent-blue)}.analytics-page{min-height:100vh;background:#f8f9fa;padding:20px}.analytics-header{text-align:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.analytics-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.analytics-header p{font-size:16px;color:var(--text-secondary);margin:0}.analytics-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.time-range-selector{display:flex;align-items:center;gap:12px}.time-range-selector label{font-size:16px;font-weight:600;color:var(--text-primary)}.time-range-select{padding:8px 12px;border:2px solid var(--border-color);border-radius:6px;font-size:14px;background:#fff;min-width:150px}.refresh-btn{padding:8px 16px;background:var(--accent-blue);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.analytics-loading{text-align:center;padding:60px 20px;color:var(--text-secondary);background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.loading-spinner{font-size:48px;margin-bottom:16px}.analytics-error{text-align:center;padding:40px 20px;color:#dc2626;background:#fef2f2;border-radius:8px;margin:20px 0;box-shadow:0 2px 4px #0000001a}.retry-btn{margin-top:16px;padding:8px 16px;background:#dc2626;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer}.analytics-content{max-width:1200px;margin:0 auto}.analytics-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:40px}.metric-card{display:flex;align-items:center;gap:16px;padding:24px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.metric-icon{font-size:32px}.metric-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:4px}.metric-label{font-size:14px;color:var(--text-secondary);font-weight:500}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:40px}.analytics-section{background:#fff;border-radius:8px;padding:24px;box-shadow:0 2px 4px #0000001a}.analytics-section h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid var(--border-color)}.users-list,.products-list,.activity-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.user-item,.product-item,.activity-item{display:flex;align-items:center;gap:12px;padding:16px;background:#f8f9fa;border-radius:6px;border:1px solid var(--border-color);transition:background-color .2s ease}.user-item:hover,.product-item:hover,.activity-item:hover{background:#e9ecef}.user-rank,.product-rank{font-size:16px;font-weight:700;color:var(--accent-blue);min-width:30px;text-align:center}.user-name,.product-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.user-stats{display:flex;gap:12px;font-size:12px;color:var(--text-secondary)}.stat{background:#fff;padding:4px 8px;border-radius:4px;border:1px solid var(--border-color)}.product-category{font-size:12px;color:var(--text-secondary)}.activity-score,.usage-count{font-size:20px;font-weight:700;color:var(--text-primary);line-height:1}.activity-label,.usage-label{font-size:12px;color:var(--text-secondary);margin-top:4px}.activity-icon{font-size:20px;min-width:30px;text-align:center}.activity-description{font-size:14px;color:var(--text-primary);margin-bottom:4px;line-height:1.4}.activity-time{font-size:12px;color:var(--text-secondary)}.growth-chart{display:flex;align-items:end;gap:8px;height:200px;padding:20px;background:#f8f9fa;border-radius:6px;border:1px solid var(--border-color)}.bar-fill{width:100%;background:var(--accent-blue);border-radius:4px 4px 0 0;min-height:8px;transition:height .3s ease}.bar-label{font-size:10px;color:var(--text-secondary);margin-top:8px;transform:rotate(-45deg);white-space:nowrap}.bar-value{font-size:12px;font-weight:600;color:var(--text-primary);margin-top:4px}.analytics-empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px}.empty-state-icon{font-size:64px;margin-bottom:20px;opacity:.6}.analytics-empty-state h3{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.analytics-empty-state p{font-size:16px;color:var(--text-secondary);max-width:500px;margin:0 auto;line-height:1.5}@media (max-width: 768px){.analytics-page{padding:10px}.analytics-grid{grid-template-columns:1fr;gap:20px}.analytics-overview{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.metric-card{padding:16px}.metric-value{font-size:24px}.analytics-controls{flex-direction:column;gap:15px;align-items:stretch}.time-range-selector{justify-content:center}}.analytics-section{background:#f8f9fa;border-radius:6px;margin-bottom:12px;overflow:hidden}.analytics-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px;background:#e9ecef;border-radius:4px}.time-range-selector{display:flex;align-items:center;gap:8px}.time-range-selector label{font-size:12px;font-weight:600;color:var(--text-primary)}.time-range-select{padding:4px 8px;border:1px solid var(--border-color);border-radius:4px;font-size:12px;background:#fff}.refresh-btn{padding:4px 8px;background:var(--accent-blue);color:#fff;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:background-color .2s ease}.refresh-btn:hover:not(:disabled){background:#2563eb}.refresh-btn:disabled{background:#9ca3af;cursor:not-allowed}.analytics-loading{text-align:center;padding:20px;color:var(--text-secondary)}.loading-spinner{font-size:24px;margin-bottom:8px}.analytics-error{text-align:center;padding:20px;color:#dc2626;background:#fef2f2;border-radius:4px;margin:12px}.retry-btn{margin-top:8px;padding:6px 12px;background:#dc2626;color:#fff;border:none;border-radius:4px;font-size:12px;cursor:pointer}.analytics-content{padding:12px}.analytics-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;margin-bottom:20px}.metric-card{display:flex;align-items:center;gap:8px;padding:12px;background:#fff;border-radius:6px;border:1px solid var(--border-color)}.metric-icon{font-size:20px}.metric-content{flex:1}.metric-value{font-size:18px;font-weight:700;color:var(--text-primary);line-height:1}.metric-label{font-size:10px;color:var(--text-secondary);margin-top:2px}.analytics-section-content{margin-bottom:20px}.analytics-section-content h3{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 12px;padding-bottom:6px;border-bottom:1px solid var(--border-color)}.users-list,.products-list,.activity-list{display:flex;flex-direction:column;gap:6px}.user-item,.product-item,.activity-item{display:flex;align-items:center;gap:8px;padding:8px;background:#fff;border-radius:4px;border:1px solid var(--border-color)}.user-rank,.product-rank{font-size:12px;font-weight:700;color:var(--accent-blue);min-width:20px}.user-info,.product-info{flex:1}.user-name,.product-name{font-size:12px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.user-stats{display:flex;gap:8px;font-size:10px;color:var(--text-secondary)}.stat{background:#f3f4f6;padding:2px 6px;border-radius:3px}.product-category{font-size:10px;color:var(--text-secondary)}.user-activity,.product-usage{text-align:right}.activity-score,.usage-count{font-size:14px;font-weight:700;color:var(--text-primary);line-height:1}.activity-label,.usage-label{font-size:9px;color:var(--text-secondary);margin-top:2px}.activity-icon{font-size:16px;min-width:20px;text-align:center}.activity-content{flex:1}.activity-description{font-size:12px;color:var(--text-primary);margin-bottom:2px}.activity-time{font-size:10px;color:var(--text-secondary)}.growth-chart{display:flex;align-items:end;gap:4px;height:120px;padding:12px;background:#fff;border-radius:4px;border:1px solid var(--border-color)}.growth-bar{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.bar-fill{width:100%;background:var(--accent-blue);border-radius:2px 2px 0 0;min-height:4px;transition:height .3s ease}.bar-label{font-size:9px;color:var(--text-secondary);margin-top:4px;transform:rotate(-45deg);white-space:nowrap}.bar-value{font-size:10px;font-weight:600;color:var(--text-primary);margin-top:2px}.furniture-categories{display:flex;flex-direction:column;gap:12px}.furniture-category{display:flex;flex-direction:column;gap:6px}.furniture-category h3{font-size:12px;font-weight:600;color:var(--text-primary);margin:0;padding:0}.furniture-subcategory{margin-bottom:8px}.furniture-subcategory h4{font-size:11px;font-weight:500;color:var(--text-secondary);margin-bottom:4px;display:flex;align-items:center;gap:4px}.size-options{display:flex;gap:3px;flex-wrap:wrap;margin-bottom:6px}.size-btn{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:3px;padding:3px 6px;font-size:10px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s ease;min-width:35px;text-align:center}.size-btn:hover,.size-btn.active{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.bed-style-dropdown{margin-bottom:12px;padding:8px 0}.bed-style-select{width:100%;padding:6px 8px;border:1px solid #D1D5DB;border-radius:4px;font-size:11px;background-color:#fff;color:#374151;cursor:pointer;transition:border-color .2s ease}.bed-style-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a}.bed-style-select:hover{border-color:#9ca3af}.furniture-select{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);font-size:13px;color:var(--text-primary);cursor:pointer;transition:border-color .2s ease}.furniture-select:hover{border-color:var(--accent-blue)}.furniture-select:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f61a}.layer-controls{display:flex;gap:8px;margin-bottom:12px}.layer-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:500}.layer-btn:hover{border-color:var(--accent-blue);background:#f8faff}.layer-info{padding:8px 12px;background:#f9fafb;border:1px solid var(--border-color);border-radius:6px;font-size:12px;color:var(--text-secondary);text-align:center}.export-buttons{display:flex;flex-direction:column;gap:8px}.export-btn{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease;font-size:13px;font-weight:500;text-align:left}.export-btn:hover{border-color:var(--accent-blue);background:#f8faff}.export-btn.primary{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.export-btn.primary:hover{background:var(--accent-blue-hover);border-color:var(--accent-blue-hover)}@media (max-width: 1400px){.left-panel{width:420px}}@media (max-width: 1200px){.left-panel{width:380px;min-width:350px}.canvas-container{margin-left:-70px;min-height:800px}.form-row{grid-template-columns:1fr}}@media (max-width: 1000px){.left-panel{width:320px;min-width:300px}.canvas-container{margin-left:-60px;min-height:700px}}.drawing-tools-content{display:flex;flex-direction:column;gap:16px}.drawing-mode-section{text-align:center}.drawing-mode-btn{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .2s ease}.drawing-mode-btn:hover{border-color:var(--accent-blue)}.drawing-mode-btn.active{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.drawing-instructions{margin:8px 0 0;font-size:12px;color:var(--text-secondary);font-style:italic}.label-selection h4{margin:0 0 8px;font-size:13px;color:var(--text-primary);font-weight:600}.label-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:12px}.label-btn{padding:8px 10px;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);font-size:11px;cursor:pointer;transition:all .2s ease;text-align:center}.label-btn:hover{border-color:var(--accent-blue);background-color:var(--bg-secondary)}.label-btn.selected{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.custom-label-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);font-size:12px}.custom-label-input:focus{outline:none;border-color:var(--accent-blue)}.drawing-tips{background-color:var(--bg-primary);padding:12px;border-radius:6px;border:1px solid var(--border-color)}.drawing-tips h4{margin:0 0 8px;font-size:12px;color:var(--text-primary);font-weight:600}.drawing-tips ul{margin:0;padding-left:16px;font-size:11px;color:var(--text-secondary);line-height:1.4}.drawing-tips li{margin-bottom:4px}.customer-sessions-content{display:flex;flex-direction:column;gap:16px}.save-session-btn{width:100%;padding:12px 16px;border:2px solid var(--accent-blue);border-radius:6px;background-color:var(--accent-blue);color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease}.save-session-btn:hover{background-color:var(--accent-blue-hover)}.save-form{margin-top:12px;display:flex;flex-direction:column;gap:8px}.customer-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);font-size:13px}.customer-input:focus{outline:none;border-color:var(--accent-blue)}.save-form-actions{display:flex;gap:8px}.save-confirm-btn,.save-cancel-btn{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s ease}.save-confirm-btn{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.save-cancel-btn{background-color:var(--bg-primary);color:var(--text-primary)}.saved-sessions h4{margin:0 0 8px;font-size:13px;color:var(--text-primary);font-weight:600}.no-sessions{text-align:center;color:var(--text-secondary);font-style:italic;font-size:12px;margin:16px 0}.sessions-list{display:flex;flex-direction:column;gap:8px}.session-item{padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);display:flex;justify-content:space-between;align-items:center}.session-info{flex:1}.session-name{font-weight:600;font-size:13px;color:var(--text-primary)}.session-date{font-size:11px;color:var(--text-secondary);margin-top:2px}.session-email{font-size:10px;color:var(--text-secondary);margin-top:2px}.session-actions{display:flex;gap:4px}.session-action-btn{width:28px;height:28px;border:1px solid var(--border-color);border-radius:4px;background-color:var(--bg-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s ease}.session-action-btn:hover{background-color:var(--border-color)}.session-action-btn.delete:hover{background-color:#dc2626;color:#fff;border-color:#dc2626}.session-action-btn.email:hover{background-color:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.session-action-btn.load:hover{background-color:#059669;color:#fff;border-color:#059669}.view-toggle-header{padding:12px 16px;border-bottom:1px solid var(--border-color);background-color:var(--bg-primary);border-radius:8px 8px 0 0}.view-toggle-header h4{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--text-primary)}.item-counts{display:flex;gap:16px;font-size:12px}.count-item{color:var(--text-secondary);font-weight:500}.view-toggle-btn{width:100%;padding:12px 16px;margin:4px 0;border:none;border-radius:0 0 8px 8px;background-color:var(--accent-blue);color:#fff;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:4px}.view-toggle-btn:hover{background-color:var(--accent-blue-hover)}.view-toggle-btn.showing-existing{background-color:#059669}.view-toggle-btn.showing-existing:hover{background-color:#047857}.toggle-hint{font-size:11px;font-weight:400;opacity:.8}.image-overlay-toggle,.template-outline-toggle{padding:0;margin:4px 0;border-bottom:1px solid var(--border-color)}.overlay-toggle-btn{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:2px}.overlay-toggle-btn:hover{background-color:var(--bg-secondary);border-color:var(--accent-blue)}.overlay-toggle-btn.overlays-on{background-color:#10b981;color:#fff;border-color:#059669}.overlay-toggle-btn.overlays-on:hover{background-color:#059669}.overlay-toggle-btn.overlays-off{background-color:#6b7280;color:#fff;border-color:#4b5563}.overlay-toggle-btn.overlays-off:hover{background-color:#4b5563}.view-description{padding:8px 16px 12px}.view-description p{margin:0;font-size:11px;color:var(--text-secondary);font-style:italic;text-align:center}.selection-info-header{padding:12px 16px;border-bottom:1px solid var(--border-color);background-color:var(--bg-primary);border-radius:8px 8px 0 0}.selection-info-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-primary)}.selection-info-content{padding:12px 16px}.selection-info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px}.selection-info-row:last-child{margin-bottom:0}.selection-info-row .label{color:var(--text-secondary);font-weight:500;min-width:80px}.selection-info-row .value{color:var(--text-primary);font-weight:400;text-align:right;flex:1}.selection-info-row .value.price{color:#059669;font-weight:600}.selection-info-row .value.availability.in-stock{color:#059669;font-weight:500}.selection-info-row .value.availability.delayed{color:#dc2626;font-weight:500}.selection-info-actions{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.duplicate-btn{width:100%;padding:10px 16px;border:none;border-radius:6px;background-color:#8b5cf6;color:#fff;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s ease;margin-bottom:8px}.duplicate-btn:hover{background-color:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 8px #8b5cf64d}.duplicate-btn:active{transform:translateY(0)}.duplicate-btn:disabled{background-color:#ccc;color:#666;cursor:not-allowed;transform:none;box-shadow:none}.duplicate-btn:disabled:hover{background-color:#ccc;transform:none;box-shadow:none}.duplicate-section{margin:10px 0}.product-actions-spacing{margin-top:12px}.overlay-toggle-btn.compact{padding:8px 12px;font-size:12px;min-height:auto}.overlay-toggle-btn.compact .toggle-hint{display:none}.view-toggle .product-labels-toggle,.view-toggle .image-overlay-toggle,.view-toggle .template-outline-toggle{margin:6px 0}.view-toggle .view-toggle-header{padding:8px 16px;margin-bottom:4px}.view-toggle .view-toggle-header h4{font-size:14px;margin:0}.add-to-quote-btn{width:100%;padding:10px 16px;border:none;border-radius:6px;background-color:var(--accent-blue);color:#fff;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s ease}.add-to-quote-btn:hover:not(:disabled){background-color:var(--accent-blue-hover)}.add-to-quote-btn:disabled{background-color:#059669;cursor:not-allowed}@media (max-width: 1200px){.selection-info{width:240px;top:130px;right:15px}}@media (max-width: 768px){.selection-info{position:relative;width:100%;top:0;right:0;margin:10px 0;order:-1}}@media print{.left-panel,.header,.footer,.selection-info{display:none!important}.right-panel{width:100%!important;height:100vh!important}.canvas-container{height:100vh!important}#roomCanvas{width:100%!important;height:100%!important}}.button-content-with-image{display:flex;align-items:center;gap:8px}.button-image{width:24px;height:24px;object-fit:cover;border-radius:4px;border:1px solid rgba(0,0,0,.1)}.rug-size-btn.with-image{padding:8px 12px;min-height:40px}.dropdown-image{width:20px;height:20px;object-fit:cover;border-radius:3px;margin-right:8px}.dropdown-option-with-image{display:flex;align-items:center}.compact-template-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:15px}.compact-template-btn{padding:8px 10px;background-color:#fff;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-primary);min-height:36px}.compact-template-btn:hover{border-color:#3b82f6;background-color:#f8fafc;transform:translateY(-1px)}.compact-template-btn.last-used{border-color:#10b981;background-color:#ecfdf5}.compact-template-btn .template-icon{font-size:12px;flex-shrink:0}.compact-template-btn .template-size{font-weight:600;color:var(--text-primary)}.custom-size-section{margin-bottom:10px}.custom-size-btn{width:100%;padding:8px 12px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--text-primary);min-height:32px}.custom-size-btn:hover{border-color:#3b82f6;background-color:#f8fafc}.custom-size-btn .btn-icon{font-size:16px}.custom-size-inputs{margin-top:12px;padding:15px;background-color:#f8fafc;border:1px solid var(--border-color);border-radius:8px}.dimension-inputs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:15px}.input-group{display:flex;flex-direction:column;gap:4px}.input-group label{font-size:12px;font-weight:600;color:var(--text-secondary)}.input-group input{padding:8px 10px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;background-color:#fff}.input-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.custom-actions{display:flex;gap:8px}.create-room-btn{flex:1;padding:10px 16px;background-color:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.create-room-btn:hover{background-color:#2563eb}.room-dimensions-overlay{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:10}.room-dimensions-overlay .dimension-label{position:absolute;background:#fffffff2;border:2px solid #3B82F6;border-radius:8px;padding:6px 12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;align-items:center;gap:1px;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;min-width:60px}.room-dimensions-overlay .dimension-label.dimension-width{transform:translate(-50%)}.room-dimensions-overlay .dimension-label.dimension-depth{transform:rotate(-90deg);transform-origin:center;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;backface-visibility:hidden;-webkit-backface-visibility:hidden}.room-dimensions-overlay .dimension-value{font-size:14px;font-weight:700;color:#3b82f6;line-height:1}.dimension-text{font-size:10px;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.5px;line-height:1}.cancel-btn{padding:10px 16px;background-color:#fff;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.cancel-btn:hover{background-color:#f8fafc;border-color:#d1d5db}@media (max-width: 768px){.quick-template-grid,.dimension-inputs{grid-template-columns:1fr}.custom-actions{flex-direction:column}}.search-container{position:relative;margin-bottom:12px;padding:0}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:8px 32px 8px 12px;border:2px solid var(--border-color);border-radius:6px;font-size:13px;background-color:var(--bg-secondary);color:var(--text-primary);transition:border-color .2s ease}.search-input:focus{outline:none;border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;right:10px;color:var(--text-secondary);font-size:14px;pointer-events:none}.search-results-dropdown{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-secondary);border:2px solid var(--border-color);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 6px -1px #0000001a;max-height:300px;overflow-y:auto;overflow-x:hidden;z-index:1000;scroll-behavior:smooth;overscroll-behavior:contain}.search-result-item{padding:12px 16px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background-color .2s ease}.search-result-item:hover{background-color:var(--bg-primary)}.search-result-item:last-child{border-bottom:none}.search-result-content{display:flex;align-items:center;gap:12px}.search-result-image{width:48px;height:48px;object-fit:cover;border-radius:4px;border:1px solid var(--border-color)}.search-result-text{display:flex;flex-direction:column;gap:2px;flex:1}.search-result-name{font-weight:500;color:var(--text-primary);font-size:14px}.search-result-details{font-size:12px;color:var(--text-secondary);display:flex;flex-direction:column;gap:2px}.search-section-header{padding:8px 16px 4px;border-bottom:1px solid var(--border-color);background-color:var(--bg-primary);position:sticky;top:0;z-index:1}.search-section-title{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.search-history-item,.search-suggestion-item{padding:8px 16px}.search-history-icon,.search-suggestion-icon{font-size:16px;margin-right:8px;opacity:.7}.search-history-item:hover .search-history-icon,.search-suggestion-item:hover .search-suggestion-icon{opacity:1}.right-panel-unified{position:fixed;top:calc(12vh + 5px);right:20px;width:322px;height:calc(88vh - 80px);overflow-y:auto;z-index:1000;display:flex;flex-direction:column;gap:10px}.selection-info,.product-details-section,.view-toggle{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin-bottom:16px;flex-shrink:0}.view-toggle{flex:.85}.product-details-section{flex:0 0 auto}.right-panel-unified>*:first-child{margin-top:0}.right-panel-unified>*:last-child{margin-bottom:20px}.selection-info{position:relative;top:auto;right:auto;width:100%;height:auto;z-index:1}.view-toggle{position:relative;bottom:auto;right:auto;width:100%;z-index:1}.product-details-panel{position:relative;width:100%;height:auto;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1;overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;margin:0 0 16px;flex-shrink:1}.product-details-content{padding:0;display:flex;flex-direction:column;height:100%}.product-details-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);border-bottom:1px solid var(--border-color);margin:0}.product-details-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.3;flex:1;padding-right:16px}.product-details-close{background:transparent;border:1px solid var(--border-color);font-size:20px;color:var(--text-secondary);cursor:pointer;padding:8px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease;flex-shrink:0}.product-details-close:hover{background-color:#ef4444;color:#fff;border-color:#ef4444;transform:scale(1.05)}.product-details-body{flex:1;display:flex;flex-direction:column;padding:16px;gap:16px}.product-image-container{position:relative;width:100%;height:138px;border-radius:8px;overflow:hidden;background:var(--bg-primary);border:1px solid var(--border-color);box-shadow:0 2px 8px #0000001a}.product-image{width:100%;height:100%;object-fit:contain;cursor:crosshair;transition:transform .2s ease;transform:scale(1.69);image-rendering:-webkit-optimize-contrast;image-rendering:optimize-quality;image-rendering:auto}.product-image:hover{transform:scale(1.7069)}.product-image-zoom{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;border-radius:8px}.product-info{display:flex;flex-direction:column;gap:8px;padding:0;background:transparent;border:none}.product-dimensions,.product-category{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg-primary);border-radius:6px;border:1px solid var(--border-color);box-shadow:0 1px 3px #0000001a}.product-dimensions .dimension-label,.category-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0;position:static!important;background:transparent!important;border:none!important;box-shadow:none!important;display:inline!important;flex-direction:row!important;align-items:center!important;gap:0!important;min-width:auto!important;padding:0!important;transform:none!important}.product-dimensions .dimension-value,.category-value{font-size:13px;color:var(--text-primary);font-weight:600;margin:0;position:static!important;font-size:13px!important;color:var(--text-primary)!important;line-height:normal!important}.product-actions{margin-top:8px;padding-top:0;border-top:none}.product-link-button{display:block;width:100%;padding:14px 20px;background:#48604d;color:#fff!important;text-decoration:none;border-radius:8px;font-weight:600;text-align:center;transition:all .3s ease;font-size:14px;box-shadow:0 2px 8px #0000001a;border:none;cursor:pointer;text-shadow:0 1px 2px rgba(0,0,0,.3)}.product-link-button:hover{background:#3c5041;transform:translateY(-2px);box-shadow:0 6px 20px #0003}.product-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;height:200px}.placeholder-icon{font-size:48px;margin-bottom:16px;opacity:.6}.placeholder-text h4{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--text-primary)}.placeholder-text p{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.4}.floor-dropdown-container{position:relative;width:100%}.floor-dropdown-trigger{width:100%;padding:12px 16px;background-color:var(--bg-primary);border:2px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:500;color:var(--text-primary);transition:all .2s ease}.floor-dropdown-trigger:hover{background-color:var(--bg-secondary);border-color:var(--accent-blue)}.dropdown-arrow{font-size:12px;color:var(--text-secondary);transition:transform .2s ease}.floor-dropdown-trigger:hover .dropdown-arrow{transform:translateY(1px)}.floor-dropdown-menu{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-primary);border:2px solid var(--border-color);border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:300px;overflow-y:auto}.floor-option{display:flex;align-items:center;padding:12px 16px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid var(--border-color)}.floor-option:last-child{border-bottom:none}.floor-option:hover{background-color:var(--bg-secondary)}.floor-option.active{background-color:var(--accent-blue);color:#fff}.floor-option-image{width:40px;height:30px;margin-right:12px;border-radius:4px;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:var(--bg-secondary);border:1px solid var(--border-color)}.floor-option-image img{width:100%;height:100%;object-fit:cover}.no-floor-icon{font-size:18px;color:var(--text-secondary)}.floor-option-label{font-size:14px;font-weight:500;flex:1}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;box-sizing:border-box}.auth-container{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;padding:20px;width:100%;max-width:400px;max-height:calc(100vh - 40px);overflow-y:auto;box-sizing:border-box}.auth-header{text-align:center;margin-bottom:20px}.auth-header h1{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.auth-header p{color:var(--text-secondary);margin:0 0 15px;font-size:14px}.auth-logo{display:block;margin:0 auto 15px;object-fit:contain;border-radius:8px;max-width:200px;max-height:200px;width:auto;height:auto}.pricing-info{background:var(--bg-secondary);border-radius:8px;padding:16px;margin:20px 0}.pricing-info .price{font-size:24px;font-weight:700;color:var(--accent-blue);display:block;margin-bottom:4px}.pricing-info .features{font-size:14px;color:var(--text-secondary)}.domain-info{background:var(--bg-secondary);border-radius:8px;padding:16px;margin:20px 0;border-left:4px solid var(--accent-green)}.domain-info .domain-requirement{font-size:16px;font-weight:600;color:var(--accent-green);display:block;margin-bottom:4px}.domain-info .features{font-size:14px;color:var(--text-secondary)}.auth-form{display:flex;flex-direction:column;gap:15px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:var(--text-primary)}.form-group input{padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;font-size:16px;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:var(--accent-blue)}.form-group input:disabled{background-color:var(--bg-secondary);color:var(--text-secondary)}.auth-button{background:var(--accent-blue);color:#fff;border:none;padding:14px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.auth-button:hover:not(:disabled){background:#3b82f6}.auth-button:disabled{background:var(--text-secondary);cursor:not-allowed}.auth-footer{text-align:center;margin-top:20px;padding-top:15px;border-top:1px solid var(--border-color)}.auth-footer p{margin:8px 0;color:var(--text-secondary)}.auth-link{color:var(--accent-blue);text-decoration:none;font-weight:500}@media (max-height: 700px){.auth-container{padding:15px;max-height:calc(100vh - 20px)}.auth-header{margin-bottom:15px}.auth-logo{max-width:150px;max-height:150px;margin-bottom:10px}.auth-form{gap:12px}.auth-footer{margin-top:15px;padding-top:12px}}@media (max-height: 600px){.auth-container{padding:10px}.auth-header{margin-bottom:10px}.auth-logo{max-width:120px;max-height:120px;margin-bottom:8px}.auth-form{gap:10px}.auth-footer{margin-top:10px;padding-top:10px}}@media (max-width: 480px){.auth-page{padding:10px}.auth-container{padding:15px;border-radius:8px}.auth-header h1{font-size:20px}.auth-header p{font-size:13px}}.auth-link:hover{text-decoration:underline}.error-message{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;border:1px solid #fecaca;font-size:14px}.error-container{text-align:center}.error-container h2{color:#dc2626;margin-bottom:16px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--accent-blue);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dashboard-page{min-height:100vh;background:var(--bg-primary);padding-bottom:40px}.dashboard-header{background:#fff;border-bottom:1px solid var(--border-color);padding:20px;display:flex;justify-content:center;align-items:center}.dashboard-logo{max-height:120px}.user-account-info{display:flex;align-items:center;gap:12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:12px 16px;margin-top:20px}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.user-details{display:flex;flex-direction:column;gap:2px}.user-name{font-weight:600;color:var(--text-primary);font-size:14px;line-height:1.2}.user-email{color:var(--text-secondary);font-size:12px;line-height:1.2}.user-role{font-size:11px;font-weight:500;line-height:1.2}.user-role.admin{color:#059669}.user-role.user{color:#6b7280}.dashboard-user-profile{display:flex;align-items:center;gap:16px}.dashboard-user-profile .user-info{display:flex;align-items:center;gap:12px}.dashboard-user-profile .user-avatar{width:40px;height:40px;border-radius:50%;background:var(--accent-blue);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.dashboard-user-profile .user-details{display:flex;flex-direction:column;align-items:flex-start}.dashboard-user-profile .user-name{font-weight:600;color:var(--text-primary);font-size:14px}.dashboard-user-profile .user-role{font-size:12px;color:var(--text-secondary);font-weight:500}.dashboard-user-profile .signout-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f3f4f6;border:1px solid #d1d5db;border-radius:8px;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.dashboard-user-profile .signout-btn:hover{background:#e5e7eb;color:var(--text-primary);border-color:#9ca3af}.dashboard-user-profile .signout-icon{font-size:16px}.dashboard-user-profile .signout-text{font-size:14px}.action-button.logout-button{background-color:#f3f4f6;color:#6b7280;border:1px solid #d1d5db;margin-top:16px;border-top:1px solid #e5e7eb;padding-top:12px}.action-button.logout-button:hover{background-color:#e5e7eb;color:#374151;border-color:#9ca3af}.welcome-section h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.welcome-section p{color:var(--text-secondary);margin:0;font-size:16px}.company-info{text-align:right}.company-info h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.company-info p{color:var(--text-secondary);margin:0;font-size:14px}.verification-success,.verification-sent,.verification-info{text-align:center;padding:20px}.success-icon,.sent-icon,.info-icon{font-size:48px;margin-bottom:16px}.verification-success h2,.verification-sent h2,.verification-info h2{color:var(--text-primary);margin:0 0 12px;font-size:24px}.verification-success p,.verification-sent p,.verification-info p{color:var(--text-secondary);margin:0 0 16px;line-height:1.5}.verification-actions{display:flex;flex-direction:column;gap:12px;margin-top:24px}.auth-button.secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.auth-button.secondary:hover{background:var(--bg-hover)}.verification-banner{background:linear-gradient(135deg,#fef3c7,#fde68a);border-bottom:1px solid #f59e0b;padding:16px 32px}.verification-banner-content{display:flex;align-items:center;gap:16px;max-width:1200px;margin:0 auto}.verification-banner-icon{font-size:24px;flex-shrink:0}.verification-banner-text{flex:1}.verification-banner-text h4{margin:0 0 4px;color:#92400e;font-size:16px;font-weight:600}.verification-banner-text p{margin:0;color:#92400e;font-size:14px;line-height:1.4}.verification-banner-actions{flex-shrink:0}.verification-resend-btn{background:#f59e0b;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.verification-resend-btn:hover:not(:disabled){background:#d97706}.verification-resend-btn:disabled{opacity:.6;cursor:not-allowed}.verification-sent{color:#059669;font-size:14px;font-weight:500}.dashboard-grid{padding:32px;display:grid;grid-template-columns:1fr 2fr;gap:32px;max-width:1400px;margin:0 auto;min-height:calc(100vh - 200px);align-items:start}.quick-actions{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.quick-actions h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.action-buttons{display:flex;flex-direction:column;gap:12px}.action-button{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:8px;text-decoration:none;color:var(--text-primary);font-weight:500;transition:all .2s ease}.action-button:hover,.action-button.primary{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.action-button .icon{font-size:20px}.customer-projects{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;max-height:80vh;overflow-y:auto}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-actions{display:flex;align-items:center;gap:12px}.refresh-btn{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:8px 12px;cursor:pointer;transition:all .2s ease;font-size:16px;display:flex;align-items:center;justify-content:center;min-width:40px;height:40px}.refresh-btn:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.refresh-btn:active{transform:translateY(0)}.section-header h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.view-all-link{color:var(--accent-blue);text-decoration:none;font-weight:500;font-size:14px}.view-all-link:hover{text-decoration:underline}.empty-state{text-align:center;padding:40px 20px}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.empty-state p{color:var(--text-secondary);margin:0 0 24px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.project-card{border:1px solid var(--border-color);border-radius:8px;overflow:hidden;transition:box-shadow .2s ease}.project-card:hover{box-shadow:0 4px 12px #0000001a}.project-thumbnail{height:25px;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.project-thumbnail img{width:100%;height:100%;object-fit:cover}.placeholder-thumbnail{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);position:relative}.placeholder-icon{font-size:10px;margin-bottom:1px;opacity:.6;color:var(--text-secondary)}.regenerate-thumbnail-btn{position:absolute;top:2px;right:2px;background:var(--accent-blue);color:#fff;border:none;border-radius:50%;width:14px;height:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:8px;transition:all .2s ease;box-shadow:0 2px 8px #00000026}.regenerate-thumbnail-btn:hover{background:var(--accent-blue-dark);transform:scale(1.1);box-shadow:0 4px 12px #0003}.project-info{padding:3px}.project-info .form-group{margin-bottom:8px}.project-info .form-group label{font-size:12px;margin-bottom:3px}.project-info .form-group input,.project-info .form-group select,.project-info .form-group textarea{padding:4px 8px;font-size:13px;border-radius:4px}.project-info .form-group textarea{min-height:40px}.project-info .form-row{gap:8px;margin-bottom:8px}.project-info .collapsible-content{padding-top:6px}.project-info .collapsible-header{margin-bottom:6px}.project-info h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.project-info p{font-size:14px;color:var(--text-secondary);margin:0}.project-actions{padding:0 4px 4px}.project-link{color:var(--accent-blue);text-decoration:none;font-weight:500;font-size:14px}.project-link:hover{text-decoration:underline}.company-stats{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;grid-column:1 / -1;margin-top:20px}.company-stats h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.stat-card{text-align:center;padding:20px;background:var(--bg-secondary);border-radius:8px}.stat-value{font-size:32px;font-weight:700;color:var(--accent-blue);margin-bottom:8px}.stat-label{font-size:14px;color:var(--text-secondary);font-weight:500}.admin-page{min-height:100vh;background:var(--bg-primary)}.admin-header{background:#fff;border-bottom:1px solid var(--border-color);padding:24px 32px}.admin-header-content{display:flex;justify-content:space-between;align-items:center}.admin-header-left{display:flex;align-items:center;gap:20px}.back-button{background:#f3f4f6;border:2px solid #d1d5db;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.back-button:hover{background:#e5e7eb;border-color:#9ca3af;transform:translateY(-1px)}.back-button:active{transform:translateY(0)}.admin-title{text-align:left}.admin-title h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.admin-title p{color:var(--text-secondary);margin:0;font-size:16px}.admin-tabs{background:#fff;border-bottom:1px solid var(--border-color);padding:0 32px;display:flex;gap:0}.tab{background:none;border:none;padding:16px 24px;font-size:16px;font-weight:500;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;transition:all .2s ease}.tab:hover{color:var(--text-primary);background:var(--bg-secondary)}.tab.active{color:var(--accent-blue);border-bottom-color:var(--accent-blue)}.admin-content{padding:32px;max-width:1400px;margin:0 auto}.overview-tab .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:32px}.recent-activity{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.recent-activity h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-secondary);border-radius:8px}.activity-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%}.activity-details p{margin:0;font-size:14px}.activity-details p:first-child{font-weight:500;color:var(--text-primary)}.activity-time{color:var(--text-secondary)}.users-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.users-header h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.invite-button{background:var(--accent-blue);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.invite-button:hover{background:#3b82f6}.users-list{display:flex;flex-direction:column;gap:16px}.user-card{background:#fff;border:1px solid var(--border-color);border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px}.user-avatar{width:48px;height:48px;background:var(--accent-blue);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px}.user-info{flex:1}.user-info h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.user-info p{font-size:14px;color:var(--text-secondary);margin:0 0 8px}.user-role{font-size:12px;font-weight:500;padding:4px 8px;border-radius:4px;display:inline-block}.user-role.admin{background:#fef3c7;color:#92400e}.user-role.user{background:#e5e7eb;color:#374151}.user-stats{text-align:right;font-size:14px;color:var(--text-secondary)}.user-stats p{margin:0 0 4px}.user-actions{display:flex;gap:8px}.action-btn{background:var(--bg-secondary);border:1px solid var(--border-color);padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.action-btn:hover{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.action-btn.danger:hover{background:#dc2626;border-color:#dc2626}.projects-tab h3,.analytics-tab h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 24px}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.analytics-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.analytics-card h4{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.user-activity-list{display:flex;flex-direction:column;gap:12px}.user-activity-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:8px}.rank{font-weight:600;color:var(--accent-blue);min-width:30px}.name{flex:1;font-weight:500;color:var(--text-primary)}.sessions{color:var(--text-secondary);font-size:14px}.trends-chart{display:flex;align-items:end;gap:8px;height:120px}.trend-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}.bar{background:var(--accent-blue);width:100%;min-height:4px;border-radius:2px;transition:all .2s ease}.trend-bar:hover .bar{background:#3b82f6}.date{font-size:12px;color:var(--text-secondary);writing-mode:horizontal-tb}.room-planner-page{min-height:100vh;background:var(--bg-primary)}.planner-header{background:#fff;border-bottom:1px solid var(--border-color);padding:16px 24px;display:flex;justify-content:space-between;align-items:center}.project-info h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0}.session-name-input{background:#fff;border:2px solid #e1e5e9;border-radius:8px;padding:8px 12px;font-size:1.2rem;font-weight:600;color:#333;min-width:200px;transition:border-color .2s ease}.session-name-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.session-name-input::placeholder{color:#999;font-weight:400}.saving-indicator{font-size:14px;color:var(--text-secondary);margin-left:12px}.header-actions{display:flex;gap:12px}.header-btn{background:var(--bg-secondary);border:1px solid var(--border-color);padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease}.header-btn:hover,.header-btn.primary{background:var(--accent-blue);color:#fff;border-color:var(--accent-blue)}.header-btn:disabled{background:var(--text-secondary);color:#fff;cursor:not-allowed}.planner-layout{display:flex;height:calc(88vh - 80px)}.rooms-footer{position:fixed;bottom:0;left:480px;right:0;height:60px;background-color:var(--bg-secondary);border-top:1px solid var(--border-color);z-index:1000;overflow-y:auto}.rooms-footer-content{padding:8px 20px;height:100%;display:flex;flex-direction:row;align-items:center;gap:12px}.rooms-footer-header{display:flex;align-items:center;gap:12px;flex-shrink:0}.rooms-footer-header h3{font-size:14px;font-weight:600;color:var(--text-primary);margin:0;white-space:nowrap}.add-room-form{display:flex;gap:8px;align-items:center}.room-name-input{padding:4px 8px;border:1px solid var(--border-color);border-radius:4px;font-size:13px;width:200px}.add-room-btn{padding:4px 12px;background-color:var(--accent-blue);color:#fff;border:none;border-radius:4px;font-size:12px;cursor:pointer;white-space:nowrap}.add-room-btn:disabled{background-color:var(--text-secondary);cursor:not-allowed}.rooms-list{flex:1;overflow-x:auto;overflow-y:hidden;min-width:0}.rooms-grid{display:flex;gap:8px;height:100%;align-items:center;min-width:0}.room-item{display:flex;align-items:center;gap:8px;padding:6px 12px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;min-width:150px;white-space:nowrap;cursor:pointer;transition:all .2s ease}.room-item:hover{border-color:var(--accent-blue);background-color:#3b82f60d;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.room-item.selected{border-color:var(--accent-blue);background-color:#3b82f61a;box-shadow:0 2px 4px #3b82f633}.room-info{flex:1;min-width:0}.room-name{font-size:12px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis}.room-date{font-size:10px;color:var(--text-secondary)}.room-actions{display:flex;gap:4px}.room-action-btn{padding:2px 6px;background:none;border:none;cursor:pointer;font-size:12px;border-radius:3px;transition:background-color .2s}.room-action-btn:hover{background-color:var(--bg-secondary)}.room-action-btn.delete:hover{background-color:#ef44441a}.no-rooms{font-size:12px;color:var(--text-secondary);text-align:center;margin:0;font-style:italic;display:flex;align-items:center;justify-content:center;height:100%}.user-profile-container{position:fixed;bottom:0;left:20px;z-index:1001;display:flex;gap:16px;align-items:center;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px 16px 0 0;padding:12px 16px;box-shadow:0 8px 32px #0000001f;border:1px solid rgba(255,255,255,.2);height:80px}.back-to-dashboard-btn{display:flex;align-items:center;gap:8px;padding:12px 18px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:14px;font-weight:600;min-width:120px;height:48px;position:relative;overflow:hidden}.back-to-dashboard-btn:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);transform:translateY(-2px);box-shadow:0 12px 24px #667eea66}.back-to-dashboard-btn:active{transform:translateY(0);box-shadow:0 4px 12px #667eea4d}.back-to-dashboard-btn .btn-icon{font-size:16px}.back-to-dashboard-btn .btn-text{font-size:13px}@media (max-width: 1400px){.user-profile-container{left:16px}}@media (max-width: 1200px){.user-profile-container{left:12px}}@media (max-width: 1000px){.user-profile-container{left:8px}}@media (max-width: 768px){.user-profile-container{left:16px;bottom:0;height:100px;padding:10px 14px;gap:12px}.back-to-dashboard-btn{min-width:100px;height:44px;padding:10px 14px;font-size:13px}.profile-trigger{min-width:140px;height:44px;padding:10px 14px}.profile-avatar{width:36px;height:36px;font-size:16px}}.user-profile-button{position:relative}.profile-trigger{display:flex;align-items:center;gap:12px;padding:12px 18px;background:#fffc;border:1px solid rgba(0,0,0,.08);border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:160px;height:48px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.profile-trigger:hover{background:#667eea1a;border-color:#667eea4d;transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.profile-trigger:active{transform:translateY(0);box-shadow:0 4px 12px #00000014}.profile-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0;box-shadow:0 4px 12px #667eea4d;border:2px solid rgba(255,255,255,.2)}.profile-info{flex:1;min-width:0}.profile-name{font-size:15px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.01em}.profile-role{font-size:12px;color:var(--text-secondary);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.dropdown-arrow{font-size:10px;color:var(--text-secondary);transition:transform .2s ease;flex-shrink:0}.dropdown-arrow.open{transform:rotate(180deg)}.profile-dropdown{position:absolute;bottom:100%;left:0;right:0;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;margin-bottom:8px;min-width:200px;overflow:hidden}.dropdown-header{padding:12px;background-color:var(--bg-primary);border-bottom:1px solid var(--border-color)}.user-details{text-align:center}.user-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.user-email{font-size:11px;color:var(--text-secondary);margin-bottom:4px}.user-role{font-size:10px;color:var(--accent-blue);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.dropdown-divider{height:1px;background-color:var(--border-color)}.dropdown-actions{padding:8px 0}.dropdown-action{width:100%;display:flex;align-items:center;gap:8px;padding:8px 12px;background:none;border:none;cursor:pointer;font-size:13px;color:var(--text-primary);transition:background-color .2s ease;text-align:left}.dropdown-action:hover{background-color:var(--bg-primary)}.dropdown-action.admin-action:hover{background-color:#3b82f61a;color:var(--accent-blue)}.dropdown-action.logout-action:hover{background-color:#ef44441a;color:#ef4444}.action-icon{font-size:14px;width:16px;text-align:center}@media (max-width: 1400px){.rooms-footer{left:420px}}@media (max-width: 1200px){.rooms-footer{left:380px}}@media (max-width: 1000px){.rooms-footer{left:320px}}@media (max-width: 768px){.rooms-footer{left:0;height:100px}.planner-layout{height:calc(88vh - 100px)}}.canvas-container{flex:1;position:relative;background:#fff}.project-naming-modal{max-width:700px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-group{display:flex;flex-direction:column}.form-group label{font-size:14px;font-weight:600;color:#374151;margin-bottom:6px}.form-input{width:100%;padding:10px 12px;border:2px solid #e5e7eb;border-radius:6px;font-size:14px;transition:border-color .2s ease}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input::placeholder{color:#9ca3af}.input-help{font-size:12px;color:#6b7280;margin:4px 0 0}.current-project-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:12px;margin-bottom:16px}.current-project-info h4{margin:0 0 8px;color:#495057;font-size:14px;font-weight:600}.project-name{font-size:16px;font-weight:600;color:#212529;margin-bottom:4px}.project-status{font-size:12px}.status-active{color:#28a745;font-weight:600}.status-inactive{color:#6c757d}.session-item.active{background:#e3f2fd;border:1px solid #2196f3}.session-item.active .session-name{color:#1976d2;font-weight:600}.current-indicator{color:#1976d2;font-size:12px;font-weight:500}.session-action-btn:disabled{opacity:.5;cursor:not-allowed}.session-action-btn:disabled:hover{background:#f8f9fa;color:#6c757d}.rooms-count{font-size:12px;color:#6c757d;margin-top:4px}.sessions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.sessions-header h4{margin:0;color:#495057;font-size:14px;font-weight:600}.header-actions{display:flex;gap:8px;align-items:center}.refresh-btn{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;padding:4px 8px;font-size:12px;color:#6c757d;cursor:pointer;transition:all .2s ease}.refresh-btn:hover{background:#e9ecef;color:#495057;border-color:#adb5bd}.dropdown-toggle{background:#007bff;border:1px solid #007bff;border-radius:4px;padding:4px 8px;font-size:12px;color:#fff;cursor:pointer;transition:all .2s ease;min-width:24px;height:24px;display:flex;align-items:center;justify-content:center}.dropdown-toggle:hover{background:#0056b3;border-color:#0056b3}.projects-dropdown{background:#fff;border:1px solid #dee2e6;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;max-height:300px;overflow-y:auto;margin-top:8px}.projects-dropdown .sessions-list{padding:8px}.projects-dropdown .session-item{margin-bottom:8px;padding:8px;border-radius:6px;border:1px solid #e9ecef;background:#f8f9fa}.projects-dropdown .session-item:last-child{margin-bottom:0}.projects-dropdown .session-item.active{background:#e3f2fd;border-color:#2196f3}.projects-dropdown .session-item:hover{background:#e9ecef}.projects-dropdown .session-item.active:hover{background:#bbdefb}.customer-details-modal{max-width:500px;padding:0}.customer-details-modal .modal-header{padding:24px 24px 16px;border-bottom:1px solid #e5e7eb;background:linear-gradient(135deg,#48604d,#3c5041);color:#fff;border-radius:12px 12px 0 0}.customer-details-modal .modal-header h2{margin:0 0 8px;font-size:24px;font-weight:700}.customer-details-modal .modal-subtitle{margin:0;font-size:14px;opacity:.9;font-weight:400}.customer-details-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:6px;font-weight:600;color:#374151;font-size:14px}.required{color:#dc2626}.form-group input,.form-group textarea{width:100%;padding:12px;border:2px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#48604d;box-shadow:0 0 0 3px #48604d1a}.form-group input.error,.form-group textarea.error{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.form-group input:disabled,.form-group textarea:disabled{background-color:#f9fafb;color:#6b7280;cursor:not-allowed}.error-message{display:block;margin-top:4px;color:#dc2626;font-size:12px;font-weight:500}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.btn{padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s;min-width:100px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#e5e7eb;border-color:#9ca3af}.btn-primary{background:linear-gradient(135deg,#48604d,#3c5041);color:#fff;border:1px solid rgb(60,80,65)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#3c5041,#304035);border-color:#304035;transform:translateY(-1px);box-shadow:0 4px 12px #48604d4d}.success-modal{max-width:400px;text-align:center;padding:0}.success-modal .modal-header{display:flex;flex-direction:column;align-items:center;padding:32px 24px 16px;border-bottom:none;margin-bottom:0}.success-icon{display:flex;justify-content:center;align-items:center;width:80px;height:80px;border-radius:50%;margin:0 auto 16px}.success-icon.success{background-color:#d1fae5;color:#059669}.success-icon.error{background-color:#fee2e2;color:#dc2626}.success-modal .modal-title{font-size:24px;font-weight:700;margin:0 0 8px}.success-modal .modal-title.success{color:#059669}.success-modal .modal-title.error{color:#dc2626}.success-modal .modal-body{padding:0 24px 24px}.success-modal .modal-message{font-size:16px;color:#6b7280;margin:0;line-height:1.5}.success-modal .modal-actions{padding:0 24px 24px;border-top:none;margin-top:0;justify-content:center}.btn-success{background:linear-gradient(135deg,#059669,#047857);color:#fff;border:1px solid #047857}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,#047857,#065f46);border-color:#065f46;transform:translateY(-1px);box-shadow:0 4px 12px #0596694d}.btn-error{background:linear-gradient(135deg,#dc2626,#b91c1c);color:#fff;border:1px solid #B91C1C}.btn-error:hover:not(:disabled){background:linear-gradient(135deg,#b91c1c,#991b1b);border-color:#991b1b;transform:translateY(-1px);box-shadow:0 4px 12px #dc26264d}.analytics-drawer{position:fixed;top:0;right:0;width:500px;height:100vh;background:#fff;box-shadow:-2px 0 10px #0000001a;z-index:1000;overflow-y:auto}.drawer-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.drawer-title{font-size:18px;font-weight:600;color:#111827}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;padding:4px}.close-btn:hover{color:#374151}.drawer-content{padding:20px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:24px}.kpi-grid .metric-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px 12px;text-align:center;min-height:80px;display:flex;flex-direction:column;justify-content:center;overflow:hidden}.kpi-grid .metric-label{font-size:11px;color:#64748b;margin-bottom:6px;font-weight:500;line-height:1.2;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.kpi-grid .metric-value{font-size:16px;font-weight:600;color:#1e293b;line-height:1.1;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}@media (max-width: 768px){.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.kpi-grid .metric-card{padding:12px 8px;min-height:70px}.kpi-grid .metric-label{font-size:10px}.kpi-grid .metric-value{font-size:14px}}.analytics-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182780;z-index:1100;display:flex;align-items:flex-start;justify-content:center;padding:40px 24px}.analytics-panel{width:100%;max-width:1200px;background:#fff;border-radius:12px;box-shadow:0 20px 40px #0003;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.panel-title{font-size:18px;font-weight:600}.panel-content{padding:20px}.panel-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.panel-col{min-width:0}@media (max-width: 1024px){.panel-grid{grid-template-columns:1fr}}
