.viewer-header{background:var(--surface);border-bottom:1px solid var(--border);gap:clamp(12px,3vw,28px);justify-content:space-between;padding:12px clamp(20px,4vw,28px)}.header-left,.viewer-header{align-items:flex-start;display:flex}.header-left{gap:14px;padding-top:4px}.brand{align-items:center;display:flex;gap:12px}.brand-logo{display:inline-block;flex-shrink:0;height:120px;margin:-30px 0;width:120px}.brand-logo img{display:block;height:100%;object-fit:contain;width:100%}.header-center{align-items:center;display:flex;flex:1 1;justify-content:center;overflow:visible;padding-top:0}.summary-title-img{max-height:70px;width:auto}.header-center .brand{align-items:center;display:flex;flex-direction:column;gap:0;height:auto;position:relative}.header-center .brand-logo{display:none}.header-center .brand-copy{text-align:center;width:-webkit-max-content;width:max-content}.header-right{align-items:flex-end;gap:8px;justify-content:flex-start}.header-right,.property-details{display:flex;flex-direction:column}.property-details{gap:2px;line-height:1.3;text-align:right}.property-details h1{color:var(--text-primary);font-size:16px;font-weight:600;letter-spacing:-.01em;margin:0}.property-meta{color:var(--text-primary);font-size:14px;font-weight:500;letter-spacing:0;margin:0;text-transform:none}.download-dropdown{position:relative}.dropdown-toggle,.viewer-button{align-items:center;display:inline-flex;gap:6px}.viewer-button{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:12px;font-weight:500;letter-spacing:.02em;padding:6px 12px;transition:color .2s ease,border-color .2s ease,background .2s ease}.viewer-button.primary{background:var(--accent-soft)}.viewer-button.primary,.viewer-button:hover{border-color:var(--accent);color:var(--accent)}.dropdown-menu{background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-soft);margin-top:4px;min-width:220px;position:absolute;right:0;top:100%;z-index:100}.dropdown-item{align-items:center;background:#0000;border:none;color:var(--text-primary);cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:8px;padding:10px 14px;text-align:left;transition:background .2s ease;width:100%}.dropdown-item:hover{background:var(--surface-alt)}.dropdown-item:first-child{border-radius:7px 7px 0 0}.dropdown-item:last-child{border-radius:0 0 7px 7px}.dropdown-item i{color:var(--priority-high)}@media (max-width:640px){.viewer-header{align-items:center;flex-direction:row;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:12px 16px}.header-left{order:1}.header-center{flex:none;order:3;width:100%}.header-right{align-items:flex-end;flex-direction:column;gap:8px;order:2}.brand-logo{height:70px;margin:-10px 0;width:70px}.summary-title-img{max-height:50px}.property-details{text-align:right}.property-details h1{font-size:14px}.property-meta{font-size:12px}.viewer-button{flex:1 1;font-size:11px;justify-content:center}}.zones-bar{background:var(--surface);border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:0;padding:12px clamp(16px,3vw,20px) 16px}.zones-grid{grid-gap:8px 4px;display:grid;gap:8px 4px;grid-template-columns:repeat(8,1fr);width:100%}.legend-item{--zone-accent:var(--accent);background:#0000;border:1px solid var(--border);border-radius:12px;min-width:0;transition:border-color .2s ease,box-shadow .2s ease}.legend-item.active{border:1px solid var(--zone-accent);box-shadow:0 12px 24px #0f172a1f}.legend-item.empty{opacity:1}.legend-button{align-items:center;background:var(--surface);border:none;border-radius:9px;color:inherit;cursor:pointer;display:flex;font:inherit;justify-content:space-between;outline:none;overflow:hidden;padding:5px 8px;text-align:left;transition:background .2s ease;width:100%}.legend-button:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.legend-item.active .legend-button{background:var(--surface-alt)}.legend-labels{display:flex;flex:1 1;gap:8px}.legend-labels,.legend-name{align-items:center;min-width:0}.legend-name{color:var(--text-primary);display:inline-flex;font-size:12px;font-weight:500;gap:6px;letter-spacing:.01em}.legend-number{align-items:center;background:var(--zone-dim);border:1px solid #0000;border-radius:999px;color:#fff;display:inline-flex;flex-shrink:0;font-size:10px;font-weight:600;height:20px;justify-content:center;transition:box-shadow .2s ease;width:20px}.legend-item.active .legend-number{box-shadow:0 0 0 2px var(--surface)}.legend-text{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-meta{align-items:center;color:var(--text-primary);display:flex;flex-shrink:0;font-size:12px;font-weight:500;gap:4px;margin-left:auto}@media (max-width:900px){.zones-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:640px){.zones-bar{padding:12px 16px}.zones-grid{gap:5px;grid-template-columns:1fr}}.canvas-area{align-items:center;background:var(--bg-page);display:flex;flex:1 1;flex-direction:column;justify-content:flex-start;min-height:0;overflow:hidden;padding:0;position:relative}.canvas-image-container{display:inline-block;line-height:0;position:relative}.canvas-image-container img{display:block;height:auto;max-height:calc(100vh - 195px);max-width:100%;width:auto}.zone-overlay-layer{inset:0;pointer-events:none;position:absolute}.zone-overlay{align-items:center;background:var(--zone-medium);border:2px solid #fff;border-radius:50%;box-shadow:0 18px 32px #0f172a2e;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;height:44px;justify-content:center;letter-spacing:.02em;pointer-events:auto;position:absolute;transform:translate(-50%,-50%);transition:transform .2s ease,background .2s ease,opacity .2s ease;width:44px}.zone-overlay.active{box-shadow:0 0 0 3px #ffffffe6,0 22px 40px #0f172a47;opacity:1;transform:translate(-50%,-50%) scale(1.12)}.zone-overlay.dimmed{background:var(--zone-dim);box-shadow:none;color:#fff;opacity:.55}.zone-overlay.dimmed:hover{opacity:.7;transform:translate(-50%,-50%)}.zone-overlay.empty{box-shadow:none}.zone-overlay.empty.dimmed{opacity:.35}@media (max-width:640px){.canvas-area{flex:0 0 auto;height:calc(100vh - 260px);max-height:calc(100vh - 260px);min-height:0;overflow:hidden;padding:0}.canvas-image-container img{max-height:calc(100vh - 300px)}.zone-overlay{font-size:11px;height:32px;width:32px}}.side-panel{background:var(--surface);border-left:1px solid var(--border);border-radius:0;box-shadow:none;display:flex;flex:0 0 min(420px,35vw);flex-direction:column;height:100%;min-height:0;overflow:hidden;width:min(420px,35vw)}.panel-handle{display:none}.mobile-summary{background:var(--surface);border-bottom:1px solid var(--border);display:none;padding:16px}.mobile-summary-content{align-items:center;display:flex;gap:16px;justify-content:center}.mobile-summary-stats{display:flex;flex-wrap:nowrap;gap:32px;justify-content:space-around;padding:8px 16px;width:100%}.mobile-stat{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:4px;text-align:center}.mobile-stat-value{color:var(--text-primary);font-size:24px;font-weight:700}.mobile-stat-label{color:var(--text-muted);font-size:11px;letter-spacing:.05em;text-transform:uppercase}.findings-section{border-bottom:1px solid var(--border);display:flex;flex:1 1;flex-direction:column;gap:12px;min-height:0;padding:16px 18px}.section-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.section-header h2{font-size:15px;font-weight:600;letter-spacing:-.01em;margin:0}.findings-count{color:var(--text-muted);font-size:14px;font-weight:400;margin-left:8px}.legend-filters{display:flex;flex-wrap:nowrap;gap:5px;margin-bottom:12px}.filter-button{background:#0000;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);cursor:pointer;font-size:10px;font-weight:500;letter-spacing:.02em;padding:4px 8px;text-transform:uppercase;transition:all .2s ease;white-space:nowrap}.filter-button:hover,.filter-button[aria-pressed=true]{border-color:var(--accent);color:var(--accent)}.filter-button[aria-pressed=true]{background:var(--accent-soft)}.state-message{background:var(--surface-alt);border:1px solid var(--border);border-radius:8px;color:var(--text-secondary);font-size:13px;padding:18px}.findings-scroll{flex:1 1;overflow:auto;scrollbar-color:#c8ccd666 #0000;scrollbar-width:thin}.findings-list{display:flex;flex-direction:column;gap:10px}.finding-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 14px #0f172a14;padding:16px;transition:box-shadow .2s ease,transform .2s ease}.finding-card:hover{box-shadow:0 12px 26px #0f172a1f;transform:translateY(-2px)}.finding-card header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.finding-title{font-size:14px;font-weight:400;margin:0}.finding-detail{color:var(--text-secondary);font-size:13px;line-height:1.55;margin:12px 0 0}.priority-chip{border:1px solid;border-radius:999px;flex-shrink:0;font-size:11px;font-weight:600;letter-spacing:.08em;padding:4px 12px;text-transform:uppercase}.media-strip{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.media-thumb{background:#000;border:1px solid var(--border);border-radius:10px;cursor:pointer;height:70px;overflow:hidden;padding:0;position:relative;width:94px}.media-thumb.video-thumb{background:linear-gradient(135deg,#1e293b,#334155);height:100px;width:140px}.media-thumb img,.media-thumb video{height:100%;object-fit:cover;transition:opacity .3s ease;width:100%}.video-placeholder{align-items:center;background:linear-gradient(135deg,#1e293b,#334155);color:#fff6;display:flex;font-size:24px;height:100%;justify-content:center;width:100%}.media-thumb span{background:#111827bf;border-radius:4px;bottom:6px;color:#fff;font-size:10px;letter-spacing:.08em;padding:3px 6px;position:absolute;right:6px}.media-thumb:after{border:2px solid #0000;border-radius:10px;content:"";inset:0;position:absolute;transition:border-color .2s ease}.media-thumb:focus-visible:after,.media-thumb:hover:after{border-color:var(--accent)}@media (max-width:1080px){.side-panel{flex:0 0 min(360px,38vw);width:min(360px,38vw)}}@media (max-width:640px){.side-panel{background:var(--surface);border:none;border-radius:20px 20px 0 0;border-top:1px solid var(--border-strong);bottom:0;box-shadow:0 -12px 32px #1117292e;display:flex;flex-direction:column;height:auto;left:0;max-height:none;max-width:none;position:fixed;right:0;transform:translateY(0);transition:transform .32s ease;width:100%;z-index:100}.side-panel.collapsed{max-height:120px;transform:translateY(calc(100% - 120px))}.side-panel:not(.collapsed){height:calc(100vh - 95px);max-height:calc(100vh - 95px)}.panel-handle{-webkit-tap-highlight-color:transparent;background:var(--surface);border-radius:20px 20px 0 0;cursor:pointer;display:block;padding:10px 0 6px;text-align:center;touch-action:manipulation}.panel-handle .handle-bar{background:var(--border-strong);border-radius:3px;display:inline-block;height:5px;width:48px}.mobile-summary{cursor:pointer;display:block;padding:4px 8px 16px}.side-panel.collapsed .mobile-summary{cursor:pointer}.side-panel.collapsed .findings-section{display:none}.findings-section{padding:12px 14px}.section-header h2{font-size:14px}.legend-filters{flex-wrap:wrap;gap:4px}.filter-button{font-size:10px;padding:4px 8px}.finding-card{padding:12px}.finding-card header{align-items:flex-start;flex-direction:column;gap:8px}.finding-title{font-size:13px}.finding-detail{font-size:12px}.priority-chip{font-size:10px;padding:3px 10px}.media-thumb{height:60px;width:80px}.side-panel:not(.collapsed){height:55vh;max-height:55vh}.side-panel.collapsed{max-height:100px;transform:translateY(calc(100% - 100px))}.mobile-summary{display:block}}.lightbox{background:#111729bf;display:grid;inset:0;padding:40px;place-items:center;position:fixed;z-index:999}.lightbox-content{background:var(--surface);border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:min(92vw,980px)}.lightbox-footer,.lightbox-header{align-items:center;display:flex;justify-content:space-between;padding:16px 22px}.lightbox-header{border-bottom:1px solid var(--border)}.lightbox-footer{border-top:1px solid var(--border)}.lightbox-header h3{font-size:14px;letter-spacing:.05em;margin:0}.lightbox-body{background:#111827;display:grid;flex:1 1;min-height:300px;place-items:center;position:relative}.lightbox-media{align-items:center;display:flex;height:100%;justify-content:center;width:100%}.lightbox-media img,.lightbox-media video{max-height:82vh;max-width:100%}.lightbox-close{background:#0000;border:1px solid var(--border);border-radius:6px;cursor:pointer;font-size:12px;letter-spacing:.08em;padding:6px 12px;transition:border-color .2s ease,color .2s ease}.lightbox-close:hover{border-color:var(--accent);color:var(--accent)}.lightbox-controls{align-items:center;color:var(--text-secondary);display:flex;font-size:12px;gap:12px}.lightbox-caption{color:var(--text-primary);font-size:13px}.lightbox-counter{color:var(--text-muted);font-size:12px}.lightbox-nav{align-items:center;display:flex;inset:0;justify-content:space-between;padding:0 16px;pointer-events:none;position:absolute}.lightbox-nav button{align-items:center;background:#11182799;border:1px solid #ffffff3d;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:20px;height:44px;justify-content:center;pointer-events:auto;transition:background .2s ease,border-color .2s ease;width:44px}.lightbox-nav button:hover:not(:disabled){background:#111827cc;border-color:#fff6}.lightbox-nav button:disabled{cursor:not-allowed;opacity:.4}@media (max-width:640px){.lightbox{padding:20px 10px}.lightbox-content{width:95vw}.lightbox-footer,.lightbox-header{padding:12px 16px}.lightbox-nav button{font-size:16px;height:36px;width:36px}}.report-viewer{flex-direction:column;height:100%}.report-viewer,.viewer-main{display:flex;gap:0;overflow:hidden}.viewer-main{align-items:stretch;flex:1 1;min-height:0;padding:0}@media (max-width:640px){.report-viewer{overflow-y:auto}.viewer-main{flex-direction:column;min-height:100vh;padding:0}}.report-page{display:flex;flex-direction:column;height:100vh;overflow:hidden}.report-viewer-container{flex:1 1;overflow:hidden}.report-loading{align-items:center;background:#f8fafc;display:flex;flex:1 1;flex-direction:column;gap:1rem;justify-content:center}.report-loading p{color:#64748b;font-size:1.125rem}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#3b82f6;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.report-error{align-items:center;background:#f8fafc;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:2rem;text-align:center}.report-error h2{color:#dc2626;margin-bottom:.5rem}.report-error p{color:#64748b;margin:.25rem 0}.zone-position-editor{background:#1a1a2e;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh;padding:20px}.editor-header{margin-bottom:20px;text-align:center}.editor-header h1{color:#10b981;font-size:24px;margin:0 0 8px}.editor-header p{color:#94a3b8;font-size:14px;margin:0}.editor-controls{align-items:center;background:#16213e;border-radius:8px;display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-bottom:20px;padding:16px}.editor-controls label{align-items:center;display:flex;font-size:14px;gap:8px}.editor-controls select{background:#1e293b;border:1px solid #334155;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 12px}.editor-controls button{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.btn-save{background:#10b981;color:#fff}.btn-save:hover{background:#059669}.btn-copy{background:#3b82f6;color:#fff}.btn-copy:hover{background:#2563eb}.btn-export{background:#8b5cf6;color:#fff}.btn-export:hover{background:#7c3aed}.editor-main{align-items:flex-start;display:flex;gap:20px}.image-container{background:#0f172a;border-radius:8px;flex:1 1;max-width:calc(100% - 320px);overflow:hidden;position:relative;-webkit-user-select:none;user-select:none}.image-container img{display:block;height:auto;pointer-events:none;width:100%}.zone-marker{align-items:center;background:#10b981;border:3px solid #fff;border-radius:50%;box-shadow:0 4px 12px #0006;color:#fff;cursor:grab;display:flex;font-size:14px;font-weight:700;height:40px;justify-content:center;position:absolute;transform:translate(-50%,-50%);transition:transform .1s,box-shadow .1s;width:40px;z-index:10}.zone-marker:hover{box-shadow:0 6px 20px #10b98180;transform:translate(-50%,-50%) scale(1.1);z-index:20}.zone-marker.dragging{background:#059669;box-shadow:0 8px 24px #10b98199;cursor:grabbing;transform:translate(-50%,-50%) scale(1.2);z-index:100}.coordinates-panel{background:#16213e;border-radius:8px;max-height:calc(100vh - 200px);overflow-y:auto;padding:16px;width:300px}.coordinates-panel h3{border-bottom:1px solid #334155;color:#10b981;font-size:16px;margin:0 0 16px;padding-bottom:8px}.coordinates-list{display:flex;flex-direction:column;gap:8px}.coordinate-item{grid-gap:8px;align-items:center;background:#1e293b;border-radius:6px;display:grid;font-size:12px;gap:8px;grid-template-columns:30px 1fr auto;padding:8px}.zone-number{align-items:center;background:#10b981;border-radius:50%;color:#fff;display:flex;font-size:11px;font-weight:700;height:24px;justify-content:center;width:24px}.zone-name{color:#e2e8f0;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.zone-coords{color:#94a3b8;font-family:monospace;font-size:11px}@media (max-width:900px){.editor-main{flex-direction:column}.image-container{max-width:100%}.coordinates-panel{max-height:300px;width:100%}}:root{--bg-page:#f5f6f9;--surface:#fff;--surface-alt:#f8f9fb;--border:#d8dce5;--border-strong:#c4c8d4;--text-primary:#151823;--text-secondary:#5e6373;--text-muted:#8d92a3;--accent:#1d4ed8;--accent-soft:#1d4ed829;--priority-high:#dc2626;--priority-low:#047857;--warning:#f59e0b;--shadow-soft:0 6px 18px #1117291a;--zone-high:#dc2626;--zone-medium:#f59e0b;--zone-clear:#10b981;--zone-dim:#a1a6b7;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*,:after,:before{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f6f9;background:var(--bg-page);color:#151823;color:var(--text-primary);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0}body.lightbox-open{overflow:hidden}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#c8ccd666;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#c8ccd699}button{font-family:inherit}a{color:#1d4ed8;color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}
/*# sourceMappingURL=main.6d755ca0.css.map*/