/* ── Self-hosted fonts (no Google Fonts request, zero render-blocking) ─── */
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:300; font-display:swap; src:url('../fonts/cormorant-garamond-300-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:italic; font-weight:300; font-display:swap; src:url('../fonts/cormorant-garamond-300-italic.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/cormorant-garamond-400-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:italic; font-weight:400; font-display:swap; src:url('../fonts/cormorant-garamond-400-italic.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:500; font-display:swap; src:url('../fonts/cormorant-garamond-500-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:italic; font-weight:500; font-display:swap; src:url('../fonts/cormorant-garamond-500-italic.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:600; font-display:swap; src:url('../fonts/cormorant-garamond-600-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:italic; font-weight:600; font-display:swap; src:url('../fonts/cormorant-garamond-600-italic.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:normal; font-weight:700; font-display:swap; src:url('../fonts/cormorant-garamond-700-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'Cormorant Garamond'; font-style:italic; font-weight:700; font-display:swap; src:url('../fonts/cormorant-garamond-700-italic.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'DM Sans'; font-style:normal; font-weight:300; font-display:swap; src:url('../fonts/dm-sans-300-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'DM Sans'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/dm-sans-400-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'DM Sans'; font-style:italic; font-weight:400; font-display:swap; src:url('../fonts/dm-sans-400-italic.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'DM Sans'; font-style:normal; font-weight:500; font-display:swap; src:url('../fonts/dm-sans-500-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }
@font-face { font-family:'DM Sans'; font-style:normal; font-weight:600; font-display:swap; src:url('../fonts/dm-sans-600-normal.woff2') format('woff2'); unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD; }

:root {
  --cream: #F8F4EE;
  --cream-alt: #EFE9E0;
  --petal: #C8967A;
  --petal-lt: #E8B898;
  --petal-dark: #A8724E;
  --petal-btn: #8B5E3A;
  --bark: #3A2E24;
  --bark-mid: #5C4A38;
  --text: #2A1F16;
  --white: #FFFFFF;
  --nav-bg: rgba(253, 250, 247, 0.98);
  --footer-bg: #111111;
  --border: #DDD5C8;
  --border-light: rgba(221, 213, 200, .5);
  --shadow-sm: 0 1px 14px rgba(42, 31, 22, .08);
  --shadow: 0 4px 28px rgba(42, 31, 22, .10);
  --shadow-lg: 0 12px 52px rgba(42, 31, 22, .16);
  --radius: 2px;
  --nav-h: 88px;
  --font-serif: 'Cormorant Garamond', Georgia, serif;
  --font-sans: 'DM Sans', system-ui, sans-serif;
  --max-w: 1280px;
  --ease: 0.22s ease;
  --sage: #7A9B8A;
  --sage-lt: rgba(122,155,138,.18);
}

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

html {
  scroll-behavior: smooth
}

html { overflow-x: hidden; }
body {
  font-family: var(--font-sans);
  color: var(--text);
  background: var(--white);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  /* Reserve scrollbar gutter so it doesn't cause layout shift when it appears */
  scrollbar-gutter: stable;
}

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

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

ul {
  list-style: none
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
}

.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--bark);
  color: var(--white);
  padding: 10px 18px;
  z-index: 9999;
  font-size: .85rem;
  transition: top .15s;
}

.skip-link:focus {
  top: 0
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-serif);
  line-height: 1.2;
  color: var(--bark);
  font-weight: 600;
}

h1 {
  font-size: clamp(2rem, 4vw, 3rem)
}

h2 {
  font-size: clamp(1.5rem, 2.8vw, 2.2rem);
  margin-top: 0;
  margin-bottom: 16px;
}

h3 {
  font-size: clamp(1.15rem, 2vw, 1.5rem)
}

h4 {
  font-size: 1.25rem
}

p {
  margin-bottom: 1.2rem;
  color: var(--text);
}

p:last-child {
  margin-bottom: 0
}

strong {
  font-weight: 600
}

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

.section {
  padding: 96px 0
}

.section--sm {
  padding: 56px 0
}

.section--lg {
  padding: 136px 0
}

.text-center {
  text-align: center
}

.text-center>p,
.text-center>.lead {
  max-width: 680px;
  margin-left: auto;
  margin-right: auto;
}

.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

.fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .6s ease, transform .6s ease;
}

.fade-in.visible {
  opacity: 1;
  transform: none;
}

.eyebrow {
  display: block;
  font-family: var(--font-sans);
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--petal-dark);
  margin-bottom: 14px;
}

.rule-divider {
  display: flex;
  align-items: center;
  gap: 20px;
  margin: 28px auto;
  max-width: 300px;
}

.rule-divider::before,
.rule-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}

.rule-divider span {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  color: var(--petal);
  font-style: italic;
}

.btn {
  display: inline-block;
  padding: 15px 40px;
  font-family: var(--font-sans);
  font-size: .76rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  transition: all var(--ease);
  border-radius: var(--radius);
  line-height: 1;
  cursor: pointer;
}

.btn-primary {
  background: var(--bark);
  color: var(--white);
  border: 1.5px solid var(--bark);
}

.btn-primary:hover {
  background: var(--bark-mid);
  border-color: var(--bark-mid);
}

.btn-outline {
  background: transparent;
  color: var(--bark);
  border: 1.5px solid var(--bark);
}

.btn-outline:hover {
  background: var(--bark);
  color: var(--white);
}

.btn-petal {
  background: var(--petal-btn);
  color: var(--white);
  border: 1.5px solid var(--petal-btn);
}

.btn-petal:hover {
  background: var(--petal-dark);
  border-color: var(--petal-dark);
}

/* Navigation */

#header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: var(--nav-h);
  background: transparent;
  transition: background .35s ease, box-shadow .35s ease, border-color .35s ease;
  border-bottom: 1px solid transparent;
}

#header.scrolled {
  background: var(--nav-bg);
  box-shadow: var(--shadow-sm);
  border-bottom-color: var(--border-light);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.nav-bar {
  display: flex;
  flex-direction: row;
  align-items: center;
  height: 100%;
  max-width: var(--max-w);
  margin: 0 auto;
  padding: 0 32px;
}

.nav-socials {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
  margin-right: 12px;
}

.nav-socials a {
  width: 30px;
  height: 30px;
  border-radius: 4px;
  border: 1px solid rgba(255, 255, 255, .5);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, .9);
  transition: all var(--ease);
  flex-shrink: 0;
}

.nav-socials a svg {
  width: 13px;
  height: 13px;
  display: block;
}

.nav-socials a:hover {
  background: rgba(255, 255, 255, .2);
  border-color: white;
}

#header.scrolled .nav-socials a {
  color: var(--bark-mid);
  border-color: rgba(90, 74, 56, .35);
}

#header.scrolled .nav-socials a:hover {
  background: var(--bark);
  border-color: var(--bark);
  color: var(--white);
}

.nav-sep {
  width: 1px;
  height: 18px;
  background: rgba(255, 255, 255, .3);
  margin-right: 12px;
  flex-shrink: 0;
  transition: background var(--ease);
}

#header.scrolled .nav-sep {
  background: var(--border)
}

.nav-left,
.nav-right {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
  flex-shrink: 0;
}

.nav-link {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: .72rem;
  font-weight: 500;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .92);
  padding: 8px 10px;
  white-space: nowrap;
  position: relative;
  transition: color var(--ease);
}

.nav-link:hover,
.nav-link.active {
  color: white;
}

.nav-link.active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 10px;
  right: 10px;
  height: 2px;
  background: rgba(255, 255, 255, .7);
  border-radius: 1px;
}

/* When a dropdown child page is active, highlight the parent nav-link too */
.nav-item:has(.dropdown a[href][class*="active"]) > .nav-link::after,
.nav-item:has(.dropdown-sub a[href][class*="active"]) > .nav-link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 10px;
  right: 10px;
  height: 2px;
  background: rgba(255, 255, 255, .7);
  border-radius: 1px;
}

#header.scrolled .nav-link {
  color: var(--bark)
}

#header.scrolled .nav-link:hover,
#header.scrolled .nav-link.active {
  color: var(--petal-dark);
}

#header.scrolled .nav-link.active::after {
  background: var(--petal);
}

.nav-logo {
  margin: 0 auto;
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.nav-logo img {
  height: 80px;
  width: auto;
  display: block;
  filter: brightness(0) invert(1) drop-shadow(0 1px 6px rgba(0, 0, 0, .55));
  transition: filter var(--ease);
}

#header.scrolled .nav-logo img {
  filter: brightness(0);
}

.nav-item {
  position: relative;
  display: inline-block;
}

.nav-item:hover>.dropdown,
.nav-item:focus-within>.dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}

