:root{--panel: #ffffff;--border: #e4eaec;--border-soft: #eef2f3;--border-faint: #f1f5f5;--text: #16252b;--muted: #7c8c93;--muted-2: #9bacb2;--nav: #5a6b71;--accent: #2e7bff;--danger: #d05a5a;--danger-border: #f0dada;--bg: #ffffff;--surface: #fbfcfd;--surface-2: #f0f4f5;--input-bg: #fbfcfd;--accent-soft: #eaf2ff;--accent-border: #bcd5ff;--accent-strong: #2665d1;--accent-grad: #609bff;--accent-ring: rgba(46, 123, 255, .12);--accent-shadow: rgba(46, 123, 255, .18);--mono: "Geist Mono", ui-monospace, "SFMono-Regular", Menlo, monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Geist,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;color:var(--text);background:var(--bg)}h1,h2,h3,h4{font-weight:700;letter-spacing:-.02em}button{font-family:inherit}input,select,textarea{font-family:inherit;color:var(--text)}.app{display:grid;grid-template-columns:380px 1fr;height:100vh;height:100dvh;overflow:hidden}.panel{background:var(--panel);border-right:1px solid var(--border);display:grid;grid-template-rows:1fr auto;min-height:0;overflow:hidden}.panel-scroll{overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px;min-height:0}.panel-head{display:flex;align-items:center;gap:11px}.panel-head h1{margin:0;font-size:19px}.panel-head-sub{display:block;font-size:12px;color:var(--muted);margin-top:1px}.brand-mark{flex:none;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:linear-gradient(160deg,var(--accent-grad),var(--accent))}.brand-mark.big{width:44px;height:44px;border-radius:12px;margin-bottom:6px}.panel-footer{padding:14px 20px calc(20px + env(safe-area-inset-bottom,0px));background:var(--panel);border-top:1px solid var(--border);box-shadow:0 -8px 20px #0f172a0f;display:flex;flex-direction:column;gap:10px}.footer-total{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);font-variant-numeric:tabular-nums}.job-card{border:1px solid var(--border);border-radius:12px;background:var(--surface)}.job-card-row{display:flex;align-items:center;gap:10px;padding:12px 14px}.job-card-icon{flex:none;display:inline-flex;color:var(--accent)}.job-card-headtext{min-width:0;display:flex;flex-direction:column;gap:1px}.job-card-title{font-size:14px;font-weight:700;overflow:hidden;text-overflow:ellipsis}.job-card-sub{font-size:12px;color:var(--muted)}.hint{padding:8px 10px;background:var(--accent-soft);border:1px solid var(--accent-border);border-radius:8px;font-size:12px;color:#1e40af;line-height:1.4}.field-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.empty{margin:0;font-size:13px;color:var(--muted);line-height:1.55}.measure-empty{border:1px dashed var(--border);border-radius:10px;padding:14px}.link{background:none;border:none;cursor:pointer;font-size:12px;padding:0;color:var(--accent);font-weight:600}.link.danger{color:var(--danger)}.measurements{display:flex;flex-direction:column;gap:10px}.measure-row{border:1px solid var(--border);border-radius:10px;padding:12px;scroll-margin:12px}.measure-row.collapsed{padding:9px 12px}.measure-row.flash{animation:row-flash 1.2s ease-out}@keyframes row-flash{0%{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb59}to{border-color:var(--border);box-shadow:0 0 #2563eb00}}.measure-head{width:100%;display:flex;align-items:center;gap:8px;border:none;background:none;padding:0;cursor:pointer;text-align:left;font-size:14px;color:var(--text)}.row-chev{flex:none;color:var(--muted-2);font-size:12px;transition:transform .15s ease}.row-chev.open{transform:rotate(90deg)}.swatch{flex:none;width:14px;height:14px;border-radius:4px}.measure-title{flex:1;min-width:0;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.measure-metrics{display:flex;align-items:center;gap:10px}.value{font-size:13px;color:var(--nav);font-variant-numeric:tabular-nums;white-space:nowrap}.measure-remove{flex:none;color:var(--danger);font-size:13px;padding:2px 5px;border-radius:6px;cursor:pointer}.measure-remove:hover{background:#fdf4f4}.measure-body{margin-top:11px;display:flex;flex-direction:column;gap:10px}.measure-field{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.measure-field select{padding:9px 11px;border:1px solid var(--border);border-radius:8px;font-size:14px;font-weight:400;text-transform:none;letter-spacing:normal;background:var(--input-bg)}.measure-field select:focus{outline:2px solid var(--accent);border-color:var(--accent)}.measure-tip{margin:0;font-size:12px;color:var(--muted);line-height:1.4}.deductions{border-top:1px dashed var(--border);padding-top:8px;display:flex;flex-direction:column;gap:5px}.deduction-row{display:flex;align-items:center;justify-content:space-between;font-size:12.5px}.deduction-label{color:var(--danger);font-variant-numeric:tabular-nums}.add-deduction{width:100%;padding:8px;border:1px dashed var(--danger-border);border-radius:8px;background:#fef2f2;color:var(--danger);font-size:12.5px;font-weight:600;cursor:pointer}.add-deduction:hover{border-color:var(--danger)}@keyframes reveal{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.reveal{animation:reveal .22s ease}.finalize{padding:13px;border:none;border-radius:10px;background:#16a34a;color:#fff;font-size:15px;font-weight:700;cursor:pointer}.finalize:hover:not(:disabled){background:#15803d}.finalize:disabled{opacity:.6;cursor:default}.cfg-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 15px;border-radius:9px;border:1px solid var(--border);background:var(--panel);color:var(--text);font-size:14px;font-weight:600;cursor:pointer;transition:background .12s,border-color .12s,box-shadow .12s}.cfg-btn:hover:not(:disabled){background:var(--surface-2)}.cfg-btn:disabled{opacity:.55;cursor:default}.cfg-btn-primary{border-color:transparent;background:var(--accent);color:#fff;box-shadow:0 1px 2px var(--accent-shadow)}.cfg-btn-primary:hover:not(:disabled){background:var(--accent-strong)}.map-wrap{position:relative;height:100%;min-height:0}.map-holder{position:absolute;top:0;right:0;bottom:0;left:0}.map{width:100%;height:100%}.map-toolbar{position:absolute;top:12px;left:50%;transform:translate(-50%);z-index:6;display:flex;flex-wrap:wrap;justify-content:center;gap:6px;padding:5px;border-radius:12px;background:#fffffff5;box-shadow:0 2px 10px #0f172a40}.map-tool{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border:1px solid var(--border);border-radius:8px;background:var(--input-bg);font-size:13px;font-weight:600;color:var(--text);cursor:pointer;white-space:nowrap}.map-tool[data-tip]:hover:after{content:attr(data-tip);position:absolute;top:calc(100% + 9px);left:50%;transform:translate(-50%);padding:7px 10px;border-radius:7px;background:#0f172a;color:#fff;font-size:12px;font-weight:500;line-height:1.3;white-space:normal;width:max-content;max-width:230px;text-align:center;box-shadow:0 4px 14px #0f172a59;z-index:11;pointer-events:none}.map-tool[data-tip]:hover:before{content:"";position:absolute;top:calc(100% + 3px);left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#0f172a;z-index:11;pointer-events:none}.map-tool:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.map-tool.active{background:var(--accent);border-color:var(--accent);color:#fff}.map-tool:disabled{opacity:.5;cursor:not-allowed}.map-drawing-bar{position:absolute;top:60px;left:50%;transform:translate(-50%);z-index:7;width:min(440px,calc(100% - 28px))}.measure-control.drawing{background:#fff;border:1.5px solid var(--accent);border-radius:12px;padding:10px 14px;box-shadow:0 4px 16px #16252b38}.measuring-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.measuring-label{color:var(--accent-strong);font-size:14px;font-weight:600}.measuring-hint{margin:5px 0 0;font-size:12px;color:var(--muted)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--panel);border-radius:14px;padding:22px;width:100%;max-width:420px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:10px;box-shadow:0 12px 40px #00000040}.modal h2{margin:0;font-size:18px}.modal-sub{margin:0 0 6px;font-size:13px;color:var(--muted);line-height:1.45}.modal-field{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.modal-field textarea{padding:9px 11px;border:1px solid var(--border);border-radius:8px;font-size:15px;font-weight:400;text-transform:none;letter-spacing:normal;resize:vertical;background:var(--input-bg)}.modal-field textarea:focus{outline:2px solid var(--accent);border-color:var(--accent)}.modal-actions{display:flex;align-items:center;justify-content:space-between;margin-top:8px;gap:10px}.modal-actions .finalize{width:auto;padding:11px 18px}.summary-list{border:1px solid var(--border);border-radius:10px;padding:4px 12px}.summary-row{display:flex;align-items:center;gap:9px;padding:8px 0;border-bottom:1px solid var(--border-faint);font-size:13.5px}.summary-row:last-of-type{border-bottom:none}.summary-name{flex:1;min-width:0;overflow:hidden;font-weight:600}.summary-svc{display:block;font-size:11.5px;font-weight:500;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-value{color:var(--nav);font-variant-numeric:tabular-nums;white-space:nowrap}.summary-totals{display:flex;gap:14px;padding:9px 0;border-top:1px solid var(--border);font-size:12.5px;color:var(--muted)}.summary-totals b{color:var(--text);font-variant-numeric:tabular-nums}.sync-note{margin:0;font-size:11.5px;color:var(--muted-2);line-height:1.4}.sync-note.office{color:var(--accent-strong);font-weight:600}.sm-status{margin:0;font-size:12.5px;line-height:1.4}.sm-status.err{color:var(--danger)}.sm-status.ok{color:#166534}.sm-status.info{color:var(--muted)}.gate{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--surface)}.gate-card{width:100%;max-width:460px;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:30px 28px;box-shadow:0 1px 2px #0f172a0a}.gate-card h1{margin:6px 0 8px;font-size:22px}.gate-card p{margin:0 0 10px;font-size:14px;color:var(--nav);line-height:1.55}.gate-hint{font-size:12.5px!important;color:var(--muted)!important}.done-card{text-align:center}.done-tick{width:54px;height:54px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#dcfce7;color:#16a34a;font-size:28px;font-weight:700}.done-summary{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:14px 0}.done-summary span{padding:5px 11px;border-radius:999px;background:var(--surface-2);color:var(--nav);font-size:12.5px;font-weight:600;font-variant-numeric:tabular-nums}.done-next{text-align:left;padding:11px 13px;background:var(--accent-soft);border:1px solid var(--accent-border);border-radius:10px;font-size:13px!important;color:#1e40af!important}.tour-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000}.tour-dim{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a8c}.tour-spotlight{position:fixed;border-radius:12px;box-shadow:0 0 0 9999px #0f172a8c;pointer-events:none;transition:all .25s ease}.tour-card{position:fixed;z-index:2001;width:min(340px,calc(100vw - 24px));background:var(--panel);border-radius:14px;padding:18px;box-shadow:0 12px 40px #00000059;display:flex;flex-direction:column;gap:7px}.tour-step-count{font-size:11px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.06em}.tour-title{font-size:16px;font-weight:700}.tour-body{margin:0;font-size:13px;color:var(--nav);line-height:1.5}.tour-actions{display:flex;align-items:center;justify-content:space-between;margin-top:8px;gap:10px}.tour-nav{display:flex;gap:8px}.mobile-tabs{display:none}@media(max-width:899px){.app{grid-template-columns:1fr;grid-template-rows:1fr;height:100vh;height:100dvh}.panel,.map-wrap{grid-column:1;grid-row:1;width:100vw;min-height:0;height:calc(100vh - 56px);height:calc(100dvh - 56px)}.app.tab-details .map-wrap,.app.tab-map .panel{display:none}.mobile-tabs{display:flex;position:fixed;left:0;right:0;bottom:0;height:56px;z-index:60;background:var(--panel);border-top:1px solid var(--border)}.mtab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;border:none;background:none;font-size:15px;font-weight:700;color:var(--muted);cursor:pointer}.mtab.active{color:var(--accent);box-shadow:inset 0 3px 0 var(--accent)}}
