/* ============================================================
   AgeInnovate — style.css  v0.1.0
   Source of truth: DESIGN-SYSTEM-AND-STANDARDS.md
   ⚠️  Fonts loaded from Google Fonts for dev preview only.
       Self-host woff2 files in /assets/fonts/ before deploy.
   ============================================================ */

/* === RESET (Josh Comeau minimal modern) === */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body { -webkit-font-smoothing: antialiased; }
img, picture, video, canvas, svg { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
ul, ol { list-style: none; }

/* === DESIGN TOKENS === */
:root {
  /* — Surfaces — */
  --color-surface-dark:   #0E1F2C;
  --color-surface-darker: #0A1822;
  --color-surface-card:   #172938;
  --color-surface-light:  #EDF1F4;
  --color-surface-white:  #FFFFFF;

  /* — Text — */
  --color-ink:            #0E1F2C;
  --color-ink-light:      #FFFFFF;
  --color-ink-muted:      #3F4E5A;
  --color-ink-muted-dark: #B8C3CC;
  --color-line:           #DCE3E8;
  --color-line-dark:      rgba(255, 255, 255, 0.06);

  /* — Accent (one only — teal) — */
  --color-accent:         #22C997;
  --color-accent-dark:    #16A37A;
  --color-accent-tint:    rgba(34, 201, 151, 0.12);

  /* — Status (semantic UI only) — */
  --color-success:        #16A37A;
  --color-warning:        #B45309;
  --color-error:          #B91C1C;
  --color-focus:          #22C997;

  /* — Typography — */
  --font-display: "Outfit", "Manrope", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --font-sans:    "Inter", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;

  /* — Type scale (major third, 16px base) — */
  --fs-xs:   0.75rem;    /*  12px */
  --fs-sm:   0.875rem;   /*  14px */
  --fs-base: 1rem;       /*  16px */
  --fs-lg:   1.125rem;   /*  18px */
  --fs-xl:   1.25rem;    /*  20px */
  --fs-2xl:  1.5rem;     /*  24px */
  --fs-3xl:  1.875rem;   /*  30px */
  --fs-4xl:  2.25rem;    /*  36px */
  --fs-5xl:  3rem;       /*  48px */
  --fs-6xl:  3.75rem;    /*  60px */

  /* — Line heights — */
  --lh-tight:  1.15;
  --lh-snug:   1.3;
  --lh-normal: 1.6;
  --lh-loose:  1.8;

  /* — Font weights — */
  --fw-regular:  400;
  --fw-medium:   500;
  --fw-semibold: 600;
  --fw-bold:     700;

  /* — Spacing (8pt grid) — */
  --space-0:  0;
  --space-1:  0.25rem;  /*  4px */
  --space-2:  0.5rem;   /*  8px */
  --space-3:  0.75rem;  /* 12px */
  --space-4:  1rem;     /* 16px */
  --space-5:  1.5rem;   /* 24px */
  --space-6:  2rem;     /* 32px */
  --space-7:  3rem;     /* 48px */
  --space-8:  4rem;     /* 64px */
  --space-9:  6rem;     /* 96px */
  --space-10: 8rem;     /* 128px */

  /* — Layout — */
  --container-sm:  640px;
  --container-md:  768px;
  --container-lg:  1024px;
  --container-xl:  1200px;
  --container-2xl: 1440px;
  --gutter:        var(--space-5);
  --gutter-sm:     var(--space-4);

  /* — Radius — */
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   16px;
  --radius-full: 9999px;

  /* — Shadows — */
  --shadow-sm: 0 1px 2px rgba(17, 24, 39, 0.06);
  --shadow-md: 0 4px 12px rgba(17, 24, 39, 0.08);
  --shadow-lg: 0 12px 32px rgba(17, 24, 39, 0.12);

  /* — Motion — */
  --ease-out:      cubic-bezier(0.16, 1, 0.3, 1);
  --duration-fast: 150ms;
  --duration-base: 250ms;
  --duration-slow: 400ms;
}

/* === BASE === */
html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  color: var(--color-ink);
  background-color: var(--color-surface-white);
}