.dropdown {
  position: absolute;
  top: calc(100% + 10px);
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow-lg);
  min-width: 222px;
  padding: 8px 0;
  opacity: 0;
  visibility: hidden;
  transition: all var(--ease);
  z-index: 200;
}

.dropdown a {
  display: block;
  padding: 10px 20px;
  font-size: .79rem;
  font-family: var(--font-sans);
  color: var(--bark-mid);
  transition: background var(--ease), color var(--ease);
}

.dropdown a:hover {
  background: var(--cream);
  color: var(--bark);
}

.nav-item .nav-item:hover>.dropdown-sub,
.nav-item .nav-item:focus-within>.dropdown-sub {
  opacity: 1;
  visibility: visible;
}

.dropdown-sub {
  position: absolute;
  top: 0;
  left: 100%;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow-lg);
  min-width: 242px;
  padding: 8px 0;
  opacity: 0;
  visibility: hidden;
  transition: all var(--ease);
}

.dropdown-sub a {
  padding: 9px 20px;
  font-size: .77rem;
}

.has-sub>a::after {
  content: ' ›';
  opacity: .5;
  font-size: .85em;
}

.nav-search {
  display: flex;
  align-items: center;
  padding: 8px 7px;
  color: rgba(255, 255, 255, .9);
  transition: color var(--ease);
  text-decoration: none;
}

.nav-search:hover {
  color: white
}

.nav-search svg {
  width: 16px;
  height: 16px;
  display: block;
}

#header.scrolled .nav-search {
  color: var(--bark-mid)
}

#header.scrolled .nav-search:hover {
  color: var(--bark)
}

.nav-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 22px;
  margin-left: 8px;
  font-family: var(--font-sans);
  font-size: .69rem;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .95);
  border: 1.5px solid rgba(255, 255, 255, .8);
  border-radius: var(--radius);
  white-space: nowrap;
  transition: all var(--ease);
  background: transparent;
  flex-shrink: 0;
}

.nav-cta:hover {
  background: rgba(255, 255, 255, .15);
  border-color: white;
  color: white;
}

#header.scrolled .nav-cta {
  color: var(--bark);
  border-color: var(--bark);
}

#header.scrolled .nav-cta:hover {
  background: var(--bark);
  color: var(--white);
}

/* Mobile nav */

.nav-hamburger {
  display: none;
  position: fixed;
  top: 25px;
  right: 18px;
  z-index: 10001;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 38px;
  height: 38px;
  background: none;
  border: none;
  padding: 6px;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transition: opacity .2s ease;
}

body.menu-open .nav-hamburger {
  display: none; /* hide hamburger when dedicated close button is visible inside menu */
}

.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: rgba(255, 255, 255, .95);
  border-radius: 2px;
  transition: all .25s ease;
  box-shadow: 0 1px 4px rgba(0, 0, 0, .6);
}

body.header-scrolled .nav-hamburger span {
  background: var(--bark);
  box-shadow: none;
}
body.menu-open .nav-hamburger span {
  background: var(--bark);
  box-shadow: none;
}

.mobile-menu {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--cream);
  z-index: 10000;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  transform: translateX(100%);
  transition: transform .32s cubic-bezier(.4, 0, .2, 1);
  padding: 20px 0 0;
}

.mobile-menu.open {
  display: flex !important;
  transform: translateX(0);
}

.mobile-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: none;
  border: none;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--bark-mid);
  -webkit-tap-highlight-color: transparent;
  transition: color .15s ease;
}

.mobile-close svg {
  width: 16px;
  height: 16px;
  display: block;
  stroke: currentColor;
  stroke-width: 2.5;
  stroke-linecap: round;
  fill: none;
}

.mobile-close:hover {
  color: var(--bark)
}

.mobile-brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 8px 32px 24px;
  border-bottom: 1px solid rgba(170, 148, 128, .25);
}

.mobile-brand-icon {
  width: 38px;
  height: 38px;
  display: block;
  margin: 0 auto 14px;
  filter: brightness(0);
  opacity: .9;
}

.mobile-brand-name {
  font-family: var(--font-serif);
  font-size: 1.45rem;
  color: var(--bark);
  margin: 0 0 8px;
  font-weight: 500;
  letter-spacing: .01em;
  text-align: center;
}

.mobile-brand-tag {
  font-size: .78rem;
  font-family: var(--font-sans);
  letter-spacing: .01em;
  color: var(--bark-mid);
  line-height: 1.75;
  margin: 0;
  text-align: center;
}

.mobile-nav {
  display: flex;
  flex-direction: column;
  padding: 4px 0;
}

.mobile-link,
.mobile-toggle-sub {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 15px 28px;
  font-family: var(--font-serif);
  font-size: 1.08rem;
  font-weight: 500;
  color: var(--bark);
  letter-spacing: .01em;
  text-decoration: none;
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  border-bottom: 1px solid rgba(170, 148, 128, .18);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background .15s, color .15s;
  position: relative;
}

@media(hover:hover) {

  .mobile-link:hover,
  .mobile-toggle-sub:hover {
    background: rgba(200, 148, 120, .08);
  }

  .mobile-link:hover::before,
  .mobile-toggle-sub:hover::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--petal);
    border-radius: 0 2px 2px 0;
  }
}

.mobile-chevron {
  font-size: .52rem;
  color: var(--petal);
  flex-shrink: 0;
  transition: transform .22s ease;
}

.mobile-toggle-sub[aria-expanded="true"] .mobile-chevron {
  transform: rotate(180deg);
}

.mobile-submenu {
  display: none;
  background: rgba(239, 233, 224, .6);
}

.mobile-submenu.open {
  display: block
}

.mobile-submenu .mobile-toggle-sub,
.mobile-submenu a {
  padding: 12px 28px 12px 44px;
  font-family: var(--font-serif);
  font-size: .9rem;
  font-weight: 400;
  color: var(--bark-mid);
  border-bottom: 1px solid rgba(170, 148, 128, .12);
  display: block;
  text-decoration: none;
}

.mobile-submenu .mobile-toggle-sub {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: none;
  background: none;
  width: 100%;
  font-family: var(--font-serif) !important;
  font-size: .9rem !important;
  font-weight: 400 !important;
}

.mobile-submenu a:hover,
.mobile-submenu .mobile-toggle-sub:hover {
  color: var(--petal-dark);
  background: rgba(200, 148, 120, .07);
}

.mobile-submenu .mobile-submenu a {
  padding-left: 56px;
  font-size: .84rem;
}

.mobile-submenu .mobile-submenu a:hover {
  color: var(--petal-dark)
}

.mobile-bottom {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px 28px;
  flex-shrink: 0;
  margin-top: 0;
}

.mobile-socials {
  display: flex;
  gap: 7px;
  flex-shrink: 0;
}

.mobile-socials a {
  width: 34px;
  height: 34px;
  border: 1px solid rgba(170, 148, 128, .35);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bark-mid);
  text-decoration: none;
  transition: all .18s ease;
}

.mobile-socials a svg {
  width: 13px;
  height: 13px;
  display: block;
}

.mobile-socials a:hover {
  background: var(--bark);
  border-color: var(--bark);
  color: white;
}

.mobile-search-wrap {
  display: flex;
  flex: 1;
  min-width: 0;
}

.mobile-search-input {
  flex: 1;
  min-width: 0;
  padding: 8px 11px;
  border: 1px solid rgba(170, 148, 128, .35);
  border-right: none;
  border-radius: 4px 0 0 4px;
  font-family: var(--font-sans);
  font-size: .8rem;
  color: var(--text);
  background: rgba(255, 255, 255, .65);
  outline: none;
}

.mobile-search-input::placeholder {
  color: var(--bark-mid)
}

.mobile-search-input:focus {
  background: white;
  border-color: var(--petal);
}

.mobile-search-btn {
  padding: 8px 12px;
  background: var(--petal);
  color: white;
  border: none;
  border-radius: 0 4px 4px 0;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  font-family: var(--font-sans);
  cursor: pointer;
  flex-shrink: 0;
}

body.menu-open {
  overflow: hidden
}

/* Hero */

.hero {
  position: relative;
  overflow: hidden;
  height: 100vh;
  height: 100dvh;
  /* Mobile: JS sets --hero-h as static px (no response to address bar).
     Desktop: 100dvh is stable (no address bar to change it). */
  height: var(--hero-h, 100dvh);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  background: #F0EDE8;
}

.hero-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  /* Prevent GPU recompositing on scroll */
  transform: translateZ(0);
  backface-visibility: hidden;
  will-change: transform;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
      rgba(28, 20, 12, .55) 0%,
      rgba(28, 20, 12, .18) 35%,
      rgba(28, 20, 12, .18) 55%,
      rgba(28, 20, 12, .68) 100%);
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 860px;
  padding: calc(var(--nav-h) + 32px) 32px 64px;
  animation: heroUp .9s ease both;
  /* Pause until fonts loaded — prevents animation playing with fallback font.
     JS (document.fonts.ready) unpauses it, giving consistent first-load experience. */
  animation-play-state: paused;
}

