/**
 * Long Light v2.0.0 — base stylesheet
 *
 * Loads on every page. Single source of truth.
 *
 * Sections:
 *   1. Tokens (CSS variables)
 *   2. Reset + base typography
 *   3. Block style variants (Eyebrow, Lead, Pull-gold, Display, Section: Paper/Paper-Deep/Ink/CTA)
 *   4. Navigation (responsive with hamburger)
 *   5. Footer
 *   6. Section adjacencies & spacing
 *   7. Special components (FAQ accordion, hero cream-wash, etc)
 *   8. Responsive overrides
 */

/* ============================================================
   1. TOKENS
   ============================================================ */
:root {
  --paper:        #f7f1e6;
  --paper-deep:   #efe5d2;
  --ink:          #1c1815;
  --ink-soft:     #4a3f36;
  --ink-faint:    #8a7d6f;
  --gold:         #b08344;
  --gold-soft:    #d9b87c;
  --line:         #b8ac97;

  --serif: 'Cormorant Garamond', 'Lyon', Georgia, serif;
  --sans:  'Inter', -apple-system, system-ui, sans-serif;

  --gutter: clamp(1.25rem, 4vw, 3rem);
  --max-w-content: 720px;
  --max-w-wide:    1200px;
}

/* ============================================================
   2. RESET + BASE TYPOGRAPHY
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 1.0625rem;
  font-weight: 300;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Body copy is a soft ink for less harshness */
p { color: var(--ink-soft); }

/* Headings — serif, light weight */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--serif);
  font-weight: 300;
  color: var(--ink);
  margin: 0 0 0.6em;
  letter-spacing: -0.005em;
}
h1 { font-size: clamp(2.5rem, 5.5vw, 4.75rem); line-height: 1.05; letter-spacing: -0.015em; }
h2 { font-size: clamp(1.9rem, 3.6vw, 3rem);    line-height: 1.15; letter-spacing: -0.01em; }
h3 { font-size: clamp(1.4rem, 2.2vw, 1.85rem); line-height: 1.25; font-weight: 400; }
h4 { font-size: 1.1rem; font-weight: 500; }

em, i { font-style: italic; }

a {
  color: var(--gold);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color 0.2s, color 0.2s;
}
a:hover { border-bottom-color: var(--gold); }

ul, ol { color: var(--ink-soft); padding-left: 1.5em; }
li { margin-bottom: 0.4em; }

img, svg, video { max-width: 100%; height: auto; display: block; }

/* WP block default reset for paragraphs that have inherited huge gaps */
.wp-block-group + .wp-block-group { margin-top: 0; }

/* Buttons — used by core/button block */
.wp-block-button__link {
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
  padding: 0.85rem 1.6rem;
  border-radius: 0;
  transition: background 0.2s, color 0.2s;
  text-decoration: none;
  display: inline-block;
}
.wp-block-button__link:hover {
  background: var(--ink);
  color: var(--paper);
  border-bottom-color: var(--ink);
}

/* Lists default styling */
.wp-block-list { padding-left: 1.5em; }
.wp-block-list li { color: var(--ink-soft); margin-bottom: 0.4em; line-height: 1.7; }
.wp-block-list li strong { color: var(--ink); font-weight: 500; }

/* ============================================================
   3. BLOCK STYLE VARIANTS
   ============================================================ */

/* Paragraph: Eyebrow — small uppercase gold lead-in */
.is-style-eyebrow {
  font-family: var(--sans) !important;
  font-size: 0.78rem !important;
  font-weight: 400 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  margin-bottom: 0.75rem !important;
  line-height: 1.4 !important;
}

/* Paragraph: Lead — italic decorative intro */
.is-style-lead {
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  font-size: clamp(1.15rem, 1.7vw, 1.4rem) !important;
  color: var(--ink-soft) !important;
  line-height: 1.55 !important;
}

/* Paragraph: Pull quote — gold italic, centred */
.is-style-pull-gold {
  font-family: var(--serif) !important;
  font-style: italic !important;
  font-weight: 300 !important;
  text-align: center !important;
  color: var(--gold) !important;
  font-size: clamp(1.5rem, 2.6vw, 1.95rem) !important;
  line-height: 1.4 !important;
  max-width: 32ch;
  margin: 1em auto !important;
  padding: 0;
  border: none;
  background: transparent;
}

/* Heading: Display (extra-large hero) */
.is-style-display {
  font-family: var(--serif) !important;
  font-weight: 300 !important;
  font-size: clamp(2.5rem, 5.5vw, 4.75rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.015em !important;
}
.is-style-display em {
  font-style: italic;
  font-weight: 300;
}

/* Group: Section variants — full-bleed sections with backgrounds */
.wp-block-group.is-style-section-paper,
.wp-block-group.is-style-section-paper-deep,
.wp-block-group.is-style-section-ink,
.wp-block-group.is-style-section-cta {
  width: 100vw;
  max-width: none;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  padding-block: clamp(4rem, 8vw, 6rem);
  padding-inline: var(--gutter);
}
.wp-block-group.is-style-section-paper        { background: var(--paper); }
.wp-block-group.is-style-section-paper-deep   { background: var(--paper-deep); }
.wp-block-group.is-style-section-ink {
  background: var(--ink);
  color: rgba(247, 241, 230, 0.9);
}
.wp-block-group.is-style-section-ink p { color: rgba(247, 241, 230, 0.85); }
.wp-block-group.is-style-section-ink h1,
.wp-block-group.is-style-section-ink h2,
.wp-block-group.is-style-section-ink h3 { color: var(--paper); }
.wp-block-group.is-style-section-ink .is-style-eyebrow { color: var(--gold-soft) !important; }
.wp-block-group.is-style-section-ink a { color: var(--gold-soft); }
.wp-block-group.is-style-section-ink .wp-block-button__link {
  border-color: var(--paper);
  color: var(--paper);
}
.wp-block-group.is-style-section-ink .wp-block-button__link:hover {
  background: var(--paper);
  color: var(--ink);
}

.wp-block-group.is-style-section-cta {
  background: var(--paper-deep);
  text-align: center;
}

/* Constrain inner content of full-bleed sections */
.wp-block-group.is-style-section-paper > .wp-block-group,
.wp-block-group.is-style-section-paper-deep > .wp-block-group,
.wp-block-group.is-style-section-ink > .wp-block-group,
.wp-block-group.is-style-section-cta > .wp-block-group,
.wp-block-group.is-style-section-paper > .wp-block-columns,
.wp-block-group.is-style-section-paper-deep > .wp-block-columns,
.wp-block-group.is-style-section-ink > .wp-block-columns,
.wp-block-group.is-style-section-cta > .wp-block-columns,
.wp-block-group.is-style-section-paper > p,
.wp-block-group.is-style-section-paper-deep > p,
.wp-block-group.is-style-section-paper > h1,
.wp-block-group.is-style-section-paper > h2,
.wp-block-group.is-style-section-paper > h3,
.wp-block-group.is-style-section-paper-deep > h2,
.wp-block-group.is-style-section-paper-deep > h3,
.wp-block-group.is-style-section-cta > h2,
.wp-block-group.is-style-section-cta > p,
.wp-block-group.is-style-section-cta > .wp-block-buttons {
  max-width: var(--max-w-wide);
  margin-left: auto;
  margin-right: auto;
}

/* Tighter inner constrained block for prose */
.wp-block-group.is-style-section-paper > .wp-block-group:has(.wp-block-paragraph),
.wp-block-group.is-style-section-paper-deep > .wp-block-group:has(.wp-block-paragraph) {
  max-width: var(--max-w-content);
}


/* ============================================================
   5. FOOTER
   ============================================================ */
.footer {
  background: var(--ink);
  color: var(--paper);
  padding: 3.5rem var(--gutter) 1.5rem;
}
.footer__inner {
  max-width: var(--max-w-wide);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 3rem;
  align-items: start;
}
@media (max-width: 900px) { .footer__inner { grid-template-columns: 1fr 1fr; gap: 2.5rem; } }
@media (max-width: 540px) { .footer__inner { grid-template-columns: 1fr; gap: 2rem; } }

.footer__brand {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 1.6rem;
  color: var(--paper);
  line-height: 1.2;
  margin: 0 0 0.75rem;
}
.footer__tagline {
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-soft);
  margin: 0 0 1.5rem;
  line-height: 1.4;
}
.footer__addr {
  font-style: normal;
  font-size: 0.875rem;
  color: rgba(247, 241, 230, 0.7);
  line-height: 1.7;
}
.footer__addr a {
  color: rgba(247, 241, 230, 0.85);
  border: none;
  display: inline-block;
  transition: color 0.2s;
}
.footer__addr a:hover { color: var(--paper); border-bottom: none; }

.footer__col h4 {
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-soft);
  margin: 0 0 1rem;
  line-height: 1.4;
}
.footer__col h4.footer__col-second { margin-top: 1.75rem; }
.footer__col ul { list-style: none; padding: 0; margin: 0; }
.footer__col li { margin: 0; padding: 0; }
.footer__col li + li { margin-top: 0.55rem; }
.footer__col a {
  font-size: 0.875rem;
  color: rgba(247, 241, 230, 0.78);
  border: none;
  line-height: 1.5;
  transition: color 0.2s;
}
.footer__col a:hover { color: var(--paper); border: none; }

.footer__bottom {
  max-width: var(--max-w-wide);
  margin: 2.5rem auto 0;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(247, 241, 230, 0.15);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.footer__legal {
  font-size: 0.78rem;
  color: rgba(247, 241, 230, 0.5);
  line-height: 1.6;
  margin: 0;
}
.footer__seal {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
}
.footer__seal a { display: inline-block; line-height: 0; }
.footer__seal img { max-height: 44px; width: auto; opacity: 0.85; transition: opacity 0.2s; }
.footer__seal a:hover img { opacity: 1; }

@media (max-width: 540px) {
  .footer__bottom { flex-direction: column-reverse; align-items: flex-start; gap: 1.25rem; }
}

/* ============================================================
   6. HOMEPAGE HERO (only coded section)
   ============================================================ */
.home-hero {
  position: relative;
  min-height: clamp(560px, 80vh, 820px);
  display: flex;
  align-items: flex-end;
  padding: 0 var(--gutter) clamp(3rem, 8vh, 6rem);
  overflow: hidden;
}
.home-hero__bg { position: absolute; inset: 0; z-index: 0; }
.home-hero__bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.65;
}
.home-hero__bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg,
    rgba(247, 241, 230, 0.20) 0%,
    rgba(247, 241, 230, 0.45) 45%,
    rgba(247, 241, 230, 0.78) 100%);
}
.home-hero__inner {
  position: relative;
  z-index: 1;
  max-width: var(--max-w-wide);
  margin: 0 auto;
  width: 100%;
}
.home-hero__eyebrow {
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.25rem;
}
.home-hero__title,
.home-hero h1 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(2.5rem, 5.5vw, 4.75rem);
  line-height: 1.05;
  letter-spacing: -0.015em;
  color: var(--ink);
  max-width: 22ch;
  margin: 0 0 1.5rem;
}
.home-hero__title em,
.home-hero h1 em {
  font-style: italic;
  font-weight: 300;
  color: var(--ink);
}
.home-hero__sub {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.2rem, 2vw, 1.45rem);
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 38ch;
  margin-bottom: 2.5rem;
}
.home-hero__ctas {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  align-items: center;
}
.home-hero__ctas .btn-primary {
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 1rem 1.8rem;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
  text-decoration: none;
  display: inline-block;
  transition: background 0.25s ease, color 0.25s ease;
}
.home-hero__ctas .btn-primary:hover {
  background: var(--ink);
  color: var(--paper);
}
.home-hero__ctas .btn-secondary {
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink);
  padding: 1rem 0;
  border: none;
  border-bottom: 1px solid var(--ink);
  text-decoration: none;
  transition: color 0.25s ease, border-color 0.25s ease;
}
.home-hero__ctas .btn-secondary:hover {
  color: var(--gold);
  border-bottom-color: var(--gold);
}

/* ============================================================
   7. FAQ ACCORDION (native <details>)
   ============================================================ */
.faq-item {
  border-bottom: 1px solid var(--line);
  padding: 1.25rem 0;
}
.faq-item summary {
  font-family: var(--serif);
  font-size: clamp(1.05rem, 1.6vw, 1.2rem);
  font-weight: 400;
  color: var(--ink);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  list-style: none;
  padding-right: 1rem;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+';
  font-size: 1.6rem;
  font-weight: 300;
  color: var(--gold);
  transition: transform 0.2s;
  margin-left: 1rem;
  flex-shrink: 0;
}
.faq-item[open] summary::after { content: '−'; }
.faq-item-answer {
  padding: 1rem 0 0.5rem;
  color: var(--ink-soft);
  line-height: 1.7;
}
.faq-item-answer p:last-child { margin-bottom: 0; }

/* ============================================================
   8. ACCREDITATION BADGES (homepage section)
   ============================================================ */