/* Heading families */
h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
}
h4, h5, h6 {
  font-family: var(--font-sans);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-snug);
}

/* Signature move: italic teal in display headings */
h1 em, h2 em, h3 em {
  font-style: italic;
  color: var(--color-accent);
  font-weight: var(--fw-semibold);
}

p { line-height: var(--lh-normal); }

/* Links */
a {
  color: inherit;
  text-decoration: underline;
}
a:hover { text-decoration: none; }
a:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
  text-decoration: none;
}

/* === SKIP LINK === */
.skip-link {
  position: absolute;
  top: -200%;
  left: var(--space-4);
  padding: var(--space-2) var(--space-4);
  background: var(--color-accent);
  color: var(--color-surface-dark);
  font-family: var(--font-sans);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  border-radius: var(--radius-md);
  text-decoration: none;
  z-index: 9999;
  transition: top var(--duration-fast);
}
.skip-link:focus {
  top: var(--space-4);
}

/* === CONTAINER === */
.container {
  width: 100%;
  max-width: var(--container-xl);
  margin-inline: auto;
  padding-inline: var(--space-5);
}
@media (min-width: 1024px) {
  .container { padding-inline: var(--space-6); }
}

/* === EYEBROW LABEL === */
/* Always sentence-case in HTML — text-transform handles display */
.eyebrow {
  display: block;
  font-family: var(--font-sans);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-3);
}
/* On light surfaces: use accent-dark for contrast (≥4.5:1 on #EDF1F4) */
.eyebrow--on-light { color: var(--color-accent-dark); }

/* === BUTTONS === */
/* Primary: filled teal pill */
.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  background: var(--color-accent);
  color: var(--color-surface-dark);
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  line-height: 1.2;
  text-decoration: none;
  border: 1.5px solid transparent;
  border-radius: var(--radius-full);
  cursor: pointer;
  min-height: 44px;
  min-width: 44px;
  transition:
    background var(--duration-fast) var(--ease-out),
    color var(--duration-fast) var(--ease-out),
    transform var(--duration-fast) var(--ease-out);
}
.button:hover {
  background: var(--color-accent-dark);
  text-decoration: none;
}
.button:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
}
@media (prefers-reduced-motion: no-preference) {
  .button:hover  { transform: translateY(-1px); }
  .button:active { transform: translateY(0); }
}

/* Secondary: ghost/outline on dark surface */
.button--ghost {
  background: transparent;
  color: var(--color-ink-light);
  border-color: var(--color-ink-light);
}
.button--ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--color-ink-light);
}

/* Secondary: ghost/outline on light surface */
.button--ghost-dark {
  background: transparent;
  color: var(--color-ink);
  border-color: var(--color-ink);
}
.button--ghost-dark:hover {
  background: rgba(14, 31, 44, 0.06);
  color: var(--color-ink);
}

/* Link-arrow: no background, trailing teal arrow */
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  min-height: 44px;
  padding: 0;
  color: inherit;
  transition: gap var(--duration-fast) var(--ease-out);
}
.link-arrow::after {
  content: "→";
  color: var(--color-accent);
  font-style: normal;
  transition: transform var(--duration-fast) var(--ease-out);
}
@media (prefers-reduced-motion: no-preference) {
  .link-arrow:hover::after { transform: translateX(4px); }
}
.link-arrow:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* === STAT COMPONENT === */
.stat__num {
  font-family: var(--font-display);
  font-weight: var(--fw-bold);
  font-size: var(--fs-5xl);
  color: var(--color-accent);
  line-height: 1;
  letter-spacing: -0.02em;
}
.stat__cap {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  line-height: var(--lh-snug);
  color: var(--color-ink-muted-dark);
  margin-top: var(--space-2);
}
/* On light surfaces */
.stat__cap--on-light { color: var(--color-ink-muted); }

/* === SITE HEADER === */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--color-surface-dark);
  border-bottom: 1px solid var(--color-line-dark);
}
.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);        /* tighter on mobile */
  padding-block: var(--space-4);
}
@media (min-width: 768px) {
  .site-header__inner { gap: var(--space-5); }
}