@keyframes heroUp {
  from {
    opacity: 0;
    transform: translateY(28px);
  }

  to {
    opacity: 1;
    transform: none;
  }
}

.hero h1 {
  font-size: clamp(3.2rem, 7vw, 6.5rem);
  color: var(--white);
  line-height: 1.05;
  margin-bottom: 28px;
  font-weight: 500;
  text-shadow: 0 2px 24px rgba(0, 0, 0, .55), 0 4px 48px rgba(0, 0, 0, .35);
}

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

.hero-tag {
  display: block;
  font-family: var(--font-sans);
  font-size: .68rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .95);
  margin-bottom: 32px;
  line-height: 2.2;
  text-shadow: 0 1px 12px rgba(0, 0, 0, .7), 0 2px 24px rgba(0, 0, 0, .45);
}

.hero 

/* ═══════════════════════════════════════════════════════════════════════
   PAGE HERO — Complete height & image position controls
   ═══════════════════════════════════════════════════════════════════════

   HOW HEIGHT WORKS:
   • height: Xvw  → X% of the browser window width (scales with screen)
   • max-height   → hard ceiling so it never gets too tall
   • min-height   → floor so it never collapses

   HOW IMAGE POSITION WORKS:
   • Each hero <img> has an inline style="object-position: X% Y%"
   • Change Y% per-page: 20% = more top/faces, 50% = center, 70% = lower
   • The CSS default below applies if no inline style is set

   ═══════════════════════════════════════════════════════════════════════ */

/* ── MOBILE FIRST: phones ≤480px — FIXED HEIGHT (prevents iOS jump bug) ──
   Do NOT use vw, vh, or % here — they cause iOS address-bar reflow.
   Change px value to resize on phones.
   ──────────────────────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .page-hero {
    height: 440px;         /* ← PHONE HEIGHT (fixed px — DO NOT change to vw/vh) */
    min-height: 0;
    max-height: 440px;
  }
  .page-hero-img {
    position: fixed;       /* frozen relative to hero via transform parent = no jump */
    top: 0;
    left: 0;
    width: 100%;
    height: 440px;         /* must match height above */
    object-fit: cover;
    object-position: center 35%; /* ← PHONE image position (overridden by inline style per-page) */
    backface-visibility: hidden;
  }
}
/* ── Hero content overlay & breadcrumbs ─────────────────────────────── */
.page-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(28,20,12,.88) 0%, rgba(28,20,12,.35) 60%, rgba(28,20,12,.12) 100%);
}
.page-hero-content {
  position: relative;
  z-index: 1;
  width: 100%;
  padding: calc(var(--nav-h) + 80px) 0 64px;
  text-align: center;
}
.page-hero-content h1 {
  color: var(--white);
  font-weight: 500;
  font-size: clamp(2.4rem, 5vw, 4.2rem);
  text-shadow: 0 2px 8px rgba(0,0,0,.5);
}
.page-hero-content p {
  color: rgba(255,255,255,.88);
  max-width: 600px;
  margin: 14px auto 0;
}
.page-hero-content .eyebrow {
  color: rgba(255,255,255,.90);
  text-shadow: 0 1px 4px rgba(0,0,0,.45);
}
.breadcrumb {
  font-size: .74rem;
  color: rgba(255,255,255,.7);
  margin-bottom: 16px;
  text-shadow: 0 1px 3px rgba(0,0,0,.4);
}
.breadcrumb a { color: rgba(255,255,255,.85); }
.breadcrumb a:hover { color: var(--petal-lt); }
.page-hero-plain {
  background: var(--bark);
  padding: calc(var(--nav-h) + 64px) 0 64px;
  text-align: center;
  border-bottom: 1px solid rgba(248,244,238,.1);
}
@media(max-width:768px) {
  .page-hero-content { padding: calc(var(--nav-h) + 40px) 0 48px; }
}


/* ── TABLET (481px – 768px) ──────────────────────────────────────────────
   Change height: Xvw to resize. Change max-height cap.
   ──────────────────────────────────────────────────────────────────────── */
@media (min-width: 481px) and (max-width: 768px) {
  .page-hero {
    height: 65vw;          /* ← TABLET HEIGHT */
    max-height: 520px;     /* ← TABLET CAP */
    min-height: 280px;
  }
}

/* ── DESKTOP BASE (769px – 1439px) ──────────────────────────────────────
   This is the main rule for laptops and standard monitors.
   Change height: Xvw — every 5vw ≈ 65px at 1280px wide.
   Change max-height to allow taller heroes on wide screens.
   ──────────────────────────────────────────────────────────────────────── */
.page-hero {
  position: relative;
  height: 45vw;            /* ← DESKTOP HEIGHT: 45vw = ~576px at 1280px */
  max-height: 600px;       /* ← DESKTOP CAP: raise to allow taller heroes */
  min-height: 320px;       /* ← DESKTOP FLOOR */
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: var(--bark);
  touch-action: pan-y;
  -webkit-overflow-scrolling: touch;
  transform: translateZ(0);
}

/* ── IMAGE DEFAULT POSITION (all screens unless overridden inline per-page) ──
   To reposition a specific page's hero image, add this to the <img> tag:
   style="object-position: center 25%;"  (lower % = more top/faces)
   ──────────────────────────────────────────────────────────────────────── */
.page-hero-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%; /* ← CSS DEFAULT: overridden per-page via inline style */
  transform: translateZ(0);
  backface-visibility: hidden;
  will-change: transform;
}

/* ── LARGE DESKTOP / ULTRAWIDE (1440px and wider) ────────────────────────
   On very wide monitors, 45vw gets very tall. Cap it here.
   Raise max-height if you want taller heroes on ultrawide.
   ──────────────────────────────────────────────────────────────────────── */
@media (min-width: 1440px) {
  .page-hero {
    height: 40vw;          /* ← ULTRAWIDE HEIGHT */
    max-height: 700px;     /* ← ULTRAWIDE CAP */
  }
}

/* ── Keyboard focus styles (WCAG 2.4.7) ───────────────────────────────── */
:focus-visible {
  outline: 3px solid var(--petal);
  outline-offset: 3px;
  border-radius: 2px;
}
button:focus-visible,
a:focus-visible {
  outline: 3px solid var(--petal);
  outline-offset: 3px;
}

/* ── Footer map: commented out for now, uncomment to re-enable ─────────── */
.footer-map-wrap { display: none; }
/* svc-benefit-icon color handled via ::before diamond */

/* ═══════════════════════════════════════════════════════════════════════
   ORNAMENTAL SECTION DIVIDERS — service pages
   ═══════════════════════════════════════════════════════════════════════ */
.svc-ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 0;
  color: var(--petal-dark);
}
.svc-ornament::before,
.svc-ornament::after {
  content: '';
  flex: 1;
  max-width: 120px;
  height: 1px;
  background: linear-gradient(to right, transparent, var(--petal), transparent);
}

.svc-ornament-glyph {
  font-size: .75rem;
  letter-spacing: .2em;
  color: var(--petal-dark);
  opacity: .8;
}

/* Subtle full-width rule divider */
.svc-rule {
  border: none;
  border-top: 1px solid var(--border);
  margin: 48px 0;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

/* Pull quote — refined version */
.svc-pullquote {
  position: relative;
  border-left: 3px solid var(--petal);
  padding: 32px 40px;
  margin: 0;
  background: var(--cream-alt);
  border-radius: 0 8px 8px 0;
}
/* When pullquote sits inline next to sibling paragraphs/headings within a section,
   restore breathing room. When it's the sole child, margin stays 0 (flex gap handles it). */
p + .svc-pullquote,
h2 + .svc-pullquote,
h3 + .svc-pullquote { margin-top: 32px; }
.svc-pullquote + p,
.svc-pullquote + h2,
.svc-pullquote + h3 { margin-top: 32px; }
.svc-pullquote::before {
  content: '\201C';
  position: absolute;
  top: -8px;
  left: 20px;
  font-family: var(--font-serif);
  font-size: 4rem;
  color: var(--petal);
  opacity: .3;
  line-height: 1;
}
.svc-pullquote p {
  font-family: var(--font-serif);
  font-size: clamp(1.2rem, 2.2vw, 1.6rem);
  font-style: italic;
  font-weight: 400;
  line-height: 1.65;
  color: var(--bark);
  margin: 0 0 12px;
  max-width: 100%;
}
.svc-pullquote cite {
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--petal-dark);
  font-style: normal;
  font-family: var(--font-sans);
}

