/*
Theme Name: Speech & Hearing Hub
Theme URI:
Author: The Speech & Hearing Hub
Description: Custom WordPress theme for The Speech & Hearing Hub — a speech therapy and audiology practice in Johannesburg.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: Proprietary
Text Domain: speech-hearing-hub
*/

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --bg: #EFE9DF;
  --bg-2: #E7DFD2;
  --bg-3: #F6F1E7;
  --ink: #2A2320;
  --ink-soft: #584B44;
  --ink-mute: #8A7C73;
  --taupe: #9A7B65;
  --taupe-dark: #7A5E4B;
  --coral: #E4896B;
  --coral-deep: #C96A4F;
  --blush: #E7C9BC;
  --sage: #96A58C;
  --butter: #E8D5A4;
  --line: #C9BDAE;
  --line-soft: #DDD2C1;
  --shadow: 0 2px 0 rgba(42,35,32,.04), 0 30px 60px -30px rgba(42,35,32,.18);
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box }
html {
  margin: 0; padding: 0;
}
body {
  margin: 0; padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img {
  max-width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }
p { margin: 0 0 1em; }
h1, h2, h3, h4, h5, h6 { margin: 0; }

/* ============================================================
   TYPOGRAPHY UTILITIES
   ============================================================ */
.serif  { font-family: 'DM Serif Display', Georgia, serif; font-weight: 400; letter-spacing: -0.01em; }
.mono   { font-family: 'JetBrains Mono', ui-monospace, monospace; }
.italic { font-style: italic; }

.eyebrow {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--coral-deep);
}

/* ============================================================
   LAYOUT
   ============================================================ */
.container      { max-width: 1240px; margin: 0 auto; padding: 0 40px; }
.container-wide { max-width: 1400px; margin: 0 auto; padding: 0 40px; }

.rule      { height: 1px; background: var(--line);      border: 0; }
.rule-soft { height: 1px; background: var(--line-soft); border: 0; }

/* ============================================================
   NAV
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(239,233,223,.86);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line-soft);
}
.nav-inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 14px 40px;
  gap: 24px;
}
.nav-left, .nav-right { display: flex; gap: 28px; align-items: center; }
.nav-right { justify-content: flex-end; }
.nav a.link {
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft); transition: color .2s;
}
.nav a.link:hover { color: var(--coral-deep); }
.nav .brand { display: flex; flex-direction: column; align-items: center; line-height: 1; }
.nav .brand .mark {
  font-family: 'DM Serif Display', serif; font-size: 22px;
  color: var(--taupe-dark); font-style: italic; white-space: nowrap; letter-spacing: -.01em;
}
.nav .brand .sub {
  font-family: 'Inter', sans-serif; font-size: 9px; letter-spacing: .32em;
  color: var(--ink-mute); margin-top: 4px; text-transform: uppercase;
}
.nav .cta-book {
  padding: 10px 18px; border: 1px solid var(--ink); border-radius: 999px;
  font-size: 11px; letter-spacing: .2em; text-transform: uppercase;
  background: transparent; color: var(--ink); cursor: pointer; transition: all .2s;
  display: inline-block;
}
.nav .cta-book:hover { background: var(--ink); color: var(--bg); }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; padding: 80px 0 90px; overflow: hidden; }
.hero-grid {
  display: grid; grid-template-columns: 1.1fr .9fr;
  gap: 60px; align-items: center;
}
.hero h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(60px, 8vw, 120px);
  line-height: .95;
  color: var(--ink);
  margin: 24px 0 28px;
  letter-spacing: -0.02em;
}
.hero h1 em        { color: var(--taupe-dark); font-style: italic; }
.hero h1 .amp      { color: var(--coral-deep); font-style: italic; font-family: 'DM Serif Display', serif; }
.hero-sub          { font-size: 17px; color: var(--ink-soft); max-width: 480px; line-height: 1.6; }
.hero-meta         { display: flex; gap: 28px; margin-top: 36px; align-items: center; flex-wrap: wrap; }
.hero-meta .btn-primary {
  background: var(--ink); color: var(--bg-3);
  padding: 16px 26px; border-radius: 999px; font-size: 12px;
  letter-spacing: .2em; text-transform: uppercase; border: 0; cursor: pointer;
  display: inline-flex; align-items: center; gap: 10px; transition: all .2s;
}
.hero-meta .btn-primary:hover { background: var(--taupe-dark); }
.hero-meta .btn-text {
  font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink);
  border-bottom: 1px solid var(--ink); padding-bottom: 4px;
}
.hero-art { position: relative; height: 560px; }
.hero-frame {
  position: absolute; inset: 0;
  border-radius: 280px 280px 20px 20px;
  overflow: hidden; box-shadow: var(--shadow);
}
.hero-frame img { width: 100%; height: 100%; object-fit: cover; }
.hero-decor {
  position: absolute; top: -20px; right: -30px;
  width: 180px; height: 180px; border-radius: 50%;
  background: var(--coral); opacity: .88;
  display: flex; align-items: center; justify-content: center;
  color: var(--bg-3);
  font-family: 'DM Serif Display', serif; font-size: 20px; text-align: center;
  padding: 20px; line-height: 1.15; transform: rotate(-8deg); z-index: 2;
}
.hero-decor .badge-ring {
  position: absolute; inset: 8px;
  border: 1px dashed rgba(255,255,255,.5); border-radius: 50%;
}
.hero-chip {
  position: absolute; bottom: 30px; left: -30px;
  background: var(--bg-3); padding: 14px 18px; border-radius: 14px;
  box-shadow: var(--shadow); display: flex; gap: 12px; align-items: center; z-index: 2;
}
.hero-chip .dot    { width: 10px; height: 10px; border-radius: 50%; background: var(--sage); }
.hero-chip .t1     { font-size: 11px; color: var(--ink-mute); letter-spacing: .18em; text-transform: uppercase; }
.hero-chip .t2     { font-family: 'DM Serif Display', serif; font-size: 17px; color: var(--ink); }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee {
  border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft);
  padding: 22px 0; overflow: hidden; white-space: nowrap; background: var(--bg-3);
  margin-top: 80px;
}
.marquee-track {
  display: inline-flex; gap: 60px;
  animation: scroll 40s linear infinite;
  font-family: 'DM Serif Display', serif; font-style: italic; font-size: 28px; color: var(--taupe);
}
.marquee-track span { display: inline-flex; align-items: center; gap: 60px; }
.marquee-track .star { color: var(--coral); font-size: 18px; }
@keyframes scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ============================================================
   ABOUT
   ============================================================ */
