/* ============================================================================
 * AITCOH Certified Installer Network Operating Hub
 * Blue theme — Products division "Trust Blue" per Aging In The Comfort Of Home®
 * BRAND.md. Headings: Montserrat. Body: Source Sans Pro. Static HTML/CSS/JS.
 * ==========================================================================*/

:root{
  /* Trust Blue (Products) */
  --blue-dark:#1b477e;
  --blue:#255ea0;
  --blue-light:#d9ecff;
  /* Shared brand */
  --gold:#fdd841;
  --gold-deep:#e7be1f;
  --charcoal:#333333;
  --gray:#e0e0e0;
  --linen:#fffce5;
  /* Derived UI */
  --bg:#eef4fb;
  --card:#ffffff;
  --ink:#333333;
  --muted:#5b6b82;
  --line:#d6e2f1;
  --danger:#a83b2b;
  --ok:#1c7a4d;
  --shadow:0 18px 45px rgba(27,71,126,.12);
  --shadow-sm:0 6px 18px rgba(27,71,126,.10);
  --radius:18px;
  --font-head:"Montserrat",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --font-body:"Source Sans Pro","Source Sans 3",ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);line-height:1.55}
h1,h2,h3,h4,.btn,.tool-btn,.mini-btn,.side-btn,.filter-btn,.label-chip,.logo-text strong{font-family:var(--font-head)}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:6px}

.app-shell{min-height:100vh;display:grid;grid-template-columns:330px 1fr}