/* Logo */
.site-header__logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  flex-shrink: 0;
}
.site-header__logo:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}
.site-header__logo-img {
  display: block;
  width: 140px;   /* mobile — leaves room for hamburger */
  height: auto;
}
@media (min-width: 768px) {
  .site-header__logo-img { width: 180px; }
}

/* Primary nav — hidden on mobile, shown at md */
.site-nav { display: none; }
@media (min-width: 768px) { .site-nav { display: block; } }

.site-nav__list {
  display: flex;
  align-items: center;
  gap: var(--space-6);
}
.site-nav__list a {
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--color-ink-muted-dark);
  text-decoration: none;
  transition: color var(--duration-fast);
  white-space: nowrap;
}
.site-nav__list a:hover { color: var(--color-ink-light); }
.site-nav__list a:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

/* Nav CTA — desktop only */
.site-header__cta { display: none; }
@media (min-width: 768px) { .site-header__cta { display: inline-flex; } }

/* Mobile menu toggle */
.site-header__toggle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  flex-shrink: 0;
}
.site-header__toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-ink-light);
  border-radius: 2px;
  transition: transform var(--duration-base) var(--ease-out),
              opacity var(--duration-fast);
}
.site-header__toggle:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 2px;
}
@media (min-width: 768px) { .site-header__toggle { display: none; } }

/* Mobile nav drawer */
.site-nav--mobile-open {
  display: block;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--color-surface-darker);
  border-bottom: 1px solid var(--color-line-dark);
  padding: var(--space-5) var(--space-5) var(--space-6);
}
.site-nav--mobile-open .site-nav__list {
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-4);
}
.site-nav--mobile-open .site-nav__list a {
  font-size: var(--fs-base);
}

/* === SECTION: HERO === */
.hero {
  /* Subtle teal radial glow — top-right blooms toward the photo side,
     faint secondary glow bottom-left for depth. Navy stays dominant. */
  background:
    radial-gradient(ellipse 65% 70% at 85% 10%, rgba(34, 201, 151, 0.10) 0%, transparent 60%),
    radial-gradient(ellipse 40% 50% at 10% 90%, rgba(34, 201, 151, 0.05) 0%, transparent 50%),
    var(--color-surface-dark);
  padding-block: var(--space-9) var(--space-8);
}
.hero__inner {
  display: grid;
  gap: var(--space-7);
}
@media (min-width: 768px) {
  .hero__inner {
    grid-template-columns: 55fr 45fr;
    align-items: center;
    gap: var(--space-8);
  }
}

.hero h1 {
  font-size: var(--fs-4xl);
  color: var(--color-ink-light);
  margin-bottom: var(--space-5);
  max-width: 16ch;
}
@media (min-width: 768px)  { .hero h1 { font-size: var(--fs-5xl); } }
@media (min-width: 1024px) { .hero h1 { font-size: var(--fs-6xl); } }

.hero__body {
  font-size: var(--fs-lg);
  color: var(--color-ink-muted-dark);
  max-width: 52ch;
  margin-bottom: var(--space-6);
  line-height: var(--lh-loose);
}

.hero__cta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.hero__cta .link-arrow { color: var(--color-ink-muted-dark); }

/* Hero photo */
.hero__visual {
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: block;
  line-height: 0;
}
.hero__photo {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  display: block;
}

