:root{color-scheme:light;font-family:Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,sans-serif;color:#1f2933;background:#f6f7f9}*{box-sizing:border-box}body{margin:0;-webkit-user-select:none;user-select:none;overflow:hidden}.app{padding:24px}.app__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.app__header-title{display:grid;gap:4px}.app__header h1{margin:0;font-size:24px}.app__header-layout{margin:0;font-size:13px;color:#64748b}.app__header-actions{display:flex;gap:12px;align-items:center}.app__header-actions .panel__section{margin:0;padding:0;border:none}.app__header-actions .panel__section h2{display:none}.app__header-actions .actions{grid-auto-flow:column;grid-auto-columns:max-content;align-items:center}.app__columns{display:grid;grid-template-columns:minmax(220px,260px) minmax(0,1fr) minmax(260px,320px);gap:24px;align-items:stretch}.panel{background:#fff;border-radius:12px;padding:16px;box-shadow:0 8px 24px #0f172a14}.panel--list,.panel--editor{display:flex;flex-direction:column;max-height:calc(100vh - 96px);height:calc(100vh - 96px);overflow:hidden}.panel--list .panel__section--list{flex:1;overflow:auto}.panel--list .panel__section--actions{border-bottom:1px solid #e5e7eb;padding-bottom:12px;display:grid;gap:8px}.furniture-add-row{display:grid;gap:8px}.furniture-add-row .btn{margin-top:0}.fixture-add-row{display:grid;gap:6px;padding:8px;border:1px dashed #e2e8f0;border-radius:10px;background:#f8fafc}.fixture-add-row__label{font-size:12px;font-weight:600;color:#334155}.fixture-add-row__buttons{display:flex;flex-wrap:wrap;gap:6px}.fixture-list{margin:8px 0 4px;padding:8px;border:1px dashed #e2e8f0;border-radius:10px;background:#f8fafc;display:grid;gap:6px}.fixture-list__title{font-size:12px;font-weight:600;color:#334155}.fixture-list__items{list-style:none;padding:0;margin:0;display:grid;gap:4px}.fixture-list__item{font-size:12px;color:#475569}.fixture-list__button{border:none;background:transparent;padding:0;font-size:12px;color:#334155;cursor:pointer}.fixture-list__button:hover{color:#0f172a}.fixture-type-label{font-size:13px;font-weight:600;color:#1f2933}.panel--editor{overflow:auto}.panel__section+.panel__section{margin-top:16px;padding-top:12px;border-top:1px solid #e5e7eb}.panel__section h2{margin:0 0 12px;font-size:16px}.form-grid{display:grid;gap:8px}.form-grid label{display:grid;gap:4px;font-size:13px}.template-select{background:#eef2ff;border:1px solid #c7d2fe;border-radius:10px;padding:8px 10px;font-weight:600;color:#1e1b4b}.template-select select{border-color:#818cf8;background:#fff;font-weight:600}.template-select--modal{padding:12px;border-radius:12px;box-shadow:0 8px 20px #1e1b4b1f}.object-list{list-style:none;margin:0;padding:0;display:grid;gap:8px}.object-list__item{display:grid;gap:6px}.object-list__group{background:transparent;border:none;padding:0}.object-list__summary{list-style:none;cursor:pointer;padding:6px 4px;font-size:13px;font-weight:600;display:grid;grid-template-columns:20px 1fr;gap:8px;align-items:center}.object-list__summary::-webkit-details-marker{display:none}.object-list__summary.is-selected{color:#0f172a}.object-list__children{list-style:none;margin:0;padding-left:28px;display:grid;gap:6px}.object-list__child{display:grid}.object-list__button{text-align:left;border:none;background:transparent;padding:4px 0;font-size:13px;cursor:pointer}.object-list__button--child{color:#475569}.object-list__button.is-selected{color:#0f172a;font-weight:600}.object-list__toggle{width:20px;height:20px;border-radius:6px;border:1px solid #e2e8f0;background:#fff;position:relative;box-shadow:0 2px 6px #0f172a14}.object-list__group[open] .object-list__toggle:before{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border-radius:4px;background:#0f172a}.object-list__group:not([open]) .object-list__toggle:before{content:"";position:absolute;top:8px;right:6px;bottom:8px;left:6px;border-radius:2px;background:#94a3b8}.inline-input{width:100%;border-radius:6px;border:1px solid #cbd5e1;padding:4px 6px;font-size:13px}.inline-input--child{background:#fff}.range-field{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}.editor-group{border-top:1px solid #e5e7eb;padding-top:10px}.editor-group--open{border-top:none;padding-top:0}.editor-group summary{cursor:pointer;font-weight:600;font-size:14px;list-style:none;margin-bottom:8px}.editor-group summary::-webkit-details-marker{display:none}.object-list__empty{font-size:12px;color:#9ca3af}input[type=number],input[type=text],input[type=color],input[type=file],input:not([type]),select{padding:6px 8px;border-radius:6px;border:1px solid #d1d5db;font-size:14px}input[type=range]{width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;margin-top:10px;padding:8px 12px;border-radius:8px;border:none;background:#1f2933;color:#fff;font-size:14px;cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--ghost{background:#f1f5f9;color:#1f2933;border:1px solid #cbd5e1}.btn--small{padding:6px 10px;font-size:12px;margin-top:0}.actions{display:grid;gap:8px}.editor-actions{margin-top:8px}.fixture-row{display:grid;gap:8px;padding:8px;border:1px dashed #e2e8f0;border-radius:8px;background:#f8fafc}.muted{color:#6b7280;font-size:13px}.canvas-wrap{width:100%;height:100%;overflow:hidden;flex:1;min-width:0;min-height:0;position:relative;touch-action:none}.canvas-wrap--drag{overflow-x:auto;overflow-y:auto}.canvas-toolbar{position:absolute;top:12px;right:12px;z-index:2;pointer-events:none;width:max-content}.canvas-toolbar .btn{pointer-events:auto}.panel--canvas{display:flex;padding:0;min-height:calc(100vh - 96px);height:calc(100vh - 96px);overflow:hidden}.mobile-drawer{display:none}.mobile-drawer__tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mobile-drawer__tab{border:none;border-radius:10px;padding:8px 12px;background:#f1f5f9;font-size:13px;font-weight:600;color:#334155;cursor:pointer}.mobile-drawer__tab.is-active{background:#0f172a;color:#fff}.mobile-drawer__content{overflow:hidden;display:grid;gap:12px}@media (max-width: 900px){:root{--mobile-drawer-height: 32vh}body{overflow:hidden}.app{padding:16px;height:100vh;display:flex;flex-direction:column}.app__header{flex-direction:column;align-items:flex-start;gap:12px}.app__header-actions{flex-wrap:wrap}.app__columns{grid-template-columns:1fr;gap:16px;flex:1;min-height:0}.panel--list,.panel--editor{display:none}.panel--canvas{height:100%;min-height:0}.canvas-wrap--drag{overflow:hidden}.mobile-drawer{position:relative;height:var(--mobile-drawer-height);display:grid;grid-template-rows:auto 1fr;gap:12px;padding:12px 0 0;border-top:1px solid #e5e7eb;background:transparent;overflow:hidden}.mobile-drawer__tabs{padding:0 4px}.mobile-drawer__content{overflow:auto;min-height:0;padding-bottom:12px}.mobile-drawer__content .panel__section{padding-left:4px;padding-right:4px}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;display:grid;place-items:center;z-index:20;padding:24px}.modal{width:min(720px,100%);max-height:min(80vh,760px);overflow:auto;background:#fff;border-radius:16px;padding:20px;box-shadow:0 24px 64px #0f172a40}.modal__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.modal__header h2{margin:0;font-size:18px}.modal__tabs{display:flex;gap:8px;border-bottom:1px solid #e5e7eb;margin-bottom:12px;padding-bottom:8px;flex-wrap:wrap}.modal__tab{border:1px solid #cbd5e1;background:#f8fafc;color:#0f172a;padding:6px 12px;border-radius:999px;font-size:13px;cursor:pointer}.modal__tab.is-active{background:#0f172a;color:#fff;border-color:#0f172a}.modal__body .panel__section{padding-top:0;border-top:none}.auth-card{display:grid;gap:12px}.auth-mode-toggle{display:flex;gap:8px;flex-wrap:wrap}.auth-error{margin:0;color:#b91c1c;font-size:13px}.cloud-save{margin-top:20px;padding-top:16px;border-top:1px solid #e5e7eb;display:grid;gap:12px}.cloud-save__header h4,.saved-layouts__header h4{margin:0;font-size:15px}.saved-layouts{display:grid;gap:10px}.saved-layouts__header{display:flex;justify-content:space-between;align-items:center;gap:12px}.saved-layouts__list{list-style:none;padding:0;margin:0;display:grid;gap:8px}.saved-layouts__item{border:1px solid #dbe3ee;border-radius:10px;padding:10px 12px;display:grid;gap:10px;background:#f8fafc}.saved-layouts__item.is-selected{border-color:#0f172a;background:#eef2ff}.saved-layouts__meta{display:grid;gap:4px}.saved-layouts__actions{display:flex;flex-wrap:wrap;gap:8px}.export-modal .modal{width:min(980px,100%);max-height:min(90vh,880px);position:relative}.export-preview{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:16px;align-items:start}.export-preview__page{background:#f1f5f9;border-radius:12px;padding:12px;display:grid;place-items:center;max-height:70vh}.export-preview__page svg{width:100%;height:100%;background:#fff;border-radius:6px;box-shadow:0 10px 24px #0f172a26}.export-preview__actions{display:grid;gap:12px}.export-edit-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a59;display:grid;place-items:center;padding:16px}.export-edit{width:min(420px,100%);background:#fff;border-radius:12px;padding:16px;display:grid;gap:10px;box-shadow:0 16px 36px #0f172a33}.export-edit h3{margin:0;font-size:16px}.export-edit__checkbox{display:flex;align-items:center;gap:8px}.export-edit__actions{display:flex;justify-content:flex-end;gap:8px}@media (max-width: 900px){.export-preview{grid-template-columns:1fr}.export-preview__page{max-height:55vh}}