.about { padding: 110px 0; }
.about-grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: 80px; align-items: start; }
.about-title {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(56px, 6vw, 88px);
  line-height: 1; margin: 14px 0 0; color: var(--ink);
}
.about-title em { color: var(--taupe-dark); font-style: italic; display: block; margin-left: 80px; }
.about-body p { font-size: 18px; color: var(--ink-soft); line-height: 1.7; margin: 0 0 18px; }
.about-body p:first-child::first-letter {
  font-family: 'DM Serif Display', serif; font-size: 72px; float: left;
  line-height: .85; padding: 6px 10px 0 0; color: var(--taupe-dark);
}
.about-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; margin-top: 40px; }
.stat { border-top: 1px solid var(--line); padding-top: 18px; }
.stat .num { font-family: 'DM Serif Display', serif; font-size: 44px; color: var(--taupe-dark); line-height: 1; }
.stat .lbl { font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink-mute); margin-top: 6px; }

/* ============================================================
   TEAM
   ============================================================ */
.team { padding: 40px 0 110px; position: relative; }
.section-head {
  display: flex; justify-content: space-between; align-items: end;
  margin-bottom: 48px; gap: 40px; flex-wrap: wrap;
}
.section-head h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(52px, 5.5vw, 80px);
  line-height: 1; margin: 10px 0 0; color: var(--ink); letter-spacing: -0.01em;
}
.section-head h2 em { color: var(--taupe-dark); font-style: italic; }
.section-head .aside { max-width: 360px; color: var(--ink-soft); font-size: 15px; }
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 36px; }
.member .arch {
  aspect-ratio: 3/4;
  border-radius: 240px 240px 16px 16px;
  overflow: hidden; background: var(--bg-2); position: relative;
  box-shadow: var(--shadow);
}
.member .arch img { width: 100%; height: 100%; object-fit: cover; }
.member .name  { font-family: 'DM Serif Display', serif; font-size: 30px; margin: 24px 0 4px; color: var(--ink); }
.member .role  { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--coral-deep); }
.member .bio   { font-size: 14px; color: var(--ink-soft); margin-top: 14px; line-height: 1.6; }
.member .creds { display: flex; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.member .cred  {
  font-size: 10px; letter-spacing: .15em; text-transform: uppercase;
  padding: 5px 10px; border: 1px solid var(--line); border-radius: 999px; color: var(--ink-mute);
}

/* ============================================================
   SERVICES
   ============================================================ */
.services {
  padding: 110px 0; background: var(--bg-3);
  border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft);
}
.services-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-top: 50px; }
.service-card {
  background: var(--bg); border-radius: 4px; padding: 40px 40px 36px;
  border: 1px solid var(--line-soft); position: relative; transition: transform .25s ease;
}
.service-card:hover { transform: translateY(-4px); }
.service-card .svc-head {
  display: flex; justify-content: space-between; align-items: start;
  gap: 20px; margin-bottom: 28px;
}
.service-card h3 { font-family: 'DM Serif Display', serif; font-size: 44px; margin: 0; color: var(--ink); line-height: 1; }
.service-card .num-chip { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--ink-mute); letter-spacing: .15em; }
.service-card .desc { font-size: 15px; color: var(--ink-soft); margin-bottom: 24px; max-width: 440px; }
.svc-list { list-style: none; padding: 0; margin: 0; column-count: 2; column-gap: 28px; }
.svc-list li {
  font-size: 14px; color: var(--ink); padding: 10px 0;
  border-top: 1px solid var(--line-soft); break-inside: avoid;
  display: flex; align-items: center; gap: 10px;
}
.svc-list li:last-child { border-bottom: 1px solid var(--line-soft); }
.svc-list li .bullet { width: 6px; height: 6px; border-radius: 50%; background: var(--coral); flex-shrink: 0; }
.service-card.audi .svc-list li .bullet { background: var(--sage); }
.service-cta {
  margin-top: 28px; font-size: 11px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--ink); display: inline-flex; align-items: center; gap: 10px;
  border-bottom: 1px solid var(--ink); padding-bottom: 4px;
}

/* ============================================================
   WHO WE HELP
   ============================================================ */
.who { padding: 110px 0; position: relative; }
.who-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 60px; align-items: center; }
.who-copy h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(56px, 6vw, 86px); line-height: 1; margin: 14px 0 28px; color: var(--ink);
}
.who-copy h2 em { color: var(--taupe-dark); font-style: italic; }
.who-copy p { font-size: 17px; color: var(--ink-soft); line-height: 1.7; }
.who-copy p + p { margin-top: 18px; }
.cohort-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 36px; }
.cohort {
  border: 1px solid var(--line); border-radius: 2px; padding: 18px 20px; background: var(--bg-3);
  display: flex; align-items: center; gap: 14px;
}
.cohort .age { font-family: 'DM Serif Display', serif; font-size: 28px; color: var(--taupe-dark); line-height: 1; }
.cohort .lbl { font-size: 13px; color: var(--ink-soft); }
.cohort .lbl strong { display: block; color: var(--ink); font-weight: 500; margin-bottom: 2px; }
.who-art { position: relative; aspect-ratio: 4/5; }
.who-art .frame-a {
  position: absolute; top: 0; right: 0; width: 72%; height: 70%;
  border-radius: 200px 200px 10px 10px; overflow: hidden; box-shadow: var(--shadow);
}
.who-art .frame-b {
  position: absolute; bottom: 0; left: 0; width: 55%; height: 48%;
  border-radius: 10px; overflow: hidden; box-shadow: var(--shadow);
  border: 6px solid var(--bg);
}
.who-art .frame-a img,
.who-art .frame-b img { width: 100%; height: 100%; object-fit: cover; }
.who-art .tag {
  position: absolute; top: 44%; left: 5%;
  background: var(--blush); padding: 10px 14px; border-radius: 999px;
  font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--ink);
  box-shadow: var(--shadow); z-index: 3;
}

/* ============================================================
   DIFFERENCE
   ============================================================ */
.diff {
  padding: 110px 0; background: var(--taupe-dark);
  color: var(--bg-3); position: relative; overflow: hidden;
}
.diff h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(52px, 5.5vw, 84px); color: var(--bg-3); margin: 0 0 16px; line-height: 1;
}
.diff .eyebrow { color: var(--blush); }
.diff-head { max-width: 700px; margin-bottom: 60px; }
.diff-head p { color: rgba(246,241,231,.78); font-size: 17px; max-width: 560px; }
.diff-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; position: relative; }
.diff-steps::before {
  content: ""; position: absolute; top: 28px; left: 3%; right: 3%; height: 1px;
  background: repeating-linear-gradient(to right, rgba(255,255,255,.35) 0 6px, transparent 6px 12px);
}
.step { position: relative; padding-top: 0; }
.step .dot {
  width: 56px; height: 56px; border-radius: 50%; background: var(--coral);
  display: flex; align-items: center; justify-content: center;
  font-family: 'DM Serif Display', serif; font-size: 22px; color: var(--bg-3);
  margin-bottom: 22px; position: relative; z-index: 1;
  border: 6px solid var(--taupe-dark);
}
.step h4 { font-family: 'DM Serif Display', serif; font-size: 26px; margin: 0 0 10px; color: var(--bg-3); line-height: 1.1; }
.step p  { color: rgba(246,241,231,.75); font-size: 14px; line-height: 1.6; margin: 0; }

/* ============================================================
   BLOG
   ============================================================ */