/* === PHOTO BAND ===
   Full-bleed horizontal strip between sections.
   No container, no border-radius — pure edge-to-edge photo.
   Replace .photo-band__placeholder with a <picture> element when photos arrive.
*/
.photo-band {
  width: 100%;
  overflow: hidden;
  line-height: 0; /* prevents gap below inline images */
}
.photo-band picture,
.photo-band img {
  width: 100%;
  aspect-ratio: 37 / 16;
  object-fit: cover;
  display: block;
}
@media (max-width: 640px) {
  .photo-band picture,
  .photo-band img { aspect-ratio: 3 / 2; }
}
/* Styled placeholder — shown until real photo is ready */
.photo-band__placeholder {
  width: 100%;
  aspect-ratio: 37 / 16;
  background: linear-gradient(135deg, #0d2436 0%, var(--color-surface-card) 50%, #0d2436 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  color: var(--color-ink-muted-dark);
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  font-style: normal;
  line-height: var(--lh-normal);
  text-align: center;
}
.photo-band__placeholder strong {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  color: var(--color-accent);
  font-style: normal;
  margin-bottom: var(--space-1);
}
@media (max-width: 640px) {
  .photo-band__placeholder { aspect-ratio: 3 / 2; }
}

/* === SECTION: NUMBERS === */
.numbers {
  background: var(--color-surface-darker);
  padding-block: var(--space-8);
  border-top: 1px solid var(--color-line-dark);
}
.numbers__intro {
  max-width: 65ch;
  margin-bottom: var(--space-7);
}
.numbers__intro h2 {
  font-size: var(--fs-3xl);
  color: var(--color-ink-light);
  margin-bottom: var(--space-5);
}
@media (min-width: 768px) { .numbers__intro h2 { font-size: var(--fs-4xl); } }
.numbers__intro p {
  font-size: var(--fs-lg);
  color: var(--color-ink-muted-dark);
  line-height: var(--lh-loose);
  margin-bottom: var(--space-4);
}
.numbers__intro p:last-of-type { margin-bottom: 0; }

.numbers__stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-bottom: var(--space-7);
}
@media (min-width: 640px) {
  .numbers__stats {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-5);
  }
}

/* === SECTION: WHAT WE DO === */
.what-we-do {
  background: var(--color-surface-dark);
  padding-block: var(--space-8);
}
.what-we-do__header {
  margin-bottom: var(--space-7);
}
.what-we-do__header h2 {
  font-size: var(--fs-3xl);
  color: var(--color-ink-light);
  margin-bottom: var(--space-3);
}
@media (min-width: 768px) { .what-we-do__header h2 { font-size: var(--fs-4xl); } }
.what-we-do__subhead {
  font-size: var(--fs-lg);
  color: var(--color-ink-muted-dark);
  line-height: var(--lh-snug);
}

.what-we-do__cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
@media (min-width: 768px) {
  .what-we-do__cards { grid-template-columns: repeat(3, 1fr); }
}

/* Card (dark surface variant) */
.card {
  background: var(--color-surface-card);
  border: 1px solid var(--color-line-dark);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  display: flex;
  flex-direction: column;
}
.card__icon {
  width: 48px;
  height: 48px;
  background: var(--color-accent-tint);
  color: var(--color-accent);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-bottom: var(--space-5);
}
.card__title {
  font-family: var(--font-display);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-2xl);
  color: var(--color-ink-light);
  margin-bottom: var(--space-3);
  line-height: var(--lh-snug);
}
.card__body {
  font-size: var(--fs-base);
  color: var(--color-ink-muted-dark);
  line-height: var(--lh-normal);
  margin-bottom: var(--space-5);
  flex: 1;
}
.card .link-arrow { color: var(--color-ink-muted-dark); margin-top: auto; }

/* === SECTION: ORIGIN STORY (half-bleed layout) ===
   Text column is container-padded on the left.
   Photo column extends all the way to the right viewport edge — no container constraint.
   The overflow: hidden on .origin clips the photo cleanly.
*/
.origin {
  background: var(--color-surface-light);
  overflow: hidden;
}
.origin__inner {
  display: grid;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
  .origin__inner {
    grid-template-columns: 1fr 1fr;
    min-height: 620px;
  }
}

/* Text column — padding manually mirrors the container centering */
.origin__content-col {
  padding: var(--space-8) var(--space-5);
}
@media (min-width: 1024px) {
  .origin__content-col {
    padding-top: var(--space-8);
    padding-bottom: var(--space-8);
    padding-right: var(--space-8);
    /* Left padding = container gutter + half the whitespace outside container */
    padding-left: max(var(--space-6), calc((100vw - var(--container-xl)) / 2 + var(--space-6)));
  }
}

