*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;color:var(--color-text);font-family:Inter,system-ui,sans-serif;background:var(--color-bg)}.container{margin:0 auto;padding:16px;max-width:1200px}.brand{font-weight:700;font-size:1.5rem}.hello{margin-top:8px;font-size:1.25rem}.layout{display:flex;flex-direction:column;min-height:100dvh}.layout__body{display:grid;grid-template-columns:320px 1fr;gap:0}.layout__main{min-width:0}.app-header{position:sticky;z-index:20;top:0;height:56px;display:flex;justify-content:space-between;align-items:center;padding:0 16px;background:#0f141b;border-bottom:1px solid rgba(255,255,255,.06)}.app-header__brand{font-weight:700;letter-spacing:.02em}.app-header__actions{display:flex;gap:8px}.app-header__btn{border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:6px 12px;color:var(--color-text);appearance:none;background:transparent;cursor:pointer}.app-header__btn:hover{border-color:#ffffff59}:root{--color-bg: #0b0f14;--color-text: #e6edf3;--color-accent: #f04438}.sidebar{position:sticky;top:56px;width:320px;height:calc(100dvh - 56px);padding:16px;min-width:280px;background:#0c1016;border-right:1px solid rgba(255,255,255,.06);overflow:auto}.sidebar__title{margin:0 0 8px;font-weight:700;font-size:1rem}.sidebar__group{margin-top:8px;display:grid;gap:6px}.sidebar__label{font-size:.85rem;opacity:.9}.sidebar__input{border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:8px 10px;color:var(--color-text);background:#0f141b;outline:none}.sidebar__input:focus{border-color:#ffffff59}.sidebar__help{margin-top:16px;font-size:.85rem;opacity:.7}.sidebar .sidebar__note{margin-top:16px}.canvas{height:calc(100dvh - 56px);overflow:hidden}.canvas__svg{display:block}.canvas__building{stroke:#ffffff40;stroke-width:1;opacity:.9;rx:2}.canvas__limit{stroke:var(--color-accent);stroke-width:2}.canvas__limitTag-bg{fill:#f044381f}.canvas__limitTag-text{fill:var(--color-accent);font:600 12px/1 Inter,system-ui,sans-serif}.canvas__ground{stroke:#ffffff40}.canvas__groundLabel{fill:#fffc;font:12px Inter,system-ui,sans-serif}.canvas__exceed{fill:var(--color-accent);opacity:.12}.canvas__rulerLeft,.canvas__rulerRight{stroke:#ffffff59;fill:#ffffffd9;font:11px Inter,system-ui,sans-serif;text-anchor:end}.canvas__rulerRight{text-anchor:start}
