.toolbar.app-toolbar{position:relative;flex:0 0 auto;width:100%;min-height:56px;max-height:none;box-sizing:border-box;background:#2c3e50;color:#fff;display:flex;flex-wrap:nowrap;align-items:center;padding:0 clamp(12px,2vw,20px);gap:clamp(8px,1.2vw,20px);z-index:200;box-shadow:0 2px 8px #00000026;overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;-webkit-overflow-scrolling:touch}.toolbar.app-toolbar::-webkit-scrollbar{height:6px}.toolbar.app-toolbar::-webkit-scrollbar-thumb{background:#ffffff40;border-radius:3px}.toolbar h2{margin:0;font-size:clamp(16px,1.5vw,20px);font-weight:600;white-space:nowrap;flex-shrink:0}.upload-toolbar-btn{padding:clamp(8px,.9vw,10px) clamp(12px,1.5vw,20px);background:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:clamp(12px,1.05vw,14px);font-weight:500;transition:background .2s;flex-shrink:0}.upload-toolbar-btn:hover{background:#229954}.calibrate-btn{padding:clamp(8px,.9vw,10px) clamp(12px,1.5vw,20px);background:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:clamp(12px,1.05vw,14px);font-weight:500;transition:background .2s;flex-shrink:0}.calibrate-btn:hover:not(:disabled){background:#2980b9}.calibrate-btn:disabled{background:#95a5a6;cursor:not-allowed;opacity:.6}.templates-toolbar-btn{padding:clamp(8px,.9vw,10px) clamp(12px,1.5vw,20px);background:#8e44ad;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:clamp(12px,1.05vw,14px);font-weight:500;transition:background .2s;flex-shrink:0}.templates-toolbar-btn:hover{background:#7d3c98}.toolbar-utilities{display:flex;align-items:center;flex-wrap:nowrap;gap:clamp(6px,.8vw,10px);margin-left:4px;padding-left:clamp(10px,1.2vw,16px);border-left:1px solid rgba(255,255,255,.25);flex-shrink:0}.utility-btn{padding:clamp(7px,.85vw,10px) clamp(10px,1.1vw,16px);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:clamp(11px,1vw,14px);font-weight:500;transition:background .2s,opacity .2s;flex-shrink:0}.utility-btn-undo,.utility-btn-redo{background:#566573}.utility-btn-undo:hover:not(:disabled),.utility-btn-redo:hover:not(:disabled){background:#4a5f6f}.utility-btn-clear{background:#c0392b}.utility-btn-clear:hover:not(:disabled){background:#a93226}.utility-btn-export{background:#8e44ad}.utility-btn-export:hover:not(:disabled){background:#7d3c98}.utility-btn-save{background:#16a085}.utility-btn-save:hover:not(:disabled){background:#138d75}.utility-btn-load{background:#2874a6}.utility-btn-load:hover:not(:disabled){background:#21618c}.utility-btn:disabled{background:#5d6d7e;cursor:not-allowed;opacity:.65}.calibration-info{font-size:clamp(11px,1vw,14px);padding:clamp(5px,.6vw,8px) clamp(8px,1vw,15px);background:#ffffff1a;border-radius:4px;white-space:nowrap;flex-shrink:0}@media (max-width: 1320px){.toolbar.app-toolbar{gap:8px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:30px;border-radius:8px;box-shadow:0 8px 24px #0003;width:400px;max-width:90%}.modal-content h2{margin:0 0 10px;color:#2c3e50}.modal-content p{margin:0 0 20px;color:#555;font-size:14px}.input-group{display:flex;gap:15px;margin-bottom:20px}.input-field{flex:1;display:flex;flex-direction:column}.input-field label{font-size:13px;font-weight:500;margin-bottom:5px;color:#555}.input-field input{padding:12px;border:1px solid #ddd;border-radius:4px;font-size:16px}.modal-buttons{display:flex;gap:10px}.cancel-btn,.submit-btn{flex:1;padding:12px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.cancel-btn{background:#95a5a6;color:#fff}.cancel-btn:hover{background:#7f8c8d}.submit-btn{background:#3498db;color:#fff}.submit-btn:hover{background:#2980b9}.hint{margin-top:15px;padding:12px;background:#e8f4f8;border-left:3px solid #3498db;font-size:13px;color:#555}.hint strong{color:#2c3e50}.clear-confirm-btn{flex:1;padding:12px;border:none;border-radius:4px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;background:#e74c3c;color:#fff}.clear-confirm-btn:hover{background:#c0392b}.furniture-panel{height:100%;width:100%;max-width:min(330px,100%);background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:50;display:flex;flex-direction:column;min-height:0;overflow:hidden}.furniture-panel__main{flex:1;min-height:0;overflow-x:hidden;overflow-y:auto}.panel-section--presets{flex:0 1 auto;min-height:0}.panel-section{padding:20px;border-bottom:1px solid #e0e0e0}.furniture-panel__main .panel-section:last-child{border-bottom:none}.panel-section h3{margin:0 0 15px;font-size:16px;color:#2c3e50}.furniture-panel__next-step{background:linear-gradient(135deg,#e8f4fc,#f0f9ff);border:1px solid rgba(59,130,246,.22);border-radius:12px;box-shadow:0 2px 8px #0f172a0f}.furniture-panel__next-step-title{margin:0 0 14px;font-size:15px;line-height:1.35;color:#1e3a5f}.furniture-panel__calibrate-cta{width:100%;padding:11px 16px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;color:#fff;background:#2563eb;box-shadow:0 2px 6px #2563eb59;transition:background .2s,box-shadow .2s}.furniture-panel__calibrate-cta:hover{background:#1d4ed8;box-shadow:0 3px 10px #2563eb66}.furniture-panel__calibrate-cta:focus-visible{outline:2px solid #2563eb;outline-offset:2px}.furniture-panel__uncalibrated-furniture{opacity:.5}.furniture-panel__uncalibrated-furniture,.furniture-panel__uncalibrated-furniture *{pointer-events:none}.presets-scroll{max-height:min(280px,42vh);overflow-y:auto;overflow-x:hidden;padding-right:4px;margin-right:-4px;scrollbar-gutter:stable}.presets-scroll::-webkit-scrollbar{width:8px}.presets-scroll::-webkit-scrollbar-track{background:#f0f2f4;border-radius:4px}.presets-scroll::-webkit-scrollbar-thumb{background:#bdc3c7;border-radius:4px}.presets-scroll::-webkit-scrollbar-thumb:hover{background:#95a5a6}.toggle-form-btn{width:100%;padding:10px;background:#27ae60;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background .2s}.toggle-form-btn:hover:not(:disabled){background:#229954}.toggle-form-btn:disabled{background:#95a5a6;cursor:not-allowed}.add-form{margin-top:15px;display:flex;flex-direction:column;gap:10px}.add-form input[type=text]{padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.dimension-row{display:flex;align-items:center;gap:8px}.dimension-row label{min-width:50px;font-size:13px;font-weight:500;color:#555}.dimension-row input{flex:1;padding:8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.add-btn,.update-btn,.delete-btn{padding:10px;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background .2s}.add-btn,.update-btn{background:#3498db;color:#fff}.add-btn:hover,.update-btn:hover{background:#2980b9}.delete-btn{background:#e74c3c;color:#fff;margin-top:8px}.delete-btn:hover{background:#c0392b}.selected-section{background:#f8f9fa}.furniture-panel .ad-slot--sidebar{flex-shrink:0;margin-top:auto;margin-bottom:8px}@media (max-height: 820px) and (min-width: 901px){.presets-scroll{max-height:min(200px,32vh)}.furniture-panel .ad-slot--sidebar{width:min(300px,100%);height:min(220px,28vh);max-height:min(220px,28vh)}}@media (max-width: 1100px) and (min-width: 901px){.panel-section{padding:14px 16px}}.color-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.color-row label{font-size:13px;font-weight:500;color:#555;min-width:44px}.color-row input[type=color]{width:48px;height:32px;padding:0;border:1px solid #bdc3c7;border-radius:4px;cursor:pointer;background:transparent}.color-row--selected{margin-bottom:14px}.preset-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.preset-item-card{display:flex;align-items:stretch;gap:8px;min-width:0;padding:8px;border-radius:12px;border:1px solid rgba(15,23,42,.12);box-shadow:0 1px 3px #0f172a14}.preset-item-card--with-delete{align-items:center}.preset-item-place{flex:1;min-width:0;margin:0;padding:0;border:none;background:transparent;cursor:pointer;text-align:left;font:inherit;color:inherit;border-radius:8px;transition:opacity .15s ease}.preset-item-place:hover:not(:disabled){opacity:.92}.preset-item-place:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.preset-item-place:disabled{opacity:.55;cursor:not-allowed}.preset-item-bubble{width:100%;box-sizing:border-box;background-color:#fff;border-radius:8px;padding:8px 12px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;box-shadow:inset 0 0 0 1px #0f172a0f}.preset-name{font-size:14px;font-weight:600;color:#0f172a;line-height:1.25}.custom-presets-empty{margin:0;padding:8px 4px 4px;font-size:13px;color:#64748b;line-height:1.4}.custom-preset-delete{flex-shrink:0;align-self:stretch;min-width:32px;padding:0 4px;border:1px solid rgba(255,255,255,.65);border-radius:8px;background:#ffffffeb;color:#64748b;font-size:18px;line-height:1;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.custom-preset-delete:hover{background:#fee2e2f2;border-color:#fca5a5e6;color:#b91c1c}.custom-preset-delete:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.preset-dims{font-size:12px;font-weight:500;color:#475569;line-height:1.3}@media (max-width: 1100px){.preset-name{font-size:13px}.preset-dims{font-size:11px}}.selected-color-field{display:flex;align-items:center;gap:10px;margin-bottom:14px}.selected-swatch-wrap{position:relative;flex-shrink:0;width:36px;height:36px;border-radius:6px;cursor:pointer}.selected-color-native{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:1}.selected-color-swatch{display:block;width:100%;height:100%;border-radius:6px;border:1px solid rgba(15,23,42,.12);box-shadow:inset 0 0 0 1px #fff3;pointer-events:none}.selected-hex-input{flex:1;min-width:0;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:13px;font-weight:500;letter-spacing:.02em;padding:8px 10px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#0f172a}.selected-hex-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.templates-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1100;padding:24px;box-sizing:border-box}.templates-modal{background:#fff;border-radius:10px;box-shadow:0 12px 40px #0003;width:100%;max-width:720px;max-height:min(90vh,640px);overflow:auto;padding:28px 28px 32px}.templates-modal__header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:8px}.templates-modal__header h2{margin:0;font-size:1.35rem;font-weight:600;color:#2c3e50}.templates-modal__close{flex-shrink:0;width:36px;height:36px;border:none;border-radius:6px;background:#ecf0f1;color:#2c3e50;font-size:22px;line-height:1;cursor:pointer;transition:background .15s ease}.templates-modal__close:hover{background:#dfe6e9}.templates-modal__lead{margin:0 0 22px;font-size:14px;color:#546e7a;line-height:1.45}.templates-modal__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.template-card{display:flex;flex-direction:column;align-items:flex-start;text-align:left;gap:8px;padding:18px 16px;border:2px solid #e0e6ea;border-radius:8px;background:#fafcfd;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.template-card:hover{border-color:#3498db;background:#f4f9fc;box-shadow:0 4px 14px #3498db26}.template-card:focus-visible{outline:2px solid #3498db;outline-offset:2px}.template-card__title{font-size:15px;font-weight:600;color:#2c3e50}.template-card__desc{font-size:13px;color:#607d8b;line-height:1.4}.app{width:100%;height:100vh;height:100dvh;position:relative;overflow:hidden;display:flex;flex-direction:column}.app-shell{display:flex;flex-direction:column;flex:1;min-height:0;width:100%}.app-main{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,330px);grid-template-rows:minmax(0,1fr);flex:1;min-height:0;width:100%;gap:0 10px;padding:0 10px 10px;box-sizing:border-box}@media (min-width: 901px){.app-main{overflow:hidden}}.canvas-column{display:flex;flex-direction:column;min-width:0;min-height:0;position:relative;overflow:hidden}.canvas-host{flex:1;min-height:0;position:relative;overflow:hidden;background:#fff;touch-action:none;-ms-touch-action:none;user-select:none;-webkit-user-select:none;overscroll-behavior:none}.canvas-host .konvajs-content{touch-action:none;-ms-touch-action:none;border-radius:0}.canvas-host--pan-mode{box-shadow:inset 0 0 0 2px #3b82f68c}.calibration-toast{position:absolute;top:20px;left:20px;z-index:50;display:flex;align-items:center;gap:10px;max-width:min(380px,calc(100% - 40px));padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;line-height:1.35;color:#065f46;background:#fff;box-shadow:0 8px 24px #0f172a1f,0 2px 8px #0f172a14;border:1px solid rgba(16,185,129,.25);pointer-events:none}.calibration-toast__icon{flex-shrink:0;display:flex;color:#059669}.canvas-pan-mode-toast{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:35;max-width:min(420px,calc(100% - 24px));padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;line-height:1.35;color:#0f172a;background:#fffffff5;border:1px solid rgba(59,130,246,.35);box-shadow:0 4px 16px #0f172a1f,0 1px 3px #0f172a14;pointer-events:none;text-align:center}.canvas-map-controls{position:absolute;right:12px;bottom:12px;z-index:30;display:flex;flex-direction:column;align-items:flex-end;gap:8px;pointer-events:none}.canvas-map-controls>*{pointer-events:auto}.canvas-map-controls__lock{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid rgba(15,23,42,.08);border-radius:10px;background:#fff;color:#374151;box-shadow:0 2px 8px #0f172a1f,0 1px 2px #0f172a0f;cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease,border-color .15s ease}.canvas-map-controls__lock:hover{background:#f8fafc;color:#111827;box-shadow:0 4px 12px #0f172a24,0 2px 4px #0f172a0f}.canvas-map-controls__lock:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.canvas-map-controls__lock[aria-pressed=true]{border-color:#e67e228c;background:#fef5e7;color:#9a3412}.canvas-map-controls__recenter{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid rgba(15,23,42,.08);border-radius:10px;background:#fff;color:#374151;box-shadow:0 2px 8px #0f172a1f,0 1px 2px #0f172a0f;cursor:pointer;transition:background .15s ease,color .15s ease,box-shadow .15s ease}.canvas-map-controls__recenter:hover{background:#f8fafc;color:#111827;box-shadow:0 4px 12px #0f172a24,0 2px 4px #0f172a0f}.canvas-map-controls__recenter:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.canvas-map-controls__zoom-pill{display:flex;flex-direction:column;align-items:stretch;width:40px;border-radius:20px;overflow:hidden;border:1px solid rgba(15,23,42,.08);background:#fff;box-shadow:0 2px 8px #0f172a1f,0 1px 2px #0f172a0f}.canvas-map-controls__zoom-btn{display:flex;align-items:center;justify-content:center;min-height:38px;padding:0;border:none;background:#fff;color:#374151;font-size:22px;font-weight:500;line-height:1;cursor:pointer;transition:background .15s ease,color .15s ease}.canvas-map-controls__zoom-btn:hover{background:#f8fafc;color:#111827}.canvas-map-controls__zoom-btn:focus-visible{outline:2px solid #3b82f6;outline-offset:-2px;position:relative;z-index:1}.canvas-map-controls__zoom-divider{height:1px;margin:0;background:#e5e7eb;flex-shrink:0}.sidebar-column{min-width:0;max-width:330px;width:100%;min-height:0;display:flex;flex-direction:column;overflow:hidden;justify-self:end}.ad-slot{display:flex;align-items:center;justify-content:center;background:#e8e8e8;color:#7f8c8d;font-size:13px;font-weight:500;letter-spacing:.02em;box-sizing:border-box;flex-shrink:0}.ad-slot--leaderboard{width:100%;max-width:728px;margin:6px auto 0;min-height:50px;max-height:90px;height:clamp(50px,12vh,90px);border:1px dashed #ccc;border-radius:4px}.ad-slot--sidebar{width:300px;max-width:100%;height:250px;max-height:250px;margin:12px auto 0;border:1px dashed #ccc;border-radius:4px}@media (max-width: 1280px) and (min-width: 901px){.app-main{grid-template-columns:minmax(0,1fr) minmax(252px,300px);gap:0 8px;padding:0 8px 8px}.sidebar-column{max-width:300px}}@media (max-width: 1100px) and (min-width: 901px){.app-main{grid-template-columns:minmax(0,1fr) minmax(240px,280px);padding:0 6px 8px;gap:0 6px}.sidebar-column{max-width:280px}}@media (max-height: 820px) and (min-width: 901px){.ad-slot--leaderboard{height:clamp(50px,10vh,72px);max-height:72px;margin-top:4px}}@media (max-width: 900px){.app-main{grid-template-columns:1fr;grid-template-rows:auto auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.sidebar-column{max-width:none;width:100%;justify-self:stretch;min-height:0;max-height:none}.canvas-column{min-height:min(50vh,420px)}.canvas-host{min-height:240px}.ad-slot--leaderboard{max-width:100%;height:auto;min-height:50px;max-height:90px}}.konvajs-content{background:#fff}.drop-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#3498dbe6;display:flex;align-items:center;justify-content:center;z-index:999;pointer-events:none}.drop-message{background:#fff;padding:40px 60px;border-radius:12px;box-shadow:0 8px 32px #0003}.drop-message p{font-size:24px;font-weight:600;color:#2c3e50;margin:0}.no-floorplan{position:absolute;top:0;right:0;bottom:0;left:0;background:#ecf0f1;z-index:40}.upload-prompt{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-sizing:border-box;width:min(500px,calc(100% - 32px));text-align:center;padding:40px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a;max-width:500px}.upload-prompt h2{margin:0 0 15px;color:#2c3e50;font-size:24px}.upload-prompt p{margin:0 0 30px;color:#7f8c8d;font-size:16px}.upload-hint{margin:-18px 0 24px;font-size:14px;color:#546e7a;line-height:1.5}.upload-btn{padding:15px 30px;background:#3498db;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.upload-btn:hover{background:#2980b9}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5}#root{width:100vw;height:100vh;overflow:hidden}