.blog { padding: 110px 0; }
.blog-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 28px; margin-top: 48px; }
.post { cursor: pointer; transition: transform .25s ease; }
.post:hover { transform: translateY(-3px); }
.post .thumb {
  aspect-ratio: 4/3; border-radius: 3px; overflow: hidden; background: var(--bg-2);
  box-shadow: var(--shadow); margin-bottom: 20px;
}
.post.big .thumb { aspect-ratio: 5/6; }
.post .thumb img { width: 100%; height: 100%; object-fit: cover; }
.post .cat  { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--coral-deep); }
.post .date { font-size: 11px; color: var(--ink-mute); margin-left: 10px; letter-spacing: .1em; }
.post h3    { font-family: 'DM Serif Display', serif; font-size: 26px; margin: 10px 0 6px; color: var(--ink); line-height: 1.15; }
.post.big h3 { font-size: 36px; }
.post .snippet { font-size: 14px; color: var(--ink-soft); line-height: 1.6; }

/* ============================================================
   SHOP
   ============================================================ */
.shop { padding: 40px 0 110px; }
.shop-header { display: grid; grid-template-columns: 1fr auto; gap: 20px; align-items: end; margin-bottom: 40px; }
.shop-filters { display: flex; gap: 8px; flex-wrap: wrap; }
.filter {
  font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
  padding: 8px 14px; border: 1px solid var(--line); border-radius: 999px;
  background: transparent; color: var(--ink-soft); cursor: pointer; transition: all .2s;
}
.filter.active          { background: var(--ink); color: var(--bg-3); border-color: var(--ink); }
.filter:hover:not(.active) { border-color: var(--ink); }
.products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.product {
  background: var(--bg-3); border: 1px solid var(--line-soft); border-radius: 3px;
  overflow: hidden; cursor: pointer; transition: all .2s; position: relative;
}
.product:hover { border-color: var(--taupe); }
.product.hidden { display: none; }
.product .p-img { aspect-ratio: 1/1; background: var(--bg-2); position: relative; overflow: hidden; }
.product .p-img img { width: 100%; height: 100%; object-fit: cover; }
.product .p-tag {
  position: absolute; top: 14px; left: 14px; background: var(--coral); color: var(--bg-3);
  font-size: 9px; letter-spacing: .2em; text-transform: uppercase; padding: 4px 8px; border-radius: 999px;
}
.p-body   { padding: 16px 18px 20px; }
.p-cat    { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-mute); }
.p-name   { font-family: 'DM Serif Display', serif; font-size: 20px; color: var(--ink); margin: 6px 0 10px; }
.p-row    { display: flex; justify-content: space-between; align-items: center; }
.p-price  { font-family: 'DM Serif Display', serif; font-size: 20px; color: var(--taupe-dark); }
.p-price s { color: var(--ink-mute); font-size: 14px; margin-right: 6px; }
.p-stars  { color: var(--coral); font-size: 12px; letter-spacing: 1px; }

/* ============================================================
   BOOKING CTA STRIP
   ============================================================ */
.booking-strip {
  padding: 80px 0; background: var(--bg-3);
  border-top: 1px solid var(--line-soft); border-bottom: 1px solid var(--line-soft);
  text-align: center;
}
.booking-strip h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(42px, 5vw, 72px); color: var(--ink); margin: 14px 0 20px; line-height: 1;
}
.booking-strip h2 em { color: var(--taupe-dark); font-style: italic; }
.booking-strip p { font-size: 17px; color: var(--ink-soft); max-width: 520px; margin: 0 auto 36px; }
.booking-strip .btn-book {
  background: var(--ink); color: var(--bg-3); padding: 18px 36px; border-radius: 999px;
  font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
  display: inline-block; transition: background .2s;
}
.booking-strip .btn-book:hover { background: var(--taupe-dark); }

/* ============================================================
   CONTACT
   ============================================================ */
.contact { padding: 110px 0; background: var(--bg-3); border-top: 1px solid var(--line-soft); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; }
.contact h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(60px, 6vw, 96px); line-height: 1; margin: 14px 0 28px; color: var(--ink);
}
.contact h2 em { font-style: italic; color: var(--taupe-dark); }
.locations { display: flex; flex-direction: column; gap: 0; }
.location {
  display: grid; grid-template-columns: 28px 1fr; gap: 18px; padding: 22px 0;
  border-top: 1px solid var(--line);
}
.location:last-child { border-bottom: 1px solid var(--line); }
.location .pin        { color: var(--coral-deep); font-size: 20px; padding-top: 2px; }
.location .loc-label  { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--coral-deep); margin-bottom: 4px; }
.location h4          { font-family: 'DM Serif Display', serif; font-size: 22px; margin: 0 0 4px; color: var(--ink); }
.location .addr       { font-size: 14px; color: var(--ink-soft); line-height: 1.5; }
.location .hrs        { font-size: 12px; color: var(--ink-mute); margin-top: 8px; letter-spacing: .04em; }
.loc-phones { display: flex; align-items: center; gap: 8px; margin-top: 8px; flex-wrap: wrap; }
.loc-phones a { font-size: 13px; color: var(--coral-deep); display: inline-flex; align-items: center; gap: 4px; }
.loc-phones a:hover { color: var(--taupe-dark); }
.loc-phone-sep { color: var(--ink-mute); font-size: 12px; }

/* Contact Form 7 overrides */
.contact-form { background: var(--bg); border: 1px solid var(--line); border-radius: 3px; padding: 36px; }
.contact-form .form-title   { font-family: 'DM Serif Display', serif; font-size: 30px; color: var(--ink); margin-bottom: 4px; }
.contact-form .form-sub     { font-size: 13px; color: var(--ink-mute); margin-bottom: 8px; }
.contact-form label         { display: block; font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 8px; margin-top: 18px; }
.contact-form label:first-of-type { margin-top: 0; }
.contact-form input[type="text"],
.contact-form input[type="email"],
.contact-form input[type="tel"],
.contact-form select,
.contact-form textarea,
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea {
  width: 100%; padding: 12px 0; background: transparent; border: 0;
  border-bottom: 1px solid var(--line);
  font-family: 'Inter', sans-serif; font-size: 15px; color: var(--ink); outline: none;
}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus,
.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus { border-color: var(--taupe-dark); }
.contact-form textarea,
.wpcf7-form textarea { min-height: 80px; resize: vertical; padding-top: 12px; }
.wpcf7-submit,
.contact-form .send {
  margin-top: 28px; width: 100%; padding: 16px; border-radius: 999px;
  background: var(--ink); color: var(--bg-3); border: 0;
  font-size: 11px; letter-spacing: .22em; text-transform: uppercase; cursor: pointer; transition: background .2s;
}
.wpcf7-submit:hover,
.contact-form .send:hover { background: var(--taupe-dark); }
.wpcf7-response-output { margin-top: 16px; padding: 14px; border-radius: 2px; font-size: 14px; text-align: center; }
.wpcf7-mail-sent-ok     { background: var(--sage); color: white; border: 0 !important; }
.wpcf7-validation-errors { background: var(--blush); color: var(--ink); border: 0 !important; }

