/* =========================================================
   Dovetail Edition — Design System
   ========================================================= */

/* --- Reset ---------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; -moz-tab-size: 4; tab-size: 4; }
body { line-height: 1.5; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img, picture, video, canvas, svg { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; color: inherit; }
p, h1, h2, h3, h4, h5, h6 { overflow-wrap: break-word; }
a { color: inherit; text-decoration: none; }
button { background: none; border: 0; cursor: pointer; }
ul, ol { list-style: none; }

/* --- Tokens --------------------------------------------- */
:root {
  /* Color — warm editorial neutrals */
  --ink: #0a0a0a;
  --ink-soft: #1e1e1e;
  --charcoal: #3a3a3a;
  --stone: #595959;
  --stone-soft: #c4c4c4;
  --linen: #ededed;
  --linen-soft: #f2f2f2;
  --bone: #f8f8f8;
  --bone-warm: #fafafa;
  --white: #ffffff;

  /* Type */
  --font-display: "Fraunces", "Times New Roman", Georgia, serif;
  --font-body: "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  /* Type scale */
  --fs-micro: 0.6875rem;   /* 11px */
  --fs-xs: 0.75rem;        /* 12px */
  --fs-sm: 0.8125rem;      /* 13px */
  --fs-base: 1rem;         /* 16px */
  --fs-md: 1.125rem;       /* 18px */
  --fs-lg: 1.375rem;       /* 22px */
  --fs-xl: 1.75rem;        /* 28px */
  --fs-2xl: 2.375rem;      /* 38px */
  --fs-3xl: 3.25rem;       /* 52px */
  --fs-display: clamp(2.75rem, 7.5vw, 5.75rem);
  --fs-display-lg: clamp(3.25rem, 9vw, 7rem);

  /* Spacing — 8px base */
  --s-1: 0.25rem;   /* 4 */
  --s-2: 0.5rem;    /* 8 */
  --s-3: 1rem;      /* 16 */
  --s-4: 1.5rem;    /* 24 */
  --s-5: 2rem;      /* 32 */
  --s-6: 3rem;      /* 48 */
  --s-7: 4rem;      /* 64 */
  --s-8: 6rem;      /* 96 */
  --s-9: 8rem;      /* 128 */
  --s-10: 10rem;    /* 160 */

  /* Rhythm — section padding */
  --section-y: clamp(3rem, 5vw, 4rem);
  --section-y-compact: clamp(2rem, 3.5vw, 3rem);

  /* Layout */
  --container: 1240px;
  --container-narrow: 960px;
  --text-measure: 40rem;

  /* Borders & motion */
  --line: 1px solid rgba(10, 10, 10, 0.12);
  --line-soft: 1px solid rgba(10, 10, 10, 0.06);
  --radius: 2px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
  --t-fast: 200ms var(--ease);
  --t-med: 400ms var(--ease);
  --t-slow: 700ms var(--ease);
}

/* --- Base ----------------------------------------------- */
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--charcoal);
  background: var(--bone);
  font-feature-settings: "ss01", "ss02";
}

::selection { background: var(--ink); color: var(--bone); }

/* --- Typography ----------------------------------------- */
.display,
.h-display,
.h-1, .h-2, .h-3 {
  font-family: var(--font-display);
  color: var(--ink);
  font-weight: 340;
  line-height: 1.02;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 144, "SOFT" 50, "WONK" 0;
  text-wrap: balance;
}

.h-display {
  font-size: var(--fs-display-lg);
  line-height: 0.92;
  letter-spacing: -0.035em;
  font-variation-settings: "opsz" 144, "SOFT" 40, "WONK" 0;
}

.h-1 {
  font-size: var(--fs-display);
  line-height: 0.96;
  letter-spacing: -0.03em;
  font-variation-settings: "opsz" 144, "SOFT" 50, "WONK" 0;
}

.h-2 {
  font-size: var(--fs-3xl);
  line-height: 1.04;
  letter-spacing: -0.022em;
  font-variation-settings: "opsz" 96, "SOFT" 50, "WONK" 0;
}

.h-3 {
  font-size: var(--fs-2xl);
  line-height: 1.08;
  letter-spacing: -0.018em;
  font-variation-settings: "opsz" 72, "SOFT" 50, "WONK" 0;
}

.h-4 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  line-height: 1.15;
  color: var(--ink);
  font-weight: 360;
  letter-spacing: -0.015em;
  font-variation-settings: "opsz" 48;
}

/* Italic display — Fraunces italic is beautiful */
.display em, .h-display em, .h-1 em, .h-2 em, .h-3 em {
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  color: var(--ink);
}

/* Eyebrow labels */
.eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--stone);
}

.eyebrow-ink {
  color: var(--ink);
  opacity: 0.65;
}

/* Body text */
.lede {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  line-height: 1.5;
  color: var(--ink-soft);
  font-weight: 340;
  letter-spacing: -0.005em;
  font-variation-settings: "opsz" 48;
  text-wrap: pretty;
}