/* ---------------------------------------------------------------- Sidebar */
.sidebar{position:sticky;top:0;height:100vh;overflow:auto;background:linear-gradient(180deg,var(--blue-dark),#0f2f57);color:#fff;padding:24px 20px;border-right:1px solid rgba(255,255,255,.12)}
.logo-block{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.logo-mark{width:46px;height:46px;border:2px solid var(--gold);border-radius:14px;display:grid;place-items:center;font-weight:900;color:var(--gold);background:rgba(255,255,255,.06);font-family:var(--font-head)}
.logo-mark-img{width:46px;height:46px;border-radius:12px;display:block;flex:none;box-shadow:0 4px 12px rgba(0,0,0,.25)}
.logo-text strong{display:block;font-size:15px;letter-spacing:.02em}
.logo-text span{font-size:12px;color:#bcd4f1}
.sidebar .search-wrap{position:relative;margin:16px 0}
.search-wrap input{width:100%;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.10);color:#fff;border-radius:12px;padding:12px 38px 12px 12px;font-size:14px;outline:none}
.search-wrap input::placeholder{color:#b4c5df}
.search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:26px;height:26px;border-radius:8px;background:rgba(255,255,255,.16);color:#fff;border:0;cursor:pointer;font-size:15px;line-height:1;display:none}
.search-clear.show{display:block}
.nav-label{font-size:11px;text-transform:uppercase;letter-spacing:.12em;color:#9ec0ea;font-weight:800;margin:22px 0 8px}
.doc-nav{display:grid;gap:6px}
.doc-nav a{display:grid;grid-template-columns:26px 1fr;gap:8px;align-items:start;color:#eaf2ff;border-radius:12px;padding:9px 10px;font-size:13px}
.doc-nav a:hover,.doc-nav a.active{background:rgba(255,255,255,.13);text-decoration:none}
.doc-nav a.nav-dim{opacity:.38}
.doc-num{height:22px;width:22px;border-radius:7px;background:rgba(253,216,65,.18);color:var(--gold);display:grid;place-items:center;font-weight:800;font-size:11px;font-family:var(--font-head)}
.sidebar-actions{display:grid;gap:8px;margin-top:18px}
.side-btn{border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.08);color:#fff;border-radius:12px;padding:10px 12px;font-weight:700;cursor:pointer;text-align:center;font-size:13px}
.side-btn:hover{background:rgba(255,255,255,.16)}
.side-btn.gold{background:var(--gold);border-color:var(--gold);color:#23303f}
.side-btn.gold:hover{background:var(--gold-deep)}

/* ------------------------------------------------------------------- Main */
.main{min-width:0}
.hero{background:radial-gradient(circle at top right,rgba(37,94,160,.16),transparent 42%),linear-gradient(135deg,#ffffff,#e7f1ff);padding:42px 52px 26px;border-bottom:1px solid var(--line)}
.hero-logo{height:54px;width:auto;margin:0 0 18px;display:block}
.kicker{display:inline-flex;gap:8px;align-items:center;color:var(--blue);font-weight:800;text-transform:uppercase;letter-spacing:.12em;font-size:12px}
.kicker:before{content:"";width:10px;height:10px;border-radius:50%;background:var(--gold);display:inline-block}
.hero h1{font-family:var(--font-head);font-size:clamp(30px,4.4vw,50px);line-height:1.04;margin:10px 0 12px;color:var(--blue-dark);letter-spacing:-.02em}
.hero p{max-width:980px;font-size:18px;color:#43516a}
.hero em{font-style:italic}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--blue-dark);padding:11px 16px;font-weight:800;cursor:pointer;font-size:14px}
.btn:hover{text-decoration:none;box-shadow:var(--shadow-sm)}
.btn.primary{background:var(--blue-dark);border-color:var(--blue-dark);color:#fff}
.btn.blue{background:var(--blue);border-color:var(--blue);color:#fff}
.btn.gold{background:var(--gold);border-color:var(--gold);color:#23303f}
.meta-strip{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}
.pill{background:#fff;border:1px solid var(--line);border-radius:999px;padding:7px 12px;font-size:13px;color:#43516a;font-weight:600}
.pill strong{color:var(--blue-dark);font-family:var(--font-head)}

.content{padding:30px 52px 70px}

/* -------------------------------------------------------------- Dashboard */
.section-eyebrow{font-family:var(--font-head);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--blue);font-weight:800;margin:6px 0 10px}
.dashboard{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;margin-bottom:8px}
.dash-card{text-align:left;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}
.dash-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--blue)}
.dash-card .number{font-family:var(--font-head);font-size:30px;font-weight:800;color:var(--blue-dark);letter-spacing:-.03em;line-height:1}
.dash-card .label{font-size:13px;color:var(--charcoal);font-weight:700;margin-top:6px}
.dash-card .sub{font-size:12px;color:var(--muted);margin-top:2px}
.dash-card.is-active{border-color:var(--blue);box-shadow:0 0 0 2px var(--blue) inset, var(--shadow-sm)}

.notice{background:var(--linen);border:1px solid #f1e3a3;border-left:5px solid var(--gold);border-radius:14px;padding:14px 16px;color:#5a4a13;margin:18px 0}
.small-note{font-size:14px}

/* ------------------------------------------------------------ Filter bars */
.filters{position:sticky;top:0;z-index:40;background:rgba(238,244,251,.94);backdrop-filter:blur(6px);margin:6px -52px 4px;padding:8px 52px 9px;border-bottom:1px solid var(--line)}
.filter-row{display:flex;align-items:center;gap:8px;margin:3px 0}
.filter-row .filter-title{font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:800;flex:none;min-width:50px;line-height:1.2}
/* Single-line, horizontally scrollable strips keep every pill one click away
   while staying compact. Pills wrap only on narrow (mobile) screens. */
.filter-group{display:flex;flex-wrap:nowrap;gap:4px;flex:1;min-width:0;overflow-x:auto;scrollbar-width:thin;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.filter-group::-webkit-scrollbar{height:5px}
.filter-group::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px}
.filter-btn{flex:none}
.filter-btn{border:1px solid var(--line);background:#fff;color:var(--blue-dark);border-radius:999px;padding:2px 9px;font-size:11.5px;font-weight:700;cursor:pointer;min-height:24px;line-height:1.25}
.filter-btn:hover{border-color:var(--blue)}
.filter-btn.is-active{background:var(--blue-dark);border-color:var(--blue-dark);color:#fff}
.filter-row.stage .filter-btn.is-active{background:var(--blue);border-color:var(--blue)}
.filter-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:6px;flex-wrap:wrap}
.result-count{font-size:11.5px;color:var(--muted);font-weight:600}
.result-count strong{color:var(--blue-dark)}
.filter-actions{display:flex;gap:6px;flex-wrap:wrap}
.text-btn{background:none;border:1px solid var(--line);border-radius:9px;padding:3px 9px;font-size:11px;font-weight:700;color:var(--blue-dark);cursor:pointer;min-height:24px}
.text-btn:hover{background:#fff;border-color:var(--blue)}

/* ------------------------------------------------------------ Status labels */
.label-chip{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:4px 10px;font-size:11.5px;font-weight:800;letter-spacing:.01em;border:1px solid transparent;white-space:nowrap}
.label-chip:before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.label--legal{background:#fbeceb;color:#a83b2b;border-color:#f0c9c3}
.label--internal{background:#e9f1fb;color:#1b477e;border-color:#caddf1}
.label--operational{background:#e7f5ee;color:#1c7a4d;border-color:#c2e6d2}
.label--field{background:#fff7d9;color:#8a6d05;border-color:#f0e2a0}
.label--draft{background:#eef0f3;color:#5b6b82;border-color:#d8dde4}

/* --------------------------------------------------------- Resource cards */
.resource-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin:18px 0 10px}
.resource-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px}
.resource-card .rc-top{display:flex;gap:13px;align-items:flex-start}
.resource-card .badge{flex:none;width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--blue-dark),var(--blue));color:#fff;display:grid;place-items:center;font-weight:900;font-family:var(--font-head)}
.resource-card h3{margin:0 0 2px;color:var(--blue-dark);font-size:17px;line-height:1.2}
.resource-card .rc-purpose{margin:0;color:var(--muted);font-size:13.5px}
.rc-facts{display:grid;gap:4px;font-size:12.5px;color:var(--charcoal);border-top:1px solid var(--line);padding-top:10px}
.rc-facts div{display:flex;gap:6px}
.rc-facts .k{color:var(--muted);font-weight:700;min-width:78px}
.rc-labels{display:flex;flex-wrap:wrap;gap:6px}
.mini-actions{margin-top:auto;display:flex;gap:7px;flex-wrap:wrap;padding-top:4px}
.mini-btn{font-size:12px;border:1px solid var(--line);border-radius:999px;padding:6px 11px;background:#f4f8fd;font-weight:800;color:var(--blue-dark);cursor:pointer;min-height:34px;display:inline-flex;align-items:center}
.mini-btn:hover{background:#fff;border-color:var(--blue);text-decoration:none}

/* ----------------------------------------------------------- Empty state */
.empty-state{display:none;text-align:center;padding:46px 20px;background:#fff;border:1px dashed var(--line);border-radius:var(--radius);color:var(--muted)}
.empty-state.show{display:block}
.empty-state strong{display:block;font-family:var(--font-head);color:var(--blue-dark);font-size:18px;margin-bottom:6px}

/* ---------------------------------------------------- Scripts / checklists */
.hub-block{margin:30px 0}
.block-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:6px}
.block-head h2{font-size:25px;color:var(--blue-dark);margin:0;letter-spacing:-.02em}
.block-head p{margin:4px 0 0;color:var(--muted);font-size:14px;max-width:760px}
.script-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.script-card{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column}
.script-card .sc-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 15px;background:linear-gradient(135deg,#f5f9ff,#fff);border-bottom:1px solid var(--line)}
.script-card .sc-head h3{margin:0;font-size:15px;color:var(--blue-dark)}
.script-card .sc-body{padding:13px 15px;font-size:13.5px;color:var(--charcoal);white-space:pre-wrap;line-height:1.5;flex:1}
.copy-btn{border:1px solid var(--blue);background:var(--blue);color:#fff;border-radius:10px;padding:7px 12px;font-size:12.5px;font-weight:800;cursor:pointer;min-height:34px;white-space:nowrap}
.copy-btn:hover{background:var(--blue-dark);border-color:var(--blue-dark)}
.copy-btn.copied{background:var(--ok);border-color:var(--ok)}

.checklist-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.checklist{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-sm);overflow:hidden}
.checklist .cl-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 15px;background:linear-gradient(135deg,#f5f9ff,#fff);border-bottom:1px solid var(--line)}
.checklist .cl-head h3{margin:0;font-size:15px;color:var(--blue-dark)}
.cl-progress{font-size:12px;color:var(--muted);font-weight:700;font-family:var(--font-head)}
.cl-items{list-style:none;margin:0;padding:8px 15px 12px}
.cl-items li{margin:0}
.cl-items label{display:flex;gap:10px;align-items:flex-start;padding:8px 6px;border-radius:10px;cursor:pointer;font-size:13.5px;color:var(--charcoal)}
.cl-items label:hover{background:#f4f8fd}
.cl-items input[type=checkbox]{margin-top:3px;width:18px;height:18px;accent-color:var(--blue);flex:none;cursor:pointer}
.cl-items label.done span{text-decoration:line-through;color:var(--muted)}
.cl-foot{padding:0 15px 13px}
.reset-btn{border:1px solid var(--line);background:#f4f8fd;color:var(--blue-dark);border-radius:10px;padding:7px 12px;font-size:12.5px;font-weight:700;cursor:pointer;min-height:34px}
.reset-btn:hover{border-color:var(--blue);background:#fff}

/* --------------------------------------------------------- Document library */
.section-title{font-family:var(--font-head);margin-top:30px;margin-bottom:6px;color:var(--blue-dark);font-size:26px;letter-spacing:-.02em}
.doc-section{background:#fff;border:1px solid var(--line);border-radius:20px;margin:18px 0;box-shadow:var(--shadow-sm);overflow:hidden}
.doc-section.is-open{box-shadow:var(--shadow)}
.doc-header{padding:18px 22px;background:linear-gradient(135deg,#f6faff,#fff);border-bottom:1px solid var(--line);display:flex;gap:16px;align-items:flex-start}
.doc-section:not(.is-open) .doc-header{border-bottom-color:transparent}
.doc-header .badge{width:46px;height:46px;border-radius:14px;background:var(--blue-dark);color:#fff;display:grid;place-items:center;font-weight:900;font-family:var(--font-head);flex:none}
.doc-head-main{min-width:0;flex:1}
.doc-header h2{font-family:var(--font-head);margin:0;color:var(--blue-dark);font-size:21px;letter-spacing:-.02em}
.doc-header p{margin:5px 0 0;color:var(--muted);font-size:14px}
.doc-head-labels{display:flex;gap:7px;flex-wrap:wrap;margin-top:9px}
.doc-tools{margin-left:auto;display:flex;gap:7px;flex-wrap:wrap;justify-content:flex-end;align-items:center}
.tool-btn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 11px;font-size:12px;font-weight:800;color:var(--blue-dark);cursor:pointer;min-height:34px}
.tool-btn:hover{background:#f4f8ff;border-color:var(--blue);text-decoration:none}
.accordion-toggle{border:1px solid var(--blue);background:var(--blue);color:#fff;border-radius:10px;padding:8px 12px;font-size:12px;font-weight:800;cursor:pointer;min-height:34px;display:inline-flex;align-items:center;gap:6px}
.accordion-toggle:hover{background:var(--blue-dark);border-color:var(--blue-dark)}
.accordion-toggle .chev{transition:transform .18s ease;font-size:11px}
.doc-section.is-open .accordion-toggle .chev{transform:rotate(180deg)}

.doc-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:18px 22px 4px}
.doc-summary .sum-card{background:#f7faff;border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.doc-summary .sum-card h4{font-family:var(--font-head);margin:0 0 5px;font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--blue)}
.doc-summary .sum-card.legal{background:#fbeceb;border-color:#f0c9c3}
.doc-summary .sum-card.legal h4{color:#a83b2b}
.doc-summary .sum-card ul{margin:4px 0 0 16px;padding:0}
.doc-summary .sum-card li{margin:3px 0;font-size:13.5px}
.doc-summary .sum-card p{margin:0;font-size:13.5px;color:var(--charcoal)}

.doc-body{padding:14px 22px 30px}
.doc-section:not(.is-open) .doc-body,.doc-section:not(.is-open) .doc-summary{display:none}
.doc-body h2{display:none}
.doc-body h3{font-family:var(--font-head);color:var(--blue-dark);font-size:19px;margin:24px 0 10px;padding-top:4px;border-top:1px solid #eef2f7}
.doc-body h3:first-child{border-top:0;margin-top:0}
.doc-body h4{font-family:var(--font-head);color:var(--blue);font-size:16px;margin:18px 0 8px}
.doc-body p{margin:9px 0}
.brand-eyebrow{font-family:var(--font-head);font-weight:800;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;font-size:12px}
.doc-body ul{margin:10px 0 14px 18px}
.doc-body li{margin:5px 0}
.table-wrap{overflow:auto;margin:14px 0 18px;border:1px solid var(--line);border-radius:14px}
table{width:100%;border-collapse:collapse;background:#fff;font-size:14px}
th{background:var(--blue-light);color:var(--blue-dark);text-align:left;font-weight:800;font-family:var(--font-head)}
th,td{padding:10px 11px;border-bottom:1px solid #e8eef6;vertical-align:top}
tr:last-child td{border-bottom:0}
.signature-line{border:0;border-top:1px solid #aab5c7;margin:20px 0}

/* ---------------------------------------------------------------- Footer */
.legal-footer{background:#0f2f57;color:#d4e3f6;padding:32px 52px}
.footer-logo{height:48px;width:auto;display:block;margin:0 0 18px}
.legal-footer strong{color:#fff;font-family:var(--font-head)}
.legal-footer em{font-style:italic}
.legal-footer p{max-width:1100px;margin:0 0 8px;font-size:14px}

/* ------------------------------------------------------------- Mobile top */
.mobile-top{display:none;background:var(--blue-dark);color:#fff;padding:12px 16px;position:sticky;top:0;z-index:120;align-items:center}
.mobile-top button{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:10px;padding:9px 12px;font-weight:800;min-height:40px}
.mobile-title{font-weight:800;margin-left:10px;font-family:var(--font-head);font-size:14px}
.scrim{display:none;position:fixed;inset:0;background:rgba(15,47,87,.45);z-index:99}
.scrim.show{display:block}

.highlight{background:rgba(253,216,65,.55);border-radius:3px;padding:0 1px}
.is-hidden{display:none!important}

/* --------------------------------------------------------------- Toast */
.toast{position:fixed;right:18px;bottom:18px;background:var(--blue-dark);color:#fff;padding:12px 16px;border-radius:12px;box-shadow:0 16px 40px rgba(0,0,0,.22);z-index:9999;font-weight:700;font-family:var(--font-head);font-size:14px}

/* ----------------------------------------------------- Access gate (client) */
/* Lightweight password gate. Content is hidden until unlocked; the early inline
   <head> script adds .authed for already-unlocked sessions to avoid any flash.
   NOTE: client-side only — a deterrent, not real security. Use Netlify password
   protection / Basic Auth on hub.aitcoh.com for true access control. */
html:not(.authed) body{overflow:hidden}
html:not(.authed) .app-shell,html:not(.authed) .mobile-top,html:not(.authed) .scrim{display:none!important}
html.authed .gate{display:none}
.gate{position:fixed;inset:0;z-index:10000;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top right,rgba(37,94,160,.45),transparent 45%),linear-gradient(135deg,var(--blue-dark),#0c2545)}
.gate-card{width:100%;max-width:400px;background:#fff;border-radius:20px;box-shadow:0 30px 70px rgba(0,0,0,.35);padding:30px 28px;text-align:center}
.gate-logo{height:46px;width:auto;display:block;margin:0 auto 18px}
.gate-card h1{font-family:var(--font-head);font-size:20px;line-height:1.2;color:var(--blue-dark);margin:0 0 6px;letter-spacing:-.01em}
.gate-card .gate-sub{margin:0 0 20px;color:var(--muted);font-size:14px}
.gate-label{display:block;text-align:left;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 6px}
.gate-card input{width:100%;border:1px solid var(--line);border-radius:12px;padding:12px 13px;font-size:15px;outline:none;margin-bottom:12px}
.gate-card input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,94,160,.18)}
.gate-card button{width:100%;border:0;background:var(--blue-dark);color:#fff;border-radius:12px;padding:12px;font-family:var(--font-head);font-weight:800;font-size:15px;cursor:pointer}
.gate-card button:hover{background:var(--blue)}
.gate-error{color:var(--danger);font-size:13px;font-weight:700;margin:12px 0 0}
.gate-note{margin:18px 0 0;font-size:12px;color:var(--muted)}
@media print{html:not(.authed) .gate{display:none!important}}

/* ---------------------------------------------------------- Responsive */
@media(max-width:1100px){
  .app-shell{grid-template-columns:1fr}
  .mobile-top{display:flex}
  .sidebar{position:fixed;z-index:100;left:0;top:0;bottom:0;width:min(88vw,330px);transform:translateX(-105%);transition:transform .22s ease}
  .sidebar.open{transform:translateX(0)}
  .hero,.content,.legal-footer{padding-left:20px;padding-right:20px}
  .filters{margin-left:-20px;margin-right:-20px;padding-left:20px;padding-right:20px}
  .dashboard{grid-template-columns:repeat(2,minmax(0,1fr))}
  .doc-tools{margin-left:0;width:100%}
  .doc-header{flex-wrap:wrap}
}
@media(max-width:720px){
  .resource-grid,.script-grid,.checklist-grid,.doc-summary{grid-template-columns:1fr}
  .hero h1{font-size:30px}
  .hero p{font-size:16px}
  .doc-header,.doc-body,.doc-summary{padding-left:16px;padding-right:16px}
  .content{padding:18px 16px 56px}
  .filter-row .filter-title{display:block;margin-bottom:6px}
  .table-wrap{border-radius:10px}
  table{font-size:13px}
  th,td{padding:8px}
}

/* ------------------------------------------------------------------ Print */
@media print{
  .sidebar,.mobile-top,.scrim,.hero-actions,.doc-tools,.filters,.dashboard,.block-head .reset-btn,.copy-btn,.footer-logo{display:none!important}
  .app-shell{display:block}
  .hero,.content,.legal-footer{padding:0}
  .hero{border:0;background:#fff}
  .doc-section{box-shadow:none;border:0;border-radius:0;break-inside:avoid;margin:10px 0}
  .doc-section .doc-body,.doc-section .doc-summary{display:block!important}
  .doc-header{padding:12px 0;background:#fff}
  .doc-body{padding:0 0 16px}
  .notice{border:1px solid #999;background:#fff}
  .legal-footer{background:#fff;color:#111;border-top:1px solid #999;margin-top:20px}
  .is-hidden{display:block!important}
  /* Single-section print */
  .printing-current .doc-section:not(.print-target),
  .printing-current .hub-block,
  .printing-current .resource-grid,
  .printing-current .section-title,
  .printing-current .notice,
  .printing-current .empty-state{display:none!important}
  .printing-current .doc-section.print-target{display:block!important}
}