.channel-row { display: flex; gap: 10px; margin-top: 30px; flex-wrap: wrap; }
.channel {
  flex: 1 1 auto; display: flex; align-items: center; gap: 10px;
  padding: 12px 16px; background: var(--bg); border: 1px solid var(--line); border-radius: 999px;
  font-size: 13px; color: var(--ink);
}
.channel .icon-circle {
  width: 26px; height: 26px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}

/* ============================================================
   FOOTER
   ============================================================ */
footer { background: var(--ink); color: var(--bg-3); padding: 80px 0 30px; }
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; margin-bottom: 60px; }
.foot-brand .mark { font-family: 'DM Serif Display', serif; font-style: italic; font-size: 44px; color: var(--bg-3); }
.foot-brand p { color: rgba(246,241,231,.6); max-width: 320px; margin-top: 12px; font-size: 14px; line-height: 1.6; }
.foot-social { display: flex; gap: 12px; margin-top: 20px; }
.foot-social a { color: var(--bg-3); opacity: .8; transition: opacity .2s; }
.foot-social a:hover { opacity: 1; }
.foot h5 { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--coral); margin: 0 0 18px; }
.foot ul { list-style: none; padding: 0; margin: 0; }
.foot ul li { margin-bottom: 10px; font-size: 14px; color: rgba(246,241,231,.75); cursor: pointer; }
.foot ul li:hover { color: var(--bg-3); }
.foot ul li a { color: rgba(246,241,231,.75); }
.foot ul li a:hover { color: var(--bg-3); }
.foot-bar {
  padding-top: 24px; border-top: 1px solid rgba(246,241,231,.12);
  display: flex; justify-content: space-between; gap: 20px;
  font-size: 12px; color: rgba(246,241,231,.55);
}

/* ============================================================
   BLOCK PATTERNS
   ============================================================ */

/* Summary Card */
.shh-summary-card {
  background: var(--bg-3); border: 1px solid var(--line); border-radius: 4px;
  padding: 36px 40px; margin-bottom: 48px;
}
.shh-summary-title { font-family: 'DM Serif Display', serif !important; font-size: 28px !important; color: var(--ink); margin: 0 0 20px !important; }
.shh-summary-desc { font-size: 15px; color: var(--ink-soft); margin-bottom: 24px; }
.shh-info-cards { gap: 20px; }
.shh-info-card {
  background: var(--bg); border: 1px solid var(--line-soft); border-radius: 3px; padding: 20px;
}
.shh-card-name { font-size: 15px; color: var(--ink); font-family: 'DM Serif Display', serif; margin: 0; }
.shh-card-detail { font-size: 13px; color: var(--ink-soft); margin-top: 4px; line-height: 1.7; }
.shh-card-mute { font-size: 11px; color: var(--ink-mute); margin-top: 4px; }

/* Info Box */
.shh-info-box {
  background: var(--bg-3); border: 1px solid var(--line-soft); border-radius: 4px;
  padding: 20px 24px; margin-bottom: 24px; line-height: 2; font-size: 15px;
}
.shh-info-box a { color: var(--coral-deep); }

/* Definition List */
.shh-def-list { margin-bottom: 24px; }
.shh-def-item { padding: 20px 0; border-top: 1px solid var(--line-soft); }
.shh-def-title { font-size: 13px !important; font-weight: 600; color: var(--ink); margin-bottom: 4px !important; }
.shh-def-text { font-size: 15px; color: var(--ink-soft); margin: 0; }

/* Legal Page Header */
.shh-legal-header { margin-bottom: 48px; }
.shh-legal-title {
  font-family: 'DM Serif Display', serif !important;
  font-size: clamp(48px, 6vw, 80px) !important;
  line-height: 1 !important; margin: 14px 0 16px !important; color: var(--ink);
}
.shh-legal-title em { color: var(--taupe-dark); font-style: italic; }
.shh-legal-date { font-size: 13px; color: var(--ink-mute); letter-spacing: .04em; }

/* Styled Table — overrides wp-block-table core styles */
.shh-table table { width: 100%; border-collapse: collapse !important; font-size: 14px; }
.shh-table th {
  padding: 12px 16px !important; text-align: left; border: 1px solid var(--line) !important;
  color: var(--ink); font-weight: 600; background: var(--bg-2) !important;
}
.shh-table td { padding: 12px 16px !important; border: 1px solid var(--line-soft) !important; color: var(--ink-soft); }
.shh-table td:first-child { color: var(--ink); }
.shh-table tbody tr:nth-child(odd) { background: transparent !important; }
.shh-table tbody tr:nth-child(even) { background: var(--bg-3) !important; }
.shh-table.is-style-stripes { border-bottom: none !important; }
.shh-table .has-coral-color { color: var(--coral-deep); font-weight: 500; }

@media (max-width: 600px) {
  .shh-summary-card { padding: 24px 20px; }
  .shh-info-cards { flex-direction: column; }
}

/* ============================================================
   LEGAL PAGES (block editor content)
   ============================================================ */
.shh-legal { font-size: 16px; color: var(--ink-soft); line-height: 1.8; }
.shh-legal h2 { font-family: 'DM Serif Display', serif; font-size: 32px; color: var(--ink); margin: 0 0 16px; }
.shh-legal h3 { font-family: 'DM Serif Display', serif; font-size: 24px; color: var(--ink); margin: 28px 0 12px; }
.shh-legal ul, .shh-legal ol { padding-left: 24px; margin-bottom: 20px; line-height: 2; }
.shh-legal li { margin-bottom: 8px; }
.shh-legal a { color: var(--coral-deep); }
.shh-legal .wp-block-separator { height: 1px; background: var(--line-soft); border: 0; margin: 36px 0; opacity: 1; }

/* Override WordPress block layout spacing inside legal pages */
.shh-legal .wp-block-group__inner-container { padding: 0; }
.shh-legal .is-layout-flow > * + * { margin-block-start: 0; }
.shh-legal .is-layout-constrained > * + * { margin-block-start: 0; }
.shh-legal p { margin: 0 0 1em; }
.shh-legal .shh-legal-header { margin-bottom: 48px; }
.shh-legal .shh-legal-header .is-layout-flow > * + * { margin-block-start: 0; }
.shh-legal .shh-summary-card .is-layout-flow > * + * { margin-block-start: 0; }
.shh-legal .shh-def-item .is-layout-flow > * + * { margin-block-start: 0; }
.shh-legal .shh-info-box .is-layout-flow > * + * { margin-block-start: 0; }

/* POPIA summary card */
.popia-summary {
  background: var(--bg-3); border: 1px solid var(--line); border-radius: 4px;
  padding: 36px 40px; margin-bottom: 48px;
}
.popia-summary h2 { font-family: 'DM Serif Display', serif; font-size: 28px; color: var(--ink); margin: 0 0 20px; }
.popia-summary > p { font-size: 15px; color: var(--ink-soft); margin-bottom: 24px; }
.popia-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.popia-card { background: var(--bg); border: 1px solid var(--line-soft); border-radius: 3px; padding: 20px; }
.popia-card .eyebrow { margin-bottom: 8px; }
.popia-card-name { font-size: 15px; color: var(--ink); font-family: 'DM Serif Display', serif; }
.popia-card-detail { font-size: 13px; color: var(--ink-soft); margin-top: 4px; }
.popia-card-mute { font-size: 11px; color: var(--ink-mute); margin-top: 4px; }