.lede em { font-style: italic; color: var(--ink); }

p {
  max-width: var(--text-measure);
  color: var(--charcoal);
  text-wrap: pretty;
}

.prose p + p { margin-top: var(--s-4); }
.prose h3, .prose h4 { margin-top: var(--s-7); margin-bottom: var(--s-3); }
.prose h3 + p, .prose h4 + p { margin-top: var(--s-2); }
.prose ul { margin-top: var(--s-3); padding-left: 0; }
.prose ul li {
  position: relative;
  padding-left: var(--s-4);
  margin-bottom: var(--s-2);
  max-width: var(--text-measure);
}
.prose ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 10px;
  height: 1px;
  background: var(--stone);
}

/* --- Layout primitives ---------------------------------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}

.container-narrow {
  width: 100%;
  max-width: var(--container-narrow);
  margin: 0 auto;
  padding-inline: clamp(1.25rem, 4vw, 2.5rem);
}

.section {
  padding-block: var(--section-y);
}

.section-compact {
  padding-block: var(--section-y-compact);
}

.section-top {
  padding-top: var(--section-y);
}

.section-divider {
  border-top: var(--line);
}

/* Tighten gap when section immediately follows hero */
.hero + .section,
.hero + .section-divider,
.hero + section {
  padding-top: clamp(1rem, 2vw, 1.5rem);
}


/* Service-area nav on location pages */
.market--current {
  background: var(--linen);
  pointer-events: none;
}
.market--current .market__city {
  font-weight: 500;
}

/* --- Header --------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(248, 248, 248, 0.85);
  backdrop-filter: saturate(140%) blur(8px);
  -webkit-backdrop-filter: saturate(140%) blur(8px);
  border-bottom: var(--line-soft);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: var(--s-4);
  gap: var(--s-5);
  transition: padding-block 400ms var(--ease-out);
}

/* Compact header on scroll */
.site-header--scrolled .site-header__inner {
  padding-block: var(--s-3);
}

.brand {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  letter-spacing: -0.01em;
  color: var(--ink);
  font-weight: 400;
  font-variation-settings: "opsz" 72;
  line-height: 1;
}

.brand sup {
  font-size: 0.55em;
  vertical-align: super;
  margin-left: 2px;
  opacity: 0.6;
}

.nav {
  display: flex;
  align-items: center;
  gap: var(--s-6);
}

.nav a {
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  letter-spacing: 0.015em;
  transition: color var(--t-fast);
  position: relative;
  padding-block: var(--s-2);
}
.nav a::after {
  content: "";
  position: absolute;
  bottom: 2px;
  left: 0; right: 0;
  height: 1px;
  background: var(--ink);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform 350ms var(--ease-out);
}
.nav a:hover { color: var(--ink); }
.nav a:hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

.nav a[aria-current="page"] {
  color: var(--ink);
}
.nav a[aria-current="page"]::after {
  transform: scaleX(1);
  transform-origin: left;
}

.nav-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: var(--fs-sm);
  padding: 0.625rem 1.125rem;
  color: var(--ink);
  background: transparent;
  border: 1px solid var(--ink);
  border-radius: var(--radius);
  line-height: 1;
  letter-spacing: 0.04em;
  transition: background var(--t-fast), color var(--t-fast), transform 300ms var(--ease-spring), box-shadow var(--t-fast);
  -webkit-appearance: none;
  appearance: none;
  cursor: pointer;
  margin-left: var(--s-2);
}
.nav-cta::after { display: none; }
.nav-cta:hover {
  background: var(--ink);
  color: var(--bone);
  transform: translateY(-1px);
  box-shadow: 0 3px 8px rgba(10, 10, 10, 0.12);
}

.nav-toggle {
  display: none;
  width: 36px;
  height: 36px;
  position: relative;
}
.nav-toggle span {
  position: absolute;
  left: 8px; right: 8px;
  height: 1px;
  background: var(--ink);
  transition: transform var(--t-med), opacity var(--t-fast);
}
.nav-toggle span:nth-child(1) { top: 14px; }
.nav-toggle span:nth-child(2) { top: 21px; }

@media (max-width: 860px) {
  .nav { display: none; position: absolute; top: 100%; left: 0; right: 0; background: var(--bone); flex-direction: column; align-items: stretch; padding: var(--s-4) clamp(1.25rem, 4vw, 2.5rem) var(--s-6); gap: var(--s-3); border-bottom: var(--line); }
  .nav.open { display: flex; }
  .nav a { font-size: var(--fs-md); padding-block: var(--s-3); border-bottom: var(--line-soft); }
  .nav a.nav-cta { text-align: center; margin-top: var(--s-3); border: 1px solid var(--ink); padding: var(--s-3) var(--s-4); }
  .nav-toggle { display: block; }
  .nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-toggle.open span:nth-child(2) { transform: translateY(0) rotate(-45deg); }
}