/* Dark band pull quote */
.svc-quote-dark {
  background: var(--bark);
  padding: 64px 40px;
  text-align: center;
  margin: 0;
}
.svc-quote-dark p {
  font-family: var(--font-serif);
  font-size: clamp(1.4rem, 2.8vw, 2.2rem);
  font-style: italic;
  font-weight: 300;
  line-height: 1.55;
  color: var(--cream);
  max-width: 760px;
  margin: 0 auto 16px;
}
.svc-quote-dark cite {
  font-size: .7rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--petal-lt);
  font-style: normal;
  font-family: var(--font-sans);
}

/* Sage/petal accent bar */
.svc-accent-bar {
  height: 4px;
  background: linear-gradient(to right, var(--sage), var(--petal), var(--bark));
  margin: 56px 0;
  border-radius: 2px;
  opacity: .35;
}

/* Full-width cream band for text-only sections */
.svc-band-cream {
  background: var(--cream);
  padding: 64px 0;
  margin: 0;
}
.svc-band-sage {
  background: rgba(122,155,138,.12);
  padding: 56px 0;
  border-top: 1px solid rgba(122,155,138,.2);
  border-bottom: 1px solid rgba(122,155,138,.2);
  margin: 48px 0;
}

@media (max-width: 768px) {
  .svc-pullquote p { font-size: 1.15rem; }
  .svc-quote-dark { padding: 48px 24px; }
}


/* ═══════════════════════════════════════════════════════════════════════
   LAYOUT COMPONENTS
   ═══════════════════════════════════════════════════════════════════════ */

.section { padding: 96px 0; }
.section--lg { padding: 128px 0; }

.grid-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 48px; }
.grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 32px; }
.grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 28px; }

/* ── Service page layout ─────────────────────────────────────────────── */
.svc-layout {
  display: grid;
  grid-template-columns: minmax(0,1fr) 340px;
  gap: 64px;
  align-items: start;
  overflow: visible;
}
.svc-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 44px;
}
.svc-main h2 { font-size: clamp(1.7rem,3vw,2.4rem); margin: 0 0 20px; }
.svc-main h3 { font-size: 1.35rem; margin: 0 0 14px; }
.svc-main p { font-size: 1rem; line-height: 1.87; color: var(--text); max-width: 720px; }
.svc-sidebar { position: sticky; top: calc(var(--nav-h) + 24px); align-self: start; overflow: visible; }

.svc-intro { padding: 0 0 8px; }
.svc-intro-headline { font-family: var(--font-serif); font-size: clamp(1.45rem,2.8vw,2rem); font-weight: 500; color: var(--bark); line-height: 1.22; margin: 0 0 20px; }
.svc-lead { font-family: var(--font-serif); font-size: clamp(1.28rem,2.2vw,1.7rem); line-height: 1.55; font-weight: 400; color: var(--bark); max-width: 840px; margin: 0 auto 1.25rem; text-align: center; letter-spacing: .01em; padding: 18px 24px; border-radius: 8px; background: linear-gradient(135deg,rgba(200,148,122,.12) 0%,rgba(232,184,152,.08) 100%); }

.svc-section { padding: 0; margin: 0; clear: both; }
.svc-section-cream { margin: 0; padding: 36px 40px; background: var(--cream); border-radius: 12px; text-align: center; }
.svc-section-cream p, .svc-section-cream h2, .svc-section-cream h3 { text-align: center; max-width: 720px; margin-left: auto; margin-right: auto; }
.svc-section-heading { font-family: var(--font-serif); font-size: clamp(1.9rem,2.2vw,1.95rem); font-weight: 500; color: var(--bark); margin: 0 0 24px; line-height: 1.25; }
.svc-section-intro { font-size: 1rem; line-height: 1.85; color: var(--text); margin: 0 0 28px; max-width: 720px; }

.svc-two-col { display: grid; grid-template-columns: 1fr 380px; gap: 52px; align-items: center; }
.svc-col-img img { width: 100%; border-radius: 10px; box-shadow: var(--shadow); display: block; height: 360px; object-fit: cover; object-position: center 25%; }

.svc-clean-list, .svc-main ul { list-style: none; padding: 0; margin: 16px 0 24px; max-width: 680px; display: flex; flex-direction: column; gap: 10px; }
.svc-clean-list li, .svc-main ul li { display: flex; align-items: flex-start; gap: 14px; padding: 16px 18px; background: var(--white); border: 1px solid var(--border); border-radius: 6px; font-size: .97rem; line-height: 1.72; color: var(--text); max-width: 680px; }
.svc-clean-list li::before, .svc-main ul li::before { content: ''; display: block; width: 8px; height: 8px; background: var(--petal-dark); transform: rotate(45deg); border-radius: 1px; flex-shrink: 0; margin-top: 7px; }
.svc-icon-list li::before { display: none !important; content: none !important; }
.svc-icon-list { list-style: none !important; padding: 0 !important; }
.svc-clean-list li strong, .svc-main ul li strong { color: var(--bark); font-weight: 600; }

.svc-main blockquote, .svc-quote { border-left: 3px solid var(--petal); padding: 18px 26px; margin: 32px 0; background: var(--cream); font-family: var(--font-serif); font-size: 1.12rem; font-style: italic; color: var(--bark); border-radius: 0 8px 8px 0; line-height: 1.75; clear: both; max-width: 680px; }

.svc-cta-final { text-align: center; padding: 60px 32px 20px; clear: both; }
.svc-cta-final h3 { font-family: var(--font-serif); font-size: clamp(1.3rem,2.5vw,1.8rem); font-weight: 500; color: var(--bark); margin: 0 0 12px; }
.svc-cta-final p { font-size: .97rem; color: var(--bark-mid); margin: 0 auto 28px; max-width: 480px; line-height: 1.75; }

.svc-prose-section { max-width: 760px; margin-bottom: 12px; }

/* ── Sidebar boxes ───────────────────────────────────────────────────── */
.sidebar-box { background: var(--cream); border: 1px solid var(--border); border-radius: 4px; padding: 28px; margin-bottom: 24px; }
.sidebar-box h4 { font-size: .95rem; margin-bottom: 14px; padding-bottom: 12px; border-bottom: 1px solid var(--border); }
.sidebar-box ul li { margin-bottom: 10px; }
.sidebar-box a { font-size: .85rem; color: var(--bark-mid); transition: color var(--ease); }
.sidebar-box a:hover { color: var(--petal-dark); }
.sidebar-box .btn-primary,
.post-sidebar .sidebar-box .btn-primary {
  background: var(--bark) !important; color: var(--white) !important; border: 2px solid var(--bark) !important;
  font-weight: 600 !important; letter-spacing: .06em !important; display: block !important;
  text-align: center !important; padding: 14px 20px !important;
}

/* ── Service cards (services index page) ────────────────────────────── */
.service-card { background: var(--white); border: 1px solid var(--border); border-radius: 4px; padding: 40px 32px; transition: all var(--ease); position: relative; min-width: 0; }
.service-card::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: var(--petal); transform: scaleX(0); transform-origin: left; transition: transform .3s ease; }
.service-card:hover::after { transform: scaleX(1); }
.service-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.service-card h3 { font-size: 1.45rem; margin-bottom: 12px; }
.service-card p { font-size: .9rem; margin-bottom: 22px; line-height: 1.72; }
.svc-mark { display: inline-block; width: 36px; height: 1px; background: var(--petal); margin-bottom: 22px; }

/* ── Benefit cards ───────────────────────────────────────────────────── */
.svc-benefit-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 28px; }
.svc-benefit-grid-2col, .svc-benefit-grid.grid-2col { grid-template-columns: repeat(2,1fr) !important; }
.svc-benefit-card { background: var(--white); border: 1px solid var(--border); border-radius: 8px; padding: 24px 20px; position: relative; display: flex; flex-direction: column; text-align: center; }
.svc-benefit-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin: 0 auto 16px;
  font-size: 0;
  line-height: 0;
  color: transparent;
}
.svc-benefit-icon::before {
  content: '';
  display: block;
  width: 10px;
  height: 10px;
  background: var(--petal-dark);
  transform: rotate(45deg);
  border-radius: 1px;
}
.svc-benefit-card p { font-size: .9rem; line-height: 1.7; color: var(--text); margin: 0; }
.svc-benefit-card p strong { display: block; color: var(--bark); font-weight: 600; margin-bottom: 4px; font-size: .88rem; }