.accred-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 2.5rem;
  max-width: var(--max-w-wide);
  margin: 0 auto;
}
.accred-row a {
  border: none;
  display: block;
  opacity: 0.85;
  transition: opacity 0.2s;
}
.accred-row a:hover { opacity: 1; }
.accred-row img { max-height: 70px; width: auto; }

/* ============================================================
   9. SHARED COMPONENTS
   ============================================================ */
.eyebrow-label {
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  display: block;
  margin-bottom: 0.75rem;
}

/* Card grid (specialism cards, library entries, etc) */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
  max-width: var(--max-w-wide);
  margin: 0 auto;
}

/* Geographic neighbourhoods chip list (contact page) */
.geo-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  list-style: none;
  padding: 0;
  margin: 1.5rem 0;
}
.geo-chips li {
  font-size: 0.85rem;
  color: var(--ink-soft);
  background: var(--paper);
  border: 1px solid var(--line);
  padding: 0.4rem 0.85rem;
  border-radius: 0;
}

/* Crisis block (self-assessments page) */
.crisis-block {
  background: rgba(176, 131, 68, 0.08);
  border-left: 3px solid var(--gold);
  padding: 1.5rem 1.75rem;
  margin: 2rem auto;
  max-width: var(--max-w-content);
}
.crisis-block p { margin: 0; font-size: 0.95rem; color: var(--ink-soft); }

/* Form (contact page) */
.contact-form {
  display: grid;
  gap: 1.25rem;
  max-width: 640px;
  margin: 2rem auto 0;
}
.contact-form label {
  display: block;
  font-family: var(--sans);
  font-size: 0.78rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 0.4rem;
}
.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  font-family: var(--sans);
  font-size: 1rem;
  padding: 0.85rem 1rem;
  background: var(--paper);
  border: 1px solid var(--line);
  color: var(--ink);
  border-radius: 0;
}
.contact-form textarea { min-height: 140px; resize: vertical; }
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: 2px solid var(--gold);
  outline-offset: 1px;
}

/* ============================================================
   10. UTILITIES
   ============================================================ */
.text-center { text-align: center; }
.text-gold   { color: var(--gold); }
.divider-hairline {
  border: none;
  border-top: 1px solid var(--line);
  max-width: var(--max-w-content);
  margin: 3rem auto;
}

/* Skip link for accessibility */
.screen-reader-text {
  position: absolute;
  left: -10000px;
  width: 1px; height: 1px;
  overflow: hidden;
}


/* ============================================================
   LOCKED CSS — verbatim from page HTMLs (preserves design fidelity
   for sections that retained wp:html, plus shared component classes)
   ============================================================ */

/**
 * Long Light — locked CSS extracted from all 13 page HTMLs
 */

:root {
  --paper: #f7f1e6;
    --paper-deep: #efe5d2;
    --ink: #1c1815;
    --ink-soft: #4a3f36;
    --ink-faint: #8a7d6f;
    --gold: #b08344;
    --gold-soft: #d9b87c;
    --line: rgba(28,24,21,0.12);
    --serif: 'Cormorant Garamond', 'Lyon', Georgia, serif;
    --sans: 'Inter', -apple-system, system-ui, sans-serif;
    --max: 1240px;
    --gutter: clamp(1.5rem, 4vw, 3rem);
}

* {
  margin: 0; padding: 0; box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  background: var(--paper); color: var(--ink);
    font-family: var(--sans); font-weight: 300;
    font-size: 17px; line-height: 1.7;
    -webkit-font-smoothing: antialiased; overflow-x: hidden;
}

img {
  display: block; max-width: 100%; height: auto;
}

a {
  color: inherit; text-decoration: none;
}

.display {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.5rem, 5.5vw, 4.75rem);
    line-height: 1.05; letter-spacing: -0.015em; color: var(--ink);
}

.display em {
  font-style: italic; font-weight: 300; color: var(--ink);
}

.h2 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(1.9rem, 3.6vw, 3rem);
    line-height: 1.15; letter-spacing: -0.01em;
}

.h3 {
  font-family: var(--serif); font-weight: 400;
    font-size: clamp(1.4rem, 2.2vw, 1.85rem); line-height: 1.25;
}

.eyebrow {
  font-family: var(--sans); font-size: 0.78rem; font-weight: 400;
    letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold);
}

.lead {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.2rem, 1.9vw, 1.45rem);
    line-height: 1.5; color: var(--ink-soft);
}

p {
  color: var(--ink-soft);
}

p + p {
  margin-top: 1.1em;
}

.container {
  max-width: var(--max); margin: 0 auto; padding: 0 var(--gutter);
}

.narrow {
  max-width: 720px; margin: 0 auto;
}

.section {
  padding: clamp(4rem, 7vw, 6rem) 0;
}

.btn {
  font-family: var(--sans); font-size: 0.82rem; font-weight: 400;
    letter-spacing: 0.16em; text-transform: uppercase;
    padding: 1rem 1.8rem; border: 1px solid var(--ink); color: var(--ink);
    transition: all 0.25s; background: transparent; cursor: pointer;
    display: inline-block;
}

.btn:hover {
  background: var(--ink); color: var(--paper);
}

.btn--ghost {
  border: none; padding: 1rem 0; border-bottom: 1px solid var(--ink); letter-spacing: 0.1em;
}

.btn--ghost:hover {
  background: transparent; color: var(--gold); border-color: var(--gold);
}

.hero-actions {
  display: flex; gap: 2rem; align-items: center; flex-wrap: wrap;
}


.hero {
  position: relative; min-height: 92vh;
    display: flex; align-items: center; overflow: hidden;
    padding: 6rem 0 5rem;
    background: linear-gradient(180deg, #d4cfc0 0%, #e8e0cc 100%);
}

.hero__bg {
  position: absolute; inset: 0; z-index: 0;
}

.hero__bg img {
  width: 100%; height: 100%; object-fit: cover; opacity: 0.55;
}

.hero__bg::after {
  content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(247,241,230,0.3) 0%, rgba(247,241,230,0.6) 40%, rgba(247,241,230,0.95) 100%);
}

.hero__inner {
  position: relative; z-index: 1; width: 100%;
}

.hero h1 {
  max-width: 18ch; margin: 1.5rem 0 2rem;
}

.hero__sub {
  max-width: 38ch; margin-bottom: 3rem;
}

.creds-line {
  background: var(--paper);
    text-align: center;
    padding: 2.5rem var(--gutter);
    border-bottom: 1px solid var(--line);
    font-family: var(--sans); font-size: 0.85rem;
    letter-spacing: 0.08em; color: var(--ink-faint);
}

.testimonials {
  background: var(--paper-deep); padding: clamp(5rem, 9vw, 8rem) 0;
}

.testimonials__grid {
  grid-template-columns: 1fr; gap: 3.5rem;
}

.testimonial blockquote {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: 1.4rem; line-height: 1.45; color: var(--ink); margin-bottom: 1.5rem;
}

.testimonial blockquote::before {
  content: "\201C"; font-size: 3rem; line-height: 0; vertical-align: -0.4em;
    color: var(--gold); margin-right: 0.1em;
}

.testimonial__attr {
  font-family: var(--sans); font-size: 0.8rem;
    letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-faint);
}

.testimonial__attr strong {
  font-weight: 500; color: var(--ink); margin-right: 0.6rem;
}

.testimonials__note {
  text-align: center; margin-top: 4rem;
    font-size: 0.82rem; color: var(--ink-faint); font-style: italic;
}

.about {
  padding: clamp(5rem, 10vw, 9rem) 0;
    background: var(--paper);
}

.about__layout {
  grid-template-columns: 1fr;
}

.about__image {
  max-width: 480px; margin: 0 auto;
}

.about__image img {
  width: 100%; height: 100%; object-fit: cover; object-position: center top;
}

.about__content .h2 {
  margin: 1.25rem 0 1.5rem;
}

.about__content p {
  font-size: 1.05rem;
}

.about__credentials {
  margin-top: 2.5rem; padding-top: 2rem;
    border-top: 1px solid var(--line);
    font-family: var(--sans); font-size: 0.78rem; font-weight: 400;
    letter-spacing: 0.08em; color: var(--ink-faint); line-height: 1.9;
}

.recognise {
  background: var(--ink); color: var(--paper);
}

.recognise .eyebrow {
  color: var(--gold-soft);
}

.recognise .h2 {
  color: var(--paper); margin-bottom: 2.5rem; margin-top: 1.25rem;
}

.recognise p {
  color: rgba(247,241,230,0.78);
    font-size: 1.1rem; line-height: 1.75;
}

.recognise__highlight {
  font-family: var(--serif); font-style: italic;
    font-size: clamp(1.5rem, 2.6vw, 2rem) !important;
    color: var(--gold-soft) !important;
    line-height: 1.4 !important;
    margin: 2.5rem 0 !important;
}

.work {
  background: var(--paper);
}

.work__layout {
  grid-template-columns: 1fr;
}

.work__image {
  position: relative; top: 0; max-width: 480px; margin: 0 auto;
}

.work__image img {
  width: 100%; height: 100%; object-fit: cover;
}

.work__rumi {
  font-family: var(--serif); font-style: italic;
    font-size: clamp(1.4rem, 2.4vw, 1.85rem); line-height: 1.5;
    color: var(--gold); margin: 2.5rem 0 2rem;
    padding-left: 1.5rem; border-left: 2px solid var(--gold);
}

.work__rumi cite {
  display: block; font-style: normal;
    font-family: var(--sans); font-size: 0.78rem; font-weight: 400;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--ink-faint); margin-top: 1rem;
}

.work__list {
  margin-top: 1.75rem; list-style: none;
}

.work__list li {
  padding: 0.9rem 0; border-bottom: 1px solid var(--line);
    color: var(--ink-soft); font-size: 1rem;
    display: flex; align-items: flex-start; gap: 1rem;
}

.work__list li::before {
  content: "\2014"; color: var(--gold); flex-shrink: 0;
}

.specialisms {
  background: var(--paper-deep);
}

.specialisms__head {
  text-align: center; margin-bottom: clamp(3rem, 5vw, 5rem);
}

.specialisms__head .h2 {
  margin-top: 1.25rem; max-width: 18ch;
    margin-left: auto; margin-right: auto;
}

.specialisms__grid {
  grid-template-columns: 1fr;
}

.specialism {
  background: var(--paper); padding: 2.5rem 2rem 2rem;
    transition: all 0.3s; cursor: pointer;
    display: flex; flex-direction: column;
}

.specialism:hover {
  transform: translateY(-4px);
}

.specialism__image {
  aspect-ratio: 16/11; margin: -2.5rem -2rem 2rem;
    overflow: hidden; background: var(--paper-deep);
}

.specialism__image img {
  width: 100%; height: 100%; object-fit: cover;
    transition: transform 0.6s ease;
}

.specialism:hover .specialism__image img {
  transform: scale(1.04);
}

.specialism .h3 {
  margin-bottom: 1rem;
}

.specialism p {
  font-size: 0.96rem; margin-bottom: 1.75rem; flex: 1;
}

.specialism__link {
  font-family: var(--sans); font-size: 0.78rem;
    letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--ink); border-bottom: 1px solid var(--ink);
    padding-bottom: 4px; align-self: flex-start; transition: all 0.25s;
}

.specialism:hover .specialism__link {
  color: var(--gold); border-color: var(--gold);
}

.pull {
  text-align: center; padding: clamp(5rem, 10vw, 9rem) 0; background: var(--paper);
}

.pull blockquote {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.7rem, 3.4vw, 2.6rem); line-height: 1.35;
    color: var(--ink); max-width: 22ch; margin: 0 auto;
}

.together {
  background: var(--paper-deep);
}

.together__inner {
  max-width: 760px; margin: 0 auto; text-align: center;
}

.together .h2 {
  margin: 1.25rem 0 2rem;
}

.together p {
  font-size: 1.1rem; margin-bottom: 1.25rem;
}

.together__cta {
  margin-top: 3rem; display: inline-block;
}

.faq {
  background: var(--paper);
}

.faq__inner {
  max-width: 760px; margin: 0 auto;
}

.faq__head {
  text-align: center; margin-bottom: 3.5rem;
}

.faq__head .h2 {
  margin-top: 1.25rem;
}

details.faq__item {
  border-bottom: 1px solid var(--line);
    padding: 1.5rem 0;
}

details.faq__item summary {
  font-family: var(--serif); font-size: 1.35rem; font-weight: 400;
    color: var(--ink); cursor: pointer; list-style: none;
    display: flex; justify-content: space-between; align-items: center; gap: 2rem;
}

details.faq__item summary::-webkit-details-marker {
  display: none;
}

details.faq__item summary::after {
  content: "+"; font-family: var(--serif);
    font-size: 1.8rem; font-weight: 300; color: var(--gold); transition: transform 0.3s;
}

details[open].faq__item summary::after {
  content: "\2212";
}

details.faq__item p {
  margin-top: 1.25rem; font-size: 1.02rem;
}