/* --- Buttons -------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  padding: var(--s-3) var(--s-5);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.03em;
  border-radius: var(--radius);
  transition: background var(--t-fast), color var(--t-fast), transform 300ms var(--ease-spring), box-shadow var(--t-fast);
  cursor: pointer;
  border: 1px solid transparent;
  line-height: 1;
  will-change: transform;
}
.btn:active { transform: scale(0.97); }

.btn-primary {
  background: var(--ink);
  color: var(--bone);
  border-color: var(--ink);
}
.btn-primary:hover {
  background: var(--ink-soft);
  border-color: var(--ink-soft);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(10, 10, 10, 0.15);
}

.btn-secondary {
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}
.btn-secondary:hover {
  background: var(--ink);
  color: var(--bone);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(10, 10, 10, 0.1);
}

.btn-ghost {
  background: transparent;
  color: var(--ink);
  border-color: transparent;
  padding-inline: 0;
}
.btn-ghost::after {
  content: "→";
  margin-left: var(--s-2);
  transition: transform 300ms var(--ease-spring);
  display: inline-block;
}
.btn-ghost:hover::after { transform: translateX(5px); }
.btn-ghost:hover { color: var(--charcoal); }

.btn-row { display: flex; flex-wrap: wrap; gap: var(--s-3); }
.center .btn-row { justify-content: center; }

/* --- Hero ----------------------------------------------- */
.hero {
  padding-top: clamp(1.5rem, 3vh, 2.5rem);
  padding-bottom: clamp(1.5rem, 3vw, 2.5rem);
  position: relative;
  overflow: hidden;
}

.hero__mark {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-4);
}
.hero__mark::before {
  content: "";
  width: 40px;
  height: 1px;
  background: var(--stone);
}

.hero__title {
  max-width: 14ch;
  margin-bottom: var(--s-4);
}

.hero__lede {
  max-width: 44ch;
  margin-bottom: var(--s-3);
}

.hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-5);
  padding-top: var(--s-4);
  margin-top: var(--s-4);
  border-top: var(--line);
  align-items: baseline;
}
.hero__meta-item { display: flex; flex-direction: column; gap: var(--s-1); }
.hero__meta .eyebrow { margin-bottom: 0; }
.hero__meta strong { font-family: var(--font-display); font-size: var(--fs-md); color: var(--ink); font-weight: 360; }

/* --- Two-up service cards (homepage) -------------------- */
.services {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: var(--line);
  border-bottom: var(--line);
}
@media (max-width: 760px) { .services { grid-template-columns: 1fr; } }

.service-card {
  background: var(--bone);
  padding: clamp(2rem, 5vw, 4rem) clamp(1.25rem, 4vw, 3rem);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: var(--s-6);
  min-height: 420px;
  position: relative;
  transition: background var(--t-med), box-shadow var(--t-med);
}
.service-card + .service-card { border-left: var(--line); }
@media (max-width: 760px) { .service-card + .service-card { border-left: none; border-top: var(--line); } }
.service-card:hover {
  background: var(--white);
  box-shadow: inset 0 0 0 1px rgba(10, 10, 10, 0.04);
}
.service-card__num {
  font-family: var(--font-display);
  font-size: var(--fs-sm);
  letter-spacing: 0.1em;
  color: var(--stone);
  font-variation-settings: "opsz" 14;
}
.service-card__title {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  color: var(--ink);
  line-height: 1.05;
  letter-spacing: -0.02em;
  font-weight: 360;
  margin-top: var(--s-3);
  margin-bottom: var(--s-4);
}
.service-card__title em { font-style: italic; font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1; }
.service-card__body {
  font-size: var(--fs-md);
  color: var(--charcoal);
  line-height: 1.55;
  max-width: 40ch;
}
.service-card__meta {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-top: var(--s-5);
  border-top: var(--line-soft);
  gap: var(--s-4);
}
.service-card__from {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  color: var(--ink);
  font-variation-settings: "opsz" 72;
}
.service-card__from span {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  color: var(--stone);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  display: block;
  margin-bottom: 2px;
}

/* --- Bundle callout ------------------------------------- */
.bundle-strip {
  background: var(--ink);
  color: var(--bone);
  padding: var(--section-y-compact) 0;
  position: relative;
  overflow: hidden;
}
.bundle-strip::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 20% 80%, rgba(60, 60, 60, 0.4) 0%, transparent 70%),
              radial-gradient(ellipse 50% 40% at 90% 20%, rgba(40, 40, 40, 0.3) 0%, transparent 60%);
  pointer-events: none;
}
.bundle-strip .container { position: relative; z-index: 1; }
.bundle-strip__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 6vw, 6rem);
  align-items: center;
}
@media (max-width: 800px) { .bundle-strip__grid { grid-template-columns: 1fr; } }
.bundle-strip h2 { color: var(--bone); max-width: 16ch; }
.bundle-strip p { color: rgba(248, 248, 248, 0.72); max-width: 40ch; }
.bundle-strip .eyebrow { color: rgba(248, 248, 248, 0.6); }
.bundle-strip .btn-secondary { color: var(--bone); border-color: var(--bone); }
.bundle-strip .btn-secondary:hover { background: var(--bone); color: var(--ink); }