/* ── Reason list ─────────────────────────────────────────────────────── */
.reason-list { display: flex; flex-direction: column; gap: 24px; margin: 28px 0; }
.reason-item { display: flex; gap: 20px; align-items: flex-start; padding: 24px; background: var(--cream); border: 1px solid var(--border); border-radius: 4px; }
.reason-icon { width: 40px; height: 40px; border-radius: 4px; background: var(--petal); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-family: var(--font-serif); font-size: 1.2rem; font-style: italic; color: white; }
.reason-item h4 { font-size: 1rem; margin-bottom: 6px; color: var(--bark); }
.reason-item p { font-size: .9rem; margin: 0; color: var(--bark-mid); }

/* ═══════════════════════════════════════════════════════════════════════
   TEAM & BIO
   ═══════════════════════════════════════════════════════════════════════ */
.team-card { text-align: center; padding: 36px 24px 32px; border: 1px solid var(--border); border-radius: 4px; transition: all var(--ease); background: var(--white); }
.team-card:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.team-photo { width: 130px; height: 130px; border-radius: 50%; object-fit: cover; object-position: top center; margin: 0 auto 18px; border: 2px solid var(--border); display: block; }
.team-photo-placeholder { width: 130px; height: 130px; border-radius: 50%; background: var(--cream-alt); border: 2px solid var(--border); margin: 0 auto 18px; display: none; align-items: center; justify-content: center; font-family: var(--font-serif); font-size: 2rem; font-style: italic; color: var(--petal-dark); }
.team-card h3 { font-size: 1.1rem; margin-bottom: 4px; }
.team-card .title { font-size: .68rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--petal-dark); margin-bottom: 6px; }
.team-card .creds { font-size: .75rem; color: var(--bark-mid); margin-bottom: 12px; }
.team-card p { font-size: .85rem; margin-bottom: 18px; color: var(--bark-mid); line-height: 1.65; }

.bio-layout { display: grid; grid-template-columns: 280px 1fr; gap: 72px; align-items: start; }
.bio-sidebar { position: sticky; top: calc(var(--nav-h) + 32px); }
.bio-photo-wrap { width: 100%; background: var(--cream-alt); border: 1px solid var(--border); border-radius: 4px; overflow: hidden; margin-bottom: 24px; }
.bio-photo-wrap img { width: 100%; height: auto; display: block; object-fit: cover; object-position: top center; }
.bio-photo-initials { width: 100%; height: 180px; display: none; align-items: center; justify-content: center; font-family: var(--font-serif); font-size: 3rem; font-style: italic; color: var(--petal); background: var(--cream-alt); }
.bio-meta-list li { padding: 10px 0; border-bottom: 1px solid var(--border); font-size: .85rem; color: var(--bark-mid); }
.bio-meta-list li strong { display: block; font-size: .67rem; text-transform: uppercase; letter-spacing: .12em; color: var(--bark); margin-bottom: 2px; }
.bio-body p { font-size: 1rem; line-height: 1.87; margin-bottom: 1.3rem; }
.bio-body h3 { font-size: 1.3rem; margin: 32px 0 12px; }
.bio-quote { border-left: 3px solid var(--petal); padding: 18px 24px; margin: 32px 0; background: var(--cream); font-family: var(--font-serif); font-size: 1.2rem; font-style: italic; color: var(--bark); }
.bio-note { background: var(--cream); border: 1px solid var(--border); border-left: 3px solid var(--petal); border-radius: 0 4px 4px 0; padding: 12px 16px; font-size: .86rem; margin-bottom: 28px; color: var(--bark-mid); }

.therapist-card-grid { display: grid; grid-template-columns: repeat(auto-fit,minmax(200px,1fr)); gap: 20px; margin: 28px 0; }
.therapist-card { text-align: center; }
.therapist-card img { width: 100%; height: 240px; object-fit: cover; object-position: top; border-radius: 4px; box-shadow: var(--shadow); display: block; }
.therapist-card strong { display: block; font-family: var(--font-serif); font-size: 1rem; color: var(--bark); margin-top: 10px; }
.therapist-card span { font-size: .72rem; color: var(--petal-dark); font-weight: 600; letter-spacing: .07em; text-transform: uppercase; }
.therapists-page-intro { text-align: center; max-width: 720px; margin: 0 auto 56px; }

/* ═══════════════════════════════════════════════════════════════════════
   BLOG
   ═══════════════════════════════════════════════════════════════════════ */
.blog-card { border: 1px solid var(--border); border-radius: 4px; overflow: hidden; background: var(--white); transition: all var(--ease); display: flex; flex-direction: column; }
.blog-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); }
.blog-card-img { width: 100%; aspect-ratio: 16/9; overflow: hidden; background: var(--cream-alt); }
.blog-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.blog-card:hover .blog-card-img img { transform: scale(1.04); }
.blog-card-body { padding: 28px; flex: 1; display: flex; flex-direction: column; }
.blog-meta { font-size: .67rem; letter-spacing: .12em; text-transform: uppercase; color: var(--petal-dark); font-weight: 600; margin-bottom: 10px; }
.blog-card h3 { font-size: 1.3rem; margin-bottom: 10px; line-height: 1.3; }
.blog-card p { font-size: .88rem; margin-bottom: 18px; color: var(--bark-mid); flex: 1; }
.blog-card-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.blog-card-date, .blog-card-cat { font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; color: var(--bark-mid); font-family: var(--font-sans); }
.blog-card-sep { color: var(--petal); font-size: .75rem; }
.blog-card-title { font-family: var(--font-serif); font-size: 1.12rem; font-weight: 500; line-height: 1.4; margin-bottom: 10px; }
.blog-card-title a { color: var(--bark); text-decoration: none; }
.blog-card-title a:hover { color: var(--petal-dark); }
.blog-card-excerpt { font-size: .86rem; line-height: 1.7; color: var(--bark-mid); margin-bottom: 16px; }
.blog-card-link { font-size: .75rem; letter-spacing: .1em; text-transform: uppercase; color: var(--petal-dark); text-decoration: none; font-weight: 500; }
.blog-card-link:hover { color: var(--petal); }

.post-layout { display: grid; grid-template-columns: 1fr 300px; gap: 72px; align-items: start; }
.post-body h2 { font-size: 1.85rem; margin: 44px 0 16px; }
.post-body h3 { font-size: 1.35rem; margin: 32px 0 12px; }
.post-body p { font-size: 1rem; line-height: 1.87; margin-bottom: 1.3rem; }
.post-body ul { list-style: disc; padding-left: 24px; margin-bottom: 1.3rem; }
.post-body ul li, .post-body ol li { margin-bottom: 8px; font-size: .97rem; line-height: 1.77; }
.post-body ol { padding-left: 24px; margin-bottom: 1.3rem; }
.post-body blockquote { border-left: 3px solid var(--petal); padding: 18px 24px; margin: 36px 0; background: var(--cream); font-family: var(--font-serif); font-size: 1.25rem; font-style: italic; color: var(--bark); border-radius: 0 4px 4px 0; }
.post-sidebar { position: sticky; top: calc(var(--nav-h) + 32px); }

.author-box { display: flex; gap: 18px; align-items: flex-start; padding: 32px; background: var(--cream); border: 1px solid var(--border); border-radius: 4px; margin-top: 52px; }
.author-photo { width: 72px; height: 72px; border-radius: 50%; object-fit: cover; object-position: top; border: 2px solid var(--border); flex-shrink: 0; }
.author-placeholder { width: 72px; height: 72px; border-radius: 50%; background: var(--cream-alt); border: 2px solid var(--border); display: none; align-items: center; justify-content: center; font-family: var(--font-serif); font-size: 1.3rem; font-style: italic; color: var(--petal-dark); flex-shrink: 0; }
.author-info h4 { font-size: 1rem; margin-bottom: 4px; }
.author-info span { font-size: .7rem; text-transform: uppercase; letter-spacing: .1em; color: var(--petal-dark); font-weight: 600; }
.author-info p { font-size: .85rem; margin-top: 8px; }

/* ═══════════════════════════════════════════════════════════════════════
   FAQ
   ═══════════════════════════════════════════════════════════════════════ */