.accred {
  background: var(--paper-deep); padding: 4rem 0;
    border-top: 1px solid var(--line);
}

.accred__inner {
  text-align: center;
}

.accred__label {
  font-family: var(--sans); font-size: 0.72rem;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--ink-faint); margin-bottom: 2.5rem;
}

.accred__row {
  display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 2.5rem;
}

.accred__badge {
  font-family: var(--serif); font-size: 0.95rem;
    color: var(--ink-soft); letter-spacing: 0.04em;
    padding: 0.6rem 1.2rem; border: 1px solid var(--line); background: var(--paper);
}

.accred__badge strong {
  font-weight: 400; color: var(--ink);
}

footer {
  background: var(--ink); color: var(--paper);
    padding: clamp(4rem, 7vw, 6rem) 0 2rem;
}

.footer__top {
  grid-template-columns: 1fr;
}

.footer__brand {
  font-family: var(--serif); font-size: 1.6rem; margin-bottom: 1rem;
}

.footer__brand small {
  display: block; font-family: var(--sans);
    font-size: 0.7rem; letter-spacing: 0.18em;
    text-transform: uppercase; color: var(--gold-soft); margin-top: 4px;
}

.footer__addr {
  font-size: 0.9rem; color: rgba(247,241,230,0.65); margin-top: 1.5rem; line-height: 1.7;
}

.footer__col h5 {
  font-family: var(--sans); font-size: 0.72rem; font-weight: 500;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--gold-soft); margin-bottom: 1.25rem;
}

.footer__col ul {
  list-style: none;
}

.footer__col li {
  padding: 0.4rem 0;
}

.footer__col a {
  font-size: 0.9rem; color: rgba(247,241,230,0.78);
}

.footer__col a:hover {
  color: var(--gold-soft);
}

.footer__bottom {
  border-top: 1px solid rgba(247,241,230,0.15); padding-top: 2rem;
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
    font-size: 0.78rem; color: rgba(247,241,230,0.5);
}

section[id] {
  scroll-margin-top: 110px;
}

.about-hero {
  padding: clamp(4rem, 8vw, 7rem) 0 clamp(3rem, 6vw, 5rem);
    background: var(--paper);
}

.about-hero__grid {
  grid-template-columns: 1fr;
}

.about-hero__portrait {
  aspect-ratio: 3 / 4; overflow: hidden; background: var(--paper-deep);
}

.about-hero__portrait img {
  width: 100%; height: 100%; object-fit: cover;
}

.about-hero__content {
  display: flex; flex-direction: column; gap: 1.5rem;
}

.about-hero h1 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.2rem, 4.5vw, 3.6rem);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 0.5rem 0 0;
}

.about-hero h1 em {
  font-style: italic;
}

.about-hero__role {
  font-family: var(--serif); font-style: italic;
    font-size: clamp(1.1rem, 1.6vw, 1.3rem);
    color: var(--ink-soft); line-height: 1.5;
    margin-top: 0.5rem;
}

.about-section {
  padding: clamp(4rem, 8vw, 7rem) 0;
}

.about-section--paper-deep {
  background: var(--paper-deep);
}

.lede-prose {
  max-width: 680px; margin: 0 auto;
}

.lede-prose p {
  font-family: var(--serif); font-size: clamp(1.2rem, 1.8vw, 1.4rem);
    line-height: 1.55; color: var(--ink); font-weight: 300;
}

.lede-prose p + p {
  margin-top: 1.2em;
}

.narrow-prose {
  max-width: 640px; margin: 0 auto;
}

.narrow-prose p {
  font-size: 1.05rem; line-height: 1.75;
}

.narrow-prose h2 {
  margin-bottom: 1.5rem;
}

.narrow-prose h3 {
  margin-top: 2.5rem; margin-bottom: 1rem; color: var(--ink);
}

.narrow-prose .eyebrow {
  display: block; margin-bottom: 0.75rem;
}

.pull-quote-about {
  max-width: 800px; margin: 0 auto; text-align: center;
    padding: clamp(3rem, 6vw, 5rem) clamp(1rem, 4vw, 2rem);
}

.pull-quote-about p {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.5rem, 2.6vw, 2rem);
    line-height: 1.4; color: var(--ink);
}

.pull-quote-about cite {
  display: block; margin-top: 1.5rem;
    font-family: var(--sans); font-size: 0.78rem; font-style: normal;
    letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--gold);
}

.training-grid {
  grid-template-columns: 1fr;
}

.training-block h3 {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.15rem; margin-bottom: 0.5rem; color: var(--ink);
}

.training-block ul {
  list-style: none; padding: 0; margin: 0;
}

.training-block li {
  padding: 0.5rem 0; border-bottom: 1px solid var(--line);
    font-size: 0.95rem; color: var(--ink-soft); line-height: 1.5;
}

.training-block li:last-child {
  border-bottom: none;
}

.training-block li strong {
  display: block; color: var(--ink); font-weight: 500;
    font-size: 0.85rem; letter-spacing: 0.02em;
    margin-bottom: 0.15rem;
}

.bookshelves-band {
  width: 100%; height: clamp(280px, 45vw, 480px);
    overflow: hidden; background: var(--paper-deep);
}

.bookshelves-band img {
  width: 100%; height: 100%; object-fit: cover;
    object-position: center 40%;
}

.influences-list {
  columns: 1;
}

.cta-band {
  background: var(--ink); color: var(--paper);
    padding: clamp(4rem, 7vw, 6rem) 0;
    text-align: center;
}

.cta-band h2 {
  color: var(--paper);
    max-width: 26ch; margin: 1rem auto 2rem;
    font-style: italic;
}

.cta-band p {
  color: rgba(247,241,230,0.75); max-width: 500px;
    margin: 0 auto 2.5rem; font-size: 1.05rem;
}

.cta-band .btn {
  border-color: var(--paper); color: var(--paper);
}

.cta-band .btn:hover {
  background: var(--paper); color: var(--ink);
}

.cta-band .eyebrow {
  color: var(--gold-soft); margin-bottom: 1rem; display: block;
}

.therapy-hero {
  padding: clamp(4rem, 7vw, 6rem) 0 clamp(3rem, 5vw, 4rem);
    background: var(--paper);
    border-bottom: 1px solid var(--line);
}

.therapy-hero__grid {
  grid-template-columns: 1fr;
}

.therapy-hero__content {
  display: flex; flex-direction: column; gap: 1.25rem;
}

.therapy-hero h1 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.2rem, 4.5vw, 3.4rem);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 0.5rem 0 0;
}

.therapy-hero h1 em {
  font-style: italic;
}

.therapy-hero__lede {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.15rem, 1.7vw, 1.35rem);
    color: var(--ink-soft); line-height: 1.55; max-width: 36ch;
}

.therapy-hero__image {
  aspect-ratio: 4 / 3; overflow: hidden; background: var(--paper-deep);
}

.therapy-hero__image img {
  width: 100%; height: 100%; object-fit: cover;
}

.therapy-section {
  padding: clamp(4rem, 8vw, 7rem) 0;
}

.therapy-section--paper-deep {
  background: var(--paper-deep);
}

.therapy-section__header {
  text-align: center; max-width: 720px;
    margin: 0 auto clamp(2.5rem, 5vw, 4rem);
}

.therapy-section__header h2 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(1.9rem, 3.2vw, 2.6rem);
    line-height: 1.1; letter-spacing: -0.01em;
    margin-top: 0.75rem; margin-bottom: 0.75rem; color: var(--ink);
}

.therapy-section__header p {
  font-size: 1.05rem; color: var(--ink-soft); line-height: 1.65;
    max-width: 580px; margin: 0 auto;
}

.journey {
  max-width: 760px; margin: 0 auto;
    display: flex; flex-direction: column; gap: clamp(2rem, 4vw, 3rem);
}

.journey__step {
  grid-template-columns: 1fr; gap: 0.5rem;
}

.journey__step:last-child {
  border-bottom: none; padding-bottom: 0;
}

.journey__num {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    line-height: 1; color: var(--gold);
}

.journey__body h3 {
  font-family: var(--serif); font-weight: 400;
    font-size: clamp(1.3rem, 2vw, 1.6rem);
    line-height: 1.2; margin-bottom: 0.5rem; color: var(--ink);
}

.journey__body p {
  font-size: 1rem; line-height: 1.75; color: var(--ink-soft);
}

.journey__body p + p {
  margin-top: 0.75em;
}

.how-prose {
  max-width: 680px; margin: 0 auto;
}

.how-prose p {
  font-family: var(--serif); font-size: clamp(1.1rem, 1.6vw, 1.25rem);
    line-height: 1.6; color: var(--ink); font-weight: 300;
}

.how-prose p + p {
  margin-top: 1em;
}

.faq-list {
  max-width: 760px; margin: 0 auto;
}

.faq-item {
  border-bottom: 1px solid var(--line);
}

.faq-item[open] {
  background: rgba(176, 131, 68, 0.03);
}

.faq-item summary {
  padding: 1.5rem 3rem 1.5rem 0;
    cursor: pointer; list-style: none; position: relative;
    font-family: var(--serif); font-weight: 400;
    font-size: clamp(1.05rem, 1.4vw, 1.2rem);
    line-height: 1.4; color: var(--ink);
    transition: color 0.2s ease;
}

.faq-item summary:hover {
  color: var(--gold);
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary::after {
  content: "+"; position: absolute; right: 0; top: 50%;
    transform: translateY(-50%);
    font-family: var(--sans); font-weight: 300;
    font-size: 1.6rem; color: var(--gold);
    transition: transform 0.3s ease; line-height: 1;
}

.faq-item[open] summary::after {
  content: "-"; transform: translateY(-50%);
}

.faq-item__body {
  padding: 0 0 1.75rem 0;
    font-size: 1rem; line-height: 1.75;
    color: var(--ink-soft); max-width: 680px;
}

.faq-item__body p + p {
  margin-top: 1em;
}

.specialism-links {
  grid-template-columns: 1fr;
}

.specialism-card {
  background: var(--paper); padding: 2rem;
    border: 1px solid var(--line);
    transition: border-color 0.25s ease, transform 0.25s ease;
    text-decoration: none; color: var(--ink);
    display: flex; flex-direction: column; gap: 0.75rem;
}

.specialism-card:hover {
  border-color: var(--gold); transform: translateY(-2px);
}

.specialism-card .eyebrow {
  color: var(--gold);
}

.specialism-card h3 {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.3rem; margin: 0; color: var(--ink);
}

.specialism-card p {
  font-size: 0.95rem; line-height: 1.65;
    color: var(--ink-soft); margin: 0;
}

.specialism-card__more {
  margin-top: 0.5rem;
    font-family: var(--sans); font-size: 0.78rem;
    letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold);
}

.faq-hero {
  padding: clamp(4rem, 7vw, 6rem) 0 clamp(2rem, 4vw, 3rem);
    background: var(--paper);
    text-align: center;
    border-bottom: 1px solid var(--line);
}

.faq-hero h1 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.4rem, 5vw, 4rem);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 0.75rem 0 1.5rem;
}

.faq-hero__intro {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.1rem, 1.6vw, 1.3rem);
    color: var(--ink-soft); line-height: 1.55;
    max-width: 640px; margin: 0 auto;
}

.faq-section {
  padding: clamp(3rem, 6vw, 5rem) 0;
}

.faq-section--paper-deep {
  background: var(--paper-deep);
}

.faq-section__header {
  text-align: center;
    max-width: 720px; margin: 0 auto clamp(2rem, 4vw, 3rem);
}

.faq-section__header h2 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(1.8rem, 3vw, 2.4rem);
    margin-top: 0.5rem; margin-bottom: 0.5rem;
    color: var(--ink); letter-spacing: -0.01em;
}

.faq-item__body strong {
  color: var(--ink); font-weight: 500;
}

.faq-item__body ul {
  margin: 0.75em 0; padding-left: 1.25em;
}

.faq-item__body li {
  padding: 0.2em 0;
}

.faq-item__body a {
  color: var(--gold); border-bottom: 1px solid var(--gold-soft);
}

.faq-item__body a:hover {
  color: var(--ink); border-color: var(--ink);
}

.faq-fee-table {
  margin: 1em 0; padding: 1em 1.25em;
    background: var(--paper); border-left: 2px solid var(--gold);
}

.faq-fee-table strong {
  color: var(--ink); display: block; margin-bottom: 0.25em;
}

.library-hero {
  padding: clamp(4rem, 7vw, 6rem) 0 clamp(2rem, 4vw, 3rem);
    background: var(--paper);
    text-align: center;
    border-bottom: 1px solid var(--line);
}

.library-hero h1 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.4rem, 5vw, 4rem);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 0.75rem 0 1.5rem;
}

.library-hero__intro {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.15rem, 1.7vw, 1.35rem);
    color: var(--ink-soft); line-height: 1.55;
    max-width: 720px; margin: 0 auto;
}

.library-filters {
  background: var(--paper);
    border-bottom: 1px solid var(--line);
    padding: 1.25rem 0;
    position: sticky; top: 0; z-index: 10;
}