/* --- Tiers (pricing cards) ------------------------------ */
.tiers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: var(--line);
}
@media (max-width: 880px) { .tiers { grid-template-columns: 1fr; } }
.tiers--two { grid-template-columns: repeat(2, 1fr); border-top: 0; }
@media (max-width: 880px) { .tiers--two { grid-template-columns: 1fr; } }

.tier {
  background: var(--bone);
  border-right: var(--line);
  padding: clamp(1.75rem, 4vw, 2.75rem);
  display: flex;
  flex-direction: column;
  gap: var(--s-5);
  min-height: 0;
}
.tier:last-child { border-right: none; }
@media (max-width: 880px) { .tier { border-right: none; border-bottom: var(--line); } .tier:last-child { border-bottom: none; } }
.tier__head { display: flex; flex-direction: column; gap: var(--s-2); }
.tier__name {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  color: var(--ink);
  font-weight: 360;
  letter-spacing: -0.015em;
  font-variation-settings: "opsz" 72;
}
.tier__price {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  color: var(--stone);
  font-variation-settings: "opsz" 72;
}
.tier__price strong { color: var(--ink); font-weight: 360; }
.tier__list {
  display: flex;
  flex-direction: column;
  gap: var(--s-2);
  padding-top: var(--s-3);
  border-top: var(--line-soft);
  font-size: var(--fs-sm);
  color: var(--charcoal);
}
.tier__list li {
  padding-left: var(--s-4);
  position: relative;
  line-height: 1.5;
}
.tier__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--stone-soft);
}

/* --- Collection (Setting) ------------------------------- */
.collections {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: var(--line);
  border-bottom: var(--line);
}
@media (max-width: 860px) { .collections { grid-template-columns: 1fr; } }

.collection {
  background: var(--bone);
  display: flex;
  flex-direction: column;
}
.collection + .collection { border-left: var(--line); }
@media (max-width: 860px) { .collection + .collection { border-left: none; border-top: var(--line); } }

.collection__media {
  aspect-ratio: 4 / 3;
  background: var(--linen);
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.collection__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--t-slow);
}
.collection:hover .collection__media img { transform: scale(1.03); }
.collection__media-label {
  position: absolute;
  top: var(--s-4);
  left: var(--s-4);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bone);
  background: rgba(10, 10, 10, 0.5);
  padding: var(--s-2) var(--s-3);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

/* Elegant placeholder treatment (when no image) */
.collection__placeholder {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--linen) 0%, var(--linen-soft) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--s-3);
  color: var(--stone);
  text-align: center;
  padding: var(--s-5);
}
.collection__placeholder-mark {
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  color: var(--stone-soft);
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  line-height: 1;
}
.collection__placeholder-note {
  font-size: var(--fs-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--stone);
}

.collection__body {
  padding: clamp(1.75rem, 4vw, 2.75rem);
  display: flex;
  flex-direction: column;
  gap: var(--s-4);
  flex: 1;
}
.collection__num {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--stone);
}
.collection__title {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  color: var(--ink);
  font-weight: 360;
  letter-spacing: -0.02em;
  line-height: 1.05;
}
.collection__title em { font-style: italic; font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1; }
.collection__desc { font-size: var(--fs-md); color: var(--charcoal); line-height: 1.55; max-width: 42ch; }
.collection__from {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  color: var(--ink);
  font-variation-settings: "opsz" 72;
  padding-top: var(--s-4);
  border-top: var(--line-soft);
  margin-top: auto;
}
.collection__from span {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--stone);
  margin-bottom: 2px;
}
.collection__included {
  font-size: var(--fs-sm);
  color: var(--charcoal);
  line-height: 1.55;
  padding-top: var(--s-3);
}
.collection__included strong { color: var(--ink); font-weight: 500; }

/* --- Section head -------------------------------------- */
.sec-head {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: clamp(1.5rem, 4vw, 3rem);
  margin-bottom: var(--s-6);
  align-items: start;
}
@media (max-width: 780px) {
  .sec-head { grid-template-columns: 1fr; gap: var(--s-3); margin-bottom: var(--s-5); }
}
.sec-head__eyebrow .eyebrow { display: block; }
.sec-head__title { max-width: 22ch; }
.sec-head__title + p,
.sec-head__title + .lede { margin-top: var(--s-4); }

/* --- Process / steps ------------------------------------ */
.steps {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-6) clamp(2rem, 5vw, 5rem);
  counter-reset: step;
}
@media (max-width: 760px) { .steps { grid-template-columns: 1fr; gap: var(--s-6); } }

.step {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  padding-top: var(--s-4);
  border-top: var(--line);
}
.step__num {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.14em;
  color: var(--stone);
}
.step__title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  color: var(--ink);
  font-weight: 360;
  letter-spacing: -0.015em;
  font-variation-settings: "opsz" 72;
}
.step p { color: var(--charcoal); font-size: var(--fs-base); }

