/* ──────────────────────────────────────────────────────────────────────
   Harborline — Editorial · shared stylesheet (generated by SiteForge)
   Italiana display + Cormorant Garamond body, dark layered paper,
   #2F8F6B accent. Imported by every page.
   ────────────────────────────────────────────────────────────────────── */

:root{
  --paper:        #0f0f0f;
  --paper-dim:    #16161a;
  --paper-edge:   #1c1c20;

  --ink:          #B4E4D2;
  --ink-dim:      rgba(247,241,230,.84);
  --ink-mute:     rgba(247,241,230,.62);
  --ink-faint:    rgba(247,241,230,.38);
  --ink-deep:     #F5EFE3;

  --ink-on-paper:       #2B8362;
  --ink-on-paper-dim:   rgba(43,131,98,0.74);
  --ink-on-paper-mute:  rgba(43,131,98,0.52);
  --ink-on-paper-deep:  #16110D;

  --rule:         rgba(247,241,230,.12);
  --rule-strong:  rgba(247,241,230,.24);
  --line:         rgba(247,241,230,.12);
  --line-strong:  rgba(247,241,230,.24);
  --line-gold:    rgba(201,162,75,0.5);
  --line-aqua:    rgba(47,143,107,0.45);
  --line-paper:   rgba(26,20,16,.16);

  --brass:        #C9A24B;
  --brass-soft:   rgba(201,162,75,0.3);
  --tiffany:      #2F8F6B;
  --tiffany-deep: #2B8362;
  --tiffany-soft: rgba(47,143,107,0.14);
  --aqua:         #2F8F6B;
  --accent-2:     #7FC8A9;
  --glow:         rgba(47,143,107,0.18);

  --rev-bg:       #F5EFE3;
  --rev-ink:      #16110D;
  --rev-mute:     rgba(22,17,13,.62);

  --display:  "Italiana", "Bodoni Moda", "Didot", serif;
  --serif:    "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --sc:       "Cormorant SC", "Cormorant Garamond", serif;
}

