/* =========================================================
   SederTech V2 — style.css
   Production stylesheet · Hebrew · RTL · static
   Design direction: Professional Technical Services (Direction A)
   ========================================================= */

:root{
  /* Colors */
  --navy:#15233a;
  --navy-2:#1f3050;
  --graphite:#23272e;
  --graphite-2:#2c313a;
  --accent:#1f63e6;
  --accent-2:#4f86ff;
  --ink:#15233a;
  --body:#54606f;
  --muted:#8b95a3;
  --line:#e3e7ed;
  --line-soft:#eef1f5;
  --bg:#ffffff;
  --bg-soft:#f4f6f9;
  --bg-tint:#eef3fe;
  --warn:#c0392b;
  --ok:#1f7a4d;
  --ok-bright:#1f9d63;
  --amber:#d9a23b;

  /* Spacing scale */
  --s1:8px; --s2:16px; --s3:24px; --s4:40px; --section:64px;

  /* Radius */
  --r-sm:6px; --r:9px; --r-lg:13px;

  --container:1180px;
  --shadow-accent:0 4px 14px rgba(31,99,230,.30);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Assistant','Heebo',Arial,'Segoe UI',sans-serif;
  color:var(--body);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,p,ul,ol{margin:0;}
ul,ol{list-style:none;padding:0;}
a{color:inherit;text-decoration:none;}
img,svg{display:block;}

/* ---------- Accessibility ---------- */
.skip-link{
  position:absolute;right:-9999px;top:0;z-index:200;
  background:var(--accent);color:#fff;font-weight:700;
  padding:12px 18px;border-radius:0 0 8px 0;
}
.skip-link:focus{right:0;}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:4px;}
.section-navy :focus-visible,
.section-graphite :focus-visible,
.final-cta :focus-visible,
.site-footer :focus-visible{outline-color:#fff;}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin-inline:auto;padding-inline:40px;}
.section{padding-block:var(--section);}
.section-soft{background:var(--bg-soft);}
.section-navy{background:var(--navy);}
.section-graphite{background:var(--graphite);}

/* ---------- Typography helpers ---------- */
h1{font-size:clamp(34px,5vw,50px);font-weight:800;line-height:1.08;letter-spacing:-1px;color:var(--ink);}
h2{font-size:clamp(26px,3.4vw,34px);font-weight:800;line-height:1.15;letter-spacing:-.5px;color:var(--ink);}
.section-navy h2,.section-graphite h2{color:#fff;}
.accent{color:var(--accent);}
.eyebrow{display:flex;align-items:center;gap:11px;margin-bottom:14px;font-size:12px;font-weight:700;letter-spacing:1.5px;color:var(--accent);}
.eyebrow .num{font-family:'IBM Plex Mono',monospace;font-size:13px;font-weight:600;}
.eyebrow-rule{width:24px;height:2px;background:var(--accent);display:inline-block;}
.eyebrow-light{color:#9aa9c4;}
.section-navy .eyebrow-light .num{color:var(--accent-2);}
.section-graphite .eyebrow-light .num{color:#7fa3e6;}
.section-intro{font-size:15px;color:var(--body);margin-top:12px;max-width:640px;}
.section-intro-light{color:#aeb9c9;}
.section-graphite .section-intro-light{color:#a7adb6;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;
  padding:12px 20px;border-radius:var(--r);border:1.5px solid transparent;cursor:pointer;
  transition:transform .12s ease,box-shadow .12s ease,background .12s ease;white-space:nowrap;}
.btn-lg{font-size:16px;padding:15px 26px;}
.btn-block{display:flex;width:100%;}
.btn:hover{transform:translateY(-1px);}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow-accent);}
.btn-primary:hover{background:#1a56cc;}
.btn-secondary{background:#fff;color:var(--ink);border-color:#cdd5e0;}
.btn-secondary:hover{border-color:var(--accent);}
.btn-on-accent{background:#fff;color:var(--accent);box-shadow:0 8px 22px rgba(0,0,0,.18);}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.55);}
.btn-ghost:hover{background:rgba(255,255,255,.10);}
.btn-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px;}
.btn-row-center{justify-content:center;}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.95);
  backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--line-soft);}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-block:14px;}
.brand{display:flex;align-items:center;gap:11px;}
.brand-mark{width:34px;height:34px;border-radius:7px;background:var(--navy);position:relative;flex:none;}
.brand-mark::after{content:"";position:absolute;inset:0;margin:auto;width:15px;height:15px;border:2.5px solid var(--accent-2);border-radius:3px;}
.brand-text{display:flex;flex-direction:column;line-height:1;}
.brand-name{font-weight:800;font-size:17px;color:var(--ink);}
.brand-name.light{color:#fff;}
.brand-tagline{font-size:9.5px;color:var(--muted);margin-top:3px;}
.main-nav{display:flex;gap:26px;}
.main-nav a{font-size:13px;font-weight:600;color:#3c4654;}
.main-nav a:hover{color:var(--accent);}
.header-cta{display:flex;align-items:center;gap:16px;}
.nav-toggle-btn{display:none;flex-direction:column;gap:5px;width:42px;height:38px;
  align-items:center;justify-content:center;border:1px solid var(--line);border-radius:8px;cursor:pointer;}
.nav-toggle-btn span{width:20px;height:2px;background:var(--ink);display:block;}

/* ---------- Hero ---------- */
.hero{padding-top:60px;}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:44px;align-items:center;}
.hero-sub{font-size:17px;color:var(--body);line-height:1.62;margin-top:22px;max-width:520px;}

/* hero visual */
.hero-visual{display:flex;align-items:center;gap:14px;}
.source-pile{flex:1;position:relative;height:300px;}
.pile-label{position:absolute;top:0;right:0;font-family:'IBM Plex Mono',monospace;font-size:10px;color:#9aa3b1;letter-spacing:1px;}
.doc-card{position:absolute;background:#fff;border:1px solid #e0e0dc;border-radius:var(--r-sm);
  box-shadow:0 6px 16px rgba(0,0,0,.08);padding:9px;}
.doc-card i{display:block;height:3px;background:#eee;border-radius:2px;margin:5px 0 0;width:80%;}
.doc-card i.short{width:60%;}
.doc-tag{font-family:'IBM Plex Mono',monospace;font-size:8px;font-weight:600;}
.doc-tag-red{color:var(--warn);} .doc-tag-green{color:#1f7a4d;} .doc-tag-gray{color:#5a6473;} .doc-tag-warn{color:var(--warn);font-family:inherit;font-weight:700;}
.doc-a{top:24px;right:8px;width:118px;transform:rotate(-7deg);}
.doc-b{top:78px;right:58px;width:110px;transform:rotate(6deg);}
.doc-c{top:132px;right:4px;width:120px;transform:rotate(-4deg);}
.doc-d{top:186px;right:62px;width:104px;transform:rotate(8deg);}
.doc-e{top:226px;right:2px;width:112px;transform:rotate(-6deg);}
.note-green{background:#e9f7ef;border-color:#cdeada;} .note-red{background:#fdeeee;border-color:#f3cccc;}
.hero-flow{display:flex;flex-direction:column;align-items:center;gap:8px;flex:none;}
.flow-label{writing-mode:vertical-rl;font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--accent);letter-spacing:1px;}
.flow-arrow{width:34px;height:34px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;}
.output-stack{flex:1;}
.stack-label{display:block;font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--accent);letter-spacing:1px;margin-bottom:10px;text-align:left;}
.tool{display:flex;align-items:center;gap:9px;background:#fff;border:1.5px solid #dfe4ec;border-radius:8px;padding:11px 13px;margin-bottom:9px;color:var(--ink);font-weight:700;font-size:12px;}
.tool-dark{background:var(--navy);border-color:var(--navy);color:#fff;box-shadow:0 8px 20px rgba(21,35,58,.22);}
.tool .dot{width:7px;height:7px;border-radius:2px;background:var(--accent-2);}
.tool .dot.blue{background:var(--accent);}
.tool .warn{color:var(--warn);font-size:11px;font-style:normal;}

/* credibility strip */
.credibility{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:0;
  margin-top:54px;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  background:#fafbfc;padding:16px 40px;}
.credibility li{font-size:12.5px;font-weight:600;color:#3c4654;padding-inline:18px;position:relative;}
.credibility li:not(:last-child)::after{content:"";position:absolute;inset-inline-start:0;top:50%;transform:translateY(-50%);width:4px;height:4px;border-radius:50%;background:#c4ccd6;}

/* ---------- Grids ---------- */
.grid{display:grid;gap:16px;margin-top:34px;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-4{grid-template-columns:repeat(4,1fr);}

/* ---------- Problem ---------- */
.pain-card{background:#fff;border:1px solid var(--line);border-radius:11px;padding:22px;border-top:3px solid var(--navy);}
.pain-card-warn{border-top-color:var(--warn);}
.pain-card .card-num{font-family:'IBM Plex Mono',monospace;font-size:11px;color:#9aa3b1;}
.pain-card h3{font-size:16px;font-weight:700;color:var(--ink);margin:8px 0 7px;}
.pain-card p{font-size:13px;color:var(--body);line-height:1.55;}

/* ---------- Services ---------- */
.section-head-row{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;}
.section-aside{font-size:13px;color:var(--muted);max-width:240px;text-align:start;}
.service-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;}
.service-top{display:flex;justify-content:space-between;align-items:center;}
.svc-icon{width:42px;height:42px;border-radius:10px;background:var(--bg-tint);display:flex;align-items:center;justify-content:center;}
.svc-icon.dark{background:#22344f;flex:none;}
.svc-num{font-family:'IBM Plex Mono',monospace;font-size:18px;color:#dde3ec;font-weight:600;}
.svc-num.light{color:#2c405e;}
.service-card h3{font-size:18px;font-weight:800;color:var(--ink);margin:16px 0 8px;}
.service-card p{font-size:13.5px;color:var(--body);line-height:1.6;}
.service-card-wide{grid-column:span 2;background:var(--navy);display:flex;align-items:center;gap:24px;}
.service-card-wide .wide-body{flex:1;}
.service-card-wide h3{margin:0;color:#fff;}
.wide-title{display:flex;align-items:center;gap:10px;}
.service-card-wide p{color:#aeb9c9;margin-top:7px;max-width:560px;}
.tag-pill{font-family:'IBM Plex Mono',monospace;font-size:10px;color:var(--navy);background:var(--accent-2);padding:3px 8px;border-radius:11px;font-weight:600;}

/* ---------- Audiences ---------- */
.audience-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:34px;
  background:#28384f;border:1px solid #28384f;border-radius:12px;overflow:hidden;}
.audience-grid li{background:var(--navy);padding:20px 22px;}
.aud-title{display:block;font-weight:700;font-size:15px;color:#fff;}
.aud-sub{display:block;font-size:12px;color:#8b97aa;margin-top:4px;}

/* ---------- Process ---------- */
.process-row{display:flex;gap:0;margin-top:40px;align-items:flex-start;}
.process-row .step{flex:1;position:relative;padding-inline-start:8px;}
.step-num{width:44px;height:44px;border-radius:11px;background:var(--accent);color:#fff;font-weight:800;font-size:18px;
  display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-accent);position:relative;z-index:1;}
.process-row .step:not(.step-final)::after{content:"";position:absolute;top:22px;inset-inline-start:50px;inset-inline-end:-6px;height:2px;background:#cdd6e2;}
.step-final .step-num{background:var(--ok);box-shadow:0 4px 12px rgba(31,122,77,.3);}
.step h3{font-size:15.5px;font-weight:700;color:var(--ink);margin-top:16px;}
.step p{font-size:12.5px;color:var(--body);margin-top:5px;line-height:1.5;padding-inline-start:14px;}

/* ---------- Deliverables ---------- */
.deliverable{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff;}
.deliverable h3{font-size:13px;font-weight:700;color:var(--ink);padding:11px 14px;border-top:1px solid var(--line-soft);}
.dlv-preview{padding:14px;background:#fbfcfd;height:150px;}
.dlv-tag{font-family:'IBM Plex Mono',monospace;font-size:8px;color:#9aa3b1;display:block;margin-bottom:8px;}
.dlv-tag-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px;}
.dlv-tag-row .dlv-tag{margin:0;}
.fault-code{font-family:'IBM Plex Mono',monospace;font-size:7.5px;color:var(--warn);background:#fdeeee;padding:2px 5px;border-radius:8px;font-weight:600;}
/* PM table */
.mini-table{border:1px solid var(--line);border-radius:5px;overflow:hidden;}
.mt-head,.mt-row{display:flex;}
.mt-head{background:var(--navy);}
.mt-head span{flex:1;font-size:7.5px;color:#cfd8e6;padding:5px;font-weight:600;}
.mt-head span:nth-child(2),.mt-row span:nth-child(2){flex:1.4;}
.mt-head span:last-child,.mt-row span:last-child{flex:.7;}
.mt-row{border-top:1px solid var(--line-soft);}
.mt-row span{flex:1;font-size:7.5px;color:var(--body);padding:5px;}
.mt-row i{display:inline-block;width:7px;height:7px;border-radius:50%;}
.s-ok{background:var(--ok);} .s-warn{background:var(--amber);} .s-bad{background:var(--warn);}
/* quick sheet */
.qs-warn{background:#fff7e9;border:1px solid #f1ddb4;border-radius:4px;padding:5px 7px;margin-bottom:8px;font-size:7.5px;color:#a8740a;font-weight:700;}
.qs-line{display:flex;align-items:center;gap:6px;margin:6px 0;}
.qs-line i{width:11px;height:11px;border-radius:3px;border:1.5px solid #c4ccd6;flex:none;}
.qs-line b{height:4px;flex:1;background:#e7ebf0;border-radius:2px;}
.qs-line.done i{background:var(--accent);border-color:var(--accent);position:relative;}
.qs-line.done i::after{content:"✓";position:absolute;inset:0;color:#fff;font-size:7px;line-height:11px;text-align:center;}
/* troubleshooting */
.ts-step{display:flex;align-items:center;gap:7px;font-size:8.5px;color:var(--body);}
.ts-n{width:18px;height:18px;border-radius:5px;background:var(--bg-tint);color:var(--accent);font-size:8px;font-weight:700;display:flex;align-items:center;justify-content:center;flex:none;}
.ts-n.ok{background:#e9f5ee;color:var(--ok);}
.ts-step b{color:var(--ok);font-weight:700;}
.ts-conn{height:8px;border-inline-end:1.5px dashed #cdd6e2;margin-inline:8px;}
/* safety */
.safety-block{background:#fdeeee;border:1px solid #f3cccc;border-inline-start:4px solid var(--warn);border-radius:5px;padding:9px;margin-bottom:8px;}
.safety-block b{font-size:9px;color:var(--warn);font-weight:800;display:block;}
.safety-block i{display:block;height:3px;background:#f0caca;border-radius:2px;margin-top:6px;width:80%;}
.safety-block i.short{width:60%;margin-top:4px;}
.ppe-row{display:flex;gap:5px;align-items:center;}
.ppe-row span{width:20px;height:20px;border:1.5px solid #cdd6e2;border-radius:4px;}
.ppe-row small{font-size:7.5px;color:#9aa3b1;}
/* bundle */
.bundle{position:relative;height:64px;}
.bundle .sheet{position:absolute;top:0;right:14px;width:78px;height:52px;background:#fff;border:1px solid #dfe4ec;border-radius:4px;box-shadow:0 3px 8px rgba(0,0,0,.06);}
.bundle .sheet-1{transform:rotate(-5deg);}
.bundle .sheet-2{right:24px;top:4px;transform:rotate(3deg);padding:7px;}
.bundle .sheet-2 i{display:block;height:3px;width:70%;background:var(--navy);border-radius:2px;}
.bundle .sheet-2 i.thin{height:2px;background:#e7ebf0;width:85%;margin-top:5px;}
.bundle .sheet-2 i.thin.short{width:60%;margin-top:3px;}
.bundle-check{margin-top:8px;display:flex;flex-direction:column;gap:4px;}
.bundle-check span{display:flex;align-items:center;gap:5px;}
.bundle-check .chk{width:60%;height:3px;background:#e7ebf0;border-radius:2px;position:relative;padding-inline-start:13px;}
.bundle-check .chk::before{content:"✓";position:absolute;inset-inline-start:0;top:-6px;color:var(--ok);font-size:8px;}
/* manual */
.manual{display:flex;gap:7px;height:96px;}
.manual-toc{width:34%;border-inline-start:1px solid #e7ebf0;padding-inline-start:6px;}
.manual-toc i{display:block;height:2px;background:#dfe4ec;margin:4px 0;width:80%;}
.manual-toc i.lead{height:3px;background:var(--accent);width:90%;margin-bottom:6px;}
.manual-toc i.short{width:60%;}
.manual-body{flex:1;}
.manual-body i{display:block;height:2px;background:#e7ebf0;margin:4px 0;width:98%;}
.manual-body i.title{height:4px;background:var(--navy);width:65%;border-radius:2px;margin-bottom:7px;}
.manual-body .fig{display:block;height:24px;background:#f1f4f8;border:1px solid #e7ebf0;border-radius:3px;margin:7px 0;}
/* knowledge base */
.kb-root{background:var(--navy);color:#fff;font-size:8px;font-weight:700;padding:4px 10px;border-radius:5px;width:max-content;margin:0 auto 0;text-align:center;}
.kb-line{height:8px;border-bottom:1px solid #cdd6e2;width:70%;margin:0 auto;}
.kb-children{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-top:8px;}
.kb-children span{background:var(--bg-tint);color:var(--accent);font-size:7.5px;font-weight:600;padding:4px;border-radius:4px;text-align:center;}
/* note card */
.deliverable-note{border:1.5px dashed #cdd6e2;background:#fafbfc;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:18px;}
.deliverable-note strong{font-size:14px;color:var(--ink);line-height:1.35;}
.deliverable-note span{font-size:11.5px;color:var(--muted);margin-top:8px;line-height:1.5;}

/* ---------- Trust ---------- */
.trust-card{background:var(--graphite-2);border:1px solid #3a4049;border-radius:11px;padding:22px;}
.trust-icon{width:36px;height:36px;border-radius:9px;background:var(--navy-2);display:flex;align-items:center;justify-content:center;margin-bottom:14px;}
.trust-icon.mono{font-family:'IBM Plex Mono',monospace;font-size:9px;color:var(--accent-2);font-weight:600;}
.trust-card h3{font-size:15.5px;font-weight:700;color:#fff;}
.trust-card p{font-size:12.5px;color:#9aa3b1;margin-top:6px;line-height:1.55;}

/* ---------- Final CTA ---------- */
.final-cta{background:var(--accent);padding-block:72px;text-align:center;}
.final-cta h2{color:#fff;font-size:clamp(28px,4vw,38px);}
.final-cta p{font-size:16px;color:#cfe0fb;margin:14px auto 0;max-width:620px;line-height:1.6;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start;}
.contact-methods{margin-top:24px;display:flex;flex-direction:column;gap:12px;}
.contact-methods li{display:flex;align-items:center;gap:12px;}
.cm-label{font-family:'IBM Plex Mono',monospace;font-size:11px;color:var(--muted);width:80px;flex:none;}
.contact-methods a{font-weight:600;color:var(--ink);}
.contact-methods a:hover{color:var(--accent);}
.contact-form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;}
.form-title{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:6px;}
.field{margin-top:14px;}
.field label{display:block;font-size:13px;font-weight:600;color:#3c4654;margin-bottom:6px;}
.field input,.field textarea{width:100%;font-family:inherit;font-size:14px;color:var(--ink);
  border:1.5px solid #cdd5e0;border-radius:8px;padding:11px 13px;background:#fdfdfe;}
.field input:focus,.field textarea:focus{border-color:var(--accent);outline:none;}
.field textarea{resize:vertical;}
.contact-form .btn{margin-top:20px;}
.form-note{font-size:11px;color:var(--muted);margin-top:12px;line-height:1.5;}

/* ---------- Footer ---------- */
.site-footer{background:#0f1722;color:#aeb9c9;}
.footer-top{display:flex;justify-content:space-between;gap:40px;padding-top:44px;padding-bottom:30px;}
.footer-brand{max-width:300px;}
.footer-brand .brand-mark{display:inline-block;vertical-align:middle;width:30px;height:30px;}
.footer-brand .brand-name{margin-inline-start:10px;vertical-align:middle;}
.footer-brand p{font-size:12.5px;color:#8693a6;margin-top:12px;line-height:1.6;}
.footer-cols{display:flex;gap:60px;flex-wrap:wrap;}
.footer-cols h2{font-size:11px;color:#5f6b7d;font-weight:700;letter-spacing:1px;margin-bottom:12px;}
.footer-cols a{display:block;font-size:12.5px;color:#aeb9c9;margin-bottom:8px;}
.footer-cols a:hover{color:#fff;}
.footer-bottom{border-top:1px solid #1d2735;padding-block:18px 28px;}
.footer-a11y{font-size:11px;color:#7b8698;line-height:1.6;max-width:760px;}
.footer-a11y a{color:#aeb9c9;text-decoration:underline;}
.footer-legal{display:flex;justify-content:space-between;gap:16px;margin-top:14px;flex-wrap:wrap;}
.footer-legal span{font-size:11px;color:#5f6b7d;}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  .container{padding-inline:24px;}
  .section{padding-block:48px;}
  .hero-grid{grid-template-columns:1fr;gap:8px;}
  .hero-visual{margin-top:10px;}
  .grid-3{grid-template-columns:1fr 1fr;}
  .grid-4{grid-template-columns:1fr 1fr;}
  .service-card-wide{grid-column:span 2;flex-direction:row;}
  .audience-grid{grid-template-columns:1fr 1fr;}
  .process-row{flex-direction:column;gap:18px;}
  .process-row .step{padding-inline-start:0;display:grid;grid-template-columns:44px 1fr;column-gap:14px;align-items:center;}
  .process-row .step:not(.step-final)::after{display:none;}
  .step h3{margin-top:0;grid-column:2;}
  .step p{grid-column:2;padding-inline-start:0;}
  .contact-grid{grid-template-columns:1fr;gap:28px;}
}

@media (max-width:760px){
  /* Mobile nav */
  .nav-toggle-btn{display:flex;}
  .main-nav{display:none;position:absolute;inset-inline:0;top:100%;flex-direction:column;gap:0;
    background:#fff;border-bottom:1px solid var(--line);padding:8px 24px 16px;}
  .nav-toggle:checked ~ .main-nav{display:flex;}
  .main-nav a{padding:12px 0;border-bottom:1px solid var(--line-soft);font-size:15px;}
  .site-header .header-inner{position:relative;flex-wrap:wrap;}
}

@media (max-width:640px){
  h1{font-size:32px;}
  .grid-3,.grid-4{grid-template-columns:1fr;}
  .service-card-wide{grid-column:span 1;flex-direction:column;align-items:flex-start;gap:14px;}
  .service-card-wide .svc-num.light{position:absolute;}
  .audience-grid{grid-template-columns:1fr;}
  .credibility{gap:4px 0;}
  .credibility li{padding-inline:12px;}
  .footer-top{flex-direction:column;gap:28px;}
  .footer-cols{gap:32px;}
  .btn-row{flex-direction:column;}
  .btn-row .btn{width:100%;}
  /* simplify hero visual height on small screens */
  .source-pile{height:260px;}
}

/* ---------- Print ---------- */
@media print{
  .site-header,.final-cta .btn,.contact-form,.nav-toggle-btn{display:none;}
  body{color:#000;}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;transition:none !important;}
}

/* =========================================================
   VISUAL COMFORT LAYER — readability & breathing room
   Additive overrides only. No structural / positioning / text changes.
   ========================================================= */
:root{
  --navy:#1b2c47;        /* softer, less-black navy */
  --graphite:#2b3038;    /* softer graphite */
  --graphite-2:#343a45;
  --body:#4b5663;        /* a touch darker body text for readability */
  --muted:#7e8896;
  --section:76px;        /* more air between sections */
  --shadow-accent:0 6px 18px rgba(31,99,230,.20); /* softer blue shadow */
}
body{font-size:17px;line-height:1.7;}
.btn{font-size:15px;padding:13px 22px;}
.btn-lg{font-size:16px;padding:16px 28px;}
.section-intro{font-size:16px;line-height:1.7;margin-top:14px;}
.main-nav a{font-size:14px;}
.credibility li{font-size:13.5px;}
.hero-sub{font-size:17.5px;line-height:1.72;margin-top:24px;}
.grid{gap:22px;}
.pain-card{padding:26px;}
.pain-card h3{font-size:16.5px;margin:10px 0 8px;}
.pain-card p{font-size:14px;line-height:1.65;}
.service-card{padding:28px;}
.service-card h3{margin:16px 0 10px;}
.service-card p{font-size:14.5px;line-height:1.7;}
.service-card-wide p{margin-top:9px;line-height:1.7;}
.audience-grid li{padding:22px 24px;}
.aud-title{font-size:15.5px;}
.aud-sub{font-size:13px;margin-top:5px;color:#a3aec0;}
.step h3{font-size:16px;margin-top:18px;}
.step p{font-size:13.5px;line-height:1.6;}
.deliverable h3{font-size:14px;padding:13px 16px;}
.dlv-preview{padding:16px;height:156px;}
.deliverable-note strong{font-size:15px;}
.deliverable-note span{font-size:13px;}
.trust-card{padding:26px;}
.trust-card h3{font-size:16px;}
.trust-card p{font-size:14px;line-height:1.65;color:#aeb8c6;}
.final-cta p{font-size:17px;line-height:1.7;}
.contact-form{padding:30px;}
.field label{font-size:14px;}
.form-note{font-size:12.5px;line-height:1.6;}
.footer-brand p{font-size:13.5px;}
.footer-cols a{font-size:13.5px;}
.footer-a11y{font-size:12.5px;line-height:1.7;}
.doc-a{transform:rotate(-4deg);}
.doc-b{transform:rotate(4deg);}
.doc-c{transform:rotate(-3deg);}
.doc-d{transform:rotate(5deg);}
.doc-e{transform:rotate(-4deg);}
@media (max-width:980px){
  .hero-grid{gap:24px;}
  .section{padding-block:54px;}
}
@media (max-width:760px){
  .header-inner{padding-block:10px;}
  .hero-sub{font-size:16.5px;}
}
@media (max-width:640px){
  .pain-card,.service-card,.trust-card{padding:22px;}
}

/* ===================== BRAND LOGO ===================== */
.brand{gap:0;}
.brand picture{display:block;line-height:0;}
.brand-logo{display:block;height:44px;width:auto;}
@media (max-width:760px){ .brand-logo{height:38px;} }
@media (max-width:420px){ .brand-logo{height:32px;} }

/* ===================== FOOTER LOGO ===================== */
.footer-logo-card{display:inline-block;background:#fff;padding:10px 14px;border-radius:12px;line-height:0;}
.footer-logo{display:block;height:38px;width:auto;}
@media (max-width:760px){ .footer-logo{height:34px;} }