/* --- Pullquote ----------------------------------------- */
.pullquote {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  line-height: 1.2;
  color: var(--ink);
  max-width: 26ch;
  font-weight: 340;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 144, "SOFT" 50;
}
.pullquote em { font-style: italic; font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1; }

/* --- Service area (markets) ---------------------------- */
.markets {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: var(--line);
}
@media (max-width: 980px) { .markets { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .markets { grid-template-columns: 1fr; } }

/* Fill empty cell when grid has an incomplete last row (11 items in 4-col) */
.markets--fill-last > :last-child { grid-column: span 2; }
@media (max-width: 980px) { .markets--fill-last > :last-child { grid-column: span 1; } }

.market {
  background: var(--bone);
  padding: var(--s-5) var(--s-4);
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  transition: background var(--t-fast);
  border-right: var(--line);
  border-bottom: var(--line);
}
.market:nth-child(4n) { border-right: none; }
.market:hover { background: var(--bone-warm); }
@media (max-width: 980px) { .market { border-right: var(--line); } .market:nth-child(4n) { border-right: var(--line); } .market:nth-child(2n) { border-right: none; } }
@media (max-width: 540px) { .market { border-right: none; } }
.market__label {
  font-size: var(--fs-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--stone);
}
.market__city {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  color: var(--ink);
  font-weight: 400;
  font-variation-settings: "opsz" 72;
}
.market__meta { font-size: var(--fs-sm); color: var(--charcoal); }

/* --- FAQ ------------------------------------------------ */
.faq {
  display: flex;
  flex-direction: column;
  border-top: var(--line);
}
.faq details {
  border-bottom: var(--line);
  padding: var(--s-5) 0;
}
.faq summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--s-4);
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  color: var(--ink);
  font-weight: 360;
  letter-spacing: -0.01em;
  line-height: 1.3;
  font-variation-settings: "opsz" 72;
  transition: color var(--t-fast);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-xl);
  line-height: 1;
  color: var(--stone);
  transition: transform var(--t-med), color var(--t-fast);
  flex-shrink: 0;
  margin-top: -2px;
}
.faq details[open] summary::after { transform: rotate(45deg); color: var(--ink); }
.faq summary:hover { color: var(--ink-soft); }
.faq details[open] summary { color: var(--ink); }
.faq details > div {
  padding-top: var(--s-4);
  font-size: var(--fs-base);
  color: var(--charcoal);
  max-width: var(--text-measure);
  line-height: 1.65;
  animation: faq-open 400ms var(--ease-out) both;
}
@keyframes faq-open {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: none; }
}
.faq details > div p + p { margin-top: var(--s-3); }

/* --- Form ----------------------------------------------- */
.inquiry-wrap {
  background: var(--linen);
  padding: var(--section-y) 0;
}

.form {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-4) var(--s-5);
}
@media (max-width: 680px) { .form { grid-template-columns: 1fr; } }

.form__group--full { grid-column: 1 / -1; }

.form label {
  font-size: var(--fs-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--stone);
  font-weight: 500;
}

.form__group { display: flex; flex-direction: column; gap: var(--s-2); position: relative; }

.form input,
.form select,
.form textarea {
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(10, 10, 10, 0.2);
  padding: var(--s-3) 0;
  font-size: var(--fs-base);
  color: var(--ink);
  font-family: var(--font-body);
  transition: border-color var(--t-med);
  border-radius: 0;
}
.form input:focus,
.form select:focus,
.form textarea:focus {
  outline: 2px solid var(--ink);
  outline-offset: 2px;
  border-bottom-color: var(--ink);
}
.form textarea { resize: vertical; min-height: 120px; }

/* Focus highlight bar */
.form__group::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--ink);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 400ms var(--ease-out);
  pointer-events: none;
}
.form__group:focus-within::after {
  transform: scaleX(1);
}

.form__submit { grid-column: 1 / -1; margin-top: var(--s-4); display: flex; justify-content: flex-start; }
.form__honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; }
.form__note { grid-column: 1 / -1; font-size: var(--fs-sm); color: var(--stone); border-top: var(--line-soft); padding-top: var(--s-4); }

/* --- Footer --------------------------------------------- */
.site-footer {
  background: var(--ink);
  color: rgba(248, 248, 248, 0.75);
  padding: var(--section-y-compact) 0 var(--s-6);
  font-size: var(--fs-sm);
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  padding-bottom: var(--s-6);
  border-bottom: 1px solid rgba(248, 248, 248, 0.12);
}
@media (max-width: 860px) { .site-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .site-footer__grid { grid-template-columns: 1fr; } }

