:root{color-scheme:light;--bg: #f8f4e8;--bg-soft: #fffaf0;--panel: #ffffff;--ink: #10251f;--muted: #5d6b64;--line: #ded6c3;--brand: #0f3d33;--brand-2: #d64545;--brand-3: #f1c44f;--ok: #207a55;--warn: #9c6500;--bad: #aa2e25;--notice: #4566a3;--shadow: 0 18px 50px rgba(16, 37, 31, .12);--radius: 22px;--radius-sm: 12px;--max: 1120px}*{box-sizing:border-box}html{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--ink)}body{margin:0;min-height:100vh;line-height:1.6}a{color:var(--brand);text-decoration-thickness:.08em;text-underline-offset:.18em}a:hover{color:#071b16}img,svg{max-width:100%;height:auto}button,input,textarea,select{font:inherit}button{cursor:pointer}code,pre{font-family:SFMono-Regular,Consolas,Liberation Mono,monospace}:focus-visible{outline:3px solid #245fff;outline-offset:3px}.skip-link{position:absolute;left:1rem;top:1rem;transform:translateY(-150%);background:var(--ink);color:#fff;padding:.75rem 1rem;z-index:1000;border-radius:999px}.skip-link:focus{transform:translateY(0)}.site-shell{min-height:100vh;display:flex;flex-direction:column}.container{width:min(var(--max),calc(100% - 2rem));margin-inline:auto}.narrow{width:min(820px,calc(100% - 2rem));margin-inline:auto}.site-header{border-bottom:1px solid rgba(16,37,31,.12);background:#f8f4e8eb;backdrop-filter:blur(12px);position:sticky;top:0;z-index:20}.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0}.logo{display:inline-flex;gap:.6rem;align-items:center;color:var(--ink);text-decoration:none;font-weight:850;letter-spacing:-.04em}.logo-mark{width:34px;height:34px;border-radius:10px;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:900;box-shadow:0 8px 20px #0f3d3340}.logo small{display:block;color:var(--muted);font-weight:650;letter-spacing:0;font-size:.72rem;margin-top:-.1rem}.nav{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:flex-end}.nav a{text-decoration:none;color:var(--ink);font-weight:700;padding:.55rem .75rem;border-radius:999px}.nav a:hover{background:#0f3d3314}main{flex:1}.hero{padding:4.5rem 0 3rem;position:relative;overflow:hidden}.hero-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:2rem;align-items:center}.eyebrow{display:inline-flex;gap:.45rem;align-items:center;border:1px solid var(--line);background:#ffffffad;padding:.35rem .65rem;border-radius:999px;font-weight:800;font-size:.84rem;color:var(--brand)}h1,h2,h3{line-height:1.08;letter-spacing:-.055em;margin:0 0 1rem}h1{font-size:clamp(2.7rem,7vw,5.9rem);max-width:10ch}h2{font-size:clamp(2rem,4vw,3.4rem)}h3{font-size:clamp(1.35rem,3vw,2rem)}p{margin:0 0 1rem}.lead{color:#31443c;font-size:clamp(1.08rem,2vw,1.35rem);max-width:62ch}.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:1.5rem}.button,.button-secondary,.button-ghost{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;border-radius:999px;padding:.78rem 1rem;font-weight:850;text-decoration:none;border:1px solid transparent}.button{background:var(--brand);color:#fff;box-shadow:0 14px 32px #0f3d3338}.button:hover{background:#08261f;color:#fff}.button-secondary{background:#fff;color:var(--brand);border-color:var(--line)}.button-secondary:hover{background:#fff8df}.button-ghost{background:transparent;color:var(--ink);border-color:var(--line)}.button:disabled,.button-secondary:disabled,.button-ghost:disabled,button:disabled{opacity:.68;cursor:not-allowed}.card,.tool-card,.guide-card,.callout,.report-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.card{padding:1.25rem}.tool-card{padding:1.35rem}.hero-card{transform:rotate(1deg)}.hero-card strong{color:var(--brand)}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-top:1rem}.stat{border:1px solid var(--line);border-radius:16px;padding:.85rem;background:var(--bg-soft)}.stat b{display:block;font-size:1.6rem;line-height:1}.stat span{display:block;color:var(--muted);font-size:.82rem;margin-top:.2rem}.section{padding:3.5rem 0}.section-tight{padding:2rem 0}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.card h3,.tool-card h3,.guide-card h3{margin-bottom:.5rem}.card p,.tool-card p,.guide-card p{color:var(--muted)}.badge-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}.badge{border:1px solid var(--line);background:#ffffffb3;padding:.32rem .55rem;border-radius:999px;font-size:.84rem;font-weight:800;color:var(--muted)}.badge.critical{color:var(--bad);background:#fff4f1;border-color:#f2c9c2}.badge.major{color:#7b342a;background:#fff1d9;border-color:#eed3a2}.badge.moderate{color:var(--warn);background:#fff8df;border-color:#ead593}.badge.notice{color:var(--notice);background:#edf3ff;border-color:#c8d7f5}.callout{padding:1.2rem;background:#fff8df;box-shadow:none}.callout.warning{background:#fff3ec;border-color:#f1c1ad}.callout.success{background:#effaf4;border-color:#b9e4c9}.callout h2,.callout h3{font-size:1.3rem;margin-bottom:.45rem;letter-spacing:-.03em}.callout p:last-child{margin-bottom:0}.article{padding:3rem 0}.article h1{max-width:14ch;font-size:clamp(2.35rem,6vw,4.8rem)}.article-body{width:min(820px,calc(100% - 2rem));margin:0 auto}.article-body h2{margin-top:2.5rem}.article-body h3{margin-top:1.6rem}.article-body p,.article-body li{color:#293c34;font-size:1.04rem}.article-body li{margin-bottom:.45rem}.article-body table{border-collapse:collapse;width:100%;margin:1.5rem 0;font-size:.95rem}.article-body th,.article-body td{border:1px solid var(--line);padding:.75rem;text-align:left;vertical-align:top}.article-body th{background:#fff8df}.issue-index-list{display:grid;gap:.8rem}.issue-index-item{border:1px solid var(--line);border-radius:16px;background:#fff;padding:1rem}.issue-index-item h3{font-size:1.2rem;margin-bottom:.35rem;letter-spacing:-.03em}.issue-index-item p{margin-bottom:0}.before-after-example{margin:2.25rem 0}.before-after-example h2{font-size:clamp(1.55rem,3vw,2.25rem);margin-bottom:1rem}.example-panels{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.85rem}.example-panels:has(.example-panel:nth-child(3)){grid-template-columns:repeat(3,minmax(0,1fr))}.example-panel{border:1px solid var(--line);border-radius:16px;background:#fff;padding:1rem;display:grid;gap:.75rem;align-content:start}.example-panel.bad{border-left:5px solid var(--bad)}.example-panel.better{border-left:5px solid var(--warn)}.example-panel.best{border-left:5px solid var(--ok)}.example-panel-heading{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.example-panel-heading h3{font-size:1.05rem;margin:0;letter-spacing:-.03em}.example-panel pre{margin:0;border-radius:12px;background:#f6f0df;border:1px solid var(--line);padding:.85rem;overflow-x:auto;font-size:.86rem;line-height:1.45}.example-panel p{margin:0;font-size:.96rem}.example-note{border-left:4px solid var(--notice);padding-left:.85rem;color:var(--muted)}.source-list{font-size:.92rem;color:var(--muted)}.breadcrumbs{margin-bottom:1.1rem;color:var(--muted);font-size:.92rem}.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;padding:0;margin:0}.breadcrumbs li{display:inline-flex;align-items:center;gap:.35rem}.breadcrumbs li:not(:last-child):after{content:"/";color:#89938c}.breadcrumbs a{color:var(--muted);font-weight:750;text-decoration:none}.breadcrumbs a:hover{color:var(--brand);text-decoration:underline}.next-steps{border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow);padding:1.25rem;margin:2rem 0}.next-steps-heading{display:grid;gap:.25rem;margin-bottom:1rem}.next-steps-heading h2{font-size:clamp(1.55rem,3vw,2.2rem);margin:0}.next-steps-heading p{color:var(--muted);margin:0}.next-step-list{display:grid;gap:.75rem;grid-template-columns:repeat(2,minmax(0,1fr))}.next-step{display:grid;gap:.25rem;min-height:100%;padding:.9rem 1rem;border:1px solid var(--line);border-radius:16px;background:#fffaf0;color:var(--ink);text-decoration:none}.next-step:hover{border-color:#0f3d3373;background:#fff7dc;color:var(--ink)}.next-step span{font-weight:850}.next-step small{color:var(--muted);font-size:.9rem;line-height:1.45}.tool-shell{padding:2rem 0 4rem}.tool-panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:clamp(1rem,2vw,1.5rem)}.tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.tab{border:1px solid var(--line);background:#fffaf0;padding:.6rem .85rem;border-radius:999px;font-weight:800}.tab.active{background:var(--brand);color:#fff;border-color:var(--brand)}.form-row{display:grid;grid-template-columns:1fr auto;gap:.75rem}.input,.textarea,.select{width:100%;border:1px solid var(--line);border-radius:16px;padding:.85rem 1rem;background:#fffef8;color:var(--ink)}.textarea{min-height:190px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Consolas,monospace;font-size:.92rem}.help{color:var(--muted);font-size:.92rem;margin-top:.55rem}.error{color:#811d16;background:#fff0ed;border:1px solid #f1b8ad;border-radius:14px;padding:.75rem;margin-top:.85rem}.report{margin-top:1.5rem;display:grid;gap:1rem}.report-card{padding:1.1rem;box-shadow:none}.summary-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem}.summary-item{border:1px solid var(--line);border-radius:16px;padding:.9rem;background:#fffaf0}.summary-item .summary-count{display:block;font-size:1.8rem;font-weight:750;line-height:1}.summary-item .summary-label{display:block;color:var(--muted);font-size:.82rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.summary-item[data-severity=critical]{background:#fff4f1;border-color:#f2c9c2}.summary-item[data-severity=major]{background:#fff1d9;border-color:#eed3a2}.summary-item[data-severity=moderate]{background:#fff8df;border-color:#ead593}.summary-item[data-severity=notice]{background:#edf3ff;border-color:#c8d7f5}.issue-list{display:grid;gap:.8rem}.issue{border:1px solid var(--line);border-left:5px solid var(--notice);border-radius:16px;padding:1rem;background:#fff}.issue[data-severity=critical]{border-left-color:var(--bad)}.issue[data-severity=major]{border-left-color:#c15a2a}.issue[data-severity=moderate]{border-left-color:var(--warn)}.issue h4{font-size:1.05rem;margin:0 0 .3rem}.issue-meta{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.55rem}.snippet{display:block;background:#f6f0df;padding:.65rem;border-radius:10px;overflow-x:auto;color:#3a3122}.export-row{display:flex;gap:.6rem;flex-wrap:wrap}.export-row button,.small-button{border:1px solid var(--line);background:#fffaf0;border-radius:999px;padding:.55rem .75rem;font-weight:800;white-space:nowrap}.export-row button:hover,.small-button:hover{background:#f5ead0}.small-button.active,.small-button[aria-pressed=true]{background:var(--brand);border-color:var(--brand);color:#fff}.export-groups{display:grid;gap:.75rem}.export-group h4{margin:0 0 .35rem;font-size:.95rem;color:var(--muted)}.export-group .export-row{gap:.45rem}.colour-picker-row{display:flex;gap:.5rem;align-items:center;margin-top:.35rem}.colour-picker-row .colour-swatch{width:48px;min-width:48px;height:44px;padding:0;border-radius:12px;cursor:pointer}.colour-picker-row .input{flex:1;min-width:0}.report-view-tabs{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.5rem}.metadata-fields{display:grid;gap:.65rem;margin-top:.75rem}.metadata-field label{display:block;font-weight:700;margin-bottom:.2rem;font-size:.92rem}.metadata-field .input,.metadata-field .textarea{width:100%}.preset-selector{margin-top:1rem}.preset-summary{margin-top:.6rem;padding:.75rem;border:1px solid var(--line);border-radius:14px;background:#fffaf0}.preset-summary p{margin-bottom:.25rem}.owner-groups{display:grid;gap:.75rem}.owner-group h4{font-size:1rem;margin:0 0 .35rem}.ticket-list{display:grid;gap:.75rem;margin-top:.75rem}.ticket-card{border:1px solid var(--line);border-radius:16px;padding:1rem;background:#fffaf0}.ticket-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.manual-checklist .checklist-item{display:flex;gap:.55rem;align-items:flex-start;margin-bottom:.55rem;cursor:pointer}.manual-checklist .checklist-item input[type=checkbox]{margin-top:.25rem;flex-shrink:0}.client-summary h3{font-size:1.15rem;margin-top:1rem;letter-spacing:-.03em}.site-footer{margin-top:3rem;border-top:1px solid var(--line);background:#10251f;color:#f8f4e8}.footer-inner{padding:2rem 0;display:grid;grid-template-columns:1.2fr .8fr;gap:1rem}.footer-inner a{color:#fff8df}.footer-inner p{color:#ddd4bd}.footer-links{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-end;align-content:start}@media(max-width:860px){.hero-grid,.grid-3,.grid-2,.footer-inner{grid-template-columns:1fr}.example-panels,.example-panels:has(.example-panel:nth-child(3)){grid-template-columns:1fr}.summary-grid,.stat-grid{grid-template-columns:repeat(2,1fr)}.next-step-list,.form-row{grid-template-columns:1fr}.nav{justify-content:flex-start}.header-inner{align-items:flex-start;flex-direction:column}.hero{padding-top:3rem}.tool-shell{padding-top:1rem}.colour-picker-row{flex-wrap:wrap}.colour-picker-row .colour-swatch{width:100%;height:48px}}@media(max-width:520px){.summary-grid,.stat-grid{grid-template-columns:1fr}h1{font-size:2.65rem}.container,.narrow,.article-body{width:min(100% - 1.25rem,var(--max))}.hero-actions,.export-row,.tabs{gap:.5rem}.button,.button-secondary,.button-ghost,.export-row button,.small-button,.tab{width:100%}.tool-panel,.report-card,.callout,.next-steps{border-radius:16px}.input,.textarea,.select{border-radius:12px}.report-card{padding:.85rem}.colour-picker-row{flex-direction:column}.colour-picker-row .colour-swatch{width:100%;height:48px}.export-row button,.small-button{white-space:normal;word-break:break-word}.metadata-field .input,.metadata-field .textarea{max-width:100%;box-sizing:border-box}.input,.textarea,.select{max-width:100%}}@media print{.site-header,.site-footer,.nav,.button,.button-secondary,.button-ghost,.export-row,.tabs,.template-actions,.skip-link{display:none!important}.printable-checklist .checklist li{margin-bottom:.5rem;page-break-inside:avoid}.printable-checklist h2{page-break-after:avoid}.article,.article-body{background:#fff;color:#000;padding:0}.disclaimer,.callout{border:1px solid #ccc;background:#f9f9f9;color:#000}a[href]:after{content:" (" attr(href) ")";font-size:.8em;color:#555}.next-steps,.related-links{display:none}}