/* POPIA table */
.popia-table { width: 100%; border-collapse: collapse; margin-bottom: 24px; font-size: 14px; }
.popia-table th {
  padding: 12px 16px; text-align: left; border: 1px solid var(--line);
  color: var(--ink); font-weight: 600; background: var(--bg-2);
}
.popia-table td { padding: 12px 16px; border: 1px solid var(--line-soft); }
.popia-table td:first-child { color: var(--ink); }
.popia-table tbody tr:nth-child(even) { background: var(--bg-3); }
.popia-table .popia-special { color: var(--coral-deep); font-weight: 500; }

/* POPIA rights list */
.popia-rights { display: flex; flex-direction: column; margin-bottom: 24px; }
.popia-right { padding: 20px 0; border-top: 1px solid var(--line-soft); }
.popia-right-title { font-size: 13px; font-weight: 600; color: var(--ink); margin-bottom: 4px; }
.popia-right-text { font-size: 15px; color: var(--ink-soft); }

/* POPIA info boxes */
.popia-infobox {
  background: var(--bg-3); border: 1px solid var(--line-soft); border-radius: 4px;
  padding: 20px 24px; margin-bottom: 24px; line-height: 2; font-size: 15px;
}
.popia-infobox a { color: var(--coral-deep); }

@media (max-width: 600px) {
  .popia-cards { grid-template-columns: 1fr; }
  .popia-summary { padding: 24px 20px; }
}

/* ============================================================
   PLACEHOLDER IMAGERY (fallback until real photos)
   ============================================================ */