.site-footer .brand { color: var(--bone); display: inline-block; margin-bottom: var(--s-4); }
.site-footer__tagline { max-width: 36ch; line-height: 1.55; color: rgba(248, 248, 248, 0.75); margin-bottom: var(--s-5); }
.site-footer__contact { display: flex; flex-direction: column; gap: var(--s-2); color: rgba(248, 248, 248, 0.9); }
.site-footer__contact a:hover { color: var(--bone); }
.site-footer h3, .site-footer h4, .footer-heading {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(248, 248, 248, 0.6);
  margin-bottom: var(--s-4);
  font-weight: 500;
}
.site-footer ul { display: flex; flex-direction: column; gap: var(--s-2); }
.site-footer ul a { color: rgba(248, 248, 248, 0.8); transition: color var(--t-fast); }
.site-footer ul a:hover { color: var(--bone); }
.site-footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--s-5);
  gap: var(--s-4);
  flex-wrap: wrap;
  font-size: var(--fs-xs);
  color: rgba(248, 248, 248, 0.7);
  letter-spacing: 0.04em;
}
.site-footer__bottom nav { display: flex; gap: var(--s-5); }

/* --- Packages page ------------------------------------- */
/* Prevent any overflow from the matrix table leaking to the body */
html, body { overflow-x: hidden; max-width: 100%; }

.matrix-wrap { width: 100%; max-width: 100%; overflow: hidden; }

.matrix {
  width: 100%;
  border-collapse: collapse;
  border: var(--line);
  background: var(--bone);
  table-layout: fixed;
}
.matrix th, .matrix td {
  padding: var(--s-5) var(--s-4);
  text-align: left;
  border: var(--line-soft);
  vertical-align: top;
}
.matrix thead th {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  color: var(--ink);
  font-weight: 400;
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 72;
  background: var(--linen-soft);
}
.matrix thead th:first-child { background: transparent; border: 0; }
.matrix tbody th {
  font-family: var(--font-display);
  font-size: var(--fs-md);
  color: var(--ink);
  font-weight: 400;
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 72;
  background: var(--linen-soft);
  text-align: left;
  min-width: 140px;
}
.matrix td strong {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  color: var(--ink);
  font-weight: 360;
  font-variation-settings: "opsz" 72;
  display: block;
  margin-bottom: 4px;
}
.matrix td small {
  font-size: var(--fs-xs);
  color: var(--stone);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.matrix .na { color: var(--stone-soft); font-style: italic; }

/* Mobile: stack matrix as cards */
.matrix-mobile { display: none; }
@media (max-width: 720px) {
  .matrix-desktop { display: none !important; }
  .matrix-wrap .matrix { display: none !important; }
  .matrix-mobile { display: flex; flex-direction: column; gap: var(--s-4); }
  .matrix-card {
    border: var(--line);
    background: var(--bone);
    padding: var(--s-5);
    display: flex;
    flex-direction: column;
    gap: var(--s-3);
  }
  .matrix-card__tier {
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--stone);
  }
  .matrix-card__pairing {
    font-family: var(--font-display);
    font-size: var(--fs-lg);
    color: var(--ink);
    font-weight: 360;
    letter-spacing: -0.015em;
    line-height: 1.2;
    font-variation-settings: "opsz" 72;
  }
  .matrix-card__pairing em {
    font-style: italic;
    font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  }
  .matrix-card__meta {
    font-size: var(--fs-sm);
    color: var(--charcoal);
    line-height: 1.55;
  }
  .matrix-card__price {
    padding-top: var(--s-3);
    border-top: var(--line-soft);
    margin-top: auto;
    display: flex;
    flex-direction: column;
    gap: var(--s-2);
    font-family: var(--font-display);
    font-size: var(--fs-xl);
    color: var(--ink);
    font-variation-settings: "opsz" 72;
    line-height: 1.1;
  }
  .matrix-card__price span {
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--stone);
    line-height: 1;
    font-weight: 500;
  }
  .matrix-card--na { opacity: 0.55; }
  .matrix-card--na .matrix-card__price { font-style: italic; color: var(--stone); font-size: var(--fs-md); }
}

.bundle-benefit {
  padding: var(--s-5) var(--s-6);
  background: var(--bone-warm);
  border: var(--line);
  margin-top: var(--s-7);
  max-width: var(--text-measure);
}
.bundle-benefit p {
  margin-top: var(--s-3);
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--charcoal);
}
.bundle-benefit__mark {
  font-family: var(--font-display);
  font-size: var(--fs-3xl);
  color: var(--stone);
  font-style: italic;
  line-height: 1;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
}

/* --- Journal list --------------------------------------- */
.posts {
  display: flex;
  flex-direction: column;
}
.post {
  padding: var(--s-6) 0;
  border-bottom: var(--line);
  display: grid;
  grid-template-columns: 1fr 3fr;
  gap: var(--s-6);
  align-items: baseline;
  transition: padding-left var(--t-med);
}
.post:hover { padding-left: var(--s-3); }
@media (max-width: 720px) { .post { grid-template-columns: 1fr; gap: var(--s-2); } }
.post__meta {
  display: flex;
  flex-direction: column;
  gap: var(--s-1);
  font-size: var(--fs-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--stone);
}
.post__title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  color: var(--ink);
  font-weight: 360;
  letter-spacing: -0.015em;
  line-height: 1.2;
  font-variation-settings: "opsz" 72;
  margin-bottom: var(--s-2);
}
.post a { color: inherit; }
.post a:hover .post__title { color: var(--charcoal); }
.post__desc { color: var(--charcoal); max-width: 60ch; line-height: 1.55; font-size: var(--fs-base); }

