:root{
  --bg:#f6f4ee; --card:#fffdfa; --text:#17211d; --muted:#66736c; --border:#dde5de;
  --green:#003b27; --green2:#0b7442; --teal:#0b8f84; --blue:#2478c7; --amber:#f3bb24; --orange:#ef7d13; --red:#d8212b; --grey:#7c8784;
  --shadow:0 18px 45px rgba(22,34,28,.10); --soft-shadow:0 8px 22px rgba(22,34,28,.07); --radius:20px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}
button,input,select,textarea{font:inherit}a{color:inherit;text-decoration:none}.app-shell{display:grid;grid-template-columns:252px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,#003b27 0%,#00261a 100%);color:#fff;padding:22px 18px;display:flex;flex-direction:column;gap:20px;box-shadow:8px 0 30px rgba(2,35,23,.15);z-index:20}.brand-mark{display:flex;align-items:center;gap:12px;color:#fff}.brand-mark img{width:42px;height:42px}.brand-mark strong{display:block;font-size:19px;letter-spacing:-.3px}.brand-mark span{display:block;font-size:12px;color:#d7efe4;margin-top:2px}.side-nav{display:grid;gap:7px}.nav-link{display:flex;align-items:center;gap:12px;border:0;background:transparent;color:#eaf8f1;border-radius:15px;padding:12px 13px;text-align:left;cursor:pointer;font-weight:780}.nav-link span{width:28px;height:28px;border-radius:10px;background:rgba(255,255,255,.08);display:grid;place-items:center}.nav-link:hover,.nav-link.active{background:rgba(255,255,255,.13)}.nav-link.active{box-shadow:inset 0 0 0 1px rgba(255,255,255,.18)}.side-note{margin-top:auto;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.09);border-radius:18px;padding:15px}.side-note b{display:block}.side-note small{display:block;color:#d4eadf;line-height:1.45;margin-top:4px}.main-content{padding:0 26px 30px;min-width:0}.topbar{position:sticky;top:0;z-index:10;background:rgba(246,244,238,.92);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px 0 18px;border-bottom:1px solid rgba(221,229,222,.75)}.topbar h1{margin:0;font-size:31px;letter-spacing:-.75px}.topbar p{margin:3px 0 0;color:var(--muted);font-weight:650}.top-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.live-pill{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--border);background:#fff;border-radius:999px;padding:10px 12px;color:#435049;font-weight:850}.live-pill:before{content:"";width:9px;height:9px;border-radius:999px;background:var(--grey)}.live-pill.active:before{background:var(--green2)}.btn{border:1px solid transparent;border-radius:13px;padding:11px 14px;font-weight:850;cursor:pointer;transition:.16s ease;white-space:nowrap}.btn-primary{background:var(--green);color:#fff;box-shadow:0 12px 24px rgba(0,59,39,.22)}.btn-primary:hover{background:#002e20}.btn-ghost{border-color:#a9c9bb;background:#fff;color:var(--green)}.btn-soft{border-color:#bdd2c7;background:#eef8f2;color:#003b27}.page{display:none}.page.active{display:block}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--soft-shadow)}.dashboard-intro{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 20px;margin:20px 0 16px}.dashboard-intro h2{margin:0 0 5px;font-size:24px}.dashboard-intro p{margin:0;color:var(--muted);max-width:920px}.kpi-grid{display:grid;grid-template-columns:repeat(6,minmax(150px,1fr));gap:13px;margin-bottom:14px}.kpi-card{position:relative;padding:16px 16px 10px;min-height:192px;background:var(--card);border:1px solid var(--border);border-radius:20px;box-shadow:var(--soft-shadow);overflow:hidden}.kpi-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--accent,var(--green))}.kpi-card p{color:#3b4841;font-size:12px;font-weight:850;margin:0 52px 10px 0;min-height:34px}.kpi-card strong{font-size:34px;letter-spacing:-1px;color:var(--accent,var(--green))}.kpi-card small{color:var(--muted);font-weight:800}.kpi-card b{display:inline-flex;margin-top:7px;border-radius:999px;padding:5px 9px;background:color-mix(in srgb,var(--accent,var(--green)) 13%,white);color:var(--accent,var(--green));font-size:12px}.kpi-icon{position:absolute;right:14px;top:16px;width:43px;height:43px;border-radius:50%;display:grid;place-items:center;background:color-mix(in srgb,var(--accent,var(--green)) 13%,white);color:var(--accent,var(--green));font-size:21px;font-weight:900}.kpi-card canvas{width:100%;height:48px;margin-top:11px}.good{--accent:var(--green2)}.ok{--accent:var(--teal)}.moderate{--accent:var(--blue)}.warning{--accent:var(--amber)}.high{--accent:var(--orange)}.critical{--accent:var(--red)}.missing{--accent:var(--grey)}.dashboard-grid{display:grid;grid-template-columns:1.2fr 1.2fr .95fr 1fr;gap:14px;margin-bottom:16px}.chart-card{padding:16px;min-height:395px}.card-heading{display:flex;align-items:start;justify-content:space-between;gap:12px;margin-bottom:10px}.card-heading h2{font-size:16px;margin:0}.card-heading span,.source-note{color:var(--muted);font-size:12px}.source-note{margin:8px 0 0}.chart-card canvas{width:100%;height:auto}.material-card{padding:16px}.hazard-list{display:grid;gap:11px;margin-top:10px}.hazard-row{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid var(--border);border-radius:14px;padding:12px;background:#fff}.hazard-name{display:flex;align-items:center;gap:9px;font-weight:850}.hazard-icon{width:34px;height:34px;border-radius:12px;display:grid;place-items:center;background:#f3f5ef}.badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-weight:900;font-size:12px}.badge.good{background:#e4f6e9;color:#16834e}.badge.ok{background:#ddf5f2;color:#0a8278}.badge.moderate{background:#e6f1fd;color:#1f70bf}.badge.warning{background:#fff4cd;color:#966f00}.badge.high{background:#fff0df;color:#ca5c09}.badge.critical{background:#ffe5e7;color:#bb131a}.badge.missing{background:#eef2f2;color:#64706e}.alert-list{display:grid;gap:9px;margin-top:10px}.alert{border-radius:14px;padding:11px 12px;background:#fff;border:1px solid var(--border);border-left:5px solid var(--orange);font-weight:760}.alert.critical{border-left-color:var(--red)}.alert.high{border-left-color:var(--orange)}.aspects-register{padding:18px;margin-bottom:16px}.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin:22px 0 16px}.section-head h2{font-size:25px;letter-spacing:-.4px;margin:0 0 5px}.section-head p{margin:0;color:var(--muted);font-weight:640}.aspects-register .section-head{margin-top:0}.mini-kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin:16px 0}.mini-kpi{padding:13px 14px;border:1px solid var(--border);border-radius:16px;background:#fff}.mini-kpi span{display:block;font-size:11px;color:var(--muted);font-weight:800}.mini-kpi strong{display:block;font-size:26px;color:var(--accent,var(--green));line-height:1.1}.mini-kpi small{color:var(--muted);font-size:11px}.table-wrap{overflow:auto;border:1px solid var(--border);border-radius:17px}table{width:100%;border-collapse:collapse;min-width:1120px;background:#fff}th,td{padding:13px 12px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}th{font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:#546158;background:#f8faf6}td{font-size:12px;color:#2d3a34}tbody tr:hover{background:#fbfdf9}.bottom-grid{display:grid;grid-template-columns:1fr 1.15fr 1.05fr 1.35fr;gap:14px;margin-bottom:16px}.bottom-grid .card{padding:16px}.top-aspect-row{display:grid;grid-template-columns:1fr 42px;gap:12px;align-items:center;margin:13px 0}.risk-bar{height:8px;border-radius:999px;background:#edf0ed;overflow:hidden;margin-top:7px}.risk-bar i{display:block;height:100%;border-radius:999px;background:var(--accent)}.overdue-list{display:grid;gap:8px;margin-top:8px}.overdue-list div{display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--border);padding-top:8px}.overdue-list b{color:var(--red)}.reference-strip{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;margin-bottom:20px}.ref-note{display:flex;align-items:center;gap:14px}.ref-note span{width:50px;height:50px;border-radius:16px;background:#e6f4ed;color:var(--green);display:grid;place-items:center;font-size:23px}.ref-note h3{margin:0 0 3px}.ref-note p{max-width:660px;color:var(--muted);margin:0}.ref-pills{display:flex;gap:9px;flex-wrap:wrap;justify-content:flex-end}.ref-pills button{border:1px solid var(--border);background:#fff;border-radius:12px;padding:10px 12px;font-weight:800;color:#52605a}.two-col{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(360px,.8fr);gap:16px}.input-card{padding:18px}.input-card h3{margin:4px 0 14px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:18px}.form-grid label,.export-form label{display:grid;gap:7px;font-weight:850;color:#34413a}.form-grid input,.form-grid select,.export-form input,.export-form textarea,.action-notes textarea{border:1px solid var(--border);background:#fff;border-radius:12px;padding:11px 12px;min-width:150px;color:var(--text);outline:none;width:100%}.form-grid input:focus,.form-grid select:focus,.export-form input:focus,.export-form textarea:focus,.action-notes textarea:focus{border-color:#98bea9;box-shadow:0 0 0 3px rgba(31,154,88,.12)}.result-panel{padding:20px;position:sticky;top:112px;height:max-content}.result-score{display:flex;align-items:center;gap:12px;margin:16px 0;border-radius:20px;background:#f8faf6;border:1px solid var(--border);padding:16px}.result-score span{font-size:44px;font-weight:900;color:var(--accent,var(--green));letter-spacing:-1.5px}.result-score b{border-radius:999px;background:color-mix(in srgb,var(--accent,var(--green)) 13%,white);color:var(--accent,var(--green));padding:7px 11px}.result-panel dl{display:grid;grid-template-columns:130px 1fr;gap:8px 12px}.result-panel dt{font-weight:900;color:#59655f}.result-panel dd{margin:0;color:#27332e}.result-panel ul{padding-left:18px}.data-list-card{padding:16px;margin:16px 0}.records-table{overflow:auto}.record-table{min-width:900px}.record-actions button{padding:6px 10px;border-radius:10px}.empty-list{color:var(--muted);font-weight:700;display:grid;place-items:center;min-height:120px;text-align:center;background:#fbfdf9;border:1px dashed #cad6cf;border-radius:16px;padding:20px}.library-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.ref-card{padding:18px}.ref-card h3{color:var(--green);margin:0 0 9px}.ref-card p,.ref-card li{color:#46534d;line-height:1.5}.action-notes{padding:18px;margin-top:16px}.action-notes textarea{min-height:160px;resize:vertical}.modal-backdrop{position:fixed;inset:0;background:rgba(5,18,12,.52);display:none;align-items:center;justify-content:center;padding:20px;z-index:80}.modal-backdrop.show{display:flex}.modal{position:relative;max-width:680px;width:100%;background:#fffdfa;border-radius:24px;border:1px solid var(--border);box-shadow:var(--shadow);padding:24px}.modal h2{margin:0 0 8px}.modal p{color:var(--muted);margin:0 0 18px}.modal-close{position:absolute;right:16px;top:14px;border:0;background:#f0f4ef;border-radius:50%;width:34px;height:34px;font-size:22px;cursor:pointer}.export-form{display:grid;gap:14px}.export-form textarea{min-height:90px;resize:vertical}.modal-actions{display:flex;justify-content:flex-end;gap:10px;flex-wrap:wrap}.print-report{display:none}.toast{position:fixed;right:22px;bottom:22px;background:#003b27;color:#fff;border-radius:14px;padding:12px 16px;font-weight:850;box-shadow:var(--shadow);opacity:0;transform:translateY(12px);pointer-events:none;transition:.2s ease;z-index:90}.toast.show{opacity:1;transform:translateY(0)}

.field-title{display:inline-flex;align-items:center;gap:7px;line-height:1.25}.hint{display:inline-grid;place-items:center;width:18px;height:18px;border-radius:999px;background:#e6efe9;color:var(--green);border:1px solid #bdd4c7;font-size:12px;font-weight:900;cursor:help;vertical-align:middle;flex:0 0 auto}.hint:hover{background:var(--green);color:#fff}.section-hint{width:20px;height:20px;font-size:12px}.reference-library{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.primary-ref{grid-column:1/-1}.ref-links{display:flex;flex-wrap:wrap;gap:9px;margin-top:12px}.ref-links a{display:inline-flex;align-items:center;gap:6px;border:1px solid #bcd2c6;background:#f3faf5;color:var(--green);border-radius:999px;padding:8px 11px;font-weight:900;font-size:12px}.ref-links a:hover{background:var(--green);color:#fff}.ref-card ul{margin:10px 0 0;padding-left:18px}.empty-cell{text-align:center;color:var(--muted);font-weight:800;background:#fbfdf9}
@media (max-width:1320px){.sidebar{width:224px}.app-shell{grid-template-columns:224px minmax(0,1fr)}.kpi-grid{grid-template-columns:repeat(3,1fr)}.dashboard-grid{grid-template-columns:repeat(2,1fr)}.bottom-grid{grid-template-columns:repeat(2,1fr)}.mini-kpis{grid-template-columns:repeat(3,1fr)}.library-grid{grid-template-columns:repeat(2,1fr)}.reference-library{grid-template-columns:1fr}}
@media (max-width:900px){.app-shell{display:block}.sidebar{position:static;width:auto;height:auto;border-radius:0;box-shadow:none}.side-nav{overflow:auto;display:flex}.nav-link{min-width:130px;justify-content:center;font-size:12px}.nav-link span{display:none}.side-note{display:none}.main-content{padding:0 14px 24px}.topbar{position:static;align-items:flex-start;flex-direction:column}.top-actions{justify-content:flex-start}.topbar h1{font-size:25px}.dashboard-intro{flex-direction:column;align-items:flex-start}.kpi-grid,.dashboard-grid,.bottom-grid,.two-col,.library-grid,.reference-library{grid-template-columns:1fr}.mini-kpis{grid-template-columns:repeat(2,1fr)}.reference-strip{flex-direction:column;align-items:flex-start}.result-panel{position:static}.form-grid{grid-template-columns:1fr}}
@media print{body{background:#fff}.app-shell{display:block}.sidebar,.topbar,.page,.modal-backdrop,.toast{display:none!important}.main-content{padding:0}.print-report{display:block!important;padding:0;background:#fff;color:#111}.print-cover{border-bottom:3px solid #003b27;padding-bottom:18px;margin-bottom:18px}.print-cover h1{margin:0;font-size:28px}.print-cover p{margin:5px 0;color:#333}.print-section{break-inside:avoid;margin:16px 0}.print-section h2{font-size:17px;color:#003b27;border-bottom:1px solid #cbd8d0;padding-bottom:5px}.print-table{width:100%;border-collapse:collapse;font-size:11px;min-width:0}.print-table th,.print-table td{border:1px solid #ccd7d0;padding:6px;text-align:left;vertical-align:top}.print-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.print-metric{border:1px solid #ccd7d0;border-radius:8px;padding:8px}.print-metric b{display:block;font-size:18px}.print-note{white-space:pre-wrap;border:1px solid #ccd7d0;padding:10px;border-radius:8px}}

/* v4 refinements: guide popups, mobile chart alignment, and print-first-page fix */
.chart-card,.bottom-grid .card{overflow:hidden}.chart-card canvas,.bottom-grid canvas{display:block;max-width:100%;margin:0 auto}.material-card,.chart-card{min-width:0}.help-modal{max-width:620px}.help-modal h2{color:var(--green);padding-right:36px}.help-examples{margin-top:14px;border:1px solid var(--border);border-radius:16px;background:#f7fbf8;padding:14px}.help-examples h3{margin:0 0 8px;font-size:15px;color:#0d2f21}.help-examples ul{margin:0;padding-left:20px;color:#46534d;line-height:1.55}.hint{appearance:none;-webkit-appearance:none;padding:0}.ref-card.primary-ref{border-color:#bdd2c7;background:linear-gradient(180deg,#fffdfa,#f8fcf8)}.ref-links a[href$=".pdf"],.ref-links a[href*="pdf"],.ref-links a[href*="TranslatedAttachPath"]{background:#fff7e9;border-color:#e8c88e;color:#6c4800}.ref-links a[href$=".pdf"]:hover,.ref-links a[href*="pdf"]:hover,.ref-links a[href*="TranslatedAttachPath"]:hover{background:#6c4800;color:#fff}
@media (max-width:900px){.chart-card{min-height:auto}.chart-card canvas{height:auto!important}.bottom-grid canvas{height:auto!important}.kpi-card{min-height:170px}.mini-kpis{grid-template-columns:1fr}.table-wrap{border-radius:14px}table{min-width:920px}.modal{max-height:88vh;overflow:auto}.ref-links a{width:100%;justify-content:center}.dashboard-grid{gap:12px}.bottom-grid{gap:12px}.card-heading{align-items:flex-start}}
@media print{@page{size:A4;margin:12mm}html,body{margin:0!important;padding:0!important;background:#fff!important}.app-shell,.sidebar,.topbar,.page,.modal-backdrop,.toast{display:none!important;min-height:0!important;height:0!important}.print-report{display:block!important;position:static!important;margin:0!important;padding:0!important;background:#fff;color:#111;page-break-before:avoid!important;break-before:avoid!important}.print-cover{page-break-before:avoid!important;break-before:avoid!important}.print-section{break-inside:avoid;margin:12px 0}.print-grid{grid-template-columns:repeat(4,1fr);gap:6px}.print-metric{padding:7px}.print-metric span{font-size:10px;color:#46534d}.print-metric b{font-size:15px}.print-table{font-size:9.5px}.print-table th,.print-table td{padding:5px;word-break:break-word}.print-note{font-size:10px}}

/* v6 graph/report refinements */
.chart-card canvas,.bottom-grid canvas{background:#fff;border-radius:18px;max-height:340px;object-fit:contain}.chart-card{background:#fffdfa}.bottom-grid .card{background:#fffdfa}.material-card{background:#fffdfa}.dashboard-grid{align-items:stretch}.chart-card,.bottom-grid .card{display:flex;flex-direction:column}.chart-card canvas,.bottom-grid canvas{flex:0 0 auto}.source-note{min-height:14px}.print-report{display:none}.report-preview-open .print-report{display:block;margin:22px 0 40px;padding:20px;background:#fff;border:1px solid var(--border);border-radius:20px;box-shadow:var(--soft-shadow)}.report-preview-open .print-cover{border-bottom:3px solid var(--green);padding-bottom:16px;margin-bottom:18px}.report-preview-open .print-cover h1{margin:0 0 8px;color:var(--green)}.report-preview-open .print-section{margin:16px 0}.report-preview-open .print-section h2{font-size:17px;color:var(--green);border-bottom:1px solid #cbd8d0;padding-bottom:6px}.report-preview-open .print-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.report-preview-open .print-metric{border:1px solid #ccd7d0;border-radius:10px;padding:10px;background:#fbfdf9}.report-preview-open .print-metric span{display:block;font-size:11px;color:#46534d}.report-preview-open .print-metric b{display:block;font-size:16px;margin-top:4px}.report-preview-open .print-table{width:100%;border-collapse:collapse;font-size:11px;min-width:0}.report-preview-open .print-table th,.report-preview-open .print-table td{border:1px solid #ccd7d0;padding:6px;text-align:left;vertical-align:top;word-break:break-word}.report-preview-open .print-table th{background:#f0f5f2;color:var(--green)}
@media (max-width:900px){.report-preview-open .print-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.chart-card canvas,.bottom-grid canvas{max-height:none}.dashboard-grid,.bottom-grid{grid-template-columns:1fr!important}.chart-card{min-height:0}}
@media print{@page{size:A4;margin:12mm}html,body{margin:0!important;padding:0!important;background:#fff!important}.app-shell,.sidebar,.topbar,.page,.modal-backdrop,.toast{display:none!important;min-height:0!important;height:0!important}.print-report{display:block!important;position:static!important;margin:0!important;padding:0!important;background:#fff!important;color:#111!important;border:0!important;box-shadow:none!important;page-break-before:avoid!important;break-before:avoid!important}.print-cover{page-break-before:avoid!important;break-before:avoid!important;border-bottom:3px solid #003b27!important;padding-bottom:16px!important;margin-bottom:16px!important}.print-cover h1{margin:0 0 8px!important;color:#003b27!important}.print-section{break-inside:avoid;margin:12px 0!important}.print-section h2{font-size:17px;color:#003b27;border-bottom:1px solid #cbd8d0;padding-bottom:5px}.print-grid{display:grid;grid-template-columns:repeat(4,1fr)!important;gap:6px}.print-metric{border:1px solid #ccd7d0;border-radius:8px;padding:7px;background:#fbfdf9}.print-metric span{display:block;font-size:10px;color:#46534d}.print-metric b{display:block;font-size:15px}.print-table{width:100%;border-collapse:collapse;font-size:9.5px;min-width:0!important}.print-table th,.print-table td{border:1px solid #ccd7d0;padding:5px;text-align:left;vertical-align:top;word-break:break-word}.print-table th{background:#f0f5f2;color:#003b27}}