.origin__content-col h2 {
  font-size: var(--fs-3xl);
  color: var(--color-ink);
  margin-bottom: var(--space-5);
}
@media (min-width: 768px) { .origin__content-col h2 { font-size: var(--fs-4xl); } }

.origin__content-col p {
  font-size: var(--fs-lg);
  color: var(--color-ink-muted);
  line-height: var(--lh-loose);
  max-width: 52ch;
  margin-bottom: var(--space-4);
}

/* Stats row inside the text column — three numbers in a horizontal strip */
.origin__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-6);
  margin-bottom: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-line);
}
@media (max-width: 480px) {
  .origin__stats { grid-template-columns: 1fr; }
}

.origin__cta { color: var(--color-ink); }

/* Photo column — bleeds to the right viewport edge */
.origin__photo-col {
  overflow: hidden;
  min-height: 420px;
  position: relative;
}
.origin__photo-col picture,
.origin__photo-col img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* Styled placeholder */
.origin__photo-placeholder {
  width: 100%;
  height: 100%;
  min-height: 420px;
  background: linear-gradient(160deg, #162e42 0%, var(--color-surface-card) 60%, #1a3a52 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  color: var(--color-ink-muted-dark);
  font-family: var(--font-sans);
  font-size: var(--fs-sm);
  text-align: center;
  padding: var(--space-7);
}
.origin__photo-placeholder strong {
  display: block;
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  color: var(--color-accent);
  margin-bottom: var(--space-1);
}

/* === SECTION: JOIN / CLOSING CTA === */
.join {
  background: var(--color-surface-dark);
  padding-block: var(--space-8);
}
.join__inner { max-width: var(--container-md); }
.join h2 {
  font-size: var(--fs-3xl);
  color: var(--color-ink-light);
  margin-bottom: var(--space-5);
}
@media (min-width: 768px) { .join h2 { font-size: var(--fs-4xl); } }
.join__body {
  font-size: var(--fs-lg);
  color: var(--color-ink-muted-dark);
  line-height: var(--lh-loose);
  max-width: 60ch;
  margin-bottom: var(--space-4);
}
.join__body:last-of-type { margin-bottom: 0; }
.join__cta {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-top: var(--space-6);
}

/* === SITE FOOTER === */
.site-footer {
  background: var(--color-surface-darker);
  padding-block: var(--space-8);
  border-top: 1px solid var(--color-line-dark);
}
.site-footer__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
}
@media (min-width: 768px) {
  .site-footer__inner {
    grid-template-columns: 2fr 1fr 1fr;
    gap: var(--space-8);
  }
}

.site-footer__tagline {
  font-size: var(--fs-base);
  font-style: italic;
  color: var(--color-ink-muted-dark);
  margin-top: var(--space-4);
  max-width: 38ch;
  line-height: var(--lh-loose);
}
.site-footer__col-title {
  font-family: var(--font-sans);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  color: var(--color-ink-light);
  margin-bottom: var(--space-4);
}
.site-footer__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.site-footer__list a {
  font-size: var(--fs-sm);
  color: var(--color-ink-muted-dark);
  text-decoration: none;
  transition: color var(--duration-fast);
}
.site-footer__list a:hover { color: var(--color-accent); }
.site-footer__list a:focus-visible {
  outline: 2px solid var(--color-focus);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

.site-footer__bottom {
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-line-dark);
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
}
.site-footer__copy {
  font-size: var(--fs-xs);
  color: var(--color-ink-muted-dark);
}
.site-footer__copy a {
  text-decoration: underline;
}

/* ─────────────────────────────────────────────────────────────
   Suppress Blocksy parent-theme mobile panel
   Every page uses our own custom header + nav, so Blocksy's
   off-canvas drawer and overlay are unwanted. Hide them entirely.
   ───────────────────────────────────────────────────────────── */
.ct-panel,
.ct-panel-container,
.ct-overlay,
.ct-header-overlay,
[data-behaviour="toggle-mobile-header"],
[data-id="mobile-offcanvas"] {
  display: none !important;
  pointer-events: none !important;
}