/* --- About ---------------------------------------------- */
.about-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: clamp(2rem, 6vw, 6rem);
  align-items: start;
}
@media (max-width: 860px) { .about-grid { grid-template-columns: 1fr; } }

.portrait {
  aspect-ratio: 3 / 4;
  background: linear-gradient(135deg, var(--linen), var(--linen-soft));
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: var(--s-3);
  color: var(--stone);
  border: var(--line);
}
.portrait-mark {
  font-family: var(--font-display);
  font-size: 6rem;
  color: var(--stone-soft);
  font-style: italic;
  font-variation-settings: "opsz" 144, "SOFT" 100, "WONK" 1;
  line-height: 1;
}

/* --- Fine details --------------------------------------- */
.hair { height: 1px; background: rgba(10, 10, 10, 0.12); margin: var(--s-6) 0; }
.hair-narrow { width: 40px; height: 1px; background: var(--stone); }

.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
}
@media (max-width: 780px) { .two-col { grid-template-columns: 1fr; } }

.three-col {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-6);
}
@media (max-width: 860px) { .three-col { grid-template-columns: 1fr; } }

.scope-block {
  padding: var(--s-4) 0;
}
.scope-block h3 {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  color: var(--ink);
  font-weight: 360;
  letter-spacing: -0.01em;
  margin-bottom: var(--s-3);
  font-variation-settings: "opsz" 72;
}

.anchor-link {
  position: relative;
  padding-bottom: 2px;
  transition: color var(--t-fast);
}
.anchor-link::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: currentColor;
  transform-origin: right;
  transform: scaleX(1);
  transition: transform 350ms var(--ease-out);
}
.anchor-link:hover { color: var(--charcoal); }
.anchor-link:hover::after {
  transform: scaleX(0.6);
  transform-origin: left;
}

/* --- Entrance animation (scroll) ------------------------ */
/* Progressive enhancement: content is visible by default.
   Only hidden/animated when JS adds .js-ready to <html>. */
@media (prefers-reduced-motion: no-preference) {
  .js-ready .reveal {
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 700ms var(--ease-out), transform 700ms var(--ease-out);
  }
  .js-ready .reveal.in {
    opacity: 1;
    transform: none;
  }

  /* Hero variant — slightly more dramatic, staggered */
  .js-ready .reveal-up {
    opacity: 0;
    transform: translateY(14px);
    transition: opacity 800ms var(--ease-out), transform 800ms var(--ease-out);
    transition-delay: calc(var(--reveal-i, 0) * 60ms);
  }
  .js-ready .reveal-up.in {
    opacity: 1;
    transform: none;
  }
}

/* --- Utilities ----------------------------------------- */
.sr-only {
  position: absolute !important;
  width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important;
  overflow: hidden !important; clip: rect(0,0,0,0) !important;
  white-space: nowrap !important; border: 0 !important;
}
.skip-link {
  position: absolute;
  top: -100%;
  left: var(--s-4);
  z-index: 9999;
  padding: var(--s-2) var(--s-4);
  background: var(--ink);
  color: var(--bone);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  text-decoration: none;
  border-radius: var(--radius);
  transition: top var(--t-fast);
}
.skip-link:focus {
  top: var(--s-2);
  outline: 2px solid var(--ink);
  outline-offset: 2px;
}
.center { text-align: center; }
.mt-4 { margin-top: var(--s-4); }
.mt-5 { margin-top: var(--s-5); }
.mt-6 { margin-top: var(--s-6); }
.mt-7 { margin-top: var(--s-7); }
.mt-8 { margin-top: var(--s-8); }
.mb-4 { margin-bottom: var(--s-4); }
.mb-6 { margin-bottom: var(--s-6); }
.mb-7 { margin-bottom: var(--s-7); }

/* --- Direct answer block (AEO/GEO) ---------------------- */
.direct-answer {
  font-size: var(--f-body);
  line-height: 1.7;
  max-width: 65ch;
}

/* --- Comparison table ------------------------------------ */
.compare-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--fs-sm);
}
.compare-table th,
.compare-table td {
  padding: var(--s-3) var(--s-4);
  text-align: left;
  border-bottom: 1px solid rgba(10,10,10,0.08);
}
.compare-table thead th {
  font-family: var(--font-body);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-size: var(--fs-xs);
  padding-bottom: var(--s-4);
  border-bottom: 2px solid var(--ink);
}
.compare-table tbody td:first-child {
  font-weight: 500;
}
.compare-table tbody tr:last-child td,
.compare-table tbody tr:last-child th {
  border-bottom: none;
}
/* Mobile cards – hidden on desktop, shown below 680px */
.compare-mobile { display: none; }