.library-filters__wrap {
  display: flex; gap: 0.5rem; flex-wrap: wrap;
    justify-content: center; align-items: center;
}

.library-filters__label {
  font-family: var(--sans); font-size: 0.78rem;
    letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--ink-faint); margin-right: 0.5rem;
}

.filter-pill {
  font-family: var(--sans); font-size: 0.85rem;
    padding: 0.4rem 1rem; border-radius: 100px;
    border: 1px solid var(--line); background: transparent;
    color: var(--ink-soft); cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
}

.filter-pill:hover {
  border-color: var(--gold); color: var(--ink);
}

.filter-pill--active {
  background: var(--ink); color: var(--paper);
    border-color: var(--ink);
}

.library-grid {
  padding: clamp(3rem, 6vw, 5rem) 0;
}

.article-grid {
  grid-template-columns: 1fr;
}

.article-card {
  background: var(--paper);
    border: 1px solid var(--line);
    text-decoration: none; color: inherit;
    display: flex; flex-direction: column;
    transition: border-color 0.25s ease, transform 0.25s ease;
}

.article-card:hover {
  border-color: var(--gold);
    transform: translateY(-2px);
}

.article-card__image {
  aspect-ratio: 3 / 2; overflow: hidden;
    background: var(--paper-deep);
    position: relative;
}

.article-card__image::after {
  content: ""; position: absolute; inset: 0;
    background: linear-gradient(135deg, var(--paper-deep) 0%, rgba(176,131,68,0.15) 100%);
}

.article-card__type {
  position: absolute; top: 1rem; left: 1rem;
    background: var(--paper); color: var(--gold);
    font-family: var(--sans); font-size: 0.7rem;
    font-weight: 500; letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: 0.3rem 0.7rem;
    z-index: 1;
}

.article-card__body {
  padding: 1.5rem; display: flex; flex-direction: column;
    gap: 0.75rem; flex: 1;
}

.article-card__topic {
  font-family: var(--sans); font-size: 0.72rem;
    font-weight: 500; letter-spacing: 0.18em;
    text-transform: uppercase; color: var(--ink-faint);
}

.article-card__title {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.2rem; line-height: 1.3;
    color: var(--ink); margin: 0;
}

.article-card__excerpt {
  font-size: 0.95rem; line-height: 1.6;
    color: var(--ink-soft); margin: 0; flex: 1;
}

.article-card__meta {
  display: flex; justify-content: space-between;
    align-items: center; padding-top: 0.5rem;
    border-top: 1px solid var(--line);
    font-family: var(--sans); font-size: 0.78rem;
    color: var(--ink-faint);
}

.library-load-more {
  text-align: center; margin-top: clamp(2rem, 5vw, 3rem);
}

.self-assessments-callout {
  padding: clamp(4rem, 8vw, 6rem) 0;
    background: var(--paper-deep);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}

.self-assessments-callout__inner {
  grid-template-columns: 1fr;
}

.self-assessments-callout h2 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(1.6rem, 2.6vw, 2.2rem);
    line-height: 1.15; margin: 0.5rem 0 1rem;
}

.self-assessments-callout p {
  font-size: 1rem; line-height: 1.7;
    color: var(--ink-soft); margin: 0 0 1.5rem;
}

.specialism-hero {
  padding: clamp(4rem, 7vw, 6rem) 0 clamp(3rem, 5vw, 4rem);
    background: var(--paper);
    border-bottom: 1px solid var(--line);
}

.specialism-hero__grid {
  grid-template-columns: 1fr;
}

.specialism-hero__content {
  display: flex; flex-direction: column; gap: 1.25rem;
}

.specialism-hero__breadcrumb {
  font-family: var(--sans); font-size: 0.78rem;
    letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--ink-faint);
}

.specialism-hero__breadcrumb a {
  color: var(--ink-faint);
    border-bottom: 1px solid transparent;
    transition: color 0.2s, border-color 0.2s;
}

.specialism-hero__breadcrumb a:hover {
  color: var(--gold); border-bottom-color: var(--gold);
}

.specialism-hero h1 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.2rem, 4.5vw, 3.4rem);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 0.25rem 0 0;
}

.specialism-hero h1 em {
  font-style: italic;
}

.specialism-hero__lede {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.15rem, 1.7vw, 1.35rem);
    color: var(--ink-soft); line-height: 1.55; max-width: 38ch;
}

.specialism-hero__image {
  aspect-ratio: 4 / 3; overflow: hidden; background: var(--paper-deep);
}

.specialism-hero__image img {
  width: 100%; height: 100%; object-fit: cover;
}

.specialism-section {
  padding: clamp(4rem, 8vw, 7rem) 0;
}

.specialism-section--paper-deep {
  background: var(--paper-deep);
}

.specialism-section__header {
  text-align: center; max-width: 720px;
    margin: 0 auto clamp(2.5rem, 5vw, 4rem);
}

.specialism-section__header h2 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(1.9rem, 3.2vw, 2.6rem);
    line-height: 1.1; letter-spacing: -0.01em;
    margin-top: 0.75rem; margin-bottom: 0.75rem; color: var(--ink);
}

.specialism-section__header p {
  font-size: 1.05rem; color: var(--ink-soft); line-height: 1.65;
    max-width: 580px; margin: 0 auto;
}

.prose-block {
  max-width: 680px; margin: 0 auto;
}

.prose-block p {
  font-size: 1.05rem;
}

.prose-block p + p {
  margin-top: 1em;
}

.prose-block .pull {
  text-align: center;
    font-family: var(--serif); font-style: italic; font-weight: 300;
    color: var(--gold);
    font-size: clamp(1.5rem, 2.6vw, 1.95rem);
    line-height: 1.4;
    margin: 2em auto 2em;
    max-width: 32ch;
    padding: 0;
    border: none;
    background: transparent;
}

.symptom-list {
  max-width: 680px; margin: 0 auto;
    display: grid; gap: 1rem;
}

.symptom-list li {
  list-style: none; padding: 1rem 0 1rem 2rem;
    position: relative;
    font-size: 1rem; color: var(--ink-soft);
    border-bottom: 1px solid var(--line);
}

.symptom-list li:last-child {
  border-bottom: none;
}

.symptom-list li::before {
  content: ""; position: absolute;
    left: 0; top: 1.5rem;
    width: 1.25rem; height: 1px;
    background: var(--gold);
}

.related-grid {
  grid-template-columns: 1fr;
}

.related-card {
  background: var(--paper);
    border: 1px solid var(--line);
    padding: 1.75rem; text-decoration: none; color: inherit;
    display: flex; flex-direction: column; gap: 0.5rem;
    transition: border-color 0.25s ease, transform 0.25s ease;
}

.related-card:hover {
  border-color: var(--gold); transform: translateY(-2px);
}

.related-card__type {
  font-family: var(--sans); font-size: 0.72rem;
    font-weight: 500; letter-spacing: 0.18em;
    text-transform: uppercase; color: var(--gold);
}

.related-card h3 {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.1rem; margin: 0; color: var(--ink); line-height: 1.3;
}

.related-card p {
  font-size: 0.9rem; line-height: 1.6;
    color: var(--ink-soft); margin: 0;
}


.topic-blocks {
  max-width: 760px; margin: 0 auto; display: grid; gap: clamp(1.5rem, 3vw, 2rem);
}

.topic-block {
  padding-bottom: clamp(1.5rem, 3vw, 2rem);
    border-bottom: 1px solid var(--line);
}

.topic-block:last-child {
  border-bottom: none; padding-bottom: 0;
}

.topic-block h3 {
  font-family: var(--serif); font-weight: 400;
    font-size: clamp(1.2rem, 1.8vw, 1.4rem);
    line-height: 1.2; margin-bottom: 0.5rem; color: var(--ink);
}

.topic-block p {
  font-size: 1rem; line-height: 1.65; color: var(--ink-soft);
}

.topic-block p + p {
  margin-top: 0.75em;
}

.space-for-list {
  max-width: 680px; margin: 0 auto;
    display: grid; gap: 0;
}

.space-for-list li {
  list-style: none; padding: 1rem 0 1rem 2rem;
    position: relative;
    font-size: 1rem; color: var(--ink-soft);
    border-bottom: 1px solid var(--line);
}

.space-for-list li:last-child {
  border-bottom: none;
}

.space-for-list li::before {
  content: ""; position: absolute;
    left: 0; top: 1.5rem;
    width: 1.25rem; height: 1px;
    background: var(--gold);
}

.topic-block h3 a {
  color: var(--ink); text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s, color 0.2s;
}

.topic-block h3 a:hover {
  color: var(--gold); border-bottom-color: var(--gold);
}

.credentials-line {
  text-align: center; font-family: var(--sans);
    font-size: 0.78rem; letter-spacing: 0.16em;
    text-transform: uppercase; color: var(--ink-faint);
    margin: 2rem 0 0;
}

.btn--gold {
  border-color: var(--gold); color: var(--gold);
}

.btn--gold:hover {
  background: var(--gold); color: var(--paper); border-color: var(--gold);
}


.contact-hero {
  padding: clamp(4rem, 7vw, 6rem) 0 clamp(2rem, 4vw, 3rem);
    background: var(--paper);
    text-align: center;
    border-bottom: 1px solid var(--line);
}

.contact-hero h1 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.4rem, 5vw, 4rem);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 0.75rem 0 1.5rem;
}

.contact-hero__lede {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.15rem, 1.7vw, 1.35rem);
    color: var(--ink-soft); line-height: 1.55;
    max-width: 640px; margin: 0 auto;
}

.contact-intro {
  padding: clamp(3rem, 6vw, 5rem) 0;
    background: var(--paper);
}

.contact-intro__inner {
  max-width: 680px; margin: 0 auto;
}

.contact-intro p {
  font-size: 1.05rem;
}

.what-next {
  padding: clamp(3rem, 6vw, 5rem) 0;
    background: var(--paper-deep);
}

.what-next__inner {
  max-width: 880px; margin: 0 auto; text-align: center;
}

.what-next h2 {
  margin: 1rem 0 2.5rem;
}

.what-next__steps {
  grid-template-columns: 1fr; gap: 0;
}

.what-next__step {
  padding: 1.5rem 0;
}

.what-next__num {
  font-family: var(--serif); font-weight: 300;
    font-size: 2rem; color: var(--gold);
    margin-bottom: 0.4rem; line-height: 1;
}

.what-next__step h3 {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.25rem; color: var(--ink); margin-bottom: 0.6rem;
    line-height: 1.3;
}

.what-next__step p {
  font-size: 0.96rem;
}

.contact-availability {
  padding: clamp(3rem, 6vw, 5rem) 0;
    background: var(--paper);
}

.availability-block {
  max-width: 560px; margin: 0 auto 3.5rem;
    text-align: center;
    padding: 2rem 2.5rem;
    border: 1px solid var(--line);
    background: var(--paper-deep);
}

.availability-block__updated {
  font-family: var(--sans); font-size: 0.72rem;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--ink-faint); margin-bottom: 1rem;
}

.availability-block h2 {
  font-size: clamp(1.5rem, 2.4vw, 1.85rem);
    margin-bottom: 1.25rem;
}

.availability-block p {
  font-size: 1rem; margin: 0.4rem 0; color: var(--ink-soft);
}

.availability-block strong {
  font-weight: 400; color: var(--ink);
}

.signals {
  grid-template-columns: 1fr;
}

.signal {
  border-right: none; border-bottom: 1px solid var(--line);
}

.signal:last-child {
  border-bottom: none;
}

.signal:hover {
  background: var(--paper-deep);
}

.signal__label {
  font-family: var(--sans); font-size: 0.72rem;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--gold); margin-bottom: 0.85rem;
}

.signal__value {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.15rem; color: var(--ink);
    line-height: 1.4;
    display: block;
}

.signal a.signal__value {
  transition: color 0.2s;
}

.signal a.signal__value:hover {
  color: var(--gold);
}

.signal__small {
  font-family: var(--sans); font-size: 0.85rem;
    color: var(--ink-soft); margin-top: 0.3rem;
    display: block;
}

.signal:nth-child(2) {
  border-right: none;
}

.signal:nth-child(1), .signal:nth-child(2) {
  border-bottom: 1px solid var(--line);
}

.geographic {
  padding: clamp(3rem, 6vw, 5rem) 0;
    background: var(--paper);
}

.geographic__inner {
  max-width: 720px; margin: 0 auto; text-align: center;
}

.geographic h2 {
  margin: 1rem 0 1.75rem;
}

.geographic p {
  font-size: 1.05rem;
}

.geographic p + p {
  margin-top: 1.25rem;
}

.form-section {
  padding: clamp(4rem, 8vw, 7rem) 0;
    background: var(--paper-deep);
}

.form-section__inner {
  max-width: 680px; margin: 0 auto;
}

.form-section h2 {
  text-align: center; margin: 1rem 0 1rem;
}

.form-section__lede {
  text-align: center; max-width: 540px; margin: 0 auto 3rem;
    font-size: 1.05rem;
}

