*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#16181d;--panel:#1e2128;--panel2:#262a33;--border:#333845;--text:#d7dae2;--dim:#8a90a0;--accent:#e8b931;--accent-text:#16181d}html,body,#app{height:100%;overflow:hidden}body{background:var(--bg);color:var(--text);font-family:-apple-system,SF Pro,Segoe UI,Noto Sans KR,sans-serif;font-size:13px}#app{grid-template:"top top top"58px"shapes viewport side"1fr"status status status"26px/84px 1fr 270px;display:grid}#topbar{background:var(--panel);border-bottom:1px solid var(--border);scrollbar-width:none;grid-area:top;align-items:center;gap:8px;padding:0 12px;display:flex;overflow-x:auto}#topbar::-webkit-scrollbar{display:none}@media (width<=950px){#topbar .btn-label{display:none}#topbar .primary .btn-label{display:inline}#topbar .tb-btns button{padding:5px 7px}.tb-group{padding:0 6px}}@media (width<=800px){#topbar{gap:4px;padding:0 8px}.tb-group{padding:0 4px}#topbar .tb-btns{gap:2px}#topbar .tb-btns button{padding:4px}.snap-label{gap:0;font-size:0}.snap-label select{width:62px;font-size:11px}.unit-badge{display:none}.brand{margin-right:2px;font-size:13px}}.brand{letter-spacing:.5px;margin-right:8px;font-size:15px;font-weight:700}.unit-badge{color:var(--accent-text);background:var(--accent);vertical-align:2px;border-radius:3px;margin-left:6px;padding:1px 4px;font-size:10px;font-weight:600}.tb-group{border-right:1px solid var(--border);flex-direction:column;align-items:center;gap:2px;padding:0 10px;display:flex;position:relative}.tb-group:last-child{border-right:none}.tb-btns{align-items:center;gap:4px;display:flex}.tb-btns button{align-items:center;gap:5px;display:inline-flex}.tb-btns button svg{flex:none;width:14px;height:14px}.tb-caption{text-transform:uppercase;letter-spacing:.8px;color:var(--dim);opacity:.75;-webkit-user-select:none;user-select:none;font-size:9px}.tb-spacer{border:none;flex:1}button{background:var(--panel2);color:var(--text);border:1px solid var(--border);cursor:pointer;border-radius:5px;padding:5px 10px;font-family:inherit;font-size:12px}button:hover{background:#303543}button:active{background:#3a4050}button.primary{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:600}button.primary:hover{filter:brightness(1.1)}button:disabled{opacity:.4;cursor:default}select,input[type=number],input[type=text]{background:var(--panel2);color:var(--text);border:1px solid var(--border);border-radius:4px;width:100%;padding:4px 6px;font-family:inherit;font-size:12px}input[type=number]{appearance:textfield}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.snap-label{color:var(--dim);align-items:center;gap:5px;font-size:12px;display:flex}.snap-label select{width:72px}.popover{background:var(--panel2);border:1px solid var(--border);z-index:100;border-radius:6px;flex-direction:column;gap:5px;padding:8px;display:flex;position:absolute;top:34px;left:0;box-shadow:0 6px 20px #00000080}.popover.hidden{display:none}.align-row{align-items:center;gap:4px;display:flex}.align-row span{width:14px;color:var(--dim);font-weight:600}.align-row button{padding:3px 8px;font-size:11px}#shapebar{background:var(--panel);border-right:1px solid var(--border);flex-direction:column;grid-area:shapes;gap:2px;padding:8px 6px;display:flex;overflow-y:auto}.shape-btn{color:var(--dim);background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:2px;padding:7px 2px 5px;display:flex}.shape-btn:hover{background:var(--panel2);color:var(--text);border-color:var(--border)}.shape-btn svg{width:26px;height:26px}.shape-btn span{font-size:10px}#viewport{grid-area:viewport;position:relative;overflow:hidden}#viewport canvas{display:block}#viewcube{z-index:10;grid-template-areas:".n.t""w c e b"".s. .";grid-auto-rows:30px;grid-auto-columns:36px;gap:4px;display:grid;position:absolute;top:12px;right:12px}#viewcube.hidden{display:none}#viewcube button{border:1px solid var(--border);background:#1e2128e0;padding:0;font-size:11px;font-weight:600}#viewcube button:hover{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}#sidepanel{background:var(--panel);border-left:1px solid var(--border);flex-direction:column;grid-area:side;display:flex;overflow:hidden}#sidepanel h3{text-transform:uppercase;letter-spacing:1px;color:var(--dim);padding:10px 12px 6px;font-size:11px}#objlist-section{border-bottom:1px solid var(--border);flex-direction:column;flex:none;max-height:32%;display:flex}#objlist{-webkit-user-select:none;user-select:none;padding:0 6px 8px;overflow-y:auto}.obj-row{cursor:pointer;border-radius:4px;align-items:center;gap:6px;padding:4px 6px;font-size:12px;display:flex}.obj-row:hover{background:var(--panel2)}.obj-row.selected{background:#34405a}.obj-row .swatch{border-radius:2px;flex:none;width:10px;height:10px}.obj-row .obj-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.obj-row .obj-mode{color:var(--dim);border:1px solid var(--border);border-radius:3px;padding:0 3px;font-size:9px}.obj-row .vis-btn{color:var(--dim);background:0 0;border:none;padding:0 2px;font-size:11px}.obj-row .vis-btn.off{opacity:.3}.obj-row.grouped{border-left:2px solid var(--border);border-radius:0 4px 4px 0;margin-left:14px}.obj-group-header{cursor:pointer;color:var(--dim);-webkit-user-select:none;user-select:none;border-radius:4px;align-items:center;gap:6px;margin-top:3px;padding:4px 6px;font-size:11px;font-weight:600;display:flex}.obj-group-header:hover{background:var(--panel2);color:var(--text)}.obj-group-header.selected{color:var(--text);background:#34405a}#inspector-section{flex-direction:column;flex:1;display:flex;overflow:hidden}#inspector{flex:1;padding:0 12px 16px;overflow-y:auto}#inspector .hint{color:var(--dim);padding:8px 0}.insp-group{margin-bottom:12px}.insp-group h4{text-transform:uppercase;letter-spacing:.8px;color:var(--dim);margin:10px 0 6px;font-size:10px}.field-row{align-items:center;gap:6px;margin-bottom:5px;display:flex}.field-row label{color:var(--dim);flex:0 0 82px;font-size:11px}.field-row input,.field-row select{flex:1;min-width:0}.field-row .unit{color:var(--dim);flex:0 0 22px;font-size:10px}.triple{flex:1;gap:4px;display:flex}.triple input{flex:1;width:0}.field-row.triple-row{flex-direction:column;align-items:stretch;gap:3px;margin-bottom:8px}.field-row.triple-row label{flex:none;width:100%}.field-row.triple-row .triple{width:100%}.field-row.triple-row .triple input{text-align:center;font-variant-numeric:tabular-nums;padding:4px 2px}.mode-toggle{gap:4px;display:flex}.mode-toggle button{flex:1}.mode-toggle button.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:600}.color-swatches{grid-template-columns:repeat(8,1fr);gap:4px;display:grid}.color-swatches .cs{aspect-ratio:1;cursor:pointer;border:2px solid #ffffff14;border-radius:4px}.color-swatches .cs:hover{transform:scale(1.15)}.color-swatches .cs.active{border-color:#fff}.color-custom{align-items:center;gap:8px;margin-top:6px;display:flex}.color-custom input[type=color]{border:1px solid var(--border);background:var(--panel2);cursor:pointer;border-radius:4px;width:42px;height:26px;padding:0}.color-hex{color:var(--dim);font-family:ui-monospace,monospace;font-size:11px}#library-section{border-top:1px solid var(--border);flex-direction:column;flex:none;max-height:34%;display:flex}.h3-row{justify-content:space-between;align-items:center;display:flex}.h3-row button{padding:2px 7px;font-size:10px}#library-grid{grid-template-columns:1fr 1fr;gap:6px;padding:4px 10px 12px;display:grid;overflow-y:auto}#library-grid .hint{color:var(--dim);grid-column:1/-1;padding:4px 2px;font-size:11px}.lib-item{background:var(--panel2);border:1px solid var(--border);cursor:pointer;border-radius:6px;position:relative;overflow:hidden}.lib-item:hover{border-color:var(--accent)}.lib-item img{aspect-ratio:4/3;object-fit:cover;background:#14161b;width:100%;display:block}.lib-item .lib-thumb-empty{aspect-ratio:4/3;width:100%;color:var(--dim);justify-content:center;align-items:center;font-size:10px;display:flex}.lib-item .lib-name{text-overflow:ellipsis;white-space:nowrap;padding:3px 5px;font-size:10px;overflow:hidden}.lib-item .lib-del{color:#ccc;background:#0000008c;border:none;border-radius:4px;width:17px;height:17px;padding:0;font-size:11px;line-height:1;position:absolute;top:3px;right:3px}.lib-item .lib-del:hover{color:#fff;background:#a33}#statusbar{background:var(--panel);border-top:1px solid var(--border);color:var(--dim);grid-area:status;align-items:center;gap:12px;padding:0 12px;font-size:11px;display:flex}#status-dims{color:var(--accent);font-weight:600}.status-help{opacity:.7;font-size:10px}#action-bar{z-index:10;border:1px solid var(--border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#181a20d1;border-radius:8px;align-items:stretch;gap:2px;padding:4px;display:flex;position:absolute;top:12px;left:50%;transform:translate(-50%)}#action-bar .tool-btn{width:54px}.action-divider{background:var(--border);width:1px;margin:4px 3px}#action-bar .popover{top:calc(100% + 6px);left:auto;right:0}@media (width<=1400px){#action-bar .tool-btn{width:34px}#action-bar .tool-btn span{display:none}#action-bar .tool-btn svg{width:16px;height:16px}}#tool-rail{z-index:10;border:1px solid var(--border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#181a20d1;border-radius:8px;flex-direction:column;gap:4px;padding:6px;display:flex;position:absolute;top:12px;left:12px}.rail-caption{text-transform:uppercase;letter-spacing:1px;color:var(--dim);text-align:center;opacity:.7;-webkit-user-select:none;user-select:none;font-size:8px}.rail-divider{background:var(--border);height:1px;margin:4px 2px}.tool-btn{width:52px;color:var(--dim);background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:2px;padding:6px 2px 4px;display:flex}.tool-btn svg{width:18px;height:18px}.tool-btn span{font-size:9px}.tool-btn:hover{color:var(--text);border-color:var(--border);background:#303543}.tool-btn.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:600}#viewport.tool-marquee canvas,#viewport.tool-lasso canvas{cursor:crosshair}.lasso-svg{pointer-events:none;z-index:15;width:100%;height:100%;position:absolute;inset:0}.lasso-svg polygon{fill:#e8b93114;stroke:var(--accent);stroke-width:1.5px;stroke-dasharray:5 3}.lasso-rect{border:1px dashed var(--accent);pointer-events:none;z-index:15;background:#e8b93114;position:absolute}#btn-ruler.active,#btn-magnet.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent);font-weight:600}#viewport.ruler-mode canvas{cursor:crosshair}.ruler-label{border:1px solid var(--accent);pointer-events:none;white-space:nowrap;z-index:20;text-align:center;background:#16181deb;border-radius:5px;padding:4px 8px;position:absolute;transform:translate(-50%,-130%)}.ruler-label .rl-dist{color:var(--accent);font-size:13px;font-weight:700}.ruler-label .rl-delta{color:var(--dim);font-size:10px}.sketch-overlay{z-index:500;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.sketch-modal{background:var(--panel);border:1px solid var(--border);border-radius:10px;flex-direction:column;width:min(920px,92vw);height:min(680px,88vh);display:flex;overflow:hidden;box-shadow:0 20px 60px #0009}.sketch-toolbar{border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:10px 12px;display:flex}.sketch-title{margin-right:10px;font-weight:700}.sketch-hint{color:var(--dim);margin-right:8px;font-size:10px}.sketch-canvas{cursor:crosshair;touch-action:none;flex:1;width:100%}#loading{background:var(--bg);color:var(--dim);z-index:1000;justify-content:center;align-items:center;font-size:14px;display:flex;position:fixed;inset:0}#loading.hidden{display:none}.opacity-row{align-items:center;gap:8px;margin-top:8px;display:flex}.opacity-row input[type=range]{accent-color:var(--accent);flex:1}.opacity-label{color:var(--dim);white-space:nowrap;min-width:82px;font-size:11px}.recent-label{text-transform:uppercase;letter-spacing:.8px;color:var(--dim);margin:8px 0 4px;font-size:9px}
