:root{color-scheme:dark;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;--bg: #121416;--panel: #1d2226;--panel-soft: #242b30;--line: #394349;--line-strong: #5c6a72;--text: #edf2f4;--muted: #9baab2;--accent: #4fc3b1;--accent-strong: #76d4c7;--warn: #e1aa51;--danger: #d86f62;--floor: #586a62;--door: #3ba8d9;--arch: #68717a}*{box-sizing:border-box}html,body,#app{width:100%;height:100%;margin:0}body{background:var(--bg);color:var(--text);overflow:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer}#app{display:grid;grid-template-columns:minmax(280px,320px) minmax(420px,1fr) minmax(310px,360px)}.panel{position:relative;z-index:4;overflow-y:auto;background:var(--panel);border-color:var(--line)}.panel-left{border-right:1px solid var(--line)}.panel-right{border-left:1px solid var(--line)}.brand{display:grid;grid-template-columns:46px minmax(0,1fr);gap:12px;align-items:start;padding:18px;border-bottom:1px solid var(--line)}.brand-mark{display:grid;place-items:center;width:46px;height:46px;flex:0 0 46px;border:1px solid rgba(118,212,199,.34);border-radius:8px;background:linear-gradient(135deg,#4fc3b138,#e1aa5124),#14191c;box-shadow:inset 0 0 0 1px #ffffff0f,0 10px 22px #0003}.brand-mark svg{width:38px;height:38px}.logo-floor{fill:#e1aa514d}.logo-van{fill:#263238;stroke:#76d4c7;stroke-width:2;stroke-linejoin:round}.logo-window{fill:#8fd7ef94;stroke:#d8f7ffcc;stroke-width:1.3;stroke-linejoin:round}.logo-grid{fill:none;stroke:#fff3af8c;stroke-width:1.2;stroke-linecap:round}.logo-wheel{fill:#101416;stroke:#e1aa51;stroke-width:1.8}h1,h2,p{margin:0}h1{font-size:1.05rem;line-height:1.2}.hint,.dim-list,.section-heading span{color:var(--muted)}.brand input{width:100%;min-width:0;margin-top:3px;border:1px solid transparent;border-radius:6px;padding:4px 6px;background:#14181b;color:var(--text);font-size:.78rem;outline:none}.brand input::placeholder{color:var(--muted)}.brand input:focus{border-color:var(--accent)}.share-link-field{display:grid;gap:4px;margin-top:8px;color:var(--muted);font-size:.7rem}.share-link-control{display:grid;grid-template-columns:minmax(0,1fr) 30px;gap:6px;align-items:center}.share-link-field input{height:30px;font-size:.72rem}.share-link-field input[readonly]{cursor:text}.brand-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;margin-top:8px}.saved-designs-panel{margin-top:8px;border:1px solid var(--line);border-radius:7px;background:#151a1d;box-shadow:0 16px 30px #00000038}.saved-designs-panel[hidden]{display:none}.saved-designs-heading{border-bottom:1px solid var(--line);padding:8px 10px;color:#dce8eb;font-size:.72rem;font-weight:700;text-transform:uppercase}.saved-designs-list{display:grid;max-height:220px;overflow-y:auto}.saved-design-row{display:grid;grid-template-columns:minmax(0,1fr) 34px;border-bottom:1px solid rgba(57,67,73,.72)}.saved-design-row:last-child{border-bottom:0}.saved-design-item{display:grid;gap:2px;width:100%;border:0;padding:9px 10px;background:transparent;color:var(--text);text-align:left}.saved-design-delete{display:grid;place-items:center;width:34px;border:0;border-left:1px solid rgba(57,67,73,.72);padding:0;background:transparent;color:var(--muted);font-size:.9rem}.saved-design-delete svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8}.saved-design-item:hover,.saved-design-delete:hover{background:#20272c}.saved-design-delete:hover{color:#ffd1cc}.saved-design-item strong,.saved-design-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-design-item strong{font-size:.78rem}.saved-design-item span,.saved-designs-empty{color:var(--muted);font-size:.7rem}.saved-designs-empty{padding:10px}.copy-link-button{width:30px;height:30px;color:var(--text);font-size:1rem}.tool-button.compact,.primary-button.compact{min-height:30px;justify-content:center;padding:0 9px;font-size:.76rem}.share-status{margin-top:7px;color:var(--muted);font-size:.72rem;line-height:1.35}.control-section{padding:16px 18px;border-bottom:1px solid var(--line)}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.section-heading h2{font-size:.8rem;letter-spacing:0;text-transform:uppercase;color:#dce8eb}.section-heading span{font-size:.74rem}.field{display:grid;gap:6px;margin-bottom:12px;font-size:.78rem;color:var(--muted)}.field input,.field select,.field textarea{width:100%;min-width:0;border:1px solid var(--line);border-radius:7px;background:#14181b;color:var(--text);outline:none}.field input,.field select{height:36px;padding:0 10px}.field textarea{min-height:90px;resize:vertical;padding:9px 10px;line-height:1.35;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.76rem}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 2px #4fc3b12e}.field input:disabled,.field select:disabled,.field textarea:disabled{cursor:not-allowed;opacity:.58}.compact-field{margin:8px 0 0}.colour-field{grid-template-columns:1fr 54px 36px;align-items:center}.colour-field input{height:36px;padding:3px}.icon-button{width:36px;height:36px;border:1px solid var(--line);border-radius:7px;padding:0;color:var(--accent-strong);background:var(--panel-soft)}.icon-button:hover,.icon-button.active{border-color:var(--accent);background:#26343a}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.annotation-field textarea{min-height:104px}.toggle{display:flex;align-items:center;gap:10px;min-height:32px;color:#d5dee2;font-size:.86rem}.toggle input{width:18px;height:18px;accent-color:var(--accent)}.toggle-row{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.button-row{display:flex;gap:8px;flex-wrap:wrap}.tool-button,.primary-button,.danger-button{min-height:36px;border:1px solid var(--line);border-radius:7px;padding:0 12px;color:var(--text);background:var(--panel-soft)}.tool-button{display:inline-flex;align-items:center;gap:7px}.tool-button:hover,.dimension-disclosure summary:hover{border-color:var(--line-strong);background:#2a3238}.primary-button{border-color:#4fc3b199;background:#257f73}.primary-button:hover{background:#2e9487}.danger-button{border-color:#d86f628c;background:#462421}.danger-button:hover{background:#5b2a26}button:disabled{cursor:not-allowed;opacity:.46}.icon{width:16px;text-align:center;color:var(--accent-strong)}.dimension-disclosure{margin-top:4px}.dimension-disclosure summary,.opening-disclosure summary,.furniture-disclosure summary{display:flex;align-items:center;justify-content:space-between;min-height:36px;border:1px solid var(--line);border-radius:7px;padding:0 10px;color:var(--text);background:var(--panel-soft);cursor:pointer;list-style:none}.dimension-disclosure summary::-webkit-details-marker,.opening-disclosure summary::-webkit-details-marker,.furniture-disclosure summary::-webkit-details-marker{display:none}.dimension-disclosure summary:after,.opening-disclosure summary:after,.furniture-disclosure summary:after{content:"▾";color:var(--accent-strong)}.dimension-disclosure[open] summary,.opening-disclosure[open] summary,.furniture-disclosure[open] summary{border-color:var(--line-strong);border-bottom-right-radius:0;border-bottom-left-radius:0}.dimension-disclosure[open] summary:after,.opening-disclosure[open] summary:after,.furniture-disclosure[open] summary:after{transform:rotate(180deg)}.disclosure-content{display:grid;gap:4px;padding:10px;border:1px solid var(--line);border-top:0;border-bottom-right-radius:7px;border-bottom-left-radius:7px;background:#151a1d}.furniture-disclosure summary{display:grid;grid-template-columns:minmax(0,1fr) auto 14px;gap:10px;margin:0;font-size:.8rem;text-transform:uppercase}.furniture-disclosure summary span:first-child{color:#dce8eb;font-weight:700}.furniture-disclosure summary span:nth-child(2){color:var(--muted);font-size:.74rem;text-transform:none}.furniture-disclosure summary:after{justify-self:end}.dim-list{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:6px 10px;margin:0;padding:10px;border:1px solid var(--line);border-top:0;border-bottom-right-radius:7px;border-bottom-left-radius:7px;background:#151a1d;font-size:.8rem}.dim-list dt{min-width:0}.dim-list dd{margin:0;color:var(--text);font-variant-numeric:tabular-nums;overflow-wrap:anywhere}.dim-list input{width:100%;min-width:0;height:28px;border:1px solid var(--line);border-radius:6px;padding:0 7px;background:#111518;color:var(--text);font:inherit;font-variant-numeric:tabular-nums}.hint{margin-top:10px;font-size:.78rem;line-height:1.45}.viewport-shell{position:relative;min-width:0;background:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),radial-gradient(circle at 40% 24%,#283137 0,#15191c 45%,#0f1113);background-size:42px 42px,42px 42px,auto}#viewport{width:100%;height:100%}.viewport-error{display:grid;width:100%;height:100%;place-items:center;padding:24px;color:#f4f1e8;text-align:center;font-size:.95rem;line-height:1.45}#viewport canvas{display:block;width:100%;height:100%;touch-action:none}.annotation-overlay{position:absolute;inset:0;z-index:2;overflow:hidden;pointer-events:none}.annotation-lines{position:absolute;inset:0;width:100%;height:100%}.annotation-line{stroke:#76d4c7d1;stroke-width:1.5;vector-effect:non-scaling-stroke}.annotation-card{position:absolute;width:min(240px,calc(100% - 24px));border:1px solid rgba(118,212,199,.68);border-radius:7px;padding:8px 10px 9px 16px;background:#121416e6;color:var(--text);box-shadow:0 12px 26px #0000003d;transform:translate3d(var(--annotation-x, 12px),var(--annotation-y, 88px),0)}.annotation-card:before{position:absolute;top:8px;bottom:8px;left:7px;width:4px;border-radius:2px;background:var(--annotation-color, var(--accent));content:""}.annotation-card strong,.annotation-card span{display:block}.annotation-card strong{overflow:hidden;color:#f4f8f9;font-size:.78rem;line-height:1.2;text-overflow:ellipsis;white-space:nowrap}.annotation-card span{display:-webkit-box;overflow:hidden;margin-top:3px;color:#c5d2d7;font-size:.72rem;line-height:1.32;-webkit-box-orient:vertical;-webkit-line-clamp:5;white-space:pre-line}.viewport-toolbar{position:absolute;z-index:6;top:14px;left:14px;display:flex;gap:14px;align-items:center;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:8px 10px;background:#111518d1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 14px 28px #0000002e}.viewport-toolbar .toggle{min-height:26px;font-size:.78rem}.viewport-toolbar .toggle input{width:16px;height:16px}.support-banner{position:absolute;z-index:7;top:14px;right:14px;display:flex;max-width:min(440px,calc(100% - 260px));align-items:center;gap:10px;border:1px solid rgba(225,170,81,.65);border-radius:8px;padding:8px 10px 8px 12px;background:#493216eb;box-shadow:0 14px 28px #0003}.support-banner[hidden]{display:none}.support-banner a{color:#ffe4af;font-size:.8rem;font-weight:700;text-decoration:underline}.support-banner a:hover{text-decoration:underline}.support-banner button{width:24px;height:24px;flex:0 0 24px;border:1px solid rgba(255,228,175,.55);border-radius:6px;padding:0;background:#ffe4af1f;color:#fff1d2;font:inherit;font-weight:700;line-height:1}.hud{position:absolute;z-index:3;display:flex;gap:16px;align-items:center;justify-content:space-between;border:1px solid rgba(255,255,255,.12);border-radius:8px;background:#111518c7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 16px 32px #00000029}.hud-top{top:66px;left:16px;right:16px;min-height:54px;padding:10px 12px}body.read-only .hud-top{display:none}.read-only-banner{position:absolute;z-index:5;top:66px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;border:1px solid rgba(225,170,81,.65);border-radius:7px;padding:8px 12px;background:#493216eb;color:#ffe4af;font-size:.8rem;font-weight:700;box-shadow:0 14px 28px #0003}.read-only-banner[hidden]{display:none}.read-only-banner button{min-height:28px;border:1px solid rgba(255,228,175,.55);border-radius:6px;padding:0 9px;background:#ffe4af1f;color:#fff1d2;font:inherit;font-weight:700}.read-only-banner button:hover{background:#ffe4af33}.hud strong,.hud span{display:block;line-height:1.35}.hud strong{font-size:.9rem}.hud span{color:var(--muted);font-size:.78rem}.axis-x:before{background:#d6655b}.axis-y:before{background:#68bb67}.axis-z:before{background:#6e9ee5}.furniture-list{display:grid;gap:8px;padding-top:10px}.furniture-item{display:grid;grid-template-columns:16px minmax(0,1fr) auto;gap:9px;align-items:center;width:100%;min-height:44px;border:1px solid var(--line);border-radius:7px;padding:8px;background:#151a1d;color:var(--text);text-align:left}.furniture-item:hover,.furniture-item.selected{border-color:var(--accent)}.furniture-colour{width:14px;height:28px;border-radius:4px;box-shadow:inset 0 0 0 1px #ffffff47}.furniture-main{min-width:0}.furniture-main strong,.furniture-main span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.furniture-main strong{font-size:.84rem;font-weight:650}.furniture-main span,.furniture-status{color:var(--muted);font-size:.72rem}.furniture-status.warn{color:var(--warn)}.app-footer{display:flex;gap:10px;align-items:center;justify-content:space-between;padding:14px 18px;color:var(--muted);font-size:.76rem}.app-footer a{color:var(--accent-strong);text-decoration:none}.app-footer a:hover{text-decoration:underline}@media(max-width:1100px){body{overflow:auto}#app{min-height:100%;grid-template-columns:300px minmax(420px,1fr);grid-template-rows:minmax(560px,1fr) auto}.panel-right{grid-column:1 / -1;border-top:1px solid var(--line);border-left:0}}@media(max-width:760px){#app{display:block}body{overflow:auto}.panel{border:0;border-bottom:1px solid var(--line)}.viewport-shell{height:68vh;min-height:460px}.hud-top{align-items:flex-start;flex-direction:column}.support-banner{top:54px;left:14px;right:14px;max-width:none}.hud-top{top:104px}.read-only-banner{inset:auto 14px 14px;justify-content:space-between;transform:none}body.read-only .panel-left{position:sticky;top:0;z-index:6}body.read-only .panel-left .control-section{display:none}body.read-only .brand{min-height:62px;padding:10px 14px}body.read-only .brand-mark{width:38px;height:38px;flex-basis:38px}body.read-only .brand-mark svg{width:31px;height:31px}body.read-only .brand h1{font-size:.95rem}body.read-only .brand input{height:28px;margin-top:1px;padding:2px 6px}body.read-only .viewport-shell{height:78vh;min-height:520px}}