.enquiry-form {
  display: grid; gap: 1.5rem;
    background: var(--paper);
    padding: clamp(2rem, 5vw, 3rem);
    border: 1px solid var(--line);
}

.form-row {
  grid-template-columns: 1fr;
}

.form-field {
  display: flex; flex-direction: column;
}

.form-field label {
  font-family: var(--sans); font-size: 0.78rem;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--ink-faint); margin-bottom: 0.5rem; font-weight: 400;
}

.form-field label .optional {
  text-transform: none; letter-spacing: 0; font-style: italic;
    color: var(--ink-faint); margin-left: 0.4rem;
}

.form-field input,
  .form-field textarea,
  .form-field select {
  font-family: var(--sans); font-size: 1rem;
    padding: 0.85rem 1rem;
    border: 1px solid var(--line);
    background: var(--paper);
    color: var(--ink);
    border-radius: 0;
    transition: border-color 0.2s;
    font-weight: 300;
}

.form-field input:focus,
  .form-field textarea:focus,
  .form-field select:focus {
  outline: none; border-color: var(--gold);
}

.form-field textarea {
  resize: vertical; min-height: 140px; line-height: 1.6;
}

.form-confidentiality {
  font-size: 0.88rem; color: var(--ink-soft);
    text-align: center; margin-top: 0.5rem;
    font-style: italic;
}

.form-captcha {
  display: flex; align-items: center; gap: 1rem;
    padding: 1rem 1.25rem;
    background: var(--paper-deep);
    border: 1px solid var(--line);
}

.form-captcha label {
  font-family: var(--sans); font-size: 0.88rem;
    color: var(--ink-soft); margin: 0;
    text-transform: none; letter-spacing: 0;
}

.form-captcha input {
  width: 80px; padding: 0.5rem 0.75rem;
    border: 1px solid var(--line); background: var(--paper);
}

.form-submit {
  font-family: var(--sans); font-size: 0.82rem; font-weight: 400;
    letter-spacing: 0.16em; text-transform: uppercase;
    padding: 1rem 2rem; border: 1px solid var(--ink);
    background: var(--ink); color: var(--paper);
    cursor: pointer; transition: all 0.25s;
    align-self: center;
}

.form-submit:hover {
  background: transparent; color: var(--ink);
}

.mini-faq {
  padding: clamp(4rem, 7vw, 6rem) 0;
    background: var(--paper);
}

.mini-faq__inner {
  max-width: 760px; margin: 0 auto;
}

.mini-faq h2 {
  text-align: center; margin: 1rem 0 2.5rem;
}

.other-services {
  padding: clamp(4rem, 7vw, 6rem) 0;
    background: var(--paper-deep);
}

.other-services__inner {
  max-width: 760px; margin: 0 auto; text-align: center;
}

.other-services h2 {
  margin: 1rem 0 1.75rem;
}

.other-services p {
  font-size: 1.05rem;
}

.footer__addr a {
  color: rgba(247,241,230,0.78); transition: color 0.2s;
}

.footer__addr a:hover {
  color: var(--gold-soft);
}

.book-hero {
  padding: clamp(4rem, 7vw, 6rem) 0 clamp(2rem, 4vw, 3rem);
    background: var(--paper);
    text-align: center;
    border-bottom: 1px solid var(--line);
}

.book-hero h1 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.4rem, 5vw, 4rem);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 0.75rem 0 1.5rem;
}

.book-hero__lede {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.15rem, 1.7vw, 1.35rem);
    color: var(--ink-soft); line-height: 1.55;
    max-width: 580px; margin: 0 auto;
}

.expect {
  padding: clamp(3rem, 5vw, 4rem) 0;
    background: var(--paper);
}

.expect__grid {
  grid-template-columns: 1fr; gap: 0;
}

.expect__item {
  text-align: left;
    padding: 1.5rem 0;
    border-top: 1px solid var(--line);
}

.expect__num {
  font-family: var(--serif); font-weight: 300;
    font-size: 1.6rem; color: var(--gold);
    margin-bottom: 0.4rem; line-height: 1;
}

.expect__item h3 {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.2rem; color: var(--ink); margin-bottom: 0.5rem;
    line-height: 1.3;
}

.expect__item p {
  font-size: 0.95rem;
}

.calendar {
  padding: clamp(2rem, 5vw, 4rem) 0 clamp(4rem, 7vw, 6rem);
    background: var(--paper-deep);
}

.calendar__inner {
  max-width: 880px; margin: 0 auto;
}

.calendar__header {
  text-align: center; margin-bottom: 2.5rem;
}

.calendar__header h2 {
  margin: 1rem 0 1rem;
}

.calendar__header p {
  font-size: 1.02rem; max-width: 560px; margin: 0 auto;
}

.calendar__frame {
  background: var(--paper);
    border: 1px solid var(--line);
    padding: 0;
    overflow: hidden;
    min-height: 720px;
    position: relative;
}

.calendar__frame iframe {
  width: 100%;
    height: 720px;
    border: 0;
    display: block;
}

.calendar__fallback {
  text-align: center; margin-top: 1.5rem;
    font-size: 0.95rem; color: var(--ink-soft);
}

.calendar__fallback a {
  color: var(--gold); border-bottom: 1px solid var(--gold);
    transition: color 0.2s;
}

.calendar__fallback a:hover {
  color: var(--ink); border-color: var(--ink);
}

.next-steps {
  padding: clamp(3rem, 6vw, 5rem) 0;
    background: var(--paper);
}

.next-steps__inner {
  max-width: 680px; margin: 0 auto; text-align: center;
}

.next-steps h2 {
  margin: 1rem 0 1.5rem; font-size: clamp(1.5rem, 2.4vw, 1.85rem);
}

.next-steps p {
  font-size: 1.02rem;
}

.sa-hero {
  padding: clamp(4rem, 7vw, 6rem) 0 clamp(2rem, 4vw, 3rem);
    background: var(--paper);
    text-align: center;
    border-bottom: 1px solid var(--line);
}

.sa-hero h1 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.4rem, 5vw, 4rem);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 0.75rem 0 1.5rem;
}

.sa-hero__lede {
  font-family: var(--serif); font-style: italic; font-weight: 300;
    font-size: clamp(1.15rem, 1.7vw, 1.35rem);
    color: var(--ink-soft); line-height: 1.55;
    max-width: 640px; margin: 0 auto;
}

.sa-intro {
  padding: clamp(3rem, 6vw, 5rem) 0;
    background: var(--paper);
}

.sa-intro__inner {
  max-width: 680px; margin: 0 auto;
}

.sa-intro p {
  font-size: 1.05rem;
}

.sa-cards {
  padding: clamp(4rem, 7vw, 6rem) 0;
    background: var(--paper);
}

.sa-cards__header {
  text-align: center; max-width: 640px; margin: 0 auto 3.5rem;
}

.sa-cards__header h2 {
  margin: 1rem 0 1rem;
}

.sa-cards__grid {
  grid-template-columns: 1fr; max-width: 560px;
}

.sa-card {
  background: var(--paper-deep);
    border: 1px solid var(--line);
    padding: 2.25rem 2rem 2rem;
    display: flex; flex-direction: column;
    transition: all 0.25s;
}

.sa-card:hover {
  background: var(--paper);
    border-color: var(--gold);
}

.sa-card__type {
  font-family: var(--sans); font-size: 0.72rem;
    letter-spacing: 0.22em; text-transform: uppercase;
    color: var(--gold); margin-bottom: 1rem;
}

.sa-card h3 {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.55rem; line-height: 1.2;
    color: var(--ink); margin-bottom: 0.85rem;
}

.sa-card__instrument {
  font-family: var(--sans); font-size: 0.82rem;
    color: var(--ink-faint); margin-bottom: 1.25rem;
    font-style: italic;
}

.sa-card p {
  font-size: 0.96rem; flex: 1; margin-bottom: 1.5rem;
}

.sa-card__meta {
  display: flex; justify-content: space-between; align-items: center;
    font-family: var(--sans); font-size: 0.78rem;
    color: var(--ink-faint);
    padding-top: 1.25rem; border-top: 1px solid var(--line);
}

.sa-card__cta {
  color: var(--ink); border-bottom: 1px solid var(--ink);
    padding-bottom: 1px; transition: color 0.2s;
    font-weight: 400; letter-spacing: 0.04em;
}

.sa-card:hover .sa-card__cta {
  color: var(--gold); border-color: var(--gold);
}

.csi4 {
  padding: clamp(4rem, 7vw, 6rem) 0;
    background: var(--paper-deep);
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}

.csi4__inner {
  max-width: 720px; margin: 0 auto;
}

.csi4__header {
  text-align: center; margin-bottom: 3rem;
}

.csi4__header h2 {
  margin: 1rem 0 1rem;
}

.csi4__header p {
  font-size: 1.05rem; max-width: 560px; margin: 0 auto;
}

.csi4__instrument {
  font-family: var(--sans); font-size: 0.82rem;
    color: var(--ink-faint);
    font-style: italic; margin-top: 0.75rem;
    display: block;
}

.csi4-question {
  background: var(--paper);
    padding: 1.75rem 2rem;
    border: 1px solid var(--line);
    margin-bottom: 1rem;
}

.csi4-question__text {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.2rem; line-height: 1.4;
    color: var(--ink); margin-bottom: 1.25rem;
}

.csi4-options {
  display: flex; flex-wrap: wrap; gap: 0.5rem;
}

.csi4-option {
  flex: 1 1 auto; min-width: 0;
    cursor: pointer;
    position: relative;
}

.csi4-option input {
  position: absolute; opacity: 0; pointer-events: none;
}

.csi4-option__label {
  display: block; text-align: center;
    padding: 0.7rem 0.5rem;
    font-size: 0.85rem; line-height: 1.2;
    color: var(--ink-soft);
    background: var(--paper-deep);
    border: 1px solid var(--line);
    transition: all 0.2s;
}

.csi4-option:hover .csi4-option__label {
  border-color: var(--gold);
    color: var(--ink);
}

.csi4-option input:checked + .csi4-option__label {
  background: var(--ink); color: var(--paper);
    border-color: var(--ink);
}

.csi4-actions {
  text-align: center; margin-top: 2rem;
}

.csi4-submit {
  font-family: var(--sans); font-size: 0.82rem; font-weight: 400;
    letter-spacing: 0.16em; text-transform: uppercase;
    padding: 1rem 2.25rem; border: 1px solid var(--ink);
    background: var(--ink); color: var(--paper);
    cursor: pointer; transition: all 0.25s;
}

.csi4-submit:hover {
  background: transparent; color: var(--ink);
}

.csi4-submit:disabled {
  opacity: 0.4; cursor: not-allowed;
}

.csi4-reset {
  font-family: var(--sans); font-size: 0.78rem;
    color: var(--ink-faint); margin-left: 1rem;
    background: none; border: none; cursor: pointer;
    text-decoration: underline; padding: 0.5rem;
}

.csi4-reset:hover {
  color: var(--gold);
}

.csi4-result {
  background: var(--paper);
    border: 1px solid var(--gold);
    padding: 2.5rem 2rem;
    margin-top: 2rem;
    display: none;
    text-align: center;
}

.csi4-result.is-shown {
  display: block;
}

.csi4-result__score {
  font-family: var(--serif); font-weight: 300;
    font-size: 3.5rem; color: var(--gold);
    line-height: 1; margin-bottom: 0.5rem;
}

.csi4-result__score-label {
  font-family: var(--sans); font-size: 0.78rem;
    letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--ink-faint); margin-bottom: 1.5rem;
}

.csi4-result__interpretation {
  font-family: var(--serif); font-weight: 400;
    font-size: 1.4rem; color: var(--ink);
    line-height: 1.35; margin-bottom: 1.25rem;
    max-width: 32ch; margin-left: auto; margin-right: auto;
}

.csi4-result__body {
  font-size: 1rem; max-width: 480px; margin: 0 auto 1.5rem;
}

.csi4-result__cta {
  margin-top: 1.5rem;
}

.crisis-block {
  padding: clamp(3rem, 6vw, 5rem) 0;
    background: var(--paper-deep);
    border-top: 1px solid var(--line);
}

.crisis-block__inner {
  max-width: 720px; margin: 0 auto; text-align: center;
}

.crisis-block h2 {
  margin: 1rem 0 1.5rem; font-size: clamp(1.6rem, 2.6vw, 2rem);
}

.crisis-block p {
  font-size: 1.02rem;
}

.crisis-block__contacts {
  grid-template-columns: 1fr;
}

.crisis-block__contact {
  padding: 1.5rem 1rem;
    background: var(--paper);
    border: 1px solid var(--line);
}

.crisis-block__name {
  font-family: var(--serif); font-size: 1.05rem; font-weight: 400;
    color: var(--ink); margin-bottom: 0.4rem;
}

.crisis-block__detail {
  font-family: var(--sans); font-size: 0.92rem;
    color: var(--ink-soft);
}