.faq-list { max-width: 760px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-question { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 24px 0; font-family: var(--font-serif); font-size: 1.15rem; font-weight: 500; text-align: left; color: var(--bark); cursor: pointer; transition: color var(--ease); gap: 16px; }
.faq-question:hover { color: var(--petal-dark); }
.faq-icon { width: 26px; height: 26px; border: 1.5px solid var(--border); border-radius: 50%; display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 1rem; line-height: 1; color: var(--bark-mid); transition: all var(--ease); font-family: var(--font-sans); }
.faq-item.open .faq-icon { background: var(--bark); border-color: var(--bark); color: var(--white); }
.faq-answer { display: none; padding: 0 0 24px; color: var(--bark-mid); line-height: 1.82; font-size: .96rem; }
.faq-item.open .faq-answer { display: block; }

/* ═══════════════════════════════════════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════════════════════════════════════ */
.contact-grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 80px; align-items: start; }
.contact-rows { list-style: none; display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--border-light); }
.contact-row { display: grid; grid-template-columns: 120px 1fr; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--border-light); align-items: baseline; }
.contact-row dt { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--bark-mid); padding-top: 2px; }
.contact-row dd { font-size: .96rem; color: var(--text); margin: 0; }
.contact-row dd a { color: var(--text); text-decoration: none; }
.contact-row dd a:hover { color: var(--petal-dark); }
.form-group { margin-bottom: 20px; }
.form-group label { display: block; font-size: .7rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; margin-bottom: 8px; color: var(--bark); }
.form-group label.checkbox-label { font-size: .88rem; font-weight: 400; letter-spacing: 0; text-transform: none; margin-bottom: 0; }
.form-group input, .form-group textarea, .form-group select { width: 100%; padding: 13px 16px; border: 1px solid var(--border); border-radius: var(--radius); font-family: var(--font-sans); font-size: .95rem; color: var(--text); background: var(--white); transition: border-color var(--ease), box-shadow var(--ease); -webkit-appearance: none; appearance: none; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { outline: none; border-color: var(--petal); box-shadow: 0 0 0 3px rgba(200,150,122,.18); }
.form-group textarea { resize: vertical; min-height: 130px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

/* ═══════════════════════════════════════════════════════════════════════
   QUOTES & CALLOUTS
   ═══════════════════════════════════════════════════════════════════════ */
.pull-quote { background: var(--bark); padding: 88px 0; text-align: center; }
.pull-quote blockquote { font-family: var(--font-serif); font-size: clamp(1.55rem,3.5vw,2.5rem); font-style: italic; font-weight: 300; line-height: 1.55; max-width: 840px; margin: 0 auto; color: var(--cream); }
.pull-quote cite { display: block; margin-top: 24px; font-family: var(--font-sans); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--petal-lt); font-style: normal; }
.quote-band { background: var(--cream); border-left: 4px solid var(--petal); padding: 28px 32px; margin: 48px 0; font-family: var(--font-serif); font-size: 1.25rem; font-style: italic; color: var(--bark); border-radius: 0 4px 4px 0; }
.quote-band cite { display: block; margin-top: 10px; font-family: var(--font-sans); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--petal-dark); font-style: normal; }

/* ═══════════════════════════════════════════════════════════════════════
   PRESS
   ═══════════════════════════════════════════════════════════════════════ */
.press-feature { padding: 32px; border: 1px solid var(--border); border-radius: 4px; background: var(--white); transition: all var(--ease); margin-bottom: 20px; }
.press-feature:hover { box-shadow: var(--shadow); transform: translateX(4px); }
.press-outlet { font-size: .68rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--petal-dark); margin-bottom: 8px; }
.press-feature h3 { margin-top: 8px; margin-bottom: 12px; line-height: 1.45; }
.press-feature > p:first-of-type { margin-top: 12px; color: var(--bark-mid); line-height: 1.75; }

/* ═══════════════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════════════ */
#footer { background: #111; color: rgba(248,244,238,.82); padding: 80px 0 0; position: relative; overflow: hidden; border-top: 3px solid var(--sage); }
#footer::before { content: ''; position: absolute; right: -20px; top: -30px; width: 380px; height: 380px; background: url('../images/fbc-logo-f-white.png') center/contain no-repeat; opacity: .14; pointer-events: none; }
#footer::after { content: ''; position: absolute; left: -60px; bottom: -60px; width: 260px; height: 260px; border-radius: 50%; background: var(--sage); opacity: .06; pointer-events: none; }
.footer-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 48px; padding-bottom: 64px; border-bottom: 1px solid rgba(248,244,238,.1); }
.footer-brand p { font-size: .86rem; line-height: 1.8; max-width: 260px; margin-top: 16px; color: rgba(248,244,238,.70); }
.footer-brand-mark { display: flex; align-items: center; gap: 14px; margin-bottom: 4px; }
.footer-brand-mark img { width: 48px; height: 48px; opacity: .80; }
.footer-logo-text { font-family: var(--font-serif); font-size: 1.5rem; font-weight: 500; color: rgba(248,244,238,.95); letter-spacing: .01em; font-style: italic; }
.footer-col h4 { color: rgba(248,244,238,.95); font-family: var(--font-sans); font-size: .66rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; margin-bottom: 18px; padding-bottom: 10px; border-bottom: 1px solid var(--sage-lt); }
.footer-col ul li { margin-bottom: 10px; font-size: .86rem; color: rgba(248,244,238,.60); }
.footer-col a { font-size: .86rem; color: rgba(248,244,238,.60); transition: color var(--ease); }
.footer-col a:hover { color: var(--petal-lt); }
.footer-socials { display: flex; gap: 8px; margin-top: 20px; }
.footer-socials a { width: 36px; height: 36px; border: 1px solid rgba(248,244,238,.2); border-radius: 4px; display: flex; align-items: center; justify-content: center; color: rgba(248,244,238,.65); transition: all var(--ease); }
.footer-socials a svg { width: 20px; height: 20px; display: block; }
.footer-socials a:hover { background: var(--petal); border-color: var(--petal); color: var(--white); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; padding: 24px 0; font-size: .74rem; color: rgba(248,244,238,.38); flex-wrap: wrap; gap: 12px; }
.footer-bottom a { color: rgba(248,244,238,.38); transition: color var(--ease); }
.footer-bottom a:hover { color: var(--petal-lt); }
.footer-bottom-links { display: flex; gap: 24px; }

/* ═══════════════════════════════════════════════════════════════════════
   SEARCH OVERLAY
   ═══════════════════════════════════════════════════════════════════════ */
.search-overlay { display: none; position: fixed; inset: 0; background: rgba(28,20,12,.85); z-index: 10002; align-items: flex-start; justify-content: center; padding-top: 160px; backdrop-filter: blur(4px); }
.search-overlay.open { display: flex; }
.search-box { width: 100%; max-width: 680px; margin: 0 24px; }
.search-input-wrap { display: flex; background: var(--white); border-radius: 4px; overflow: hidden; box-shadow: var(--shadow-lg); }
.search-input-wrap input { flex: 1; padding: 18px 24px; font-size: 1.1rem; border: none; outline: none; font-family: var(--font-sans); color: var(--text); }
.search-input-wrap button { padding: 18px 24px; background: var(--petal); color: white; font-family: var(--font-sans); font-size: .8rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; border: none; cursor: pointer; }
.search-input-wrap button:hover { background: var(--petal-dark); }
.search-close { display: block; text-align: right; margin-bottom: 16px; }
.search-close button { color: rgba(255,255,255,.8); font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; font-family: var(--font-sans); }
.search-results { margin-top: 24px; max-height: 400px; overflow-y: auto; }
.search-result-item { background: var(--white); border-radius: 4px; padding: 16px 20px; margin-bottom: 8px; display: block; color: var(--text); transition: all var(--ease); }
.search-result-item:hover { background: var(--cream); transform: translateX(4px); }
.search-result-item h4 { font-size: .95rem; color: var(--bark); margin-bottom: 4px; }
.search-result-item p { font-size: .82rem; color: var(--bark-mid); margin: 0; }
.search-result-cat { font-size: .65rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--petal-dark); margin-bottom: 4px; }
.search-no-results { color: rgba(255,255,255,.8); text-align: center; padding: 24px; font-family: var(--font-serif); font-size: 1.1rem; font-style: italic; }

/* ── Mobile search modal ─────────────────────────────────────────────── */
#mobile-search-modal { display: none; position: fixed; inset: 0; z-index: 10003; background: rgba(20,14,8,.72); backdrop-filter: blur(6px); align-items: flex-start; justify-content: center; padding: 60px 20px 0; }
#mobile-search-modal.open { display: flex; }
.msm-box { width: 100%; max-width: 520px; background: var(--white); border-radius: 8px; box-shadow: 0 20px 60px rgba(0,0,0,.4); overflow: hidden; }
.msm-top { display: flex; border-bottom: 1px solid var(--border); }
.msm-input { flex: 1; padding: 16px 18px; font-family: var(--font-sans); font-size: 1rem; border: none; outline: none; color: var(--text); background: transparent; }
.msm-input::placeholder { color: var(--bark-mid); }
.msm-close { width: 52px; flex-shrink: 0; background: none; border: none; border-left: 1px solid var(--border); cursor: pointer; color: var(--bark-mid); display: flex; align-items: center; justify-content: center; }
.msm-close svg { width: 14px; height: 14px; stroke: currentColor; stroke-width: 2.5; stroke-linecap: round; fill: none; }
.msm-close:hover { background: var(--cream); color: var(--bark); }
.msm-submit { width: 100%; padding: 13px; background: var(--petal); color: white; border: none; font-family: var(--font-sans); font-size: .78rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; }
.msm-submit:hover { background: var(--petal-dark); }
.msm-results { max-height: 50vh; overflow-y: auto; }
.msm-result { display: block; padding: 14px 18px; border-bottom: 1px solid var(--border); text-decoration: none; color: var(--text); transition: background .1s ease; }
.msm-result:hover { background: var(--cream); }
.msm-result strong { display: block; font-family: var(--font-serif); font-size: .95rem; color: var(--bark); margin: 3px 0; }
.msm-result span { display: block; font-size: .78rem; color: var(--bark-mid); line-height: 1.5; }
.msm-cat { display: block; font-size: .62rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--petal-dark); }
.msm-no-results { padding: 24px 18px; color: var(--bark-mid); font-family: var(--font-serif); font-style: italic; font-size: 1rem; text-align: center; }

