:root{--bg:#1b1d24;--bg-2:#23262f;--bg-3:#2b2f3a;--line:#393e4c;--line-2:#4a5063;--text:#e7eaf0;--text-dim:#a3a9b8;--text-faint:#757b8c;--accent:#5b8def;--accent-press:#4577d6;--danger:#d9534f;--good:#4f9d69;--radius:10px;--radius-sm:7px;font-synthesis:none}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.4}.app{flex-direction:column;height:100%;min-height:0;display:flex}.app-header{border-bottom:1px solid var(--line);background:var(--bg-2);justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.app-title{align-items:center;gap:8px;display:flex}.app-logo{border-radius:6px;flex:none;display:block}.app-title strong{letter-spacing:.2px;font-size:16px}.app-subtitle{color:var(--text-faint);font-size:12px}.obr-badge{border:1px solid var(--line-2);color:var(--text-dim);white-space:nowrap;border-radius:999px;padding:3px 9px;font-size:11px}.obr-badge.ready{color:#bfe7cd;background:#213227;border-color:#3c6b4d}.obr-badge.outside-owlbear{color:#d9c79a;background:#2f2a1f;border-color:#6b5d3c}.obr-badge.error{color:#f0b3b1;background:#2f1f1f;border-color:#6b3c3c}.app-footer{border-top:1px solid var(--line);background:var(--bg-2);color:var(--text-faint);justify-content:space-between;align-items:center;gap:10px;padding:6px 14px;font-size:11px;display:flex}.app-footer-notice{color:#8a6d6d}.app-loading{color:var(--text-dim);flex:1;place-items:center;display:grid}.app-body{flex-direction:column;flex:1;min-height:0;display:flex}.app-main{flex:1;min-height:280px;padding:12px;display:flex}.app-rail{flex-direction:column;gap:12px;padding:0 12px 12px;display:flex;overflow-y:auto}@media (width>=860px){.app-body{flex-direction:row}.app-main{min-height:0}.app-rail{border-left:1px solid var(--line);flex:none;width:372px;padding:12px;overflow-y:auto}}.canvas-box{border:1px solid var(--line);border-radius:var(--radius);background-color:#15161b;background-image:linear-gradient(45deg,#191b21 25%,#0000 25%),linear-gradient(-45deg,#191b21 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#191b21 75%),linear-gradient(-45deg,#0000 75%,#191b21 75%);background-position:0 0,0 11px,11px -11px,-11px 0;background-size:22px 22px;flex:1;min-height:0;position:relative;overflow:hidden}.canvas-box.empty{place-items:center;display:grid}.canvas-empty{text-align:center;max-width:280px;padding:24px}.canvas-empty-title{margin:0 0 4px;font-size:15px}.canvas-empty-sub{color:var(--text-dim);margin:0 0 14px;font-size:12.5px}.canvas-img{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none;position:absolute}.canvas-overlay{position:absolute;overflow:visible}.canvas-labels{pointer-events:none;position:absolute}.bounds-rect{fill:none;stroke:#d9c79a;stroke-width:1.5px;stroke-dasharray:7 5;opacity:.8}.zone-rect{fill-opacity:.13;stroke-width:2px;cursor:pointer;transition:fill-opacity .1s}.zone-g.selected .zone-rect{fill-opacity:.26;stroke-width:3px}.draft-rect{fill:#5b8def2e;stroke:var(--accent);stroke-width:2px;stroke-dasharray:6 4}.draft-rect.calibrate{fill:#d9c79a26;stroke:#d9c79a}.zone-label{white-space:nowrap;border:1px solid var(--line-2);color:var(--text);pointer-events:auto;cursor:pointer;background:#14161ceb;border-left-width:3px;border-radius:5px;align-items:center;gap:6px;margin-top:-4px;padding:2px 8px;font-size:11px;display:inline-flex;position:absolute;transform:translateY(-100%)}.zone-label.selected{background:#232837f7}.zone-label-dot{border-radius:50%;width:7px;height:7px;display:inline-block}.zone-label-profile{color:var(--text-faint);font-size:10px}.canvas-mode-hint{border:1px solid var(--line-2);color:var(--text-dim);pointer-events:none;background:#14161cf0;border-radius:999px;padding:6px 14px;font-size:12px;position:absolute;bottom:12px;left:50%;transform:translate(-50%)}.panel{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:12px}.panel-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.panel-head h2{text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim);margin:0;font-size:13px}.panel-sub{color:var(--text-faint);text-overflow:ellipsis;white-space:nowrap;max-width:55%;font-size:11px;overflow:hidden}.panel-foot{border-top:1px solid var(--line);margin-top:12px;padding-top:10px}.hint{color:var(--text-faint);margin:4px 0;font-size:12.5px}.hint.sm{font-size:11.5px}.field-row{flex-wrap:wrap;gap:8px;display:flex}.field{flex-direction:column;flex:1;gap:4px;min-width:92px;display:flex}.field.narrow{flex:0 0 84px}.field.block{margin-bottom:12px;display:block}.field.block>span{margin-bottom:5px;display:block}.field>span{color:var(--text-dim);font-size:11px}input,select,textarea{background:var(--bg);border:1px solid var(--line-2);border-radius:var(--radius-sm);color:var(--text);font:inherit;width:100%;padding:7px 9px;font-size:13px}textarea{resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--accent);outline:none}.scale-readout{background:var(--bg-3);border-radius:var(--radius-sm);color:var(--text-dim);flex-wrap:wrap;gap:8px;margin-top:10px;padding:8px 10px;font-size:12px;display:flex}.scale-readout strong{color:var(--text)}.bounds-row{border-top:1px solid var(--line);margin-top:12px;padding-top:10px}.bounds-summary{justify-content:space-between;margin-bottom:8px;font-size:12px;display:flex}.bounds-label{color:var(--text-dim)}.bounds-value{color:var(--text)}.btn{background:var(--bg-3);border:1px solid var(--line-2);color:var(--text);border-radius:var(--radius-sm);font:inherit;cursor:pointer;padding:7px 12px;font-size:13px;transition:background .12s,border-color .12s}.btn:hover:not(:disabled){background:#333845}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.sm{padding:5px 10px;font-size:12px}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn.primary:hover:not(:disabled){background:var(--accent-press)}.btn.active{border-color:var(--accent);box-shadow:inset 0 0 0 1px var(--accent)}.btn.ghost{background:0 0}.btn.danger{color:#f0b3b1;border-color:#6b3c3c}.btn.danger:hover:not(:disabled){background:#2f1f1f}.btn-row{flex-wrap:wrap;gap:8px;display:flex}.zone-cards{flex-direction:column;gap:8px;margin:0;padding:0;list-style:none;display:flex}.zone-card{text-align:left;background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;align-items:stretch;width:100%;padding:0;display:flex;overflow:hidden}.zone-card:hover{border-color:var(--line-2)}.zone-card.selected{background:#2c3340}.zone-card-bar{flex:none;width:4px}.zone-card-body{flex-direction:column;gap:3px;padding:9px 11px;display:flex}.zone-card-name{font-size:13.5px;font-weight:600}.zone-card-meta{align-items:center;gap:10px;display:flex}.zone-card-badge{font-size:11px;font-weight:600}.zone-card-size{color:var(--text-faint);font-size:11px}.detail-name{margin-bottom:2px;font-size:16px;font-weight:600}.detail-blurb{color:var(--text-dim);margin:0 0 12px;font-size:12px}.detail-grid{grid-template-columns:1fr 1fr;gap:10px;margin:0 0 12px;display:grid}.detail-grid dt{text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);font-size:10.5px}.detail-grid dd{margin:2px 0 0;font-size:12.5px}.detail-notes{background:var(--bg-3);border-radius:var(--radius-sm);color:var(--text-dim);margin:0 0 12px;padding:8px 10px;font-size:12.5px}.phase-stub{border-top:1px dashed var(--line-2);margin-top:14px;padding-top:12px}.phase-stub-title{text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);margin-bottom:8px;font-size:11px;display:block}.modal-backdrop{z-index:50;background:#0000008c;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal{background:var(--bg-2);border:1px solid var(--line-2);border-radius:var(--radius);width:100%;max-width:440px;max-height:90vh;padding:18px;overflow-y:auto;box-shadow:0 18px 48px #00000080}.modal-title{margin:0 0 14px;font-size:16px}.profile-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.profile-chip{text-align:left;background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;gap:2px;padding:9px 10px;display:flex}.profile-chip:hover{border-color:var(--line-2)}.profile-chip.selected{background:#2c3340;box-shadow:inset 0 0 0 1px}.profile-dot{border-radius:50%;width:9px;height:9px;display:inline-block}.profile-name{font-size:13px;font-weight:600}.profile-blurb{color:var(--text-faint);font-size:10.5px;line-height:1.3}.modal-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.modal-foot-hint{color:var(--text-faint);margin:12px 0 0;font-size:11.5px}.sugg-list{flex-direction:column;gap:5px;max-height:240px;margin:0 0 10px;padding:0;list-style:none;display:flex;overflow-y:auto}.sugg-row{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius-sm);align-items:center;gap:7px;padding:4px 7px;display:flex}.sugg-row.disabled{opacity:.6}.sugg-row input[type=checkbox]{width:auto;accent-color:var(--accent);flex:none}.sugg-glyph{text-align:center;flex:none;width:16px;font-size:14px}.sugg-label-input{background:0 0;border:1px solid #0000;border-radius:5px;flex:1;min-width:0;padding:3px 5px;font-size:12.5px}.sugg-label-input:hover{border-color:var(--line)}.sugg-label-input:focus{background:var(--bg);border-color:var(--accent)}.sugg-vision{letter-spacing:.5px;color:#f0b3b1;border:1px solid #6b3c3c;border-radius:4px;flex:none;padding:1px 4px;font-size:9.5px;font-weight:700}.sugg-source{color:var(--text-faint);flex:none;font-size:10px}.sugg-del{color:var(--text-faint);cursor:pointer;background:0 0;border:none;border-radius:4px;flex:none;padding:2px 4px;font-size:12px}.sugg-del:hover{color:#f0b3b1;background:#2f1f1f}.sugg-actions{margin-top:4px}.vision-toggle{color:var(--text-dim);align-items:center;gap:8px;margin:10px 0;font-size:12.5px;display:flex}.vision-toggle input{width:auto;accent-color:var(--accent);flex:none}.place-status{border-radius:var(--radius-sm);border:1px solid var(--line-2);margin:10px 0 4px;padding:6px 9px;font-size:12px}.place-status.ok{color:#bfe7cd;background:#213227;border-color:#3c6b4d}.place-status.error{color:#f0b3b1;background:#2f1f1f;border-color:#6b3c3c}.place-status.busy{color:var(--text-dim)}.sugg-rect{fill-opacity:.16;stroke-width:1.5px;stroke-dasharray:5 3}.sugg-point{fill-opacity:.45;stroke-width:1.5px}.sugg-poly{stroke-width:2.5px;stroke-linejoin:round;stroke-linecap:round}