.crisis-block__detail a {
  border-bottom: 1px solid var(--gold); transition: color 0.2s;
}

.crisis-block__detail a:hover {
  color: var(--gold);
}

.privacy-hero {
  padding: clamp(4rem, 7vw, 6rem) 0 clamp(2rem, 4vw, 3rem);
    background: var(--paper);
    text-align: center;
    border-bottom: 1px solid var(--line);
}

.privacy-hero h1 {
  font-family: var(--serif); font-weight: 300;
    font-size: clamp(2.4rem, 5vw, 4rem);
    line-height: 1.05; letter-spacing: -0.015em;
    margin: 0.75rem 0 1rem;
}

.privacy-hero__updated {
  font-family: var(--sans); font-size: 0.85rem;
    color: var(--ink-faint);
    letter-spacing: 0.04em;
}

.policy {
  padding: clamp(3rem, 6vw, 5rem) 0 clamp(4rem, 7vw, 6rem);
    background: var(--paper);
}

.policy__inner {
  max-width: 760px; margin: 0 auto;
}

.policy__intro {
  padding-bottom: 2.5rem; margin-bottom: 2.5rem;
    border-bottom: 1px solid var(--line);
}

.policy__intro p {
  font-size: 1.05rem;
}

.policy__url {
  font-family: var(--sans); font-size: 0.95rem;
    color: var(--ink-soft); margin-bottom: 0.75rem;
}

.policy__url a {
  border-bottom: 1px solid var(--gold); transition: color 0.2s;
}

.policy__url a:hover {
  color: var(--gold);
}

.policy h2 {
  font-family: var(--serif); font-weight: 400;
    font-size: clamp(1.5rem, 2.4vw, 1.85rem);
    line-height: 1.25; color: var(--ink);
    margin-top: 3rem; margin-bottom: 1.25rem;
    scroll-margin-top: 110px;
}

.policy h2:first-child {
  margin-top: 0;
}

.policy h2 .num {
  color: var(--gold); font-weight: 300;
    margin-right: 0.4rem;
}

.policy p, .policy li {
  font-size: 1rem; color: var(--ink-soft);
    line-height: 1.7;
}

.policy ul {
  margin: 1rem 0 1.25rem;
    padding-left: 1.5rem;
}

.policy ul li {
  margin-bottom: 0.4rem;
}

.policy ul li::marker {
  color: var(--gold);
}

.policy__entity {
  background: var(--paper-deep);
    padding: 1.5rem 1.75rem;
    border-left: 3px solid var(--gold);
    margin: 1.25rem 0;
    font-size: 0.98rem;
}

.policy__entity strong {
  font-weight: 500; color: var(--ink);
}

.policy a {
  color: var(--ink); border-bottom: 1px solid var(--gold);
    transition: color 0.2s;
}

.policy a:hover {
  color: var(--gold);
}

.policy__toc {
  background: var(--paper-deep);
    padding: 2rem 2.25rem;
    margin-bottom: 3rem;
}

.policy__toc h2 {
  font-size: 1.1rem !important;
    margin: 0 0 1.25rem !important;
    font-family: var(--sans) !important;
    font-weight: 500 !important;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--ink-faint) !important;
}

.policy__toc ol {
  columns: 1;
}

.policy__toc li {
  padding: 0.35rem 0;
    font-size: 0.95rem;
    break-inside: avoid;
}

.policy__toc li a {
  color: var(--ink-soft); border-bottom: none;
}

.policy__toc li a:hover {
  color: var(--gold);
}

.policy__toc li a span {
  color: var(--gold); margin-right: 0.5rem;
    font-family: var(--serif);
}


/* ============================================================
   FINAL OVERRIDES — load last to win over locked CSS cascade
   ============================================================ */

/* Footer: tighter line-height in column lists */
.footer .footer__col ul { padding: 0; margin: 0; list-style: none; }
.footer .footer__col li { padding: 0 !important; margin: 0 !important; line-height: 1.5; }
.footer .footer__col li + li { margin-top: 0.5rem !important; }
.footer .footer__col a {
  font-size: 0.875rem;
  line-height: 1.4;
  color: rgba(247, 241, 230, 0.78);
  border: none;
  display: inline-block;
}
.footer .footer__col h4,
.footer .footer__col h5 {
  font-family: var(--sans);
  font-size: 0.7rem;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-soft);
  margin: 0 0 1rem;
  line-height: 1.4;
}
.footer .footer__col h4.footer__col-second,
.footer .footer__col h5.footer__col-second { margin-top: 1.75rem; }

/* Footer address: tighter */
.footer .footer__addr { line-height: 1.55 !important; font-size: 0.875rem; }
.footer .footer__addr a { line-height: 1.4; }

/* Footer brand block: tighter spacing */
.footer .footer__brand { line-height: 1.15 !important; }
.footer .footer__tagline { line-height: 1.3 !important; }


/* ============================================================
   HOMEPAGE — native Gutenberg compatibility
   Patterns now use wp-block-columns instead of CSS grid.
   These rules ensure card styling, vertical alignment,
   and responsive stacking still work as the locked design intends.
   ============================================================ */

/* All home-page sections: shared inner-content max-width (uses
   constrained layout from theme.json, but pin for clarity) */
.home-hero ~ * .wp-block-group.section,
section.section.testimonials,
section.section.about,
section.section.recognise,
section.section.work,
section.section.specialisms,
section.section.pull,
section.section.together,
section.section.faq,
section.section.accred {
  padding-top: clamp(5rem, 9vw, 8rem);
  padding-bottom: clamp(5rem, 9vw, 8rem);
}

/* Testimonials — 3-column grid on desktop, stacks on mobile (native columns default).
   Each .testimonial card sits naturally inside its column. */
.testimonials__grid {
  gap: 3.5rem !important;
  margin-bottom: 0 !important;
}
.testimonial blockquote.wp-block-quote {
  border-left: none;
  padding-left: 0;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: 1.25rem;
  line-height: 1.5;
  color: var(--ink);
  margin: 0 0 1.25rem;
}
.testimonial blockquote.wp-block-quote p {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  color: var(--ink);
  margin: 0;
}
.testimonial blockquote.wp-block-quote::before {
  content: "\201C";
  font-size: 3rem;
  line-height: 0;
  vertical-align: -0.4em;
  color: var(--gold);
  margin-right: 0.1em;
}
.testimonial__attr {
  font-family: var(--sans);
  font-size: 0.8rem;
  font-style: normal;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-faint);
  margin: 0;
}
.testimonial__attr strong {
  font-weight: 500;
  color: var(--ink);
  margin-right: 0.6rem;
}
.testimonials__note {
  margin-top: 4rem !important;
  font-size: 0.82rem;
  color: var(--ink-faint);
  font-style: italic;
}

/* About — 2-column with portrait left, content right */
.about__layout {
  gap: clamp(2.5rem, 5vw, 5rem) !important;
}
.about__image {
  max-width: 480px;
  margin: 0 auto;
}
.about__image img {
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center top;
}
.about__content .h2 {
  margin: 1.25rem 0 1.5rem;
}
.about__content p {
  font-size: 1.05rem;
}
.about__creds {
  margin-top: 2.5rem !important;
  padding-top: 2rem;
  border-top: 1px solid var(--line);
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 400;
  letter-spacing: 0.08em;
  color: var(--ink-faint);
  line-height: 1.9;
}

/* Recognise — dark section, narrow column, gold highlight on closing line */
section.recognise {
  background: var(--ink) !important;
  color: var(--paper);
}
section.recognise .h2,
section.recognise h2,
section.recognise p {
  color: var(--paper);
}
section.recognise .is-style-eyebrow {
  color: var(--gold-soft) !important;
}
section.recognise .recognise__highlight {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.25rem, 2vw, 1.5rem);
  line-height: 1.4;
  color: var(--gold-soft);
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(217, 184, 124, 0.35);
}

/* Work — image left, content right, Rumi quote stylised */
.work__layout {
  gap: clamp(2.5rem, 5vw, 5rem) !important;
}
.work__image {
  max-width: 480px;
  margin: 0 auto;
}
.work__image img {
  width: 100%;
  height: auto;
  object-fit: cover;
}
.work__rumi.wp-block-quote {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1.4rem, 2.4vw, 1.85rem);
  line-height: 1.5;
  color: var(--gold);
  margin: 2.5rem 0 2rem !important;
  padding-left: 1.5rem;
  border-left: 2px solid var(--gold);
}
.work__rumi.wp-block-quote p {
  font-family: var(--serif);
  font-style: italic;
  color: var(--gold);
  margin: 0 0 0.5rem;
}
.work__rumi.wp-block-quote cite {
  font-family: var(--sans);
  font-style: normal;
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.work__list-intro {
  margin-top: 2rem !important;
  color: var(--ink);
  font-weight: 400;
}
.work__list {
  font-family: var(--sans);
  padding-left: 1.25rem;
}
.work__list li {
  margin-bottom: 0.6rem;
  color: var(--ink-soft);
}

/* Specialisms — 3-column card grid */
.specialisms__head {
  margin: 0 auto 4rem !important;
  text-align: center;
}
.specialisms__head .h2 {
  margin-top: 1.25rem;
}
.specialisms__grid {
  gap: 2rem !important;
}
.specialisms__grid > .wp-block-column.specialism {
  background: var(--paper);
  padding: 0 0 2rem;
  transition: transform 0.3s ease;
  display: flex;
  flex-direction: column;
}
.specialisms__grid > .wp-block-column.specialism:hover {
  transform: translateY(-4px);
}
.specialism__image {
  aspect-ratio: 16 / 11;
  overflow: hidden;
  background: var(--paper-deep);
  margin: 0 0 2rem !important;
}
.specialism__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
}
.specialism:hover .specialism__image img {
  transform: scale(1.04);
}
.specialism .h3 {
  margin: 0 2rem 1rem;
}
.specialism > p,
.specialism .specialism__link-wrap {
  margin: 0 2rem;
}
.specialism > p {
  font-size: 0.96rem;
  margin-bottom: 1.75rem;
  flex: 1;
  color: var(--ink-soft);
}
.specialism__link-wrap {
  margin-top: auto !important;
}
.specialism__link {
  font-family: var(--sans);
  font-size: 0.78rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink);
  border-bottom: 1px solid var(--gold);
  padding-bottom: 0.25rem;
  text-decoration: none;
  transition: color 0.2s ease;
}
.specialism__link:hover {
  color: var(--gold);
}

/* Pull quote — keep narrow content size, vertical breathing room */
section.pull {
  text-align: center;
}

/* Together — centred narrow content */
.together__inner {
  text-align: center;
  max-width: 720px;
  margin: 0 auto;
}
.together__cta-wrap {
  justify-content: center;
  margin-top: 2.5rem !important;
}
.together__cta-wrap .wp-block-button__link {
  font-family: var(--sans);
  font-size: 0.82rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 1rem 1.8rem;
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--ink);
  border-radius: 0;
  transition: background 0.25s ease, color 0.25s ease;
}
.together__cta-wrap .wp-block-button__link:hover {
  background: var(--ink);
  color: var(--paper);
}

/* FAQ section — head spacing, faq__inner uses existing .faq-item rules */
.faq__head {
  text-align: center;
  margin: 0 auto 3rem !important;
}
.faq__head .h2 {
  margin-top: 1.25rem;
}
.faq__inner .faq__link {
  color: var(--gold);
  border-bottom: 1px solid var(--gold);
  text-decoration: none;
}

/* Accreditations row */
.accred__inner {
  text-align: center;
  max-width: 1100px;
  margin: 0 auto !important;
}
.accred__label {
  margin-bottom: 2rem !important;
}
.accred__row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem 1rem;
  margin-top: 1.5rem;
}
.accred__badge {
  display: inline-block;
  font-family: var(--serif);
  font-size: 0.95rem;
  color: var(--ink-soft);
  letter-spacing: 0.04em;
  padding: 0.6rem 1.2rem;
  border: 1px solid var(--line);
  background: var(--paper);
  text-decoration: none;
  transition: border-color 0.2s ease, color 0.2s ease;
}
.accred__badge:hover {
  border-color: var(--gold);
  color: var(--ink);
}
.accred__badge strong {
  font-weight: 400;
  color: var(--ink);
}

/* ============================================================
   FLUSH ALIGNMENT — wordmark must sit at same x-position
   as content below it. Neutralise TT5/root-padding wrappers.
   ============================================================ */
.wp-site-blocks > header,
.wp-site-blocks > header.wp-block-template-part,
header.wp-block-template-part {
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}
.wp-site-blocks > main,
.wp-site-blocks > main.wp-block-group {
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}


/* ===========================================================
   GUTENBERG CORE/COVER BLOCK BRIDGE — homepage hero
   The homepage uses WP's core/cover block (.wp-block-cover.home-hero)
   instead of the legacy custom .home-hero__bg markup. The cover
   block applies opacity to the IMG itself and uses a different
   overlay span. These rules redirect that to match the locked
   cream-wash spec: image at full opacity, gradient wash above.
   =========================================================== */