.ph {
  width: 100%; height: 100%;
  background:
    repeating-linear-gradient(135deg, rgba(154,123,101,.12) 0 2px, transparent 2px 10px),
    linear-gradient(135deg, var(--bg-2), var(--bg-3));
  position: relative; display: flex; align-items: center; justify-content: center;
}
.ph .lbl {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ink-mute);
  padding: 6px 10px; background: rgba(255,255,255,.65); border: 1px solid var(--line-soft); border-radius: 2px;
}
.ph.tone-a { background: repeating-linear-gradient(135deg, rgba(201,106,79,.1) 0 2px, transparent 2px 10px), linear-gradient(135deg, #E7C9BC, #DDB9A6); }
.ph.tone-b { background: repeating-linear-gradient(135deg, rgba(150,165,140,.15) 0 2px, transparent 2px 10px), linear-gradient(135deg, #C5D0BE, #A8B8A0); }
.ph.tone-c { background: repeating-linear-gradient(135deg, rgba(154,123,101,.14) 0 2px, transparent 2px 10px), linear-gradient(135deg, #D8C6B2, #C4AC91); }
.ph.tone-d { background: repeating-linear-gradient(135deg, rgba(232,213,164,.35) 0 2px, transparent 2px 10px), linear-gradient(135deg, #F0E2C0, #E0CC9A); }
.ph.tone-e { background: repeating-linear-gradient(135deg, rgba(122,94,75,.18) 0 2px, transparent 2px 10px), linear-gradient(135deg, #B5A08A, #9A8370); }

/* ============================================================
   INLINE SVG ICONS
   ============================================================ */
.icon-arrow::after { content: "→"; }

/* ============================================================
   NAV SEARCH
   ============================================================ */
.nav-search-btn {
  background: none; border: none; padding: 6px; cursor: pointer;
  color: var(--ink-soft); transition: color .2s; display: flex; align-items: center;
}
.nav-search-btn:hover { color: var(--coral-deep); }

.nav-search {
  position: sticky; top: 53px; z-index: 49;
  background: var(--bg-3); border-bottom: 1px solid var(--line-soft);
  max-height: 0; overflow: hidden; opacity: 0;
  transition: max-height .3s ease, opacity .2s ease;
}
.nav-search[aria-hidden="false"] { max-height: 80px; opacity: 1; }
.nav-search-form {
  display: flex; align-items: center; gap: 12px; padding: 14px 0;
}
.nav-search-form input {
  flex: 1; background: transparent; border: none; border-bottom: 1px solid var(--line);
  font-family: 'Inter', sans-serif; font-size: 15px; color: var(--ink);
  padding: 8px 0; outline: none;
}
.nav-search-form input::placeholder { color: var(--ink-mute); }
.nav-search-form input:focus { border-color: var(--taupe-dark); }
.nav-search-form button {
  background: none; border: none; padding: 8px; cursor: pointer;
  color: var(--ink-soft); display: flex; align-items: center;
}
.nav-search-form button:hover { color: var(--coral-deep); }
.screen-reader-text {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); border: 0;
}

/* Drawer search */
.drawer-search {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 24px; padding-bottom: 20px; border-bottom: 1px solid var(--line-soft);
}
.drawer-search input {
  flex: 1; background: transparent; border: none; border-bottom: 1px solid var(--line);
  font-family: 'Inter', sans-serif; font-size: 15px; color: var(--ink);
  padding: 10px 0; outline: none;
}
.drawer-search input::placeholder { color: var(--ink-mute); }
.drawer-search input:focus { border-color: var(--taupe-dark); }
.drawer-search button {
  background: none; border: none; padding: 8px; cursor: pointer;
  color: var(--ink-soft); display: flex; align-items: center;
}

/* ============================================================
   MOBILE NAVIGATION
   ============================================================ */
.nav-toggle { display: none; }

@media (max-width: 980px) {
  .nav-toggle {
    display: flex; align-items: center; justify-content: center;
    width: 40px; height: 40px; padding: 0;
    background: none; border: 1px solid var(--line); border-radius: 50%;
    cursor: pointer; position: relative;
  }
  .hamburger,
  .hamburger::before,
  .hamburger::after {
    display: block; width: 16px; height: 1.5px;
    background: var(--ink); border-radius: 1px;
    transition: transform .3s ease, opacity .2s ease;
  }
  .hamburger { position: relative; }
  .hamburger::before,
  .hamburger::after { content: ''; position: absolute; left: 0; }
  .hamburger::before { top: -5px; }
  .hamburger::after  { top: 5px; }

  /* Hamburger → X when open */
  .nav-toggle[aria-expanded="true"] .hamburger { background: transparent; }
  .nav-toggle[aria-expanded="true"] .hamburger::before { top: 0; transform: rotate(45deg); }
  .nav-toggle[aria-expanded="true"] .hamburger::after  { top: 0; transform: rotate(-45deg); }

  .nav-desktop-only { display: none !important; }
}

/* Drawer */
.mobile-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: min(340px, 85vw);
  background: var(--bg);
  z-index: 200;
  transform: translateX(100%);
  transition: transform .35s cubic-bezier(.4, 0, .2, 1);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.mobile-drawer[aria-hidden="false"] { transform: translateX(0); }

.drawer-inner { padding: 28px 28px 40px; }
.drawer-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 36px; padding-bottom: 20px; border-bottom: 1px solid var(--line-soft);
}
.drawer-close {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  background: none; border: 1px solid var(--line); border-radius: 50%;
  font-size: 22px; color: var(--ink); cursor: pointer; line-height: 1;
}
.drawer-links { display: flex; flex-direction: column; gap: 0; }
.drawer-links a {
  font-family: 'DM Serif Display', serif;
  font-size: 28px; color: var(--ink); line-height: 1;
  padding: 16px 0;
  border-bottom: 1px solid var(--line-soft);
  transition: color .2s;
}
.drawer-links a:first-child { border-top: 1px solid var(--line-soft); }
.drawer-links a:hover { color: var(--coral-deep); }

.drawer-cta {
  display: block; text-align: center; margin-top: 28px;
  padding: 16px; border-radius: 999px;
  background: var(--ink); color: var(--bg-3);
  font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
  transition: background .2s;
}
.drawer-cta:hover { background: var(--taupe-dark); }

.drawer-contact {
  margin-top: 28px; padding-top: 20px; border-top: 1px solid var(--line-soft);
  display: flex; flex-direction: column; gap: 12px;
}
.drawer-contact a {
  font-size: 14px; color: var(--ink-soft);
  display: inline-flex; align-items: center; gap: 8px;
}
.drawer-contact a:hover { color: var(--coral-deep); }

/* Overlay */
.drawer-overlay {
  position: fixed; inset: 0; z-index: 199;
  background: rgba(42, 35, 32, .4);
  opacity: 0; pointer-events: none;
  transition: opacity .35s ease;
}
.drawer-overlay.active { opacity: 1; pointer-events: auto; }

/* Hide drawer on desktop */
@media (min-width: 981px) {
  .mobile-drawer, .drawer-overlay { display: none; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .mobile-drawer { transition: none; }
  .drawer-overlay { transition: none; }
  .hamburger, .hamburger::before, .hamburger::after { transition: none; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* ============================================================
   RESPONSIVE
   ============================================================ */

/* ── Tablet (≤980px) ──────────────────────────────────────── */
@media (max-width: 980px) {
  .hero-grid, .about-grid, .who-grid, .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .team-grid     { grid-template-columns: 1fr 1fr; }
  .services-grid { grid-template-columns: 1fr; }
  .products      { grid-template-columns: 1fr 1fr; }
  .diff-steps    { grid-template-columns: 1fr 1fr; }
  .foot-grid     { grid-template-columns: 1fr 1fr; }
  .blog-grid     { grid-template-columns: 1fr 1fr; }
  .hero-art      { height: 420px; }
  .nav-inner     { grid-template-columns: auto 1fr; }
  .nav-left      { display: none; }
  .nav-right     { justify-content: flex-end; gap: 16px; }

  /* Reduce section padding */
  .hero { padding: 60px 0 70px; }
  .about, .team, .who, .blog, .shop { padding: 80px 0; }
  .services, .contact { padding: 80px 0; }
  .diff { padding: 80px 0; }
  .booking-strip { padding: 60px 0; }

  /* Typography scale down */
  .hero h1 { font-size: clamp(48px, 10vw, 80px); }
  .about-title { font-size: clamp(44px, 8vw, 72px); }
  .about-title em { margin-left: 40px; }

  /* Who-we-help art stacks below */
  .who-art { aspect-ratio: 3/4; max-height: 480px; }

  /* Section heads stack */
  .section-head { flex-direction: column; align-items: start; }
}

/* ── Mobile (≤600px) ──────────────────────────────────────── */
@media (max-width: 600px) {
  .container, .container-wide { padding: 0 20px; }

  /* Nav */
  .nav-inner { padding: 12px 20px; }
  .nav .brand .mark { font-size: 18px; }
  .nav .brand .sub { font-size: 8px; letter-spacing: .25em; }

  /* Hero */
  .hero { padding: 40px 0 50px; }
  .hero h1 { font-size: clamp(40px, 12vw, 60px); margin: 16px 0 20px; }
  .hero-sub { font-size: 15px; }
  .hero-meta { gap: 16px; }
  .hero-meta .btn-primary { padding: 14px 22px; font-size: 11px; width: 100%; justify-content: center; }
  .hero-meta .btn-text { font-size: 11px; }
  .hero-art { height: 340px; }
  .hero-decor { width: 120px; height: 120px; font-size: 16px; right: -16px; top: -12px; }
  .hero-chip { left: -10px; bottom: 20px; padding: 10px 14px; }
  .hero-chip .t2 { font-size: 14px; }
  .marquee { margin-top: 50px; padding: 16px 0; }
  .marquee-track { font-size: 20px; gap: 40px; }

  /* About */
  .about { padding: 60px 0; }
  .about-title { font-size: clamp(40px, 10vw, 56px); }
  .about-title em { margin-left: 24px; }
  .about-body p { font-size: 16px; }
  .about-body p:first-child::first-letter { font-size: 56px; }
  .about-stats { grid-template-columns: 1fr; gap: 16px; }
  .stat .num { font-size: 36px; }

  /* Team */
  .team { padding: 40px 0 60px; }
  .team-grid { grid-template-columns: 1fr; gap: 32px; }
  .member .name { font-size: 24px; }
  .member .bio { font-size: 13px; }

  /* Services */
  .services { padding: 60px 0; }
  .services-grid { gap: 20px; }
  .service-card { padding: 28px 24px; }
  .service-card h3 { font-size: 32px; }
  .svc-list { column-count: 1; }

  /* Who we help */
  .who { padding: 60px 0; }
  .who-copy h2 { font-size: clamp(40px, 10vw, 56px); }
  .cohort-grid { grid-template-columns: 1fr; gap: 10px; }
  .cohort .age { font-size: 22px; }
  .who-art { max-height: 400px; }

  /* Difference */
  .diff { padding: 60px 0; }
  .diff h2 { font-size: clamp(40px, 10vw, 56px); }
  .diff-steps { grid-template-columns: 1fr; gap: 24px; }
  .diff-steps::before { display: none; }
  .step .dot { width: 44px; height: 44px; font-size: 18px; margin-bottom: 16px; }
  .step h4 { font-size: 22px; }

  /* Blog */
  .blog { padding: 60px 0; }
  .blog-grid { grid-template-columns: 1fr; gap: 24px; }
  .post.big .thumb { aspect-ratio: 4/3; }
  .post.big h3 { font-size: 26px; }

  /* Shop */
  .shop { padding: 40px 0 60px; }
  .products { grid-template-columns: 1fr; gap: 16px; }
  .shop-header { grid-template-columns: 1fr; gap: 12px; }

  /* Booking */
  .booking-strip { padding: 50px 0; }
  .booking-strip h2 { font-size: clamp(36px, 9vw, 52px); }
  .booking-strip p { font-size: 15px; }

  /* Contact */
  .contact { padding: 60px 0; }
  .contact h2 { font-size: clamp(44px, 10vw, 64px); }
  .channel-row { flex-direction: column; }
  .channel { padding: 14px 16px; }
  .contact-form { padding: 24px 20px; }

  /* Footer */
  .foot-grid { grid-template-columns: 1fr; gap: 32px; }
  .foot-brand .mark { font-size: 32px; }
  .foot-bar { flex-direction: column; text-align: center; gap: 8px; }

  /* Touch targets — minimum 44px for all interactive elements */
  .nav a.link, .nav-search-btn, .filter, .drawer-links a { min-height: 44px; display: inline-flex; align-items: center; }
  .channel { min-height: 48px; }
  .fof-nav a, .search-suggestions a { min-height: 44px; display: inline-flex; align-items: center; }
}

/* ============================================================
   JOURNAL PAGE
   ============================================================ */
.journal-page { padding: 80px 0 120px; }

.journal-header {
  display: flex; justify-content: space-between; align-items: end;
  gap: 40px; flex-wrap: wrap; margin-bottom: 48px;
}
.journal-header h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(48px, 5.5vw, 80px);
  line-height: 1; margin-top: 10px; color: var(--ink);
}
.journal-header h1 em { color: var(--taupe-dark); font-style: italic; }
.journal-intro { max-width: 380px; font-size: 15px; color: var(--ink-soft); line-height: 1.6; }

/* Featured post */
.journal-featured {
  display: grid; grid-template-columns: 1.3fr 1fr; gap: 0;
  background: var(--bg-3); border: 1px solid var(--line-soft); border-radius: 4px;
  overflow: hidden; margin-bottom: 48px; transition: transform .25s ease;
}
.journal-featured:hover { transform: translateY(-3px); }
.jf-image { aspect-ratio: 4/3; overflow: hidden; background: var(--bg-2); }
.jf-image img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.journal-featured:hover .jf-image img { transform: scale(1.03); }
.jf-copy { padding: 40px; display: flex; flex-direction: column; justify-content: center; }
.jf-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; }
.jf-date { font-size: 11px; color: var(--ink-mute); letter-spacing: .1em; }
.jf-copy h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(28px, 3vw, 40px); line-height: 1.1; color: var(--ink); margin: 0 0 14px;
}
.jf-copy p { font-size: 15px; color: var(--ink-soft); line-height: 1.6; margin: 0 0 20px; }
.jf-read {
  font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--coral-deep);
}

/* Category filters */
.journal-filters { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 40px; }

/* Posts grid */
.journal-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
}
.journal-card { transition: transform .25s ease; }
.journal-card:hover { transform: translateY(-3px); }
.jc-thumb {
  aspect-ratio: 4/3; border-radius: 3px; overflow: hidden;
  background: var(--bg-2); margin-bottom: 16px;
}
.jc-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.journal-card:hover .jc-thumb img { transform: scale(1.03); }
.jc-body {}
.jc-meta { display: flex; align-items: center; gap: 6px; margin-bottom: 8px; flex-wrap: wrap; }
.jc-meta .cat { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--coral-deep); }
.jc-meta .date { font-size: 11px; color: var(--ink-mute); letter-spacing: .08em; }
.journal-card h3 {
  font-family: 'DM Serif Display', serif;
  font-size: 22px; color: var(--ink); line-height: 1.2; margin: 0 0 8px;
}
.journal-card p { font-size: 14px; color: var(--ink-soft); line-height: 1.6; margin: 0; }

/* Pagination */
.journal-pagination { margin-top: 60px; text-align: center; }
.journal-pagination .nav-links,
.journal-pagination .page-numbers { display: inline-flex; gap: 8px; align-items: center; }
.journal-pagination a, .journal-pagination span {
  padding: 8px 14px; border: 1px solid var(--line); border-radius: 999px;
  font-size: 12px; color: var(--ink-soft); transition: all .2s;
}
.journal-pagination a:hover { border-color: var(--coral-deep); color: var(--coral-deep); }
.journal-pagination .current { background: var(--ink); color: var(--bg-3); border-color: var(--ink); }

@media (max-width: 980px) {
  .journal-featured { grid-template-columns: 1fr; }
  .jf-copy { padding: 28px; }
  .journal-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .journal-page { padding: 50px 0 80px; }
  .journal-header { flex-direction: column; align-items: start; }
  .journal-intro { max-width: none; }
  .jf-copy { padding: 24px 20px; }
  .jf-copy h2 { font-size: 24px; }
  .journal-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   SINGLE POST
   ============================================================ */
.single-post { padding: 80px 0 0; min-height: 60vh; }

/* Header — centered, wide enough for long titles */
.sp-header { max-width: 820px; margin: 0 auto 36px; }
.sp-meta { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; }
.sp-dot { color: var(--ink-mute); font-size: 11px; }
.sp-date { font-size: 11px; color: var(--ink-mute); letter-spacing: .1em; }
.sp-header h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(40px, 5vw, 72px);
  line-height: 1.05; color: var(--ink);
}

/* Hero image — full container width, centered */
.sp-hero {
  max-width: 960px; margin: 0 auto 48px;
  aspect-ratio: 16/9; border-radius: 6px; overflow: hidden;
}
.sp-hero-img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Body — comfortable reading width, centered */
.sp-body {
  max-width: 720px; margin: 0 auto;
  font-size: 18px; color: var(--ink-soft); line-height: 1.85;
}
.sp-body p { margin: 0 0 1.4em; }
.sp-body h2 {
  font-family: 'DM Serif Display', serif;
  font-size: 32px; color: var(--ink); margin: 2.2em 0 .6em;
}
.sp-body h3 {
  font-family: 'DM Serif Display', serif;
  font-size: 24px; color: var(--ink); margin: 1.8em 0 .5em;
}
.sp-body a { color: var(--coral-deep); text-decoration: underline; text-underline-offset: 3px; }
.sp-body blockquote {
  margin: 2em 0; padding: 28px 32px; background: var(--bg-3);
  border-radius: 4px; font-style: italic; color: var(--ink);
}
.sp-body img { border-radius: 4px; margin: 1.5em 0; }
.sp-body ul, .sp-body ol { padding-left: 24px; margin-bottom: 1.4em; }
.sp-body li { margin-bottom: 8px; }
.sp-body hr {
  height: 1px; background: var(--line-soft); border: 0;
  margin: 2.5em 0;
}
.sp-body em { color: var(--ink); }

/* Footer — centered, same width as body */
.sp-footer {
  max-width: 720px; margin: 60px auto 0; padding-top: 24px;
  border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 16px;
}
.sp-share { display: flex; align-items: center; gap: 12px; }
.sp-share-label { font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-mute); }
.sp-share a {
  width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  color: var(--ink-soft); transition: all .2s;
}
.sp-share a:hover { border-color: var(--coral-deep); color: var(--coral-deep); }
.sp-back {
  font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--coral-deep);
}

/* Related posts */
.sp-related {
  margin-top: 80px; padding: 80px 0;
  background: var(--bg-3); border-top: 1px solid var(--line-soft);
}
.sp-related-head { margin-bottom: 36px; }
.sp-related-head h2 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(32px, 4vw, 48px); line-height: 1; margin-top: 10px; color: var(--ink);
}
.sp-related-head h2 em { color: var(--taupe-dark); font-style: italic; }
.sp-related-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }

@media (max-width: 980px) {
  .sp-related-grid { grid-template-columns: 1fr 1fr; }
  .sp-hero { max-width: 100%; }
}
@media (max-width: 600px) {
  .single-post { padding: 50px 0 0; }
  .sp-header h1 { font-size: clamp(32px, 8vw, 48px); }
  .sp-hero { aspect-ratio: 4/3; border-radius: 4px; }
  .sp-body { font-size: 16px; }
  .sp-body h2 { font-size: 26px; }
  .sp-related { padding: 50px 0; margin-top: 50px; }
  .sp-related-grid { grid-template-columns: 1fr; }
  .sp-footer { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   SEARCH RESULTS
   ============================================================ */
.search-page { padding: 80px 0 120px; min-height: 70vh; }
.search-header { margin-bottom: 48px; }
.search-header h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1.1; margin: 14px 0 12px; color: var(--ink);
}
.search-header h1 em { color: var(--taupe-dark); font-style: italic; }
.search-count { font-size: 13px; color: var(--ink-mute); letter-spacing: .1em; }

.search-results { display: flex; flex-direction: column; }
.search-item { border-top: 1px solid var(--line-soft); }
.search-item:last-child { border-bottom: 1px solid var(--line-soft); }
.search-item a { display: block; padding: 28px 0; transition: background .2s; }
.search-item a:hover { background: var(--bg-3); margin: 0 -20px; padding-left: 20px; padding-right: 20px; }
.search-item-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.search-type {
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase; color: var(--coral-deep);
}
.search-date { font-size: 12px; color: var(--ink-mute); }
.search-item h3 {
  font-family: 'DM Serif Display', serif;
  font-size: 24px; color: var(--ink); margin: 0 0 6px; line-height: 1.2;
}
.search-item p { font-size: 15px; color: var(--ink-soft); line-height: 1.6; margin: 0; }

.search-pagination { margin-top: 48px; text-align: center; }
.search-pagination .nav-links { display: flex; justify-content: center; gap: 12px; }
.search-pagination a, .search-pagination span {
  padding: 8px 14px; border: 1px solid var(--line); border-radius: 999px;
  font-size: 12px; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-soft);
}
.search-pagination a:hover { border-color: var(--coral-deep); color: var(--coral-deep); }
.search-pagination .current { background: var(--ink); color: var(--bg-3); border-color: var(--ink); }

.search-empty { margin-top: 8px; }
.search-empty p { font-size: 17px; color: var(--ink-soft); line-height: 1.7; margin-bottom: 24px; }
.search-suggestions { display: flex; flex-wrap: wrap; gap: 8px; }
.search-suggestions a {
  padding: 8px 16px; border: 1px solid var(--line); border-radius: 999px;
  font-size: 13px; color: var(--ink-soft); transition: all .2s;
}
.search-suggestions a:hover { border-color: var(--coral-deep); color: var(--coral-deep); }

/* ============================================================
   404 PAGE
   ============================================================ */
.four-oh-four { padding: 100px 0 120px; min-height: 70vh; display: flex; align-items: center; }
.fof-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 60px; align-items: center; }
.fof-copy h1 {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(48px, 6vw, 80px);
  line-height: 1; margin: 14px 0 24px; color: var(--ink);
}
.fof-copy h1 em { color: var(--taupe-dark); font-style: italic; }
.fof-copy > p { font-size: 17px; color: var(--ink-soft); line-height: 1.7; max-width: 480px; }
.fof-links { margin-top: 36px; }
.fof-btn {
  display: inline-block; padding: 16px 28px; border-radius: 999px;
  background: var(--ink); color: var(--bg-3);
  font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
  transition: background .2s;
}
.fof-btn:hover { background: var(--taupe-dark); }
.fof-or {
  margin: 24px 0 14px;
  font-size: 12px; letter-spacing: .15em; text-transform: uppercase; color: var(--ink-mute);
}
.fof-nav { display: flex; flex-wrap: wrap; gap: 8px; }
.fof-nav a {
  padding: 8px 16px; border: 1px solid var(--line); border-radius: 999px;
  font-size: 13px; color: var(--ink-soft); transition: all .2s;
}
.fof-nav a:hover { border-color: var(--coral-deep); color: var(--coral-deep); }

