:root{--bg:#eef2f6;--surface:#fff;--surface-muted:#f7f9fb;--surface-strong:#e8eef4;--text:#17212b;--muted:#657386;--border:#d8e0e8;--border-strong:#bdc9d6;--accent:#146ef5;--accent-strong:#0f55bd;--teal:#0f9b8e;--amber:#c27408;--green:#138a53;--red:#c0392b;--shadow:0 18px 44px #1527401f;color:var(--text);font-synthesis:none;text-rendering:optimizelegibility;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{background:var(--bg);min-width:320px;margin:0}button,input,select,textarea{font:inherit}button{cursor:pointer;border:0}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:2px;outline:2px solid #146ef552}.app-shell{grid-template-columns:232px minmax(0,1fr);min-height:100vh;display:grid}.side-nav{border-right:1px solid var(--border);background:#f8fafc;flex-direction:column;gap:22px;padding:20px 14px;display:flex}.brand{align-items:center;gap:12px;min-height:48px;display:flex}.brand-mark{color:#fff;background:#0b2f5f;border-radius:8px;place-items:center;width:38px;height:38px;font-size:12px;font-weight:800;display:grid}.brand strong,.brand span{display:block}.brand strong{font-size:15px}.brand span{color:var(--muted);margin-top:2px;font-size:12px}.nav-list{gap:4px;display:grid}.nav-item{color:#435164;text-align:left;background:0 0;border-radius:7px;align-items:center;gap:10px;width:100%;min-height:38px;padding:0 10px;display:flex}.nav-item:hover,.nav-item.active{color:#0d4f9d;background:#e8f0fb}.nav-item span{font-size:13px;font-weight:650}.capacity-panel{background:var(--surface);border:1px solid var(--border);border-radius:8px;margin-top:auto;padding:14px}.capacity-panel strong{margin:7px 0 10px;font-size:20px;display:block}.capacity-meta{color:var(--muted);justify-content:space-between;margin-top:8px;font-size:11px;display:flex}.workspace{flex-direction:column;min-width:0;padding:18px;display:flex}.topbar{justify-content:space-between;align-items:center;gap:18px;margin-bottom:14px;display:flex}.topbar h1{margin:2px 0 0;font-size:21px;line-height:1.2}.topbar-copy{min-width:260px}.product-headline{color:var(--muted);max-width:620px;margin:6px 0 0;font-size:13px;font-weight:650;line-height:1.4}.screen-label,.eyebrow{color:var(--muted);text-transform:uppercase;margin:0;font-size:11px;font-weight:750;display:block}.topbar-actions,.tool-group{align-items:center;gap:8px;display:flex}.topbar-actions input[type=file]{display:none}.search-field{background:var(--surface);border:1px solid var(--border);border-radius:8px;align-items:center;gap:8px;width:230px;min-height:36px;padding:0 10px;display:flex}.search-field input{color:var(--text);border:0;outline:0;width:100%;min-width:0}.button,.icon-button{border-radius:7px;justify-content:center;align-items:center;gap:7px;min-height:36px;padding:0 12px;font-size:13px;font-weight:750;display:inline-flex}.button.primary{background:var(--accent);color:#fff}.button.primary:hover{background:var(--accent-strong)}.button.secondary{background:var(--surface);border:1px solid var(--border);color:#263447}.button.secondary:hover{background:#f1f5f9}.button.danger{color:var(--red);border-color:#f0beb8}.button.danger:hover{background:#fff3f1}.button:disabled,.icon-button:disabled{cursor:not-allowed;opacity:.48}.button:disabled:hover,.icon-button:disabled:hover{background:var(--surface)}.button.full{width:100%}.icon-button{border:1px solid var(--border);color:#405066;background:#f3f6fa;width:34px;height:34px;padding:0}.icon-button.selected,.icon-button:hover{color:var(--accent);background:#e8f0fb;border-color:#a9c9f7}.status-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px;display:grid}.status-tile{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:12px}.status-tile div:first-child{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.status-tile span,.summary-row span{color:var(--muted);font-size:12px;font-weight:650}.status-tile strong{font-size:13px}.meter,.mini-meter{background:#dfe7ef;border-radius:999px;height:7px;overflow:hidden}.meter span,.mini-meter span{background:linear-gradient(90deg, var(--accent), var(--teal));height:100%;display:block}.workbench{grid-template-columns:minmax(0,1fr) 322px;gap:14px;min-height:430px;display:grid}.canvas-panel,.inspector-panel,.photo-strip-panel,.metadata-panel{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:8px;min-width:0}.canvas-panel,.photo-strip-panel,.metadata-panel{flex-direction:column;display:flex}.panel-toolbar,.section-heading{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;min-height:58px;padding:12px 14px;display:flex}.panel-toolbar strong,.section-heading strong{margin-top:2px;font-size:14px;display:block}.panel-toolbar small{color:var(--muted);font-size:12px;font-weight:700}.panel-toolbar.compact{min-height:54px}.markup-mode-bar{border-bottom:1px solid var(--border);background:#f6f9fc;justify-content:space-between;align-items:center;gap:12px;min-height:48px;padding:8px 14px;display:flex}.markup-tool-tabs{border:1px solid var(--border);background:#e8eef5;border-radius:8px;align-items:center;gap:3px;padding:3px;display:inline-flex}.markup-tool-button{color:#405066;background:0 0;border-radius:6px;align-items:center;gap:6px;min-height:30px;padding:0 10px;font-size:12px;font-weight:800;display:inline-flex}.markup-tool-button:hover{background:#ffffff9e}.markup-tool-button.selected{color:var(--accent);background:#fff;box-shadow:0 1px 3px #1527401f}.markup-mode-status{color:#263447;text-align:right;text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.drawing-board{background:#dfe4ea;flex:1;padding:18px}.report-preview-board{justify-content:center;align-items:flex-start;display:flex;overflow:auto}.report-sheet{color:#1a1a1a;background:#fff;border:1px solid #cfd6df;flex-direction:column;width:min(100%,690px);min-height:670px;padding:38px 54px 28px;display:flex;position:relative;box-shadow:0 14px 34px #121f2e2e}.report-header{justify-content:space-between;align-items:flex-start;min-height:78px;display:flex}.report-header p{color:#36475a;margin:18px 0 0;font-family:Arial,Helvetica,sans-serif;font-size:12px;line-height:1.35}.report-logo{color:#5f766e;place-items:center;gap:3px;width:112px;display:grid}.report-logo span{opacity:.82;background:linear-gradient(90deg,#c9f7e8 22%,#0000 22% 34%,#c9f7e8 34% 46%,#0000 46% 58%,#c9f7e8 58%),linear-gradient(#c9f7e8 0 24%,#0000 24% 38%,#c9f7e8 38% 50%,#0000 50% 64%,#c9f7e8 64%);width:82px;height:54px;display:block}.report-logo small{font-size:8px;font-weight:700}.report-rule{background:#2c6eb7;height:1px;margin-bottom:26px}.report-sheet h2,.report-sheet h3{text-align:left;font-family:Arial,Helvetica,sans-serif}.report-sheet h2{margin:0 0 18px;font-size:15px;font-weight:700}.report-sheet h3{margin:0 0 22px 116px;font-size:13px;font-weight:700;text-decoration:underline}.markup-layout{grid-template-columns:128px minmax(0,1fr);align-items:flex-start;gap:24px;display:grid}.report-legend{color:#1f1f1f;border:1px solid #6d6d6d;gap:13px;padding:8px 8px 15px;font-family:Arial,Helvetica,sans-serif;font-size:13px;display:grid}.report-legend strong{font-size:21px;font-weight:500}.report-legend div{grid-template-columns:34px 1fr;align-items:center;gap:8px;display:grid}.legend-swatch{border:1px solid #d7d558;width:29px;height:29px;display:block}.legend-swatch.inspected{background:#fffc4dad}.legend-swatch.inaccessible{background:#53fb5bd1;border-color:#52d960}.legend-photo-no{color:red;background:#eaffff;border:3px solid #003cff;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;display:inline-flex}.report-plan{--symbol-scale:1;aspect-ratio:.73;border-right:1px solid #d3d3d3;min-height:430px;font-family:Arial,Helvetica,sans-serif;position:relative;overflow:hidden}.report-plan.placing{cursor:crosshair}.report-plan:before,.report-plan:after{content:"";pointer-events:none;z-index:2;position:absolute}.report-plan:before{background:#2f2f2f;width:90%;height:1px;top:31%;left:4%}.report-plan:after{background:#2f2f2f;width:82%;height:1px;bottom:5%;left:13%}.report-room,.inspection-fill,.inaccessible-fill,.plan-stairs,.fixture-row{position:absolute}.report-room{color:#2d2d2d;text-align:center;writing-mode:vertical-rl;z-index:3;border:1px solid #909090;justify-content:center;align-items:center;font-size:13px;line-height:1.14;display:flex}.room-112{width:33%;height:18%;top:5%;right:4%}.lobby{border-left:0;border-right:0;width:58%;height:12%;top:22%;left:36%}.stair{width:34%;height:26%;top:30%;left:40%}.room-114{width:21%;height:17%;top:42%;right:5%}.room-113{width:18%;height:13%;top:45%;right:26%}.room-115{width:42%;height:22%;top:54%;right:5%}.room-116{width:58%;height:22%;top:76%;right:5%}.canteen{width:28%;height:20%;top:76%;left:4%}.inspection-fill{z-index:1;background:#fffc2d9e;border:1px solid #e0d200b8}.fill-room-112{width:31%;height:17%;top:6%;right:5%}.fill-room-115{width:40%;height:21%;top:55%;right:6%}.fill-room-116{width:56%;height:20%;top:77%;right:6%}.inaccessible-fill{z-index:1;background:#4af75873;width:17%;height:7%;top:45%;left:5%}.fixture-row{z-index:4;gap:6px;display:flex}.fixture-row span{border:2px solid #888;border-radius:3px;width:18px;height:11px}.fixture-row.upper{top:58%;right:13%}.fixture-row.lower{top:77%;right:12%}.plan-stairs{z-index:4;width:31%;height:21%;display:grid;top:34%;left:41%}.plan-stairs span{border-top:1px solid #747474}.map-direction-symbol{z-index:8;width:58px;height:58px;position:absolute;top:6%;left:5%}.compass-star{clip-path:polygon(50% 0%,58% 38%,100% 50%,58% 62%,50% 100%,42% 62%,0% 50%,42% 38%);background:conic-gradient(#111 0deg 22.5deg,#fff 22.5deg 45deg,#111 45deg 67.5deg,#fff 67.5deg 90deg,#111 90deg 112.5deg,#fff 112.5deg 135deg,#111 135deg 157.5deg,#fff 157.5deg 180deg,#111 180deg 202.5deg,#fff 202.5deg 225deg,#111 225deg 247.5deg,#fff 247.5deg 270deg,#111 270deg 292.5deg,#fff 292.5deg 315deg,#111 315deg 337.5deg,#fff 337.5deg 360deg);width:100%;height:100%;display:block}.compass-label{color:#111;font-size:10px;font-weight:800;line-height:1;position:absolute}.compass-label.north{top:-10px;left:50%;transform:translate(-50%)}.compass-label.east{top:50%;right:-10px;transform:translateY(-50%)}.compass-label.south{bottom:-10px;left:50%;transform:translate(-50%)}.compass-label.west{top:50%;left:-10px;transform:translateY(-50%)}.elevation-symbol{z-index:8;width:52px;height:46px;position:absolute;top:24%;left:6%}.elevation-symbol span{z-index:2;background:#fff;border:1px solid #8c8c8c;border-radius:50%;width:38px;height:38px;display:block;position:absolute;top:4px;left:13px}.elevation-wing{z-index:1;width:0;height:0;position:absolute;left:0}.elevation-wing.top{border-bottom:15px solid #0000;border-right:18px solid #111;top:0}.elevation-wing.middle{border-top:18px solid #0000;border-bottom:18px solid #0000;border-right:24px solid #111;top:5px}.elevation-wing.bottom{border-top:15px solid #0000;border-right:18px solid #111;bottom:0}.report-map-marker{border:calc(var(--marker-stroke,3px) * var(--symbol-scale)) solid #003cff;color:red;cursor:grab;font-family:Arial,Helvetica,sans-serif;font-size:calc(12px * var(--symbol-scale));height:calc(var(--marker-size,39px) * var(--symbol-scale));touch-action:none;-webkit-user-select:none;user-select:none;width:calc(var(--marker-size,39px) * var(--symbol-scale));z-index:7;background:0 0;border-radius:50%;justify-content:center;align-items:center;padding:0;font-weight:700;display:inline-flex;position:absolute;transform:translate(-50%,-50%)}.report-map-marker i{height:calc(3px * var(--symbol-scale));transform:translateY(-50%) rotate(var(--arrow-angle,0deg));transform-origin:0;width:calc(18px * var(--symbol-scale));background:#003cff;position:absolute;top:50%;left:calc(100% - 1px)}.report-map-marker i:after{border-bottom:calc(6px * var(--symbol-scale)) solid transparent;border-left:calc(8px * var(--symbol-scale)) solid #003cff;border-top:calc(6px * var(--symbol-scale)) solid transparent;content:"";right:calc(-6px * var(--symbol-scale));top:calc(-4px * var(--symbol-scale));position:absolute}.report-map-marker.defect{border-color:#003cff}.report-map-marker.general{background:#eaffff}.report-map-marker.square{border-radius:5px}.report-map-marker.active{box-shadow:0 0 0 5px #003cff2e}.report-map-marker.moving{cursor:grabbing;z-index:12;box-shadow:0 0 0 7px #003cff38}.report-area-marker{color:#003cff;z-index:6;background:#fffc2d33;border:2px solid #003cff;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:inline-flex;position:absolute}.report-area-marker.active{box-shadow:0 0 0 4px #003cff29}.report-footer{font-family:Arial,Helvetica,sans-serif;font-size:10px;position:absolute;bottom:22px;right:54px}.legend-row{border-top:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:12px;min-height:48px;padding:10px 14px;display:flex}.legend-row label{color:#405066;align-items:center;gap:6px;font-size:12px;font-weight:700;display:flex}.inspector-panel{flex-direction:column;min-width:0;display:flex}.marker-summary{align-items:flex-start;gap:10px;padding:14px;display:flex}.marker-summary strong{font-size:14px;display:block}.marker-summary p{color:var(--muted);margin:3px 0 0;font-size:12px;line-height:1.45}.marker-actions{padding:0 14px 14px}.marker-dot{border-radius:999px;flex:none;width:12px;height:12px;margin-top:3px;display:inline-block}.marker-dot.photo-no\.,.marker-dot.photo-no{background:var(--accent)}.marker-dot.defect-no\.,.marker-dot.defect-no{background:var(--red)}.marker-dot.general-view{background:var(--teal)}.marker-dot.inspected-area{background:var(--amber)}.field-stack{border-top:1px solid var(--border);gap:10px;padding:14px;display:grid}.symbol-control-panel{border-top:1px solid var(--border);gap:12px;padding:14px;display:grid}.symbol-control-heading{grid-template-columns:58px minmax(0,1fr);align-items:center;gap:10px;display:grid}.symbol-control-heading strong{font-size:13px;display:block}.symbol-control-heading p{color:var(--muted);margin:3px 0 0;font-size:12px;line-height:1.35}.symbol-control-preview{--symbol-scale:.82;border:calc(var(--marker-stroke,3px) * var(--symbol-scale)) solid #003cff;color:red;font-size:calc(12px * var(--symbol-scale));height:calc(var(--marker-size,39px) * var(--symbol-scale));width:calc(var(--marker-size,39px) * var(--symbol-scale));background:#eaffff;border-radius:50%;justify-content:center;align-items:center;font-weight:800;display:inline-flex;position:relative}.symbol-control-preview.square{border-radius:5px}.symbol-control-preview i{height:2px;transform:translateY(-50%) rotate(var(--arrow-angle,0deg));transform-origin:0;background:#003cff;width:18px;position:absolute;top:50%;left:calc(100% - 1px)}.symbol-control-preview i:after{content:"";border-top:5px solid #0000;border-bottom:5px solid #0000;border-left:7px solid #003cff;position:absolute;top:-4px;right:-6px}.symbol-control-panel label{color:#405066;gap:7px;font-size:12px;font-weight:750;display:grid}.symbol-control-panel label span{justify-content:space-between;align-items:center;display:flex}.symbol-control-panel output{color:var(--muted);font-size:11px;font-weight:800}.symbol-control-panel input[type=range]{accent-color:var(--accent);width:100%}.symbol-control-panel select{background:var(--surface-muted);border:1px solid var(--border);color:var(--text);border-radius:7px;width:100%;min-height:34px;padding:7px 9px}.field-stack label{color:#405066;gap:6px;font-size:12px;font-weight:750;display:grid}.field-stack input,.field-stack select,.field-stack textarea,.rename-row select{background:var(--surface-muted);border:1px solid var(--border);color:var(--text);border-radius:7px;width:100%;min-height:36px;padding:8px 9px}.field-stack textarea{resize:vertical;min-height:86px}.export-box{border-top:1px solid var(--border);gap:10px;padding:14px;display:grid}.export-box>div:first-child{align-items:center;gap:8px;display:flex}.export-box span{font-size:13px;font-weight:750}.export-box strong{color:var(--amber);font-size:13px}.export-box.subtle strong{color:var(--green)}.lower-grid{grid-template-columns:minmax(0,1.35fr) minmax(360px,.65fr);gap:14px;min-height:276px;margin-top:14px;display:grid}.rename-row{background:var(--surface-muted);border-bottom:1px solid var(--border);grid-template-columns:240px minmax(0,1fr);align-items:center;gap:10px;padding:10px 14px;display:grid}.rename-row span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.photo-grid{grid-template-columns:repeat(9,minmax(76px,1fr));gap:10px;padding:14px;display:grid;overflow:auto}.thumb{color:var(--text);text-align:left;background:0 0;border:1px solid #0000;border-radius:7px;gap:5px;padding:6px;display:grid}.thumb:hover,.thumb.active{background:#eef6ff;border-color:#a9c9f7}.thumb-image{aspect-ratio:4/3;border:1px solid var(--border);color:#ffffffe0;border-radius:6px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.thumb-image:before,.thumb-image:after{content:"";position:absolute}.thumb-image:before{background:#ffffff3d;width:82%;height:36%;bottom:12%;left:10%;transform:skew(-14deg)}.thumb-image:after{background:#0c203847;width:18%;height:100%;top:0;right:22%}.thumb-image svg{z-index:1;position:relative}.tone-1{background:linear-gradient(135deg,#375a7d,#91a8bf)}.tone-2{background:linear-gradient(135deg,#3f716a,#98b9ad)}.tone-3{background:linear-gradient(135deg,#7c6442,#ccb58a)}.tone-4{background:linear-gradient(135deg,#5c687a,#b1bcc9)}.tone-5{background:linear-gradient(135deg,#2f596e,#88b6c9)}.tone-6{background:linear-gradient(135deg,#74616d,#c2aeb8)}.thumb span{font-size:12px;font-weight:800}.thumb small{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.summary-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;padding:14px;display:grid}.summary-row div{background:var(--surface-muted);border:1px solid var(--border);border-radius:7px;padding:10px}.summary-row strong{margin-top:4px;font-size:17px;display:block}.metadata-table{padding:0 14px 14px;display:grid}.table-head,.table-row{grid-template-columns:minmax(0,1fr) 70px 104px;display:grid}.table-head{border:1px solid var(--border);color:var(--muted);text-transform:uppercase;background:#eef3f8;border-radius:7px 7px 0 0;min-height:34px;font-size:11px;font-weight:800}.table-row{border-bottom:1px solid var(--border);border-left:1px solid var(--border);border-right:1px solid var(--border);min-height:38px}.table-row:last-child{border-radius:0 0 7px 7px}.table-head span,.table-row span{text-overflow:ellipsis;white-space:nowrap;align-items:center;min-width:0;padding:0 10px;display:flex;overflow:hidden}.table-row span{color:#2b394a;font-size:12px;font-weight:650}.status{gap:5px}.status.ready{color:var(--green)}.status.draft{color:var(--amber)}.status.queued{color:#53616f}@media (width<=1180px){.app-shell{grid-template-columns:72px minmax(0,1fr)}.brand div:not(.brand-mark),.nav-item span,.capacity-panel{display:none}.brand{justify-content:center}.nav-item{justify-content:center;padding:0}.workbench,.lower-grid{grid-template-columns:1fr}.inspector-panel{min-height:auto}.photo-grid{grid-template-columns:repeat(6,minmax(82px,1fr))}}@media (width<=760px){.app-shell{display:block}.side-nav{border-bottom:1px solid var(--border);border-right:0;padding:10px;display:block}.brand{justify-content:start;margin-bottom:10px}.brand div:not(.brand-mark){display:block}.nav-list{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;display:grid;overflow:visible}.nav-item{flex-direction:column;gap:3px;min-height:48px;padding:6px 4px}.nav-item span{font-size:11px;display:inline}.workspace{padding:12px}.topbar{flex-direction:column;align-items:stretch}.topbar-copy{min-width:0}.topbar-actions{flex-wrap:wrap;align-items:stretch}.search-field{width:100%}.button{flex:150px}.status-strip,.summary-row{grid-template-columns:1fr}.drawing-board{padding:10px}.markup-mode-bar{flex-direction:column;align-items:stretch}.markup-tool-tabs{width:100%}.markup-tool-button{flex:1 1 0}.markup-mode-status{text-align:left}.report-sheet{width:100%;min-height:520px;padding:22px 18px 20px}.report-header{min-height:58px}.report-header p{margin-top:10px;font-size:7px}.report-logo{width:62px}.report-logo span{width:52px;height:34px}.report-logo small{font-size:5px}.report-rule{margin-bottom:18px}.report-sheet h2{margin-bottom:10px;font-size:10px}.report-sheet h3{margin:0 0 12px 76px;font-size:9px}.markup-layout{grid-template-columns:88px minmax(0,1fr);gap:8px}.report-legend{gap:8px;padding:6px;font-size:8px}.report-legend strong{font-size:15px}.report-legend div{grid-template-columns:26px 1fr;gap:5px}.legend-swatch{width:20px;height:20px}.legend-photo-no{border-width:2px;width:25px;height:25px;font-size:9px}.report-plan{--symbol-scale:.67;min-height:280px}.report-room{font-size:8px}.fixture-row{gap:3px}.fixture-row span{width:12px;height:8px}.report-map-marker{border-width:calc(var(--marker-stroke,3px) * var(--symbol-scale));font-size:calc(12px * var(--symbol-scale));height:calc(var(--marker-size,39px) * var(--symbol-scale));width:calc(var(--marker-size,39px) * var(--symbol-scale))}.report-map-marker i{height:calc(3px * var(--symbol-scale));width:calc(18px * var(--symbol-scale))}.report-map-marker i:after{border-bottom-width:calc(6px * var(--symbol-scale));border-left-width:calc(8px * var(--symbol-scale));border-top-width:calc(6px * var(--symbol-scale));right:calc(-6px * var(--symbol-scale));top:calc(-4px * var(--symbol-scale))}.report-area-marker{border-width:1px;font-size:8px}.report-footer{font-size:7px;bottom:14px;right:18px}.legend-row{flex-direction:column;align-items:flex-start}.rename-row{grid-template-columns:1fr}.photo-grid{grid-template-columns:repeat(3,minmax(86px,1fr))}.table-head,.table-row{grid-template-columns:minmax(0,1fr) 52px 92px}}
