*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--navy:#0f2133;--navy-mid:#1a3a52;--navy-light:#234b68;--teal:#0f9d7a;--teal-light:#e6f7f3;--red:#e85d4a;--red-light:#fef2f1;--amber:#f59e0b;--amber-light:#fffbeb;--blue:#3b82f6;--blue-light:#eff6ff;--text:#1e2d3d;--text-muted:#5a7080;--border:#dce6ee;--surface:#fff;--bg:#f4f7fa;--sidebar-w:220px;--radius:10px;--shadow:0 1px 4px #0f213314, 0 4px 16px #0f21330f;color:var(--text);background:var(--bg);font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:15px;line-height:1.5}body,#root{min-height:100vh}a{color:var(--teal);text-decoration:none}input,select,button,textarea{font:inherit}.app-layout{min-height:100vh;display:flex}.app-main{background:var(--bg);flex:1;overflow-y:auto}.sidebar{width:var(--sidebar-w);background:var(--navy);color:#c9d9e6;flex-direction:column;flex-shrink:0;height:100vh;display:flex;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:20px 16px 16px;display:flex}.brand-icon{color:var(--teal);font-size:1.5rem}.brand-icon-lg{color:var(--teal);margin-bottom:8px;font-size:2.4rem;display:block}.brand-name{color:#fff;font-size:.95rem;font-weight:700;line-height:1.1}.brand-tenant{color:#7fa3ba;margin-top:2px;font-size:.74rem}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex}.nav-item{color:#a8c0d0;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:9px 10px;font-size:.88rem;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff12}.nav-item.active{color:#5dd4b8;background:#0f9d7a33}.nav-icon{text-align:center;width:18px;font-size:1rem}.sidebar-footer{border-top:1px solid #ffffff14;flex-direction:column;gap:6px;padding:14px 16px;display:flex}.sidebar-user{color:#7fa3ba;font-size:.78rem}.role-badge{text-transform:uppercase;letter-spacing:.06em;border-radius:999px;width:fit-content;padding:2px 7px;font-size:.68rem;font-weight:700;display:inline-block}.role-admin{color:#5dd4b8;background:#0f9d7a40}.role-engineer{color:#93c5fd;background:#3b82f640}.role-viewer{color:#a8c0d0;background:#ffffff1a}.signout-btn{color:#a8c0d0;cursor:pointer;text-align:left;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:7px;margin-top:4px;padding:6px 10px;font-size:.82rem}.signout-btn:hover{color:#fff;background:#ffffff1a}.sidebar-log-cta{padding:10px 8px 4px}.sidebar-log-btn{color:#5dd4b8;cursor:pointer;text-align:left;background:#0f9d7a26;border:1px solid #5dd4b859;border-radius:10px;align-items:center;gap:8px;width:100%;padding:10px 12px;font-size:.88rem;font-weight:600;transition:background .15s,border-color .15s;display:flex}.sidebar-log-btn:hover{color:#fff;background:#0f9d7a47;border-color:#5dd4b899}.sidebar-log-btn span{font-size:1.1rem;line-height:1}.page-content{max-width:1100px;padding:28px 32px}.page-header{margin-bottom:24px}.page-header h1{color:var(--navy);font-size:1.45rem;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:3px;font-size:.88rem}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px;display:grid}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;text-align:left;width:100%;padding:18px 20px;transition:box-shadow .15s,transform .1s;display:block}.kpi-card:hover{transform:translateY(-1px);box-shadow:0 4px 20px #0f21331f}.availability-card{cursor:default}.availability-card:hover{box-shadow:var(--shadow);transform:none}.kpi-indicator{border-radius:2px;width:28px;height:4px;margin-bottom:12px}.kpi-value{color:var(--navy);margin-bottom:4px;font-size:1.9rem;font-weight:800;line-height:1}.kpi-label{color:var(--text);font-size:.82rem;font-weight:600}.kpi-desc{color:var(--text-muted);margin-top:2px;font-size:.76rem}.dashboard-panels,.two-col-layout{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;display:grid}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;display:flex}.panel-header{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:14px 18px;display:flex}.panel-header h2{color:var(--navy);flex:1;font-size:.92rem;font-weight:700}.panel-context{color:var(--text-muted);font-weight:400}.count-badge{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:1px 8px;font-size:.72rem;font-weight:700}.panel-body{flex:1;padding:16px 18px}.getting-started-list{flex-direction:column;gap:14px;list-style:none;display:flex}.getting-started-list li{align-items:flex-start;gap:12px;display:flex}.step-num{background:var(--navy);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:1px;font-size:.72rem;font-weight:700;display:flex}.getting-started-list li.done .step-num{background:var(--teal)}.getting-started-list strong{color:var(--navy);font-size:.86rem}.getting-started-list p{color:var(--text-muted);margin-top:2px;font-size:.78rem}.roadmap-list{flex-direction:column;gap:8px;list-style:none;display:flex}.roadmap-list li{color:var(--text-muted);align-items:center;gap:8px;font-size:.84rem;display:flex}.roadmap-list li:before{content:"○";color:var(--border);font-size:.7rem}.roadmap-list li.done{color:var(--text)}.roadmap-list li.done:before{content:"●";color:var(--teal)}.roadmap-list li.in-progress:before{content:"◐";color:var(--amber)}.inline-form,.asset-form{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.form-field{flex-direction:column;gap:4px;display:flex}.form-field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;font-weight:600}input,select{border:1px solid var(--border);color:var(--text);background:#fff;border-radius:8px;padding:8px 10px;font-size:.88rem;transition:border-color .15s}input:focus,select:focus{border-color:var(--teal);outline:none;box-shadow:0 0 0 3px #0f9d7a1f}button[type=submit],.btn-primary{background:var(--teal);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:9px 14px;font-size:.88rem;font-weight:600;transition:background .15s}button[type=submit]:hover,.btn-primary:hover{background:#0d8a6d}button[type=submit]:disabled,.btn-primary:disabled{opacity:.55;cursor:not-allowed}.form-error{color:var(--red);background:var(--red-light);border-radius:6px;padding:6px 10px;font-size:.8rem}.record-list{flex-direction:column;gap:4px;list-style:none;display:flex}.record-item{cursor:pointer;border:1px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;padding:9px 12px;transition:background .12s;display:flex}.record-item:hover{background:var(--bg)}.record-item.selected{background:var(--teal-light);border-color:#0f9d7a33}.record-main{font-size:.86rem}.record-meta{color:var(--text-muted);font-size:.8rem}.record-chevron{color:var(--text-muted);font-size:1.1rem}.empty-hint{color:var(--text-muted);padding:8px 0;font-size:.84rem;font-style:italic}.asset-table{border-collapse:collapse;width:100%;font-size:.85rem}.asset-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:0 10px 8px;font-size:.72rem;font-weight:700}.asset-table td{border-bottom:1px solid var(--bg);vertical-align:middle;padding:9px 10px}.asset-table tr:last-child td{border-bottom:none}.asset-table tr:hover td{background:var(--bg)}.tag-cell{color:var(--text-muted);font-family:ui-monospace,Consolas,monospace;font-size:.8rem}.date-cell{color:var(--text-muted);font-size:.78rem}.criticality-badge{color:#fff;border-radius:999px;padding:2px 8px;font-size:.72rem;font-weight:700;display:inline-block}.filter-bar{flex-wrap:wrap;align-items:flex-end;gap:8px;margin-bottom:20px;display:flex}.filter-group{flex-direction:column;gap:3px;display:flex}.filter-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-size:.72rem;font-weight:700}.filter-sep{color:var(--text-muted);padding-bottom:2px;font-size:1.2rem}.auth-page{background:var(--navy);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{background:var(--surface);border-radius:16px;width:100%;max-width:420px;padding:36px 32px;box-shadow:0 20px 60px #00000059}.auth-brand{text-align:center;margin-bottom:24px}.auth-brand h1{color:var(--navy);margin-bottom:4px;font-size:1.3rem;font-weight:800}.auth-brand p{color:var(--text-muted);font-size:.82rem}.auth-tabs{background:var(--bg);border-radius:9px;gap:0;margin-bottom:22px;padding:3px;display:flex}.auth-tabs button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;padding:7px;font-size:.86rem;font-weight:600;transition:all .15s}.auth-tabs button.active{background:var(--surface);color:var(--navy);box-shadow:0 1px 4px #0000001a}.auth-form{flex-direction:column;gap:12px;display:flex}.dashboard-filters{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.scope-chip{border:1px solid var(--border);color:var(--navy);background:#f1f5f9;border-radius:999px;padding:5px 10px;font-size:.75rem;font-weight:600}.kpi-strip{grid-template-columns:repeat(6,minmax(120px,1fr));gap:10px;margin-bottom:16px;display:grid}.kpi-tile{border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:10px}.kpi-tile-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.7rem;display:block}.kpi-tile strong{color:var(--navy);font-size:1.3rem}.kpi-action{cursor:pointer}.kpi-action:hover{border-color:#8dc0b5}.dashboard-wire-grid{grid-template-columns:1.1fr 1.2fr;gap:14px;display:grid}.trend-chart{border-bottom:2px solid #c7d2de;border-left:2px solid #c7d2de;align-items:flex-end;gap:12px;min-height:180px;padding:8px 8px 2px;display:flex;position:relative}.trend-bar-wrap{text-align:center;width:30px}.trend-bar{background:#96a7bf;border-radius:6px 6px 0 0;width:100%}.trend-bar-wrap span{color:var(--text-muted);margin-top:4px;font-size:.68rem;display:block}.trend-line{position:absolute;inset:6px 8px 22px}.trend-line span{background:#2456a5;border-radius:50%;width:7px;height:7px;position:absolute;transform:translate(-50%,50%)}.pareto-list{flex-direction:column;gap:8px;list-style:none;display:flex}.pareto-row{justify-content:space-between;gap:10px;font-size:.82rem;display:flex}.pareto-row span{color:var(--text-muted)}.pareto-meter{background:#eef3f7;border-radius:999px;height:10px;margin-top:4px;position:relative;overflow:hidden}.pareto-meter i{background:linear-gradient(90deg,#7d9cc8,#2456a5);border-radius:999px;height:100%;display:block}.pareto-meter em{color:var(--text-muted);font-size:.7rem;font-style:normal;position:absolute;top:-18px;right:8px}.risk-heatmap{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.risk-heatmap div{border-radius:4px;min-height:22px}.heatmap-axis{color:var(--text-muted);justify-content:space-between;margin-top:8px;font-size:.72rem;display:flex}.worklist-table{border-collapse:collapse;width:100%}.worklist-table td{border-bottom:1px solid #eef2f7;padding:8px 4px;font-size:.8rem}.priority-pill{border-radius:999px;padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-block}.priority-pill.high{color:#9b1c1c;background:#fee2e2}.priority-pill.medium{color:#92400e;background:#fef3c7}.hierarchy-ribbon{grid-template-columns:repeat(3,minmax(180px,1fr));gap:10px;margin-bottom:16px;display:grid}.hierarchy-ribbon div{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:10px 12px}.hierarchy-ribbon span{color:var(--text-muted);margin-bottom:4px;font-size:.72rem;display:block}.hierarchy-ribbon strong{color:var(--navy);font-size:.9rem}.hierarchy-summary{min-height:280px}.hierarchy-checklist{flex-direction:column;gap:10px;margin-bottom:16px;list-style:none;display:flex}.hierarchy-checklist li{color:var(--text-muted);padding-left:18px;font-size:.83rem;position:relative}.hierarchy-checklist li:before{content:"";background:#cbd5e1;border-radius:50%;width:9px;height:9px;position:absolute;top:5px;left:0}.hierarchy-checklist li.done{color:var(--text)}.hierarchy-checklist li.done:before{background:var(--teal)}.mockup-panel{margin-top:18px}.mockup-hint{color:var(--text-muted);margin-bottom:12px;font-size:.82rem}.mockup-switcher{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.mockup-switcher button{color:var(--navy);background:#eef2f7;border:1px solid #d8e2eb;border-radius:8px;padding:7px 10px;font-size:.78rem}.mockup-switcher button.active{background:var(--navy);color:#fff;border-color:var(--navy)}.asset-mock{border:1px solid var(--border);background:#fafcff;border-radius:12px;padding:14px}.asset-mock h3{color:var(--navy);font-size:1rem}.mock-tags{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.mock-tags span{background:#eaf0f7;border-radius:999px;padding:3px 8px;font-size:.72rem}.mock-grid{grid-template-columns:.8fr 1fr 1fr;gap:10px;margin-top:12px;display:grid}.mock-grid article{background:#fff;border:1px solid #dce6ee;border-radius:10px;padding:10px}.mock-grid h4,.asset-mock aside h4{color:var(--navy);margin-bottom:8px;font-size:.82rem}.mock-grid ul{color:var(--text-muted);flex-direction:column;gap:5px;font-size:.78rem;list-style:none;display:flex}.mini-graph{align-items:flex-end;gap:6px;min-height:70px;display:flex}.mini-graph i{background:#2456a5;border-radius:4px 4px 0 0;width:18%}.mock-grid p{color:var(--text-muted);margin-bottom:6px;font-size:.8rem}.option-b{grid-template-columns:1.4fr .8fr;gap:10px;display:grid}.scada-canvas{background:#fff;border:1px solid #c7d5e5;border-radius:10px;flex-wrap:wrap;align-content:flex-start;gap:8px;min-height:170px;padding:10px;display:flex}.node{color:var(--navy);background:#dce8f6;border:1px solid #aac0dd;border-radius:8px;padding:8px 10px;font-size:.75rem;font-weight:600}.asset-mock aside{background:#fff;border:1px solid #dce6ee;border-radius:10px;padding:10px}.asset-mock aside ul{color:var(--text-muted);flex-direction:column;gap:6px;font-size:.8rem;list-style:none;display:flex}.option-c header p{color:var(--text-muted);margin-top:4px;font-size:.82rem}.timeline-list{border-top:1px solid #dce6ee;margin-top:12px}.timeline-list div{border-bottom:1px solid #ecf1f6;grid-template-columns:80px 1fr;gap:10px;padding:9px 0;font-size:.8rem;display:grid}.timeline-list strong{color:var(--navy)}.timeline-list span{color:var(--text-muted)}.explorer-page{max-width:1320px}.explorer-summary{flex-wrap:wrap;gap:10px;margin-bottom:10px;display:flex}.explorer-summary span{color:var(--navy);background:#eaf0f7;border:1px solid #d4e0ea;border-radius:999px;padding:5px 10px;font-size:.74rem;font-weight:600}.action-toolbar{gap:10px;margin-bottom:12px;display:flex}.btn-secondary{color:var(--navy);background:#f3f7fb;border:1px solid #c8d5e3;border-radius:8px;padding:8px 12px;font-size:.82rem;font-weight:600}.btn-secondary.active{background:#e6f7f3;border-color:#7ab2a6}.top-action-drawers{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;margin-bottom:12px;display:grid}.modal-backdrop{z-index:100;background:#0f213373;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-card{background:#fff;border:1px solid #dce6ee;border-radius:14px;width:min(520px,100%);box-shadow:0 24px 60px #00000040}.modal-card.modal-wide{width:min(980px,100%)}.modal-card.modal-scrollable{flex-direction:column;max-height:min(90vh,900px);display:flex}.modal-header{border-bottom:1px solid #e4ecf4;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.modal-header h2{color:var(--navy);font-size:1rem}.modal-close{color:var(--navy);background:#f8fbff;border:1px solid #cfdae6;border-radius:8px;padding:2px 8px;font-size:1rem}.modal-body{padding:14px 16px 16px}.modal-body.modal-body-scroll{overflow:auto}.field-hint{color:var(--text-muted);margin-top:4px;font-size:.74rem;display:block}.import-flow__row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.import-flow__filename{color:var(--text-muted);font-size:.8rem}.import-map-grid{background:#f9fcff;border:1px solid #dce6ee;border-radius:10px;flex-direction:column;gap:8px;padding:10px;display:flex}.import-map-item{border-bottom:1px solid #e7eef5;padding-bottom:8px}.import-map-item:last-child{border-bottom:none;padding-bottom:0}.import-summary-bar{flex-wrap:wrap;gap:8px;display:flex}.import-summary-bar span{border:1px solid #d4e0ea;border-radius:999px;padding:4px 8px;font-size:.75rem;font-weight:700}.import-result-list{border:1px solid #dce6ee;border-radius:10px;max-height:280px;list-style:none;overflow:auto}.import-result{border-bottom:1px solid #edf2f7;padding:7px 10px;font-size:.79rem}.import-result:last-child{border-bottom:none}.import-result.ok{color:#0a755d}.import-result.skip{color:#926500}.import-result.error{color:#9b1c1c}.detail-review-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;margin-bottom:12px;display:grid}.detail-review-grid div{background:#f8fbff;border:1px solid #dce6ee;border-radius:10px;padding:8px}.detail-review-grid span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px;font-size:.72rem;display:block}.detail-review-grid strong{color:var(--navy);font-size:.88rem}.detail-review-block{background:#fff;border:1px solid #dce6ee;border-radius:10px;margin-bottom:10px;padding:10px}.detail-review-block h4{color:var(--navy);margin-bottom:6px}.detail-review-block p{color:var(--text);font-size:.82rem}.import-flow{flex-direction:column;gap:12px;display:flex}.import-notice{color:#7a5100;background:#fffaeb;border:1px solid #f2c06b;border-radius:8px;padding:8px 10px;font-size:.8rem}.header-preview{flex-wrap:wrap;gap:6px;display:flex}.header-preview span{color:var(--navy);background:#f3f8fc;border:1px solid #d4e0ea;border-radius:999px;padding:4px 8px;font-size:.73rem;font-weight:600}.import-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.import-upload-label{color:var(--navy);cursor:pointer;border:1px dashed #a4b9cc;border-radius:8px;padding:8px 12px;font-size:.82rem;font-weight:600}.import-upload-label input{margin-top:6px;display:block}.mapping-grid{background:#f9fcff;border:1px solid #dce6ee;border-radius:10px;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:10px;padding:10px;display:grid}.defaults-grid{background:#fbfdff;border:1px solid #dce6ee;border-radius:10px;padding:10px}.defaults-grid h3{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:.78rem}.defaults-fields{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px;display:grid}.mapping-row{flex-direction:column;gap:4px;display:flex}.mapping-row label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:700}.import-run-actions{flex-wrap:wrap;gap:8px;display:flex}.import-summary{flex-wrap:wrap;gap:10px;display:flex}.import-summary span{border:1px solid #d4e0ea;border-radius:999px;padding:4px 10px;font-size:.75rem;font-weight:700}.import-summary .ok{color:#0a755d;background:#e6f7f3}.import-summary .skip{color:#926500;background:#fff8e7}.import-summary .error{color:#9b1c1c;background:#feeceb}.import-results{border:1px solid #dce6ee;border-radius:10px;max-height:280px;overflow:auto}.import-results table{border-collapse:collapse;width:100%}.import-results th,.import-results td{text-align:left;border-bottom:1px solid #eef2f7;padding:8px;font-size:.78rem}.status-ok{color:#0a755d;font-weight:700}.status-skip{color:#926500;font-weight:700}.status-error{color:#9b1c1c;font-weight:700}.import-sample{background:#f9fcff;border:1px solid #dce6ee;border-radius:10px;padding:10px}.import-sample h3{color:var(--navy);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:.82rem}.import-sample table{border-collapse:collapse;width:100%}.import-sample th,.import-sample td{text-align:left;border-bottom:1px solid #eef2f7;padding:6px;font-size:.76rem}.modal-context{color:var(--text-muted);margin-bottom:2px;font-size:.82rem}.explorer-filters{margin-bottom:14px}.search-group{flex:1;min-width:260px}.search-group input{width:100%}.explorer-layout{grid-template-columns:290px 1fr 320px;gap:14px;margin-bottom:16px;display:grid}.hierarchy-column .panel-body{flex-direction:column;gap:12px;display:flex}.hierarchy-tree{flex-direction:column;gap:6px;max-height:420px;padding-right:4px;list-style:none;display:flex;overflow-y:auto}.hierarchy-tree ul{flex-direction:column;gap:4px;margin-top:4px;padding-left:14px;list-style:none;display:flex}.tree-site,.tree-line{text-align:left;width:100%;color:var(--text);background:#fff;border:1px solid #dce6ee;border-radius:8px;padding:7px 9px;font-size:.82rem}.tree-site{font-weight:700}.tree-line{font-size:.79rem;font-weight:600}.tree-site.active,.tree-line.active{color:#0f2133;background:#e6f7f3;border-color:#7ab2a6}.assets-list-column .panel-body{max-height:560px;overflow:auto}.asset-table th{z-index:2;background:#f7fbff;position:sticky;top:0}.table-sort{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:0 0;border:none;align-items:center;gap:6px;padding:0;font-size:.72rem;font-weight:700;display:inline-flex}.table-sort:hover{color:var(--navy)}.table-sort span{color:#94a5b8;font-size:.76rem;font-weight:800}.table-sort.active{color:var(--navy)}.table-sort.active span{color:#2456a5}.asset-table tr.selected-row td{background:#eaf4ff}.asset-table tr{cursor:pointer}.row-link-btn{color:var(--navy);background:#f8fbff;border:1px solid #c8d5e3;border-radius:7px;padding:4px 8px;font-size:.74rem;font-weight:600}.row-link-btn:hover{background:#eef5fd;border-color:#9db7d3}.unified-detail-panel .panel-body{background:#f8fbff}.asset-mock.combined.a .mock-grid article:first-child,.asset-mock.combined.b .option-b,.asset-mock.combined.c .timeline-list{border-radius:10px;outline:2px solid #2456a540}.node.active{background:#fecaca;border-color:#f87171}.asset-detail-page .page-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.asset-breadcrumb{color:var(--text-muted);align-items:center;gap:8px;margin-bottom:8px;font-size:.78rem;display:flex}.asset-breadcrumb span:last-child{color:var(--navy);font-weight:700}.detail-two-col{grid-template-columns:1fr 1fr;gap:10px;margin-top:12px;display:grid}.detail-form-card,.detail-log-card{background:#fff;border:1px solid #dce6ee;border-radius:10px;padding:10px}.detail-form-card h4,.detail-log-card h4{color:var(--navy);margin-bottom:8px;font-size:.84rem}.log-list{flex-direction:column;gap:8px;list-style:none;display:flex}.log-list li{border-bottom:1px solid #eef2f7;flex-direction:column;gap:2px;padding-bottom:7px;display:flex}.log-list li:last-child{border-bottom:none;padding-bottom:0}.log-list strong{color:var(--navy);font-size:.78rem}.log-list span,.form-note{color:var(--text-muted);font-size:.78rem}.modal-log-event{width:min(600px,100%)}.log-type-tabs{gap:6px;margin-bottom:14px;display:flex}.log-tab{color:var(--text-muted);cursor:pointer;background:#f6f9fc;border:1px solid #dce6ee;border-radius:8px;flex:1;padding:9px 12px;font-size:.85rem;font-weight:500;transition:all .15s}.log-tab:hover{color:var(--navy);background:#eef4fa}.log-tab.active.failure{color:#c02020;background:#fff2f2;border-color:#d94f4f;font-weight:600}.log-tab.active.maintenance{color:#1a7a5c;background:#f0fbf7;border-color:#3fba8c;font-weight:600}.log-tab.active.condition{color:#2f3f9f;background:#f3f4ff;border-color:#6b7ae0;font-weight:600}.log-asset-picker{background:#f6f9fc;border:1px solid #dce6ee;border-radius:8px;margin-bottom:12px;padding:10px 12px}.log-picker-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:.78rem;font-weight:600}.log-picker-row{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.form-row-2{grid-template-columns:1fr 1fr;gap:10px;display:grid}.log-event-form{margin-top:10px}.log-submit-btn{width:100%;margin-top:4px}.checklist-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px;margin-top:6px;display:grid}.checklist-grid label,.inline-check{color:var(--text-muted);align-items:center;gap:6px;font-size:.8rem;display:inline-flex}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:10px;display:grid}.asset-detail-header-actions{flex-wrap:wrap;gap:8px;display:flex}.btn-secondary{color:var(--navy);cursor:pointer;background:#fff;border:1px solid #a8bed4;border-radius:8px;padding:8px 12px;font-size:.82rem;font-weight:600}.asset-monitoring-grid{grid-template-columns:repeat(2,1fr)}.worklist-table{border-collapse:collapse;width:100%;font-size:.8rem}.worklist-table th,.worklist-table td{text-align:left;vertical-align:top;border-bottom:1px solid #e6edf4;padding:8px 6px}.worklist-table td strong{color:var(--navy);display:block}.worklist-table td span{color:var(--text-muted);display:block}.worklist-table select{border:1px solid #b7c7d7;border-radius:8px;padding:4px 8px;font-size:.78rem}.link-btn{color:#34506e;cursor:pointer;background:#fff;border:1px solid #c9d7e5;border-radius:8px;width:fit-content;margin-top:3px;padding:3px 8px;font-size:.74rem;font-weight:600}.log-actions-bar{background:#f6f9fc;border:1px solid #dce6ee;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;margin-top:16px;padding:14px 16px;display:flex}.log-actions-label{color:var(--text-muted);font-size:.84rem;font-weight:500}.log-actions-buttons{flex-wrap:wrap;gap:8px;display:flex}.log-action-btn{cursor:pointer;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:.84rem;font-weight:600;transition:all .15s;display:flex}.log-action-btn.failure{color:#b93030;background:#fff5f5;border:1px solid #f0c0c0}.log-action-btn.failure:hover{background:#ffe0e0;border-color:#d94f4f}.log-action-btn.maintenance{color:#1a7a5c;background:#f0fbf7;border:1px solid #b8e4d4}.log-action-btn.maintenance:hover{background:#d8f4ea;border-color:#3fba8c}.log-action-btn.condition{color:#2f3f9f;background:#f3f4ff;border:1px solid #c5ccf7}.log-action-btn.condition:hover{background:#e8ebff;border-color:#6b7ae0}.event-feed{flex-direction:column;gap:10px;list-style:none;display:flex}.event-bubble{background:#f9fbfd;border:1px solid #e4ecf4;border-radius:14px;gap:12px;padding:12px 14px;transition:box-shadow .15s;display:flex}.event-bubble:hover{box-shadow:0 2px 10px #00000012}.event-bubble.failure{background:#fff8f8;border-color:#f0d4d4}.event-bubble.maintenance{background:#f4fbf8;border-color:#c8e8dd}.event-bubble.condition{background:#f6f7ff;border-color:#d5daf7}.event-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-top:1px;font-size:.75rem;font-weight:700;display:flex}.event-bubble.failure .event-avatar{color:#c73434;background:#fcdcdc}.event-bubble.maintenance .event-avatar{color:#1f7a5a;background:#c8f0e3}.event-bubble.condition .event-avatar{color:#2f3f9f;background:#d8ddff}.event-content{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.event-header{justify-content:space-between;align-items:center;gap:10px;margin-bottom:3px;display:flex}.event-date{color:#6b7a8d;font-size:.76rem;font-weight:600}.event-title{color:var(--navy);font-size:.87rem;font-weight:600}.event-meta{color:#6b7a8d;font-size:.79rem}.event-meta-muted{opacity:.7;font-style:italic}.event-meta-by{color:#9ab0c0;margin-top:2px;font-size:.76rem}.status-pill{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;justify-content:center;align-items:center;width:fit-content;padding:4px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.status-pill.green{color:#0d8a6d;background:#0f9d7a1f}.status-pill.amber,.status-pill.wip{color:#b45309;background:#f59e0b24}.status-pill.red,.status-pill.open{color:#b91c1c;background:#dc26261f}.status-pill.grey,.status-pill.completed{color:#475569;background:#64748b24}.status-pill.low{color:#0369a1;background:#38bdf824}.status-pill.medium{color:#b45309;background:#f59e0b24}.status-pill.high{color:#b91c1c;background:#ef444424}.wizard-stepper{align-items:center;gap:0;padding:0 1.5rem 1.25rem;display:flex;overflow-x:auto}.wizard-step{cursor:default;flex-direction:column;flex:1;align-items:center;gap:.3rem;min-width:5rem;display:flex;position:relative}.wizard-step:not(:last-child):after{content:"";z-index:0;background:#e2e8f0;height:2px;position:absolute;top:1rem;left:60%;right:-40%}.wizard-step.done:not(:last-child):after{background:#16a34a}.wizard-step.active:not(:last-child):after{background:#e2e8f0}.step-bubble{color:#64748b;z-index:1;background:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.78rem;font-weight:700;transition:background .15s,color .15s;display:flex;position:relative}.wizard-step.active .step-bubble{color:#fff;background:#0f172a;box-shadow:0 0 0 3px #0f172a26}.wizard-step.done .step-bubble{color:#fff;background:#16a34a}.step-label{color:#94a3b8;text-align:center;white-space:nowrap;font-size:.68rem}.wizard-step.active .step-label{color:#0f172a;font-weight:600}.wizard-step.done .step-label{color:#16a34a}.wizard-footer{border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:.75rem;margin-top:.75rem;padding:1rem 1.5rem 0;display:flex}.an-health-grid{flex-direction:column;gap:.5rem;display:flex}.an-health-row{align-items:center;gap:.75rem;display:flex}.an-health-label{color:#475569;min-width:9rem;font-size:.82rem}.an-health-options{flex-wrap:wrap;gap:.35rem;display:flex}.an-health-btn{cursor:pointer;color:#64748b;background:#f8fafc;border:1.5px solid #cbd5e1;border-radius:.35rem;padding:.2rem .55rem;font-size:.75rem;font-weight:600;transition:all .1s}.an-health-btn:hover{border-color:#94a3b8}.an-health-btn.hs-good.active{color:#15803d;background:#dcfce7;border-color:#16a34a}.an-health-btn.hs-monitor.active{color:#1d4ed8;background:#dbeafe;border-color:#2563eb}.an-health-btn.hs-attention.active{color:#92400e;background:#fef9c3;border-color:#ca8a04}.an-health-btn.hs-critical.active{color:#991b1b;background:#fee2e2;border-color:#dc2626}.an-health-btn.hs-na.active{color:#475569;background:#f1f5f9;border-color:#94a3b8}.an-health-btn.hs-good:not(.active):hover{border-color:#16a34a}.an-health-btn.hs-monitor:not(.active):hover{border-color:#2563eb}.an-health-btn.hs-attention:not(.active):hover{border-color:#ca8a04}.an-health-btn.hs-critical:not(.active):hover{border-color:#dc2626}.an-textarea{resize:vertical;box-sizing:border-box;color:#1e293b;background:#fafafa;border:1.5px solid #e2e8f0;border-radius:.45rem;width:100%;min-height:5rem;padding:.6rem .75rem;font-size:.875rem;line-height:1.5}.an-textarea:focus{background:#fff;border-color:#0f172a;outline:none}.an-upload-label{cursor:pointer;color:#475569;border:1.5px dashed #94a3b8;border-radius:.45rem;align-items:center;gap:.4rem;padding:.45rem 1rem;font-size:.82rem;transition:border-color .15s;display:inline-flex}.an-upload-label:hover{color:#0f172a;border-color:#0f172a}.an-machine-photo-preview{object-fit:cover;border:1px solid #e2e8f0;border-radius:.4rem;max-width:15rem;max-height:9rem;margin-top:.5rem}.an-evidence-list{flex-direction:column;gap:.6rem;margin-top:.75rem;display:flex}.an-evidence-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.45rem;align-items:flex-start;gap:.75rem;padding:.6rem;display:flex}.an-evidence-preview{object-fit:cover;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:.3rem;flex-shrink:0;justify-content:center;align-items:center;width:4.5rem;height:4.5rem;font-size:1.5rem;display:flex}.an-evidence-meta{flex-direction:column;flex:1;gap:.35rem;display:flex}.an-evidence-caption{color:#475569;font-size:.8rem}.an-evidence-caption input{border:1px solid #e2e8f0;border-radius:.3rem;width:100%;padding:.2rem .4rem;font-size:.8rem}.an-evidence-controls{gap:.35rem;display:flex}.an-evidence-remove{color:#dc2626;cursor:pointer;cursor:pointer;background:0 0;border:none;padding:0;font-size:.78rem}.an-review-summary{flex-direction:column;gap:.5rem;display:flex}.an-review-row{gap:.5rem;font-size:.83rem;display:flex}.an-review-row span{color:#64748b;min-width:10rem}.an-review-row strong{color:#0f172a}.an-health-summary{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.an-health-chip{border-radius:1rem;padding:.15rem .5rem;font-size:.72rem;font-weight:600}.an-issue-actions{justify-content:flex-end;gap:.75rem;margin-top:1rem;display:flex}.an-status-badge,.an-priority-badge{white-space:nowrap;border-radius:1rem;padding:.15rem .55rem;font-size:.72rem;font-weight:700;display:inline-block}.an-status-draft{color:#475569;background:#f1f5f9}.an-status-issued{color:#1d4ed8;background:#dbeafe}.an-status-revised{color:#92400e;background:#fef9c3}.an-status-closed{color:#15803d;background:#f0fdf4}.an-priority-low{color:#0369a1;background:#f0f9ff}.an-priority-medium{color:#9a3412;background:#fff7ed}.an-priority-high{color:#991b1b;background:#fef2f2}.an-priority-critical{color:#fef2f2;background:#4a0404}.an-asset-panel-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.an-asset-panel-header h4{margin:0}.an-notes-table{border-collapse:collapse;width:100%;font-size:.83rem}.an-notes-table th{text-align:left;color:#64748b;border-bottom:1px solid #e2e8f0;padding:.4rem .6rem;font-weight:600}.an-notes-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:.45rem .6rem}.an-notes-table tr:last-child td{border-bottom:none}.an-row-actions{gap:.5rem;display:flex}.an-row-actions .link-btn{font-size:.78rem}.an-preview-backdrop{z-index:200;background:#0f172a8c;flex-direction:column;align-items:stretch;display:flex;position:fixed;inset:0}.an-preview-shell{background:#fff;flex-direction:column;flex:1;display:flex;overflow:hidden}.an-preview-toolbar{color:#f8fafc;background:#0f172a;flex-shrink:0;align-items:center;gap:.75rem;padding:.75rem 1.5rem;display:flex}.an-preview-toolbar h3{color:#f8fafc;flex:1;margin:0;font-size:.95rem}.an-preview-scroll{background:#e2e8f0;flex:1;padding:2rem;overflow-y:auto}.an-report{color:#1e293b;background:#fff;max-width:850px;margin:0 auto;padding:2.5rem 2.75rem;font-family:Segoe UI,system-ui,sans-serif;box-shadow:0 2px 24px #0000001f}.an-report-page-header{border-bottom:2px solid #0f172a;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.an-brand-bar{color:#0f172a;letter-spacing:-.02em;font-size:1.1rem;font-weight:800}.an-brand-bar span{color:#2563eb}.an-overall-badge{letter-spacing:.06em;border-radius:.4rem;padding:.25rem .9rem;font-size:.8rem;font-weight:700}.an-header-table{border-collapse:collapse;width:100%;margin-bottom:1.5rem;font-size:.83rem}.an-header-table td{vertical-align:top;padding:.35rem .6rem}.an-header-block{border:1px solid #e2e8f0;border-radius:.35rem;padding:.25rem 0}.an-header-field{flex-direction:column;display:flex}.an-header-field span{color:#94a3b8;letter-spacing:.06em;text-transform:uppercase;font-size:.68rem;font-weight:600}.an-header-field strong{color:#1e293b;font-size:.83rem}.an-machine-photo-cell{vertical-align:top;width:10rem}.an-machine-photo{object-fit:cover;border:1px solid #e2e8f0;border-radius:.35rem;width:9rem;height:6.5rem}.an-machine-photo-placeholder{color:#94a3b8;border:1.5px dashed #e2e8f0;border-radius:.35rem;justify-content:center;align-items:center;width:9rem;height:6.5rem;font-size:.75rem;display:flex}.an-health-table{border-collapse:collapse;width:100%;margin-bottom:1rem;font-size:.8rem}.an-health-table th{color:#64748b;text-transform:uppercase;letter-spacing:.06em;background:#f8fafc;border:1px solid #e2e8f0;padding:.4rem .6rem;font-size:.72rem;font-weight:600}.an-health-table td{border:1px solid #e2e8f0;padding:.35rem .6rem}.an-health-cell-badge{border-radius:1rem;padding:.15rem .5rem;font-size:.72rem;font-weight:700}.an-section{margin-bottom:1.5rem}.an-section-heading{letter-spacing:.08em;text-transform:uppercase;color:#64748b;border-bottom:1px solid #e2e8f0;margin-bottom:.6rem;padding-bottom:.3rem;font-size:.72rem;font-weight:700}.an-narrative{color:#1e293b;white-space:pre-wrap;font-size:.85rem;line-height:1.6}.an-recommendations{white-space:pre-wrap;font-size:.85rem;line-height:1.6}.an-evidence-figures{flex-wrap:wrap;gap:1rem;display:flex}.an-figure{flex-direction:column;align-items:center;gap:.4rem;max-width:14rem;display:flex}.an-figure-img{object-fit:contain;border:1px solid #e2e8f0;border-radius:.35rem;max-width:14rem;max-height:10rem}.an-figure-file{color:#64748b;text-align:center;font-size:.75rem}.an-figure figcaption{color:#475569;text-align:center;font-size:.75rem}.an-rev-table{border-collapse:collapse;width:100%;font-size:.8rem}.an-rev-table th{text-align:left;color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;padding:.3rem .5rem;font-size:.72rem;font-weight:600}.an-rev-table td{vertical-align:top;border:1px solid #e2e8f0;padding:.3rem .5rem}.an-report-footer{color:#94a3b8;text-align:center;border-top:1px solid #e2e8f0;margin-top:2rem;padding-top:.75rem;font-size:.72rem}@media print{body *{visibility:hidden}.an-report,.an-report *{visibility:visible}.an-report{box-shadow:none;max-width:100%;padding:1.5cm;position:absolute;inset:0}.an-preview-toolbar,.sidebar{display:none!important}.app-main{padding:0!important}.an-preview-backdrop{background:0 0;position:static}.an-preview-shell{overflow:visible}.an-preview-scroll{background:#fff;padding:0;overflow:visible}.an-health-btn{border-color:#0000}@page{margin:1.5cm;size:A4}}.status-pill.critical{color:#7f1d1d;background:#7f1d1d33}.score-summary-stat{flex-direction:column;gap:4px;display:flex}.score-summary-stat strong{color:var(--navy);font-size:1.6rem}.score-summary-stat span{color:var(--text-muted);font-size:.82rem}.score-summary-panel{background:linear-gradient(#f7fbfd 0%,#fff 100%);border:1px solid #dce6ee;border-radius:12px;margin-top:12px;padding:14px}.score-summary-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.score-summary-header h4{color:var(--navy);margin-bottom:4px;font-size:.95rem}.score-summary-header p{color:var(--text-muted);font-size:.8rem}.score-summary-grid,.runtime-profile-row{background:#f8fbff;border:1px solid #dce6ee;border-radius:10px;justify-content:space-between;align-items:center;gap:12px;margin-top:10px;margin-bottom:10px;padding:10px 12px;display:flex}.runtime-profile-row h5{color:var(--navy);margin:0;font-size:.82rem}.runtime-profile-row p{color:var(--text-muted);margin-top:2px;margin-bottom:0;font-size:.77rem}.runtime-profile-btn{color:var(--navy);cursor:pointer;background:#fff;border:1px solid #a8bed4;border-radius:8px;padding:6px 10px;font-size:.78rem;font-weight:600}.runtime-profile-edit{align-items:center;gap:6px;display:inline-flex}.runtime-profile-edit input,.runtime-profile-edit select{border:1px solid #b7c7d7;border-radius:8px;padding:6px 8px;font-size:.78rem}.runtime-profile-edit button{color:var(--navy);cursor:pointer;background:#fff;border:1px solid #a8bed4;border-radius:8px;padding:6px 10px;font-size:.76rem;font-weight:600}.summary-stat-grid,.health-mix-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;display:grid}.score-summary-card,.health-mix-card,.summary-stat-grid>div{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:6px;padding:12px;display:flex}.score-summary-card.emphasis{background:linear-gradient(135deg,#0f9d7a1f,#2456a514)}.score-summary-card span,.summary-stat-grid span{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.76rem}.score-summary-card strong,.health-mix-card strong,.summary-stat-grid strong{color:var(--navy);font-size:1.35rem}.score-summary-card small,.health-mix-card small{color:var(--text-muted);font-size:.77rem}.score-note-list{color:var(--text-muted);flex-direction:column;gap:6px;margin-top:12px;padding-left:18px;font-size:.8rem;list-style:outside;display:flex}.score-bar-stack{background:#e2e8f0;border-radius:999px;min-height:34px;margin-bottom:12px;display:flex;overflow:hidden}.score-bar-segment{color:#fff;justify-content:center;align-items:center;min-width:0;font-size:.74rem;font-weight:700;display:flex}.score-bar-segment.green{background:#0f9d7a}.score-bar-segment.amber{background:#f59e0b}.score-bar-segment.red{background:#dc2626}.score-bar-segment.grey{background:#64748b}.worst-asset-btn{text-align:left;cursor:pointer;background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:8px;width:100%;padding:10px;display:flex}.worst-asset-btn:hover{background:#f8fbfd}.history-item{background:#fbfdff;border:1px solid #e9eff5;border-radius:10px;padding:10px}.history-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.history-chip{color:#2456a5;background:#2456a514;border-radius:999px;align-items:center;padding:3px 8px;font-size:.72rem;font-weight:700;display:inline-flex}.criticality-editable-tag{align-items:center;gap:6px;display:inline-flex}.criticality-editable-tag>button{cursor:pointer;color:inherit;opacity:.6;background:0 0;border:none;padding:0 2px;font-size:.72rem;line-height:1}.criticality-editable-tag>button:hover{opacity:1}.criticality-edit-inline{align-items:center;gap:6px;display:inline-flex}.criticality-edit-inline select{color:var(--text);background:#fff;border:1px solid #a0b4c8;border-radius:8px;padding:3px 8px;font-size:.76rem}.criticality-edit-inline button{cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;padding:3px 10px;font-size:.76rem;font-weight:600;transition:background .12s}.criticality-edit-inline button:first-of-type{color:#0f9d7a;border-color:#0f9d7a}.criticality-edit-inline button:first-of-type:hover{background:#0f9d7a1a}.criticality-edit-inline button:last-of-type{color:var(--text-muted);border-color:var(--border)}.criticality-edit-inline button:disabled{opacity:.5;cursor:not-allowed}@media (width<=640px){.page-content{padding:18px 14px}.kpi-strip{grid-template-columns:repeat(2,minmax(120px,1fr))}.dashboard-wire-grid,.hierarchy-ribbon,.mock-grid,.option-b,.explorer-layout,.two-col-layout{grid-template-columns:1fr}.app-layout{flex-direction:column}.action-toolbar{flex-wrap:wrap}.asset-detail-page .page-header{flex-direction:column;align-items:stretch}.detail-two-col{grid-template-columns:1fr}.modal-card{width:100%}.sidebar{width:100%;height:auto;position:static}.sidebar-nav{flex-direction:row;overflow-x:auto}}