/* ═══════════════════════════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS — COMPONENTS
   ═══════════════════════════════════════════════════════════════════════ */
@media(max-width:1100px) {
  .nav-socials, .nav-sep { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .post-layout { grid-template-columns: 1fr; }
  .post-sidebar { position: static; }
  .bio-layout { grid-template-columns: 240px 1fr; gap: 48px; }
  .grid-4 { grid-template-columns: repeat(2,1fr); }
}

@media(max-width:1024px) {
  .svc-layout { grid-template-columns: 1fr; gap: 0; }
  .svc-main { width: 100%; max-width: 860px; margin: 0 auto; padding: 0 32px; }
  .svc-main p, .svc-section-intro, .svc-main ul, .svc-clean-list, .svc-main blockquote, .svc-quote { max-width: 100%; }
  .svc-sidebar { position: static; display: none; }
  /* Flex column + gap = uniform spacing between all stacked sections */
  .svc-main { display: flex; flex-direction: column; gap: 40px; }
  .svc-section { padding: 0; margin: 0; }
  .svc-section-cream { margin: 0; padding: 40px 32px; border-radius: 12px; }
  .svc-ornament { padding: 0; margin: 0; }
  .svc-pullquote { margin: 0; }
  .svc-lead { max-width: 860px; margin: 0 auto 1.5rem; }
  .svc-cta-final { max-width: 860px; margin: 0 auto; padding-left: 32px; padding-right: 32px; }
  .svc-two-col { grid-template-columns: 1fr; gap: 28px; }
  .svc-single-col { max-width: 100%; }
}

@media(max-width:768px) {
  .grid-2 { grid-template-columns: 1fr; gap: 40px; }
  .grid-3 { grid-template-columns: 1fr !important; }
  .grid-4 { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .form-row { grid-template-columns: 1fr; }
  .section { padding: 64px 0; }
  .section--lg { padding: 80px 0; }
  .bio-layout { grid-template-columns: 1fr; }
  .bio-sidebar { position: static; }
  .bio-photo-wrap { max-width: 260px; margin: 0 auto 28px; }
  .hero h1 { font-size: 2.8rem; }
  .container { padding: 0 20px; }
  .reason-item { flex-direction: column; gap: 12px; }
  .svc-layout { grid-template-columns: 1fr !important; }
  .svc-sidebar { position: static !important; display: none; }
  .svc-lead { font-size: 1.18rem; line-height: 1.5; padding: 16px 18px; }
  .svc-main { gap: 36px; }
  .svc-section { padding: 0; margin: 0; }
  .svc-section-cream { margin: 0 -20px; padding: 36px 20px; border-radius: 0; }
  .svc-ornament { padding: 0; margin: 0; }
  .svc-pullquote { margin: 0; padding: 20px 20px 20px 24px; }
  .svc-cta-final { padding: 44px 0; }
  .svc-cta-final .btn-lg { width: 100%; text-align: center; }
  .supervisor-grid { grid-template-columns: 1fr !important; gap: 24px; }
  .svc-two-col { grid-template-columns: 1fr !important; gap: 32px; }
  .contact-row { grid-template-columns: 1fr; gap: 4px; }
  .therapist-card-grid { grid-template-columns: 1fr 1fr; }

  /* ── NAV: show hamburger, hide desktop nav ── */
  .nav-left, .nav-right, .nav-socials, .nav-sep, .nav-cta, .nav-search { display: none !important; }
  .nav-hamburger, #hamburger { display: flex !important; }
  body.menu-open .nav-hamburger, body.menu-open #hamburger { display: none !important; }
  .nav-bar { justify-content: space-between !important; padding: 0 16px !important; }
  .nav-logo { margin: 0 !important; }
  .nav-logo img { height: 40px !important; width: auto !important; filter: brightness(0) invert(1) drop-shadow(0 1px 6px rgba(0,0,0,.55)) !important; display: block !important; }
  #header.scrolled .nav-logo img { filter: brightness(0) !important; }
}

@media(max-width:640px) {
  .svc-benefit-grid,
  .svc-benefit-grid-2col,
  .svc-benefit-grid.grid-2col { grid-template-columns: 1fr !important; gap: 16px; }
  .svc-benefit-grid .svc-benefit-card:last-child:nth-child(3n+1),
  .svc-benefit-grid-2col .svc-benefit-card:last-child:nth-child(odd) {
    grid-column: auto !important; max-width: 100% !important; margin-left: 0 !important; margin-right: 0 !important;
  }
  .svc-stats { grid-template-columns: 1fr; }
  .svc-stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,.1); }
  .svc-stat:last-child { border-bottom: none; }
  .svc-icon-row { grid-template-columns: 1fr; gap: 24px; }
}

/* ─ Landscape phone nav ─────────────────────────────────────────────── */
@media(min-width:769px) and (max-width:1023px) {
  .nav-left, .nav-right, .nav-socials, .nav-sep, .nav-cta, .nav-search { display: none !important; }
  .nav-hamburger, #hamburger { display: flex !important; }
  body.menu-open .nav-hamburger, body.menu-open #hamburger { display: none !important; }
  .nav-bar { justify-content: space-between !important; padding: 0 16px !important; }
  .nav-logo { margin: 0 !important; }
  .nav-logo img { height: 40px !important; width: auto !important; filter: brightness(0) invert(1) drop-shadow(0 1px 6px rgba(0,0,0,.55)) !important; display: block !important; }
  #header.scrolled .nav-logo img { filter: brightness(0) !important; transition: filter var(--ease); }
}
@media(min-width:1024px) { #hamburger { display: none !important; } }

/* ─ Centered odd grid items ─────────────────────────────────────────── */
.svc-benefit-grid:not(.svc-benefit-grid-2col) .svc-benefit-card:last-child:nth-child(3n+1) {
  grid-column: 1 / -1; max-width: calc(33.333% - 12px); margin-left: auto; margin-right: auto;
}
.svc-benefit-grid-2col .svc-benefit-card:last-child:nth-child(2n+1) {
  grid-column: 1 / -1; max-width: calc(50% - 9px); margin-left: auto; margin-right: auto;
}
@media(min-width:641px) {
  .svc-benefit-grid:has(.svc-benefit-card:nth-child(4)):not(:has(.svc-benefit-card:nth-child(5))):not(:has(.svc-benefit-card:nth-child(7))) {
    grid-template-columns: repeat(2,1fr) !important;
  }
}

/* ─ Misc ─────────────────────────────────────────────────────────────── */
.svc-single-col { max-width: 860px; }
.link { font-size: .72rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; color: var(--bark); border-bottom: 1.5px solid var(--petal); padding-bottom: 2px; transition: color var(--ease), border-color var(--ease); }
.link:hover { color: var(--petal-dark); border-color: var(--petal-dark); }
.mt-8{margin-top:8px} .mt-16{margin-top:16px} .mt-24{margin-top:24px} .mt-32{margin-top:32px} .mt-48{margin-top:48px} .mt-64{margin-top:64px}
.mb-8{margin-bottom:8px} .mb-16{margin-bottom:16px} .mb-24{margin-bottom:24px} .mb-32{margin-bottom:32px} .mb-48{margin-bottom:48px}
.lead { font-size: 1.1rem; line-height: 1.82; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }
.diamond-list { list-style: none !important; padding: 0; margin: 16px 0 0; display: flex; flex-direction: column; gap: 10px; }
.diamond-list li { display: flex; gap: 10px; align-items: flex-start; }
.diamond-list li::before, .diamond-list li::marker { display: none !important; content: none !important; }
.diamond-list .d-icon { color: var(--petal); font-size: .7rem; margin-top: 5px; flex-shrink: 0; }
.img-placeholder { background: var(--cream-alt); border: 1px dashed var(--border); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 32px; border-radius: 4px; min-height: 280px; }
.img-placeholder-icon { font-size: 2.5rem; margin-bottom: 12px; opacity: .35; }
.img-placeholder p { font-size: .78rem; color: var(--bark-mid); font-family: var(--font-sans); letter-spacing: .08em; text-transform: uppercase; margin: 0; }

/* Supervisor grid */
.supervisor-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; margin: 24px 0 36px; }
.supervisor-card { background: var(--white); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.supervisor-card img { width: 100%; height: 260px; object-fit: cover; object-position: center top; display: block; }
.supervisor-info { padding: 20px 22px 24px; }
.supervisor-info h3 { font-size: 1rem; margin: 0 0 4px; color: var(--bark); }
.supervisor-creds { display: block; font-size: .68rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--petal-dark); margin-bottom: 12px; }
.supervisor-info p { font-size: .87rem; line-height: 1.75; color: var(--bark-mid); margin: 0; }