.wp-block-cover.home-hero .wp-block-cover__image-background {
  opacity: 1;
}
.wp-block-cover.home-hero .wp-block-cover__background {
  background: linear-gradient(180deg,
    rgba(247, 241, 230, 0.20) 0%,
    rgba(247, 241, 230, 0.45) 45%,
    rgba(247, 241, 230, 0.78) 100%);
  opacity: 1;
  z-index: 1;
}
.wp-block-cover.home-hero .wp-block-cover__inner-container {
  position: relative;
  z-index: 2;
}



/* === Long Light header v3.2.0 — native block markup === */
:root{--ll-paper:#f7f1e6;--ll-ink:#1c1815;--ll-ink-soft:#4a3f36;--ll-gold:#b08344;--ll-line:#b8ac97}
html,body{overflow-x:hidden;max-width:100%}

/* Header container */
header.site-header{background:var(--ll-paper);border-bottom:1px solid rgba(184,172,151,.35);position:sticky;top:0;z-index:1000;width:100%}
.site-header__row{max-width:1320px;margin:0 auto;width:100%;gap:1rem}

/* Brand: heading + tagline */
.site-header__name{font-family:'Cormorant Garamond',Georgia,serif;font-weight:300;font-size:1.05rem;line-height:1.1;margin:0;color:var(--ll-ink);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.site-header__name a{color:inherit;text-decoration:none}
.site-header__tagline{display:block;font-family:Inter,sans-serif;font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ll-ink-soft);margin:2px 0 0;line-height:1.2}
.site-header__brand{gap:0;flex:0 1 auto;min-width:0;align-items:flex-start}

/* Navigation: top-level items */
.site-header__nav{flex:1 1 auto}
.site-header__nav .wp-block-navigation__container{gap:28px}
.site-header__nav .wp-block-navigation-item__content,
.site-header__nav .wp-block-navigation-item__content:link,
.site-header__nav .wp-block-navigation-item__content:visited,
.site-header__nav .wp-block-navigation-item__content:hover,
.site-header__nav .wp-block-navigation-item__content:focus,
.site-header__nav .wp-block-navigation-item__content:active{font-family:Inter,sans-serif;font-weight:400;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ll-ink);text-decoration:none !important;line-height:1.3;padding:8px 2px;border:none !important;box-shadow:none !important}
.site-header__nav .wp-block-navigation-item__content:hover,
.site-header__nav .wp-block-navigation-item__content:focus{color:var(--ll-gold)}
.site-header__nav .wp-block-navigation__submenu-icon{margin-left:4px}

/* Submenu (desktop dropdown) */
.site-header__nav .wp-block-navigation__submenu-container{background:var(--ll-paper);border:1px solid rgba(184,172,151,.4);min-width:240px;padding:14px 0;box-shadow:0 8px 24px rgba(28,24,21,.06);left:0}
.site-header__nav .wp-block-navigation__submenu-container .wp-block-navigation-item__content{font-family:Inter,sans-serif;font-weight:400;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ll-ink);padding:9px 22px;display:block;line-height:1.3}
.site-header__nav .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover,
.site-header__nav .wp-block-navigation__submenu-container .wp-block-navigation-item__content:focus{color:var(--ll-gold);background:rgba(184,172,151,.12);text-decoration:none !important}

/* CTA button — outline, no wrap */
.site-header__cta-wrap{flex:0 0 auto;margin:0}
.site-header__cta .wp-block-button__link,
.site-header__cta .wp-block-button__link:link,
.site-header__cta .wp-block-button__link:visited,
.site-header__cta .wp-block-button__link:hover,
.site-header__cta .wp-block-button__link:focus,
.site-header__cta .wp-block-button__link:active{font-family:Inter,sans-serif;font-weight:500;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ll-ink);text-decoration:none !important;border:1px solid var(--ll-ink);padding:11px 22px;background:transparent;transition:background .2s,color .2s;white-space:nowrap;display:inline-block;border-radius:0}
.site-header__cta .wp-block-button__link:hover,
.site-header__cta .wp-block-button__link:focus{background:var(--ll-ink);color:var(--ll-paper)}

/* Backdrop (we add this via JS) */
.nav-backdrop{position:fixed;inset:0;background:rgba(28,24,21,.55);opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:999}
body.menu-open .nav-backdrop{opacity:1;pointer-events:auto}

/* WordPress's native overlay open/close button */
.site-header__nav .wp-block-navigation__responsive-container-open{display:none;background:transparent;border:1px solid var(--ll-ink);width:44px;height:44px;padding:0;cursor:pointer;color:var(--ll-ink)}
.site-header__nav .wp-block-navigation__responsive-container-open svg{width:20px;height:20px;fill:var(--ll-ink)}
.site-header__nav .wp-block-navigation__responsive-container-close{position:absolute;top:14px;right:18px;background:transparent;border:1px solid var(--ll-ink);width:44px;height:44px;padding:0;cursor:pointer;color:var(--ll-ink);z-index:2}
.site-header__nav .wp-block-navigation__responsive-container-close svg{width:20px;height:20px;fill:var(--ll-ink)}

/* ===== Tablet & phone — bespoke right-anchored drawer ===== */
@media (max-width:1024px){
  header.site-header{padding:14px 18px !important}
  .site-header__row{gap:.75rem}
  .site-header__tagline{display:none}
  .site-header__name{font-size:.95rem;max-width:90px}

  /* Show open toggle, position it at right */
  .site-header__nav .wp-block-navigation__responsive-container-open{display:inline-flex;align-items:center;justify-content:center;order:3}

  /* CTA shrinks slightly */
  .site-header__cta .wp-block-button__link{font-size:.66rem;padding:10px 16px;letter-spacing:.14em}

  /* Hide the inline horizontal nav container; the overlay below replaces it */
  .site-header__nav > .wp-block-navigation__container{display:none}

  /* Convert WP's native overlay into a 360px-from-right drawer */
  .site-header__nav .wp-block-navigation__responsive-container{position:fixed !important;top:0;right:0;left:auto;bottom:0;height:100vh;height:100dvh;width:min(85%,340px) !important;background:var(--ll-paper) !important;transform:translateX(100%);transition:transform .28s ease;box-shadow:-8px 0 24px rgba(28,24,21,.12);overflow-y:auto;padding:84px 0 32px;z-index:1001;display:block !important;visibility:visible !important;opacity:1 !important;color:var(--ll-ink)}
  .site-header__nav .wp-block-navigation__responsive-container.has-modal-open,.site-header__nav .wp-block-navigation__responsive-container.is-menu-open{transform:translateX(0)}
  .site-header__nav .wp-block-navigation__responsive-container:not(.has-modal-open):not(.is-menu-open){pointer-events:none}
  .site-header__nav .wp-block-navigation__responsive-container.has-modal-open,.site-header__nav .wp-block-navigation__responsive-container.is-menu-open{pointer-events:auto}
  .site-header__nav .wp-block-navigation__responsive-container-content{padding:0;flex-direction:column;width:100%}
  .site-header__nav .wp-block-navigation__responsive-container-content > .wp-block-navigation__container{display:flex;flex-direction:column;gap:0;width:100%}
  .site-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation-item__content{font-family:Inter,sans-serif;font-weight:400;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ll-ink);padding:14px 24px;display:block;line-height:1.3}
  .site-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-icon{display:none}
  .site-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-container{position:static;display:block;border:none;box-shadow:none;padding:0 0 8px;background:transparent;min-width:0;opacity:1;visibility:visible}
  .site-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-container .wp-block-navigation-item__content{font-family:Inter,sans-serif;font-weight:400;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ll-ink-soft);padding:10px 24px 10px 40px;line-height:1.3}

  /* Drawer items: left-aligned, no dividers, parent/child indent visible */
  .site-header__nav .wp-block-navigation__responsive-container.has-modal-open,
  .site-header__nav .wp-block-navigation__responsive-container.is-menu-open{align-items:stretch !important;text-align:left !important}
  .site-header__nav .wp-block-navigation__responsive-container-content > .wp-block-navigation__container{align-items:stretch !important;justify-content:flex-start !important;text-align:left !important}
  .site-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation__container > .wp-block-navigation-item{width:100% !important;border:none !important;display:block !important;text-align:left !important;align-items:stretch !important}
  .site-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation-item__content{text-align:left !important;justify-content:flex-start !important;text-decoration:none !important;border:none !important;padding:14px 24px !important}
  .site-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-container{align-items:stretch !important;text-align:left !important}
  .site-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-container .wp-block-navigation-item{width:100% !important;border:none !important;display:block !important;text-align:left !important}
  .site-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation__submenu-container .wp-block-navigation-item__content{padding:10px 24px 10px 40px !important;text-align:left !important;justify-content:flex-start !important;text-decoration:none !important;border:none !important}
}
@media (max-width:480px){
  header.site-header{padding:12px 14px !important}
  .site-header__cta .wp-block-button__link{font-size:.6rem;padding:9px 12px;letter-spacing:.12em}
  .site-header__name{max-width:60px;font-size:.85rem}
  .site-header__nav .wp-block-navigation__responsive-container-open{width:40px;height:40px}
}
/* === end Long Light header === */

/* === Long Light home hero v3.3.0 — native cover block === */
.home-hero{align-items:flex-start !important;justify-content:flex-start !important;margin-left:0 !important;margin-right:0 !important;margin-inline:0 !important}
.entry-content > .home-hero,.wp-site-blocks .home-hero,body .home-hero.alignfull{margin-left:0 !important;margin-right:0 !important;width:auto !important;max-width:none !important}
.home-hero .wp-block-cover__inner-container{max-width:1320px;width:100%;margin:0 auto;color:var(--ll-ink) !important;text-align:left}

.home-hero__eyebrow{font-family:Inter,sans-serif !important;font-weight:300 !important;font-size:.78rem !important;letter-spacing:.18em !important;text-transform:uppercase !important;color:var(--ll-gold) !important;line-height:1.5 !important;margin:0 0 clamp(2rem,4vw,3rem) !important}

.home-hero__h1{font-family:'Cormorant Garamond',Georgia,serif !important;font-weight:300 !important;font-size:clamp(2.5rem,6vw,5.25rem) !important;line-height:1.05 !important;letter-spacing:-.015em !important;color:var(--ll-ink) !important;margin:0 0 clamp(1.5rem,3vw,2.25rem) !important;max-width:18ch}
.home-hero__h1 em{font-style:italic;font-weight:300;color:var(--ll-ink)}

.home-hero__lede{font-family:'Cormorant Garamond',Georgia,serif !important;font-style:italic !important;font-weight:300 !important;font-size:clamp(1.15rem,1.7vw,1.35rem) !important;line-height:1.55 !important;color:var(--ll-ink-soft) !important;max-width:36ch !important;margin:0 0 clamp(2rem,4vw,3rem) !important}

.home-hero__cta-row{margin:0 !important;gap:clamp(1.5rem,3vw,2.5rem) !important;align-items:center !important}

/* Primary button — outline style, transparent bg, ink border, ink text, hover fills ink */
.home-hero__cta-primary .wp-block-button__link,
.home-hero__cta-primary .wp-block-button__link:link,
.home-hero__cta-primary .wp-block-button__link:visited,
.home-hero__cta-primary .wp-block-button__link:hover,
.home-hero__cta-primary .wp-block-button__link:focus,
.home-hero__cta-primary .wp-block-button__link:active{font-family:Inter,sans-serif !important;font-weight:500 !important;font-size:.78rem !important;letter-spacing:.16em !important;text-transform:uppercase !important;color:var(--ll-ink) !important;text-decoration:none !important;background:transparent !important;border:1px solid var(--ll-ink) !important;padding:1.1rem 2.25rem !important;border-radius:0 !important;transition:background .25s ease,color .25s ease;display:inline-block;line-height:1.3}
.home-hero__cta-primary .wp-block-button__link:hover,
.home-hero__cta-primary .wp-block-button__link:focus{background:var(--ll-ink) !important;color:var(--ll-paper) !important}

/* Secondary text-link with thin underline that reads as part of the same colour */
.home-hero__cta-secondary .wp-block-button__link,
.home-hero__cta-secondary .wp-block-button__link:link,
.home-hero__cta-secondary .wp-block-button__link:visited,
.home-hero__cta-secondary .wp-block-button__link:hover,
.home-hero__cta-secondary .wp-block-button__link:focus,
.home-hero__cta-secondary .wp-block-button__link:active{font-family:Inter,sans-serif !important;font-weight:400 !important;font-size:.78rem !important;letter-spacing:.16em !important;text-transform:uppercase !important;color:var(--ll-ink) !important;background:transparent !important;border:none !important;padding:1.1rem 0 !important;border-radius:0 !important;text-decoration:none !important;display:inline-block;line-height:1.3;position:relative;transition:color .2s ease}
.home-hero__cta-secondary .wp-block-button__link::after{content:"";position:absolute;left:0;right:0;bottom:.55rem;height:1px;background:var(--ll-ink-soft);transition:background .2s ease}
.home-hero__cta-secondary .wp-block-button__link:hover,
.home-hero__cta-secondary .wp-block-button__link:focus{color:var(--ll-gold) !important}
.home-hero__cta-secondary .wp-block-button__link:hover::after,
.home-hero__cta-secondary .wp-block-button__link:focus::after{background:var(--ll-gold)}