@media (max-width: 680px) {
  .compare-table-wrap { display: none; }
  .compare-mobile {
    display: flex;
    flex-direction: column;
    gap: var(--s-5);
  }
  .compare-mobile__card {
    border: var(--line);
    padding: var(--s-5);
  }
  .compare-mobile__card .eyebrow {
    margin-bottom: var(--s-4);
  }
  .compare-mobile__list {
    margin: 0;
    padding: 0;
  }
  .compare-mobile__row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    padding: var(--s-2) 0;
    border-bottom: var(--line-soft);
    gap: var(--s-3);
  }
  .compare-mobile__row:last-child {
    border-bottom: none;
  }
  .compare-mobile__row dt {
    font-family: var(--font-body);
    font-size: var(--fs-xs);
    color: var(--stone);
    flex: 1 1 auto;
  }
  .compare-mobile__row dd {
    font-family: var(--font-body);
    font-size: var(--fs-sm);
    font-weight: 500;
    color: var(--ink);
    margin: 0;
    text-align: right;
    flex: 0 0 auto;
  }
}

/* --- Testimonial/review block ---------------------------- */
.testimonial-block {
  border-top: var(--line);
  padding-top: var(--s-6);
  margin-top: var(--s-6);
}
.testimonial {
  font-family: var(--font-serif);
  font-size: var(--f-h3);
  font-style: italic;
  line-height: 1.5;
  max-width: 50ch;
}
.testimonial-attribution {
  margin-top: var(--s-4);
  font-size: var(--fs-sm);
  opacity: 0.7;
}

/* --- Thank-you state (replaces form after submit) ------- */
.thanks-state {
  padding: var(--s-6) 0;
}

/* --- Success / error banner ---------------------------- */
.banner {
  padding: var(--s-4) var(--s-5);
  font-size: var(--fs-sm);
  border: var(--line);
  background: var(--bone-warm);
  margin-bottom: var(--s-5);
}
.banner--success { border-color: var(--ink); background: var(--linen); }

/* --- Responsive fluidity & mobile ----------------------- */
/* Touch targets: minimum 44px for all interactive elements on mobile */
@media (max-width: 860px) {
  .nav a { min-height: 44px; display: flex; align-items: center; }
  .faq summary { min-height: 44px; padding-block: var(--s-3); }
  .market { min-height: 52px; }
}

/* Smooth type scaling for tablets (no jarring size jumps) */
@media (max-width: 980px) and (min-width: 681px) {
  :root {
    --fs-display: clamp(2.25rem, 6.5vw, 4.5rem);
    --fs-display-lg: clamp(2.75rem, 8vw, 5.5rem);
    --fs-3xl: clamp(2rem, 4.5vw, 3rem);
  }
}

/* Mobile type and spacing refinements */
@media (max-width: 680px) {
  :root {
    --fs-display: clamp(2rem, 9vw, 3.25rem);
    --fs-display-lg: clamp(2.25rem, 10vw, 3.75rem);
    --fs-3xl: clamp(1.75rem, 6vw, 2.5rem);
    --fs-2xl: clamp(1.5rem, 5vw, 2rem);
    --section-y: clamp(2rem, 5vw, 3rem);
    --section-y-compact: clamp(1.5rem, 4vw, 2.5rem);
  }

  .service-card { min-height: 400px; }
  .hero__title { max-width: 18ch; }
  .sec-head { gap: var(--s-3); }
  .btn { padding: var(--s-3) var(--s-4); min-height: 44px; }
  .btn-row { gap: var(--s-2); }
}

/* Ultra-small screens */
@media (max-width: 380px) {
  :root {
    --fs-display: 2rem;
    --fs-display-lg: 2.25rem;
  }
  .container, .container-narrow {
    padding-inline: 1rem;
  }
}

/* --- Selection & focus accessibility -------------------- */
:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 3px;
  border-radius: 1px;
}
button:focus-visible, a:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 3px;
}

/* --- Data tables ---------------------------------------- */
.data-table {
  width: 100%;
  border-collapse: collapse;
  margin: var(--s-6) 0;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
}
.data-table caption {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--stone);
  text-align: left;
  padding-bottom: var(--s-3);
}
.data-table thead th {
  font-weight: 500;
  text-align: left;
  padding: var(--s-3) var(--s-4);
  border-bottom: 2px solid var(--ink);
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--charcoal);
}
.data-table tbody td {
  padding: var(--s-3) var(--s-4);
  border-bottom: 1px solid var(--linen);
  vertical-align: top;
  color: var(--ink-soft);
  line-height: 1.5;
}
.data-table tbody tr:last-child td {
  border-bottom: none;
}
@media (max-width: 640px) {
  .data-table { font-size: var(--fs-xs); }
  .data-table thead th, .data-table tbody td { padding: var(--s-2) var(--s-3); }
}

/* --- Source attribution --------------------------------- */
.source-note {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  color: var(--stone);
  letter-spacing: 0.02em;
  margin-top: var(--s-4);
  padding-top: var(--s-3);
  border-top: 1px solid var(--linen);
}
.source-note strong {
  font-weight: 500;
  color: var(--charcoal);
}