/* Icon row */
.svc-icon-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 36px; margin-top: 8px; }
.svc-icon-item { text-align: center; }
.svc-icon-glyph { display: block; font-size: 2rem; margin-bottom: 14px; color: var(--petal); line-height: 1; }
.svc-icon-item h4 { font-family: var(--font-serif); font-size: 1.1rem; font-weight: 500; color: var(--bark); margin-bottom: 8px; }
.svc-icon-item p { font-size: .86rem; line-height: 1.7; color: var(--bark-mid); }

/* Stat bar */
.svc-stats { display: grid; grid-template-columns: repeat(3,1fr); background: var(--bark); border-radius: 4px; overflow: hidden; }
.svc-stat { padding: 36px 28px; text-align: center; border-right: 1px solid rgba(255,255,255,.1); }
.svc-stat:last-child { border-right: none; }
.svc-stat-num { display: block; font-family: var(--font-serif); font-size: clamp(2.2rem,5vw,3.5rem); font-weight: 300; color: var(--petal-lt); line-height: 1; margin-bottom: 8px; }
.svc-stat-label { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(248,244,238,.65); font-family: var(--font-sans); }

/* Bands */
.band-cream { background: var(--cream); }
.band-cream-alt { background: var(--cream-alt); }
.band-white { background: var(--white); }
.band-bark { background: var(--bark); }
.band-bark h2, .band-bark h3, .band-bark h4 { color: var(--white); }
.band-bark p { color: rgba(248,244,238,.85); }
.band-bark .eyebrow { color: var(--petal-lt); }

/* Success page */
.success-page { min-height: 100vh; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 120px 32px 80px; background: var(--cream); }
.success-icon { width: 88px; height: 88px; background: var(--petal); border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 32px; font-size: 2.4rem; animation: popIn .6s cubic-bezier(.34,1.56,.64,1) both; }
@keyframes popIn { from { opacity: 0; transform: scale(.5); } to { opacity: 1; transform: scale(1); } }

/* Enneagram badges */
.badge-pair { display: flex; gap: 32px; align-items: center; justify-content: center; margin: 32px 0; flex-wrap: wrap; padding: 28px; background: var(--cream-alt); border-radius: 8px; }
.enneagram-badge { width: 100px; height: 100px; object-fit: contain; opacity: .85; filter: grayscale(.2); }
.badge-logo-row { display: flex; gap: 28px; align-items: center; justify-content: center; flex-wrap: wrap; margin: 20px 0; }
.enneagram-logo { width: 120px; height: auto; object-fit: contain; }

/* Konami easter egg */
#konami-overlay { display: none; position: fixed; inset: 0; z-index: 99999; background: rgba(0,0,0,.93); align-items: center; justify-content: center; flex-direction: column; gap: 20px; cursor: pointer; }
#konami-overlay.active { display: flex; animation: konamiFadeIn .5s ease; }
@keyframes konamiFadeIn { from { opacity: 0; transform: scale(.93); } to { opacity: 1; transform: scale(1); } }
.konami-tv { position: relative; background: linear-gradient(160deg,#8B5E3C 0%,#6B3E1F 35%,#7D4A28 60%,#5A2D0C 100%); border: 3px solid #3d1f08; border-radius: 18px 18px 12px 12px; box-shadow: 0 0 0 2px #2a1208, 0 0 0 5px #5a3018, 0 12px 50px rgba(0,0,0,.85); padding: 18px 24px 14px; width: min(500px,92vw); }
.konami-screen-bezel { background: #0d0d0d; border-radius: 10px; padding: 8px; box-shadow: inset 0 2px 8px rgba(0,0,0,.9); margin-bottom: 10px; }
.konami-screen { position: relative; background: #000; border-radius: 4px; overflow: hidden; aspect-ratio: 4/3; }
.konami-img { width: 100%; height: 100%; object-fit: contain; display: block; image-rendering: pixelated; background: #000; }
.konami-scanlines { position: absolute; inset: 0; pointer-events: none; z-index: 3; background: repeating-linear-gradient(0deg,rgba(0,0,0,.45) 0px,rgba(0,0,0,.45) 1px,transparent 1px,transparent 3px); }
.konami-hint { color: rgba(255,255,255,.45); font-family: 'Courier New',monospace; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; animation: konami-blink 1.5s step-end infinite; }
@keyframes konami-blink { 0%,100%{opacity:1} 50%{opacity:0} }

/* Spacing: ensure benefit grids breathe after paragraphs */
.svc-section .svc-benefit-grid,
.svc-section-cream .svc-benefit-grid {
  margin-top: 28px;
}
p + .svc-benefit-grid {
  margin-top: 32px;
}
h2 + .svc-benefit-grid,
h3 + .svc-benefit-grid {
  margin-top: 24px;
}
.svc-benefit-grid + p {
  margin-top: 24px;
}
/* Ensure all cards have consistent visual rhythm */
.svc-benefit-card strong {
  font-size: .95rem;
  font-weight: 600;
  color: var(--bark);
  display: block;
  margin-bottom: 4px;
}

/* Safe area for notched iPhones in landscape */
@supports (padding: env(safe-area-inset-left)) {
  .container {
    padding-left: max(20px, env(safe-area-inset-left));
    padding-right: max(20px, env(safe-area-inset-right));
  }
  @media(max-width:768px) {
    .container {
      padding-left: max(20px, env(safe-area-inset-left));
      padding-right: max(20px, env(safe-area-inset-right));
    }
  }
  .nav-bar, .nav-inner {
    padding-left: max(40px, env(safe-area-inset-left));
    padding-right: max(40px, env(safe-area-inset-right));
  }
  #header.scrolled .nav-bar, #header.scrolled .nav-inner {
    padding-left: max(40px, env(safe-area-inset-left));
    padding-right: max(40px, env(safe-area-inset-right));
  }
}
/* ── HOMEPAGE HERO: Desktop floor ────────────────────────────────────────
   On HiDPI (Retina/2x) displays, 100dvh can round down by a subpixel,
   exposing a 1-2px sliver of the section below the hero on load.
   min-height as a floor ensures the hero always covers the full viewport.
   DESKTOP ONLY — never add min-height on mobile (causes iOS grow animation).
   ──────────────────────────────────────────────────────────────────────── */
@media (min-width: 769px) {
  .hero {
    min-height: 100vh;       /* floor: old browsers */
    min-height: 100dvh;      /* floor: modern — seals subpixel gap on HiDPI */
  }
}

/* ── HOMEPAGE HERO: Mobile height caps ──────────────────────────────────
   iOS reports innerHeight including the chrome sometimes. Cap so hero
   never exceeds the visible viewport. svh/dvh are iOS 15.4+/16+ support.
   ──────────────────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .hero {
    max-height: 100svh;      /* iOS 15.4+: small viewport height (excludes browser UI) */
    max-height: 100dvh;      /* iOS 16+: dynamic viewport height */
  }
}
@media (max-width: 768px) and (orientation: landscape) {
  .hero {
    height: 300px !important;
    max-height: 300px;
    min-height: 0;
  }
  .hero h1 { font-size: clamp(1.8rem, 4vw, 2.6rem); }
}

/* ── Custom checkbox — cross-browser visible checkmark ─────────────── */
.custom-checkbox {
  appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  min-width: 20px;
  max-width: 20px;
  flex-grow: 0;
  border: 2px solid var(--petal-dark);
  border-radius: 4px;
  background: var(--white);
  cursor: pointer;
  flex-shrink: 0;
  margin-top: 2px;
  position: relative;
  transition: background .15s, border-color .15s;
}
.custom-checkbox:checked {
  background: var(--petal-btn);
  border-color: var(--petal-btn);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpolyline points='1.5,6 4.5,9 10.5,3' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size: 12px 12px;
  background-repeat: no-repeat;
  background-position: center;
}
.custom-checkbox:focus-visible {
  outline: 3px solid var(--petal);
  outline-offset: 2px;
}