.fof-art { display: flex; align-items: center; justify-content: center; }
.fof-num {
  font-family: 'DM Serif Display', serif;
  font-size: clamp(140px, 20vw, 260px);
  font-style: italic; line-height: .85;
  color: var(--bg-2);
  letter-spacing: -.04em;
  user-select: none;
}

@media (max-width: 980px) {
  .fof-grid { grid-template-columns: 1fr; text-align: center; }
  .fof-copy > p { max-width: none; }
  .fof-nav { justify-content: center; }
  .fof-art { order: -1; }
  .fof-num { font-size: clamp(100px, 25vw, 180px); }
}

/* ============================================================
   SCROLL REVEALS
   ============================================================ */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .7s cubic-bezier(.4, 0, .2, 1), transform .7s cubic-bezier(.4, 0, .2, 1);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
/* Stagger children inside a reveal group */
.reveal-group .reveal:nth-child(2) { transition-delay: .1s; }
.reveal-group .reveal:nth-child(3) { transition-delay: .2s; }
.reveal-group .reveal:nth-child(4) { transition-delay: .3s; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ============================================================
   ACCESSIBILITY & POLISH
   ============================================================ */

/* Skip link */
.skip-link {
  position: absolute; top: -100%; left: 16px;
  background: var(--ink); color: var(--bg-3); padding: 12px 20px;
  font-size: 13px; letter-spacing: .1em; text-transform: uppercase;
  border-radius: 0 0 4px 4px; z-index: 999; transition: top .2s;
}
.skip-link:focus { top: 0; }

/* Focus styles — visible ring for keyboard users */
:focus-visible {
  outline: 2px solid var(--coral-deep);
  outline-offset: 3px;
}
a:focus:not(:focus-visible),
button:focus:not(:focus-visible) { outline: none; }

/* Contrast fix: --ink-mute is too light on --bg for small text */
/* Darken from #8A7C73 to #6F6259 for WCAG AA on #EFE9DF */
:root { --ink-mute: #6F6259; }

/* Reduced motion — respect user preference */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .marquee-track { animation: none !important; }
  html { scroll-behavior: auto; }
}

/* Smooth scroll only for users who haven't opted out */
@media (prefers-reduced-motion: no-preference) {
  html { scroll-behavior: smooth; }
}

/* Footer fallback links — make non-link items focusable-looking */
.foot ul li { cursor: default; }
.foot ul li a { cursor: pointer; }