/* Photo credit in bottom-right corner of hero */
.home-hero{position:relative}
.home-hero__credit{position:absolute !important;right:clamp(1rem,2vw,1.5rem) !important;bottom:clamp(.75rem,1.5vw,1rem) !important;left:auto !important;margin:0 !important;padding:0 !important;font-family:Inter,sans-serif !important;font-weight:300 !important;font-size:.68rem !important;letter-spacing:.04em !important;color:var(--ll-ink-faint,#8a7d6f) !important;opacity:.7;line-height:1;max-width:none !important;text-align:right}

@media (max-width:768px){
  .home-hero{min-height:78vh !important;padding-left:1.5rem !important;padding-right:1.5rem !important}
  .home-hero__h1{max-width:100%}
  .home-hero__lede{max-width:100%}
  .home-hero__cta-row{flex-direction:column !important;align-items:flex-start !important;gap:1.25rem !important}
}
/* === end Long Light home hero === */

/* === Long Light home sections v3.4.0 — credentials, recognise, work, specialisms, about, working, testimonials, faq, final cta === */

/* Generic eyebrow re-use — for sections beyond the hero */
.eyebrow{font-family:Inter,sans-serif !important;font-weight:300 !important;font-size:.78rem !important;letter-spacing:.18em !important;text-transform:uppercase !important;color:var(--ll-gold) !important;line-height:1.5 !important;display:block;margin-bottom:1rem !important}
.eyebrow--centered{text-align:center}

/* Section headings — H2/H3 sitewide on home */
.home-recognise__h2,.home-work__h2,.home-specialisms__h2,.home-about__h2,.home-working__h2,.home-faq__h2{font-family:'Cormorant Garamond',Georgia,serif !important;font-weight:300 !important;font-size:clamp(1.9rem,3.6vw,3rem) !important;line-height:1.15 !important;letter-spacing:-.01em !important;color:var(--ll-ink) !important;margin-bottom:clamp(1.5rem,3vw,2rem) !important}
.home-recognise__h2,.home-specialisms__h2,.home-working__h2,.home-faq__h2{margin-left:auto;margin-right:auto}
.home-final-cta__h3{font-family:'Cormorant Garamond',Georgia,serif !important;font-weight:300 !important;font-size:clamp(1.5rem,2.6vw,2.1rem) !important;line-height:1.2 !important;color:var(--ll-ink) !important;margin-top:0 !important;margin-bottom:0 !important}

/* Body paragraphs across home sections */
.home-recognise p,.home-work__col-text p,.home-specialism__copy,.home-about__columns p,.home-working p,.home-testimonial__quote,.home-faq p{font-family:Inter,sans-serif !important;font-size:1.0625rem !important;line-height:1.7 !important;color:var(--ll-ink-soft) !important;font-weight:300 !important;margin-bottom:1.1em !important}

/* === Section 2: credentials strip === */
.home-credentials__line{font-family:Inter,sans-serif !important;font-size:.85rem !important;letter-spacing:.04em !important;color:var(--ll-ink-soft) !important;margin:0 !important;font-weight:300}

/* === Section 3: recognise === */
.home-recognise__lede{font-family:Inter,sans-serif !important;font-size:1.15rem !important;line-height:1.65 !important;color:var(--ll-ink) !important;font-weight:300 !important}
.home-recognise__highlight{font-family:'Cormorant Garamond',Georgia,serif !important;font-style:italic !important;font-weight:300 !important;font-size:clamp(1.4rem,2.4vw,1.85rem) !important;line-height:1.4 !important;color:var(--ll-gold) !important;text-align:center !important;margin:clamp(1.5rem,3vw,2.25rem) auto !important;max-width:32ch !important}
.home-recognise__close{font-family:'Cormorant Garamond',Georgia,serif !important;font-style:italic !important;font-weight:300 !important;font-size:clamp(1.25rem,2vw,1.5rem) !important;line-height:1.5 !important;color:var(--ll-ink-soft) !important;text-align:center !important;margin:clamp(2rem,4vw,3rem) auto 0 !important}

/* === Section 4: how I work (split column) === */
.home-work__columns{gap:clamp(2rem,5vw,4.5rem) !important;align-items:flex-start !important}
.home-work__image img{width:100%;height:auto;display:block;aspect-ratio:4/5;object-fit:cover}
.home-work__image figcaption{font-family:Inter,sans-serif;font-size:.7rem;letter-spacing:.04em;color:var(--ll-ink-faint,#8a7d6f);opacity:.7;text-align:right;margin-top:.35rem;font-weight:300}
.home-work__rumi{border:none !important;border-left:2px solid var(--ll-gold) !important;padding:.25rem 0 .25rem 1.5rem !important;margin:clamp(2rem,4vw,2.5rem) 0 !important;background:transparent !important}
.home-work__rumi p{font-family:'Cormorant Garamond',Georgia,serif !important;font-style:italic !important;font-weight:300 !important;font-size:clamp(1.4rem,2.4vw,1.85rem) !important;line-height:1.5 !important;color:var(--ll-gold) !important;margin:0 0 1rem !important}
.home-work__rumi cite{display:block !important;font-style:normal !important;font-family:Inter,sans-serif !important;font-size:.78rem !important;font-weight:400 !important;letter-spacing:.16em !important;text-transform:uppercase !important;color:var(--ll-ink-faint,#8a7d6f) !important}
.home-work__fit-intro{font-family:'Cormorant Garamond',Georgia,serif !important;font-style:italic !important;font-weight:400 !important;font-size:1.15rem !important;color:var(--ll-ink) !important;margin:1.5rem 0 1rem !important}
.home-work__fit-list{list-style:none !important;padding:0 !important;margin:0 !important}
.home-work__fit-list li{padding:.9rem 0 !important;border-bottom:1px solid var(--ll-line) !important;color:var(--ll-ink-soft) !important;font-family:Inter,sans-serif !important;font-size:1rem !important;line-height:1.65 !important;display:flex !important;align-items:flex-start !important;gap:1rem !important;font-weight:300}
.home-work__fit-list li::before{content:"\2014";color:var(--ll-gold);flex-shrink:0}
.home-work__fit-list li:last-child{border-bottom:none}

/* === Section 5: specialisms === */
.home-specialisms__grid{gap:2rem !important}
.home-specialism{background:var(--ll-paper) !important;padding:0 0 2rem !important;display:flex;flex-direction:column;transition:transform .3s ease}
.home-specialism:hover{transform:translateY(-4px)}
.home-specialism__image{margin:0 0 1.75rem !important}
.home-specialism__image img{width:100%;height:auto;aspect-ratio:16/11;object-fit:cover;display:block}
.home-specialism__h3{font-family:'Cormorant Garamond',Georgia,serif !important;font-weight:400 !important;font-size:clamp(1.3rem,2vw,1.6rem) !important;line-height:1.2 !important;margin:0 1.75rem .75rem !important;color:var(--ll-ink) !important}
.home-specialism__h3 a{color:inherit !important;text-decoration:none !important}
.home-specialism__h3 a:hover{color:var(--ll-gold) !important}
.home-specialism__copy{font-size:1rem !important;line-height:1.65 !important;margin:0 1.75rem 1rem !important;font-weight:300}
.home-specialism__link{margin:0 1.75rem !important}
.home-specialism__link a{font-family:Inter,sans-serif !important;font-weight:400 !important;font-size:.78rem !important;letter-spacing:.16em !important;text-transform:uppercase !important;color:var(--ll-ink) !important;text-decoration:none !important;border-bottom:1px solid var(--ll-ink-soft);padding-bottom:.25rem;transition:color .2s ease,border-color .2s ease}
.home-specialism__link a:hover{color:var(--ll-gold) !important;border-bottom-color:var(--ll-gold)}

/* === Section 6: about teaser === */
.home-about__columns{gap:clamp(2rem,5vw,4rem) !important;align-items:center !important}
.home-about__portrait img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;display:block}
.home-about__credentials{font-family:Inter,sans-serif !important;font-size:.85rem !important;letter-spacing:.04em !important;color:var(--ll-ink-soft) !important;line-height:1.7 !important;margin:1.5rem 0 1.75rem !important;font-weight:300 !important;font-style:normal !important}
.home-about__cta .wp-block-button__link{padding:.75rem 0 !important}

/* === Section 7: working together === */
.home-working__pull{font-family:'Cormorant Garamond',Georgia,serif !important;font-style:italic !important;font-weight:300 !important;font-size:clamp(1.4rem,2.4vw,1.85rem) !important;line-height:1.5 !important;color:var(--ll-gold) !important;text-align:center !important;margin:clamp(2.5rem,5vw,3.5rem) auto !important;max-width:34ch !important;border:none !important;background:transparent !important;padding:0 !important}

/* === Section 8: testimonials === */
.home-testimonials__grid{gap:clamp(1.5rem,3vw,2.5rem) !important}
.home-testimonial{background:var(--ll-paper) !important;padding:clamp(1.75rem,3vw,2.25rem) !important;display:flex !important;flex-direction:column !important;justify-content:space-between}
.home-testimonial__quote{font-family:'Cormorant Garamond',Georgia,serif !important;font-style:italic !important;font-weight:300 !important;font-size:1.15rem !important;line-height:1.6 !important;color:var(--ll-ink) !important;margin:0 0 1.5rem !important}
.home-testimonial__attrib{font-family:Inter,sans-serif !important;font-size:.72rem !important;letter-spacing:.14em !important;text-transform:uppercase !important;color:var(--ll-ink-faint,#8a7d6f) !important;line-height:1.6 !important;margin:0 !important;font-weight:300 !important}
.home-testimonial__attrib strong{display:inline-block;font-family:'Cormorant Garamond',Georgia,serif !important;font-weight:400 !important;font-style:italic;font-size:1.5rem !important;color:var(--ll-gold) !important;letter-spacing:0 !important;text-transform:none !important;margin-bottom:.5rem;line-height:1}
.home-testimonials__note{font-family:Inter,sans-serif !important;font-size:.8rem !important;color:var(--ll-ink-faint,#8a7d6f) !important;font-style:italic !important;font-weight:300 !important;margin:clamp(2rem,4vw,3rem) auto 0 !important;letter-spacing:.02em}

/* === Section 9: FAQ teaser === */
.home-faq__item{border-bottom:1px solid var(--ll-line);padding:1.25rem 0;margin:0}
.home-faq__item summary{font-family:'Cormorant Garamond',Georgia,serif;font-weight:400;font-size:clamp(1.1rem,1.7vw,1.3rem);line-height:1.4;color:var(--ll-ink);cursor:pointer;list-style:none;padding-right:2rem;position:relative}
.home-faq__item summary::-webkit-details-marker{display:none}
.home-faq__item summary::after{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);font-family:'Cormorant Garamond',Georgia,serif;font-size:1.5rem;color:var(--ll-gold);transition:transform .25s ease;font-weight:300}
.home-faq__item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.home-faq__item summary:hover{color:var(--ll-gold)}
.home-faq__item p{font-family:Inter,sans-serif;font-size:1rem;line-height:1.7;color:var(--ll-ink-soft);font-weight:300;margin:1rem 0 0;padding-right:2rem}
.home-faq__more{margin-top:clamp(2rem,4vw,3rem) !important}
.home-faq__more a{font-family:Inter,sans-serif !important;font-weight:400 !important;font-size:.85rem !important;letter-spacing:.16em !important;text-transform:uppercase !important;color:var(--ll-ink) !important;text-decoration:none !important;border-bottom:1px solid var(--ll-ink-soft);padding-bottom:.25rem;transition:color .2s,border-color .2s}
.home-faq__more a:hover{color:var(--ll-gold) !important;border-bottom-color:var(--ll-gold)}

/* === Section 10: final cta === */
.home-final-cta .wp-block-buttons{gap:clamp(1.25rem,3vw,2rem) !important;align-items:center !important}

/* === Mobile breakpoints for home sections === */
@media (max-width:900px){
  .home-work__columns,.home-about__columns,.home-specialisms__grid,.home-testimonials__grid{flex-direction:column !important}
  .home-work__col-image,.home-work__col-text,.home-about__columns .wp-block-column{flex-basis:100% !important;width:100% !important}
  .home-work__image{max-width:480px;margin:0 auto}
  .home-about__portrait{max-width:380px;margin:0 auto}
}
@media (max-width:600px){
  .home-credentials__line{font-size:.78rem !important;line-height:1.7 !important}
  .home-recognise__highlight{font-size:1.4rem !important}
  .home-work__rumi p{font-size:1.25rem !important}
  .home-working__pull{font-size:1.3rem !important}
}
/* === end Long Light home sections === */