*{ box-sizing: border-box; margin: 0; padding: 0; }
html, body{ color: var(--ink-dim); font-family: var(--serif); font-weight: 400; }
html{ background: linear-gradient(180deg, #141414, #0f0f0f 60%, #0a0a0a) fixed; min-height: 100%; }
body{ overflow-x: hidden; min-height: 100vh; background:
    linear-gradient(180deg, rgba(47,143,107,0.18), rgba(10,10,10,0) 55%),
    transparent; background-repeat: no-repeat; }

body::before{
  content: ""; position: fixed; inset: 0; pointer-events: none;
  z-index: 1000; opacity: .065; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .9 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

a{ color: inherit; text-decoration: none; border-bottom: 1px solid var(--rule-strong); transition: border-color .2s ease, color .2s ease; padding-bottom: 1px; }
a:hover{ color: var(--brass); border-color: var(--brass); }
a.unstyled{ border-bottom: none; }
button{ font: inherit; cursor: pointer; background: none; border: none; color: inherit; }
em, i{ font-style: italic; }
::selection{ background: var(--tiffany); color: #0a0a0a; }
.skip{ position: absolute; left: -9999px; top: 0; }
.skip:focus{ left: 16px; top: 16px; background: var(--ink); color: var(--paper); padding: 8px 14px; z-index: 9999; }

/* ── Type utilities ─────────────────────────────────────────── */
.display{ font-family: var(--display); font-weight: 400; letter-spacing: -0.01em; line-height: .92; }
.sc{ font-family: var(--sc); font-weight: 500; letter-spacing: 0.22em; text-transform: uppercase; }
.italic{ font-style: italic; font-family: var(--serif); }
.figure{ font-feature-settings: "lnum" 1; }

/* ── Masthead ───────────────────────────────────────────────── */
.masthead{ position: sticky; top: 0; z-index: 50; background: rgba(15,15,15,.86); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border-bottom: 1px solid var(--rule-strong); }
.masthead-inner{ display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; padding: 10px 32px; }
.masthead .vol{ font-family: var(--sc); font-size: 10px; letter-spacing: 0.30em; color: var(--ink-mute); }
.masthead .mid{ text-align: center; font-family: var(--display); font-size: 28px; line-height: 1; color: var(--ink); white-space: nowrap; }
.masthead .mid a{ border: none; color: inherit; padding: 0; }
.masthead .mid em{ font-family: var(--serif); font-style: italic; font-size: 13px; color: var(--ink-mute); margin-right: 4px; vertical-align: 2px; font-weight: 400; }
.masthead .right{ text-align: right; font-family: var(--sc); font-size: 10px; letter-spacing: 0.30em; color: var(--ink-mute); }

.section-nav{ border-top: 1px solid var(--rule); }
.section-nav-inner{ display: flex; align-items: center; justify-content: center; flex-wrap: wrap; padding: 9px 32px; gap: 0; }
.section-nav a{ font-family: var(--sc); font-size: 11px; letter-spacing: 0.26em; color: var(--ink-mute); border: none; padding: 4px 22px; position: relative; transition: color .15s; }
.section-nav a + a::before{ content: "·"; position: absolute; left: -2px; top: 50%; transform: translateY(-50%); color: var(--brass); opacity: .7; }
.section-nav a:hover{ color: var(--tiffany); }
.section-nav a.active{ color: var(--tiffany); }
.section-nav a.active::after{ content: ""; position: absolute; left: 50%; transform: translateX(-50%); bottom: -10px; width: 18px; height: 2px; background: var(--brass); }
.section-nav .cta{ color: var(--ink-deep); border: 1px solid var(--ink-deep); padding: 6px 16px; margin-left: 8px; background: transparent; }
.section-nav .cta:hover{ background: var(--tiffany); border-color: var(--tiffany); color: #0a0a0a; }

.nav-toggle{ display: none; }
@media (max-width: 760px){
  .masthead-inner{ grid-template-columns: 1fr auto; padding: 10px 18px; }
  .masthead .mid{ display: none; }
  .masthead .right{ display: none; }
  .nav-toggle{ display: flex; align-items: center; gap: 8px; font-family: var(--sc); font-size: 11px; letter-spacing: .22em; }
  .section-nav-inner{ flex-direction: column; padding: 16px 18px; gap: 8px; }
  .section-nav a + a::before{ display: none; }
  .section-nav.collapsed{ display: none; }
}

/* ── Page-hero ──────────────────────────────────────────────── */
.page-hero{ padding: 88px 56px 64px; border-bottom: 1px solid var(--rule-strong); }
.page-hero .eyebrow{ font-family: var(--sc); font-size: 11px; letter-spacing: 0.34em; color: var(--ink-mute); display: inline-flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.page-hero .eyebrow::before{ content: ""; display: inline-block; width: 36px; height: 1px; background: var(--brass); }
.page-hero h1{ font-family: var(--display); font-weight: 400; font-size: clamp(48px, 7.5vw, 104px); line-height: .92; letter-spacing: -0.02em; max-width: 16ch; }
.page-hero h1 em{ font-family: var(--serif); font-style: italic; font-weight: 400; color: var(--ink-dim); }
.page-hero .lede{ font-family: var(--serif); font-style: italic; font-size: clamp(20px, 2vw, 26px); line-height: 1.45; color: var(--ink-dim); max-width: 640px; margin-top: 28px; }

/* ── Body sections ──────────────────────────────────────────── */
.section{ padding: 80px 56px; border-top: 1px solid var(--rule-strong); }
.section.no-rule{ border-top: none; }
.section.muted{ background: var(--tiffany-soft); }
.gutter{ max-width: 1180px; margin: 0 auto; }

.eyebrow{ font-family: var(--sc); font-size: 10px; letter-spacing: 0.30em; color: var(--ink-mute); text-transform: uppercase; display: inline-block; }
.eyebrow.eyebrow-line::before{ content: ""; display: inline-block; vertical-align: middle; width: 28px; height: 1px; background: var(--brass); margin-right: 12px; }

.row-split{ display: grid; grid-template-columns: 240px 1fr; gap: 64px; }
.row-split .eyebrow-col{ font-family: var(--sc); font-size: 10px; letter-spacing: 0.34em; color: var(--ink-mute); padding-top: 10px; }
.row-split .eyebrow-col em{ font-family: var(--serif); font-style: italic; font-size: 14px; text-transform: none; letter-spacing: 0; color: var(--ink-mute); display: block; margin-top: 8px; }
.row-split.flip{ grid-template-columns: 1fr 240px; }
.row-split.flip .eyebrow-col{ text-align: right; }

.head-xl{ font-family: var(--display); font-weight: 400; font-size: clamp(48px, 7.5vw, 104px); line-height: .92; letter-spacing: -0.02em; }
.head-xl em{ font-family: var(--serif); font-style: italic; font-weight: 400; color: var(--ink-dim); }
.head-xl .aqua{ color: var(--aqua); font-family: var(--display); font-style: normal; }
.head-l{ font-family: var(--display); font-weight: 400; font-size: clamp(36px, 5vw, 64px); line-height: 1; letter-spacing: -0.01em; }
.head-l em{ font-family: var(--serif); font-style: italic; color: var(--ink-dim); }
.head-m{ font-family: var(--display); font-weight: 400; font-size: clamp(28px, 3.5vw, 40px); line-height: 1.05; letter-spacing: -0.01em; }

.lede{ font-family: var(--serif); font-size: clamp(19px, 1.7vw, 24px); line-height: 1.5; color: var(--ink-dim); max-width: 640px; }
.lede em{ color: var(--ink); }

/* ── Prose ──────────────────────────────────────────────────── */
.prose{ max-width: 64ch; font-size: 17px; color: var(--ink-dim); line-height: 1.65; }
.prose h2{ font-family: var(--display); font-weight: 400; color: var(--ink); font-size: clamp(28px, 3vw, 40px); line-height: 1.1; letter-spacing: -0.01em; margin-top: 56px; margin-bottom: 18px; }
.prose h2:first-child{ margin-top: 0; }
.prose h3{ font-family: var(--display); font-weight: 400; color: var(--ink); font-size: 24px; line-height: 1.2; margin-top: 36px; margin-bottom: 12px; }
.prose p{ margin-bottom: 18px; }
.prose p > b, .prose p > strong, .prose li > b, .prose li > strong{ color: var(--ink); font-weight: 600; }
.prose ul, .prose ol{ margin-bottom: 20px; padding-left: 1.5em; }
.prose ul li, .prose ol li{ margin-bottom: 12px; }
.prose ul li::marker{ color: var(--brass); }
.prose ol li::marker{ font-family: var(--display); color: var(--brass); }
.prose a{ color: var(--ink); border-bottom: 1px solid var(--brass-soft); }
.prose a:hover{ color: var(--brass); border-color: var(--brass); }

.callout{ background: var(--glow-soft, rgba(217,191,118,.06)); border-left: 2px solid var(--brass); padding: 18px 22px; margin: 24px 0; font-family: var(--serif); font-size: 16px; color: var(--ink-deep); line-height: 1.6; position: relative; }
.callout::before, .callout::after{ content: ""; position: absolute; left: 12px; right: 12px; height: 1px; background: var(--brass-soft); }
.callout::before{ top: 4px; } .callout::after{ bottom: 4px; }
.callout b{ color: var(--brass); }

/* ── Proof / review blocks ──────────────────────────────────── */
.review-proof{ display:grid; grid-template-columns:.86fr 1.14fr; gap:32px; align-items:start; border-top:1px solid var(--ink-deep); border-bottom:1px solid var(--line-strong); padding:30px 0; margin:0 0 48px; }
.review-proof.flush{ margin:48px 0 0; }
.review-proof .rp-kicker{ display:inline-flex; align-items:center; gap:10px; font-family:var(--sc); font-size:10px; letter-spacing:.30em; text-transform:uppercase; color:var(--brass); margin-bottom:14px; }
.review-proof .rp-kicker::before{ content:""; width:28px; height:1px; background:var(--brass); display:inline-block; }
.review-proof .rp-line{ font-family:var(--display); font-size:clamp(34px,4.5vw,58px); line-height:.98; letter-spacing:-.02em; color:var(--ink); max-width:12ch; }
.review-proof .rp-line em{ font-family:var(--serif); font-style:italic; color:var(--ink-dim); }
.review-proof .rp-notes{ display:grid; gap:14px; }
.review-proof .rp-note{ font-family:var(--serif); font-size:18px; line-height:1.55; color:var(--ink-dim); border-bottom:1px dotted var(--line-strong); padding-bottom:14px; }
.review-proof .rp-note:last-child{ border-bottom:none; padding-bottom:0; }
.review-proof .rp-note b{ color:var(--ink); font-weight:600; }
.review-proof .rp-source{ font-family:var(--sc); font-size:9px; letter-spacing:.24em; color:var(--ink-mute); text-transform:uppercase; margin-top:4px; }
.review-proof .rp-source a{ color:var(--ink-mute); border-bottom:1px solid var(--brass-soft); }

/* ── Tables ─────────────────────────────────────────────────── */
.tbl{ width: 100%; border-collapse: collapse; margin: 14px 0 24px; font-size: 15px; }
.tbl thead th{ font-family: var(--sc); font-weight: 500; font-size: 10px; letter-spacing: .22em; color: var(--ink-mute); text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--ink-deep); }
.tbl tbody td{ padding: 14px 12px; border-bottom: 1px dotted var(--rule-strong); vertical-align: top; color: var(--ink-dim); }
.tbl tbody td:first-child{ color: var(--ink); font-family: var(--serif); font-style: italic; font-size: 17px; }
.tbl tbody tr:last-child td{ border-bottom: 1px solid var(--ink-deep); }

/* ── Feature category grid ──────────────────────────────────── */
.cat-grid{ display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--ink-deep); border-bottom: 1px solid var(--ink-deep); }
.cat{ padding: 36px 32px 32px; border-right: 1px solid var(--rule); border-bottom: 1px solid var(--rule); position: relative; }
.cat:nth-child(3n){ border-right: none; }
.cat-num{ font-family: var(--display); font-size: 28px; color: var(--brass); line-height: 1; margin-bottom: 18px; letter-spacing: -0.01em; }
.cat-glyph{ font-family: var(--serif); font-style: italic; font-size: 40px; color: var(--ink); line-height: 1; margin-bottom: 14px; display: inline-block; }
.cat-name{ font-family: var(--display); font-size: 36px; line-height: 1; letter-spacing: -0.02em; margin-bottom: 12px; }
.cat-name em{ font-family: var(--serif); font-style: italic; color: var(--ink-dim); }
.cat-blurb{ font-family: var(--serif); font-size: 16px; line-height: 1.5; color: var(--ink-dim); margin-bottom: 16px; }
.cat-tags{ display: flex; flex-wrap: wrap; gap: 6px 10px; margin-bottom: 14px; }
.cat-tags span{ font-family: var(--sc); font-size: 9px; letter-spacing: 0.22em; color: var(--ink-mute); padding: 4px 10px; border: 1px solid var(--rule-strong); }
.cat-heal{ font-family: var(--serif); font-style: italic; font-size: 14px; color: var(--ink-mute); padding-top: 14px; border-top: 1px dotted var(--rule-strong); }
.cat-heal b{ color: var(--brass); font-style: normal; font-family: var(--sc); font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 500; margin-right: 6px; }
.cat.private{ background: var(--paper-dim); }
@media (max-width: 980px){ .cat-grid{ grid-template-columns: repeat(2, 1fr); } .cat:nth-child(3n){ border-right: 1px solid var(--rule); } .cat:nth-child(2n){ border-right: none; } }
@media (max-width: 640px){ .cat-grid{ grid-template-columns: 1fr; } .cat{ border-right: none !important; } }

/* ── Aside card ─────────────────────────────────────────────── */
.aside-card{ position: sticky; top: 96px; background: rgba(247,241,230,.04); border: 1px solid var(--line-strong); padding: 24px 24px 26px; }
.aside-card::before, .aside-card::after{ content: ""; position: absolute; left: 12px; right: 12px; height: 1px; background: var(--brass-soft); }
.aside-card::before{ top: 6px; } .aside-card::after{ bottom: 6px; }
.aside-card .eyebrow{ display: block; margin-bottom: 16px; }
.aside-card ul{ list-style: none; padding: 0; display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; }
.aside-card ul li{ display: flex; gap: 10px; align-items: flex-start; font-size: 15px; color: var(--ink-dim); line-height: 1.4; }
.aside-card ul li::before{ content: ""; display: inline-block; width: 6px; height: 6px; margin-top: 8px; background: var(--brass); border-radius: 50%; flex-shrink: 0; }
.aside-card .actions{ display: flex; flex-direction: column; gap: 10px; }

/* ── Buttons ────────────────────────────────────────────────── */
.btn{ display: inline-flex; align-items: center; justify-content: center; gap: 8px; font-family: var(--sc); font-size: 11px; letter-spacing: 0.30em; padding: 13px 26px; border: 1px solid var(--ink-deep); cursor: pointer; transition: background .15s, color .15s, border-color .15s; text-align: center; line-height: 1; }
.btn.btn-lg{ font-size: 12px; padding: 16px 30px; }
.btn-primary{ background: var(--tiffany); color: var(--paper); border-color: var(--tiffany); }
.btn-primary:hover{ background: var(--tiffany-deep); color: var(--paper); border-color: var(--tiffany-deep); }
.btn-ghost{ background: transparent; color: var(--ink-deep); border-color: var(--line-strong); }
.btn-ghost:hover{ background: var(--ink-deep); color: #0a0a0a; border-color: var(--ink-deep); }
.btn-brass{ background: var(--brass); border-color: var(--brass); color: var(--paper); }
.btn-brass:hover{ background: transparent; color: var(--brass); }
.btn:disabled{ opacity: .35; cursor: not-allowed; }
a.btn{ border-bottom-width: 1px; padding-bottom: 13px; }
a.btn.btn-lg{ padding-bottom: 16px; }

.cta-strip{ padding: 88px 56px; background: var(--paper-dim); border-top: 1px solid var(--rule-strong); }
.cta-strip-inner{ display: flex; justify-content: space-between; align-items: center; gap: 32px; flex-wrap: wrap; max-width: 1180px; margin: 0 auto; }
.cta-strip-actions{ display: flex; gap: 12px; flex-wrap: wrap; }

/* ── Colophon ───────────────────────────────────────────────── */
.colophon{ padding: 56px 56px 88px; border-top: 1px solid var(--ink-deep); }
.colophon-grid{ display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; max-width: 1180px; margin: 0 auto; }
.colophon-mark{ font-family: var(--display); font-size: 36px; line-height: 1; margin-bottom: 12px; }
.colophon-mark em{ font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--ink-mute); margin-right: 4px; vertical-align: 2px; font-weight: 400; }
.colophon-sub{ font-family: var(--serif); font-style: italic; font-size: 16px; color: var(--ink-mute); line-height: 1.55; max-width: 36ch; }
.colophon-col h5{ font-family: var(--sc); font-size: 10px; letter-spacing: .30em; color: var(--ink); margin-bottom: 12px; font-weight: 500; }
.colophon-col ul{ list-style: none; padding: 0; display: flex; flex-direction: column; gap: 7px; }
.colophon-col ul li, .colophon-col ul li a{ font-family: var(--serif); font-size: 16px; color: var(--ink-dim); border: none; }
.colophon-col ul li a:hover{ color: var(--brass); }
.colophon-bottom{ margin-top: 56px; padding-top: 24px; border-top: 1px solid var(--rule); display: flex; justify-content: space-between; gap: 18px; font-family: var(--sc); font-size: 10px; letter-spacing: .26em; color: var(--ink-mute); flex-wrap: wrap; max-width: 1180px; margin-left: auto; margin-right: auto; }

@media (max-width: 980px){
  .row-split, .row-split.flip{ grid-template-columns: 1fr; gap: 18px; }
  .row-split.flip .eyebrow-col{ text-align: left; }
  .colophon-grid{ grid-template-columns: 1fr 1fr; gap: 32px; }
  .review-proof{ grid-template-columns:1fr; gap:22px; }
}
@media (max-width: 640px){
  .page-hero{ padding: 56px 24px 48px; }
  .section, .cta-strip, .colophon{ padding-left: 24px; padding-right: 24px; }
  .section{ padding-top: 56px; padding-bottom: 56px; }
  .colophon-grid{ grid-template-columns: 1fr; }
  .aside-card{ position: relative; top: auto; }
}

/* ── Profile pattern ────────────────────────────────────────── */
.prof-hero{ display: grid; grid-template-columns: 1.2fr .8fr; gap: 48px; padding: 80px 56px 72px; border-bottom: 1px solid var(--rule-strong); align-items: end; }
.prof-eyebrow{ font-family: var(--sc); font-size: 11px; letter-spacing: .34em; color: var(--ink-mute); display: inline-flex; align-items: center; gap: 12px; margin-bottom: 14px; text-transform: uppercase; }
.prof-eyebrow::before{ content: ""; display: inline-block; width: 36px; height: 1px; background: var(--brass); }
.prof-name{ font-family: var(--serif); font-style: italic; font-weight: 400; font-size: clamp(72px, 11vw, 172px); line-height: .85; letter-spacing: -.03em; color: var(--ink); margin-bottom: 18px; }
.prof-meta{ display: flex; gap: 24px; align-items: baseline; font-family: var(--sc); font-size: 10px; letter-spacing: .22em; color: var(--ink-mute); text-transform: uppercase; padding-top: 18px; border-top: 1px solid var(--rule); flex-wrap: wrap; }
.prof-meta b{ color: var(--ink); font-family: var(--serif); font-style: italic; font-size: 17px; letter-spacing: 0; text-transform: none; font-weight: 400; margin-left: 6px; }
.prof-plate{ position: relative; aspect-ratio: 4/5; background: var(--paper-dim); border: 1px solid var(--rule-strong); display: flex; align-items: flex-end; justify-content: flex-start; padding: 28px; overflow: hidden; }
.prof-plate::before{ content: ""; position: absolute; inset: 14px; border: 1px solid var(--brass-soft); pointer-events: none; }
.prof-plate .ini{ font-family: var(--display); font-size: clamp(120px, 18vw, 200px); color: var(--ink); line-height: 1; }
.prof-plate .stamp{ position: absolute; top: 24px; right: 24px; font-family: var(--sc); font-size: 9px; letter-spacing: .30em; color: var(--ink-mute); }
.prof-essay{ display: grid; grid-template-columns: 240px 1fr; gap: 64px; }
.prof-essay .col-l{ font-family: var(--sc); font-size: 10px; letter-spacing: .34em; color: var(--ink-mute); padding-top: 12px; }
.prof-essay h2{ font-family: var(--display); font-weight: 400; font-size: clamp(40px, 5vw, 72px); line-height: .95; letter-spacing: -.02em; margin-bottom: 24px; }
.prof-essay h2 em{ font-family: var(--serif); font-style: italic; color: var(--ink-dim); }
.prof-essay p{ font-family: var(--serif); font-size: 19px; line-height: 1.65; color: var(--ink-dim); margin-bottom: 20px; max-width: 56ch; }
.prof-essay p em{ color: var(--ink); }
.prof-essay .pull{ font-family: var(--display); font-size: clamp(28px, 3vw, 36px); line-height: 1.2; color: var(--ink); margin: 32px 0; padding-left: 32px; border-left: 2px solid var(--brass); letter-spacing: -.01em; }
@media (max-width: 980px){
  .prof-hero{ grid-template-columns: 1fr; padding: 56px 24px 48px; }
  .prof-essay{ grid-template-columns: 1fr; gap: 18px; }
}

/* ── FAQ accordion ──────────────────────────────────────────── */
.faq-item{ border-bottom: 1px solid var(--rule-strong); }
.faq-item:first-child{ border-top: 1px solid var(--ink-deep); }
.faq-q{ width: 100%; display: flex; justify-content: space-between; align-items: baseline; gap: 24px; padding: 26px 0; text-align: left; font-family: var(--display); font-size: clamp(22px, 2.6vw, 32px); line-height: 1.15; color: var(--ink); letter-spacing: -.01em; }
.faq-q .mk{ font-family: var(--serif); font-style: italic; font-size: 28px; color: var(--brass); flex-shrink: 0; transition: transform .2s; }
.faq-item.open .faq-q .mk{ transform: rotate(45deg); }
.faq-a{ max-height: 0; overflow: hidden; transition: max-height .3s ease, padding .3s ease; }
.faq-item.open .faq-a{ max-height: 600px; padding-bottom: 28px; }
.faq-a p{ font-family: var(--serif); font-size: 18px; line-height: 1.6; color: var(--ink-dim); max-width: 70ch; }
.faq-a p em{ color: var(--ink); }