/* ============================================================
   Re-Joyce Memories — Vanilla CSS
   Translated from the React/Tailwind design tokens.
   ============================================================ */

:root {
  --bg: hsl(30 20% 97%);
  --fg: hsl(25 15% 15%);
  --muted-fg: hsl(25 10% 40%);
  --card: hsl(30 18% 95%);
  --border: hsl(30 12% 88%);
  --border-soft: hsl(30 12% 88% / 0.5);
  --primary: hsl(28 35% 42%);
  --primary-fg: hsl(30 20% 98%);
  --accent: hsl(350 20% 88%);
  --accent-soft: hsl(350 20% 88% / 0.3);
  --secondary: hsl(30 16% 84%);
  --radius: 0.5rem;
  --font-serif: 'Cormorant Garamond', 'Lora', Georgia, serif;
  --font-sans: 'Montserrat', system-ui, -apple-system, sans-serif;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.5;
  background: var(--bg);
  color: var(--fg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
ul { list-style: none; padding: 0; margin: 0; }

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

p { margin: 0; }

/* ---------- Layout helpers ---------- */
.container { max-width: 80rem; margin: 0 auto; padding: 0 1rem; }
@media (min-width: 640px) { .container { padding: 0 1.5rem; } }
@media (min-width: 1024px) { .container { padding: 0 2rem; } }

.container-narrow { max-width: 64rem; margin: 0 auto; padding: 0 1rem; }
@media (min-width: 640px) { .container-narrow { padding: 0 1.5rem; } }
@media (min-width: 1024px) { .container-narrow { padding: 0 2rem; } }

.container-medium { max-width: 72rem; margin: 0 auto; padding: 0 1rem; }
@media (min-width: 640px) { .container-medium { padding: 0 1.5rem; } }
@media (min-width: 1024px) { .container-medium { padding: 0 2rem; } }

.container-tight { max-width: 56rem; margin: 0 auto; padding: 0 1rem; }
@media (min-width: 640px) { .container-tight { padding: 0 1.5rem; } }
@media (min-width: 1024px) { .container-tight { padding: 0 2rem; } }

.section { padding: 5rem 0; }
.section-sm { padding: 4rem 0; }

.text-center { text-align: center; }

.eyebrow {
  color: var(--primary);
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.25em;
  margin-bottom: 0.75rem;
  font-weight: 500;
}

/* ---------- Top Navigation ---------- */
.site-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 50;
  background: hsl(30 20% 97% / 0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border-soft);
}
.site-header__inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 0 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 5rem;
}
@media (min-width: 640px) { .site-header__inner { padding: 0 1.5rem; } }
@media (min-width: 1024px) { .site-header__inner { padding: 0 2rem; } }

.brand { display: flex; flex-direction: column; align-items: flex-start; }
.brand__name {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 600;
  letter-spacing: 0.025em;
  color: var(--fg);
  line-height: 1.1;
}
.brand__tagline {
  font-family: var(--font-sans);
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.3em;
  color: var(--muted-fg);
  margin-top: 0.25rem;
}

.site-nav { display: none; align-items: center; gap: 0.25rem; }
@media (min-width: 1024px) { .site-nav { display: flex; } }
.site-nav a {
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  letter-spacing: 0.025em;
  color: var(--muted-fg);
  transition: color 0.2s;
}
.site-nav a:hover { color: var(--fg); }
.site-nav a.active { color: var(--primary); font-weight: 500; }

.menu-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  background: transparent;
  border: none;
  border-radius: var(--radius);
  color: var(--fg);
}
.menu-toggle:hover { background: hsl(0 0% 0% / 0.05); }
@media (min-width: 1024px) { .menu-toggle { display: none; } }
.menu-toggle .icon-close { display: none; }
.menu-toggle.open .icon-menu { display: none; }
.menu-toggle.open .icon-close { display: inline; }

.mobile-nav {
  display: none;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
}
.mobile-nav.open { display: block; }
.mobile-nav__list { padding: 1rem; display: flex; flex-direction: column; gap: 0.25rem; }
.mobile-nav a {
  display: block;
  padding: 0.75rem 1rem;
  font-size: 0.875rem;
  letter-spacing: 0.025em;
  color: var(--muted-fg);
  border-radius: var(--radius);
  transition: background 0.2s, color 0.2s;
}
.mobile-nav a:hover { background: hsl(0 0% 0% / 0.04); }
.mobile-nav a.active {
  color: var(--primary);
  background: var(--accent-soft);
  font-weight: 500;
}

/* Push content below fixed header */
main { padding-top: 5rem; }
main.has-fullbleed-hero { padding-top: 0; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  letter-spacing: 0.05em;
  border: 1px solid transparent;
  border-radius: var(--radius);
  background: var(--primary);
  color: var(--primary-fg);
  transition: filter 0.2s, background 0.2s, transform 0.15s;
  white-space: nowrap;
}
.btn:hover { filter: brightness(1.08); }
.btn:active { transform: translateY(1px); }
.btn--lg { padding: 0.875rem 1.75rem; font-size: 0.95rem; }
.btn--block { width: 100%; }

.btn--outline {
  background: transparent;
  color: var(--fg);
  border-color: var(--border);
}
.btn--outline:hover { background: hsl(0 0% 0% / 0.04); }

.btn--ghost {
  background: transparent;
  color: var(--fg);
  border-color: transparent;
}
.btn--ghost:hover { background: hsl(0 0% 0% / 0.04); }

.btn--glass {
  background: hsl(0 0% 100% / 0.2);
  border: 1px solid hsl(0 0% 100% / 0.35);
  color: white;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.btn--glass:hover { background: hsl(0 0% 100% / 0.3); }

.btn .arrow { width: 1rem; height: 1rem; }

/* ---------- Hero (full-bleed) ---------- */
.hero {
  position: relative;
  min-height: 90vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom,
    hsl(0 0% 0% / 0.5),
    hsl(0 0% 0% / 0.3),
    hsl(0 0% 0% / 0.6));
}
.hero__content {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 0 1rem;
  max-width: 48rem;
  margin: 0 auto;
}
.hero__location {
  color: hsl(0 0% 100% / 0.8);
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 0.35em;
  margin-bottom: 1rem;
}
.hero__title {
  font-family: var(--font-serif);
  color: white;
  font-weight: 300;
  font-size: 3rem;
  line-height: 1.1;
  margin-bottom: 1.5rem;
}
@media (min-width: 640px) { .hero__title { font-size: 3.75rem; } }
@media (min-width: 768px) { .hero__title { font-size: 4.5rem; } }

.hero__tagline {
  color: hsl(0 0% 100% / 0.9);
  font-family: var(--font-serif);
  font-style: italic;
  font-weight: 300;
  font-size: 1.25rem;
  margin-bottom: 2rem;
}
@media (min-width: 640px) { .hero__tagline { font-size: 1.5rem; } }

.hero__actions {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
}
@media (min-width: 640px) { .hero__actions { flex-direction: row; } }

/* ---------- Smaller hero (About, Mini Sessions, Studio) ---------- */
.hero--medium {
  min-height: 50vh;
}
.hero--small {
  min-height: 45vh;
}
.hero--medium .hero__title,
.hero--small .hero__title {
  font-size: 2.5rem;
}
@media (min-width: 640px) {
  .hero--medium .hero__title,
  .hero--small .hero__title { font-size: 3rem; }
}

/* ---------- Welcome / About preview section ---------- */
.welcome { padding: 5rem 1rem; max-width: 72rem; margin: 0 auto; }
.welcome__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: center;
}
@media (min-width: 768px) { .welcome__grid { grid-template-columns: 1fr 1fr; } }
.welcome__photo {
  width: 100%;
  max-width: 28rem;
  margin: 0 auto;
  border-radius: var(--radius);
  aspect-ratio: 3 / 4;
  object-fit: cover;
}
.welcome__heading {
  font-size: 1.875rem;
  font-weight: 600;
  margin: 1rem 0 1.5rem;
  line-height: 1.3;
}
@media (min-width: 640px) { .welcome__heading { font-size: 2.25rem; } }
.welcome__body p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  line-height: 1.7;
  margin-bottom: 1rem;
}
.welcome__body p:last-child { margin-bottom: 0; }

/* ---------- "What We Photograph" category cards ---------- */
.categories {
  background: var(--card);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 5rem 0;
}
.categories__title {
  font-size: 1.875rem;
  font-weight: 600;
  margin-bottom: 0;
}
@media (min-width: 640px) { .categories__title { font-size: 2.25rem; } }
.categories__header { text-align: center; margin-bottom: 3.5rem; }

.category-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 640px) { .category-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .category-grid { grid-template-columns: repeat(3, 1fr); } }

.category-card {
  position: relative;
  display: block;
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  aspect-ratio: 3 / 4;
}
.category-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.category-card:hover img { transform: scale(1.02); }
.category-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, hsl(0 0% 0% / 0.7), transparent);
  pointer-events: none;
}
.category-card__caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 1.5rem;
  z-index: 1;
}
.category-card__caption h3 {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  color: white;
  font-weight: 500;
  margin-bottom: 0.25rem;
}
.category-card__caption p {
  color: hsl(0 0% 100% / 0.8);
  font-size: 0.75rem;
  letter-spacing: 0.025em;
}

/* ---------- "How It Works" steps ---------- */
.how { padding: 5rem 1rem; max-width: 64rem; margin: 0 auto; }
.how__header { text-align: center; margin-bottom: 3.5rem; }
.how__title {
  font-size: 1.875rem;
  font-weight: 600;
  margin-bottom: 0;
}
@media (min-width: 640px) { .how__title { font-size: 2.25rem; } }
.how__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media (min-width: 768px) { .how__grid { grid-template-columns: repeat(3, 1fr); } }
.how__step { text-align: center; padding: 0 1rem; }
.how__icon {
  width: 3.5rem; height: 3.5rem;
  border-radius: 9999px;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
}
.how__icon svg { width: 1.5rem; height: 1.5rem; color: var(--fg); }
.how__step h3 {
  font-size: 1.25rem;
  font-weight: 500;
  margin-bottom: 0.75rem;
}
.how__step p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  line-height: 1.7;
}
.how__cta { text-align: center; margin-top: 3rem; }

/* ---------- Newsletter ---------- */
.newsletter {
  background: var(--card);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 4rem 1rem;
}
.newsletter__inner {
  max-width: 48rem;
  margin: 0 auto;
  text-align: center;
}
.newsletter__icon-wrap {
  display: flex; justify-content: center; margin-bottom: 1rem;
}
.newsletter__icon {
  width: 3rem; height: 3rem;
  border-radius: 9999px;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
}
.newsletter__icon svg { width: 1.25rem; height: 1.25rem; color: var(--fg); }
.newsletter__title {
  font-size: 1.875rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}
@media (min-width: 640px) { .newsletter__title { font-size: 2.25rem; } }
.newsletter__copy {
  color: var(--muted-fg);
  font-size: 0.875rem;
  max-width: 32rem;
  margin: 0 auto 2rem;
  line-height: 1.7;
}
@media (min-width: 640px) { .newsletter__copy { font-size: 1rem; } }
.newsletter__form {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  max-width: 28rem;
  margin: 0 auto;
}
@media (min-width: 640px) { .newsletter__form { flex-direction: row; } }
.newsletter__form input { flex: 1; }

/* ---------- Utility classes ---------- */
.u-stack { display: flex; flex-direction: column; gap: 0.75rem; }
.u-mt-md { margin-top: 2rem; }
.hero__bg img.is-top { object-position: top; }
.section-title { font-family: var(--font-serif); font-size: 2.25rem; font-weight: 600; margin-bottom: 1rem; }

/* ---------- Footer ---------- */
.site-footer {
  background: var(--card);
  border-top: 1px solid var(--border);
}
.site-footer__inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 4rem 1rem;
}
@media (min-width: 640px) { .site-footer__inner { padding: 4rem 1.5rem; } }
@media (min-width: 1024px) { .site-footer__inner { padding: 4rem 2rem; } }

.site-footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}
@media (min-width: 768px) { .site-footer__grid { grid-template-columns: repeat(3, 1fr); } }

.site-footer h3 {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.site-footer h4 {
  font-family: var(--font-serif);
  font-size: 1.125rem;
  font-weight: 500;
  margin-bottom: 1rem;
}
.site-footer p {
  font-size: 0.875rem;
  color: var(--muted-fg);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}
.site-footer__links { display: flex; flex-direction: column; gap: 0.75rem; }
.site-footer__links a {
  font-size: 0.875rem;
  color: var(--muted-fg);
  transition: color 0.2s;
}
.site-footer__links a:hover { color: var(--fg); }

.social { display: flex; gap: 1rem; }
.social a { color: var(--muted-fg); transition: color 0.2s; }
.social a:hover { color: var(--primary); }
.social svg { width: 1.25rem; height: 1.25rem; }

.contact-line {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.875rem;
  color: var(--muted-fg);
  margin-bottom: 0.75rem;
}
.contact-line svg { width: 1rem; height: 1rem; flex-shrink: 0; }

.site-footer__bottom {
  margin-top: 3rem;
  padding-top: 2rem;
  border-top: 1px solid var(--border-soft);
  text-align: center;
}
.site-footer__bottom p {
  margin: 0;
  font-size: 0.75rem;
  letter-spacing: 0.025em;
}

/* ---------- Forms ---------- */
.field { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1.25rem; }
.field label {
  font-size: 0.875rem;
  font-family: var(--font-sans);
  color: var(--fg);
}
.field input,
.field select,
.field textarea {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  padding: 0.625rem 0.875rem;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--fg);
  border-radius: var(--radius);
  transition: border-color 0.2s, box-shadow 0.2s;
}
.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px hsl(28 35% 42% / 0.15);
}
.field textarea { resize: vertical; min-height: 8rem; }
.field-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
@media (min-width: 640px) { .field-grid { grid-template-columns: 1fr 1fr; } }

input.input,
select.input {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  padding: 0.625rem 0.875rem;
  border: 1px solid var(--border);
  background: var(--bg);
  color: var(--fg);
  border-radius: var(--radius);
}
input.input:focus { outline: none; border-color: var(--primary); }

/* ---------- Cards (generic) ---------- */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
}
.card--lg { padding: 2rem; }
.card h3 {
  font-size: 1.125rem;
  font-weight: 500;
  margin-bottom: 1rem;
}
.card--accent {
  background: var(--accent-soft);
  border: none;
}
.card--accent .quote-text {
  font-family: var(--font-serif);
  font-size: 0.875rem;
  font-style: italic;
  color: var(--fg);
  line-height: 1.7;
}
.card--accent .quote-attr {
  font-size: 0.75rem;
  color: var(--muted-fg);
  margin-top: 0.5rem;
}

/* ---------- About page ---------- */
.about-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
}
@media (min-width: 768px) { .about-grid { grid-template-columns: 3fr 2fr; } }
.about-grid h2 {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  color: var(--fg);
  font-weight: 600;
  margin: 1rem 0 1.25rem;
}
.about-grid h2:first-child { margin-top: 0; }
.about-grid > .about-text > p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  line-height: 1.7;
  margin-bottom: 1.25rem;
}
.about-text .closing {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: 1rem;
  color: var(--fg);
}
.fun-facts li {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: 0.875rem;
  color: var(--muted-fg);
  margin-bottom: 0.75rem;
}
.fun-facts li:last-child { margin-bottom: 0; }
.fun-facts svg {
  width: 1rem; height: 1rem;
  color: var(--primary);
  flex-shrink: 0;
  margin-top: 0.125rem;
}
.aside-stack > * + * { margin-top: 1.5rem; }

/* ---------- Gallery ---------- */
.gallery-header { text-align: center; margin-bottom: 3rem; }
.gallery-header h1 {
  font-family: var(--font-serif);
  font-size: 2.25rem;
  font-weight: 600;
  margin-bottom: 1rem;
}
@media (min-width: 640px) { .gallery-header h1 { font-size: 3rem; } }
.gallery-header p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  max-width: 32rem;
  margin: 0 auto;
  line-height: 1.7;
}

.filters {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 3rem;
}
.filter-btn {
  padding: 0.5rem 1rem;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  background: transparent;
  color: var(--fg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: background 0.2s, color 0.2s;
}
.filter-btn:hover { background: hsl(0 0% 0% / 0.04); }
.filter-btn.active {
  background: var(--primary);
  color: var(--primary-fg);
  border-color: var(--primary);
}

.gallery-masonry {
  column-count: 1;
  column-gap: 1rem;
}
@media (min-width: 640px) { .gallery-masonry { column-count: 2; } }
@media (min-width: 1024px) { .gallery-masonry { column-count: 3; } }
.gallery-item {
  break-inside: avoid;
  margin-bottom: 1rem;
  cursor: pointer;
  position: relative;
  border-radius: var(--radius);
  overflow: hidden;
  display: block;
}
.gallery-item img {
  width: 100%;
  border-radius: var(--radius);
  transition: transform 0.5s ease;
}
.gallery-item:hover img { transform: scale(1.01); }
.gallery-item.hidden { display: none; }

/* ---------- Lightbox ---------- */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 100;
  background: hsl(0 0% 0% / 0.92);
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.lightbox.open { display: flex; }
.lightbox img {
  max-width: 100%;
  max-height: 85vh;
  object-fit: contain;
  border-radius: var(--radius);
}
.lightbox__close {
  position: absolute;
  top: 1rem; right: 1rem;
  width: 2.5rem; height: 2.5rem;
  background: transparent;
  border: none;
  color: white;
  border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
}
.lightbox__close:hover { background: hsl(0 0% 100% / 0.1); }
.lightbox__close svg { width: 1.5rem; height: 1.5rem; }
.lightbox__caption {
  position: absolute;
  bottom: 2rem; left: 0; right: 0;
  text-align: center;
  color: hsl(0 0% 100% / 0.85);
}
.lightbox__caption .lb-title {
  font-family: var(--font-serif);
  font-size: 1.25rem;
}
.lightbox__caption .lb-cat {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: hsl(0 0% 100% / 0.6);
  margin-top: 0.25rem;
}

/* ---------- Services / Pricing ---------- */
.services-header { text-align: center; margin-bottom: 3.5rem; }
.services-header h1 {
  font-family: var(--font-serif);
  font-size: 2.25rem;
  font-weight: 600;
  margin-bottom: 1rem;
}
@media (min-width: 640px) { .services-header h1 { font-size: 3rem; } }
.services-header p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  max-width: 36rem;
  margin: 0 auto;
  line-height: 1.7;
}

.service-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 768px) { .service-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .service-grid { grid-template-columns: repeat(3, 1fr); } }

.service-card {
  position: relative;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 2rem 1.5rem 1.5rem;
}
.service-card.popular { border-color: var(--primary); }
.service-card .badge {
  position: absolute;
  top: -0.75rem; left: 50%;
  transform: translateX(-50%);
  background: var(--primary);
  color: var(--primary-fg);
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  padding: 0.25rem 1rem;
  border-radius: 9999px;
}
.service-card h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.25rem;
}
.service-card .subtitle {
  color: var(--muted-fg);
  font-size: 0.75rem;
  letter-spacing: 0.025em;
  margin-bottom: 1.5rem;
}
.service-card .price-row {
  display: flex;
  align-items: baseline;
  gap: 0.25rem;
  margin-bottom: 1.5rem;
}
.service-card .price-label { color: var(--muted-fg); font-size: 0.75rem; }
.service-card .price {
  font-family: var(--font-serif);
  font-size: 2.25rem;
  font-weight: 600;
}
.service-card .meta {
  display: flex;
  gap: 1rem;
  margin-bottom: 1.5rem;
  font-size: 0.75rem;
  color: var(--muted-fg);
}
.service-card .meta span {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
}
.service-card .meta svg { width: 0.875rem; height: 0.875rem; }
.service-card .desc {
  color: var(--muted-fg);
  font-size: 0.875rem;
  line-height: 1.7;
  margin-bottom: 1.5rem;
}
.service-card ul.features {
  margin-bottom: 2rem;
}
.service-card ul.features li {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  font-size: 0.875rem;
  color: var(--muted-fg);
  margin-bottom: 0.625rem;
}
.service-card ul.features svg {
  width: 1rem; height: 1rem;
  color: var(--primary);
  flex-shrink: 0;
  margin-top: 0.125rem;
}

.included {
  margin-top: 4rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 2rem;
  max-width: 42rem;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.included h3 {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}
.included-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-top: 1.5rem;
  text-align: left;
}
@media (min-width: 640px) { .included-grid { grid-template-columns: 1fr 1fr; } }
.included-grid li {
  display: flex;
  align-items: flex-start;
  gap: 0.625rem;
  font-size: 0.875rem;
  color: var(--muted-fg);
}
.included-grid svg {
  width: 1rem; height: 1rem;
  color: var(--primary);
  flex-shrink: 0;
  margin-top: 0.125rem;
}
.deposit-note {
  margin-top: 3rem;
  text-align: center;
}
.deposit-note p { color: var(--muted-fg); font-size: 0.875rem; margin-bottom: 0.5rem; }
.deposit-note p.fine { font-size: 0.75rem; }

.studio-cta {
  background: var(--card);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 4rem 1rem;
  text-align: center;
}
.studio-cta__inner { max-width: 64rem; margin: 0 auto; }
.studio-cta h2 {
  font-family: var(--font-serif);
  font-size: 1.875rem;
  font-weight: 600;
  margin-bottom: 1rem;
}
.studio-cta p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  max-width: 32rem;
  margin: 0 auto 2rem;
  line-height: 1.7;
}

/* ---------- Mini Sessions cards ---------- */
.mini-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 768px) { .mini-grid { grid-template-columns: 1fr 1fr; } }
.mini-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}
.mini-card__img {
  aspect-ratio: 16 / 9;
}
.mini-card__img img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.mini-card__body { padding: 1.5rem; }
.mini-card__head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 0.75rem; margin-bottom: 0.75rem;
}
.mini-card__head h3 {
  font-family: var(--font-serif);
  font-size: 1.25rem;
  font-weight: 600;
}
.badge-secondary {
  background: var(--secondary);
  color: var(--fg);
  font-size: 0.7rem;
  padding: 0.25rem 0.625rem;
  border-radius: 9999px;
  white-space: nowrap;
  flex-shrink: 0;
}
.mini-card .description {
  color: var(--muted-fg);
  font-size: 0.875rem;
  line-height: 1.7;
  margin-bottom: 1rem;
}
.mini-meta {
  display: flex; flex-direction: column; gap: 0.5rem;
  font-size: 0.875rem; color: var(--muted-fg);
}
.mini-meta span {
  display: inline-flex; align-items: center; gap: 0.5rem;
}
.mini-meta svg { width: 1rem; height: 1rem; color: var(--primary); }

.empty-state {
  text-align: center;
  padding: 4rem 1.5rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.empty-state p:first-child {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.empty-state p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  max-width: 28rem;
  margin: 0 auto;
}

/* ---------- Book a Session ---------- */
.booking-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media (min-width: 1024px) { .booking-grid { grid-template-columns: 1fr 2fr; } }
.session-types .type {
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--border-soft);
  margin-bottom: 0.75rem;
}
.session-types .type:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.session-types .row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.25rem;
}
.session-types .name { font-size: 0.875rem; font-weight: 500; }
.session-types .price {
  font-family: var(--font-serif);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--primary);
}
.session-types .meta {
  display: flex; gap: 0.75rem;
  font-size: 0.75rem; color: var(--muted-fg);
}
.session-types .meta span {
  display: inline-flex; align-items: center; gap: 0.25rem;
}
.session-types .meta svg { width: 0.75rem; height: 0.75rem; }

.note-card { background: var(--accent-soft); border-radius: var(--radius); padding: 1.5rem; }
.note-card h4 {
  font-family: var(--font-serif);
  font-size: 1rem;
  font-weight: 500;
  margin-bottom: 0.75rem;
}
.note-card ul li {
  display: flex; align-items: flex-start; gap: 0.5rem;
  font-size: 0.75rem; color: var(--muted-fg);
  margin-bottom: 0.5rem;
}
.note-card ul li:last-child { margin-bottom: 0; }
.note-card ul svg {
  width: 0.875rem; height: 0.875rem;
  color: var(--primary); flex-shrink: 0; margin-top: 0.125rem;
}

.calendar-placeholder {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 2rem;
  min-height: 31.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.calendar-placeholder__inner { text-align: center; max-width: 28rem; }
.calendar-placeholder__icon {
  width: 4rem; height: 4rem;
  border-radius: 9999px;
  background: var(--accent);
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1.5rem;
}
.calendar-placeholder__icon svg { width: 1.75rem; height: 1.75rem; color: var(--fg); }
.calendar-placeholder h3 {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  font-weight: 600;
  margin-bottom: 0.75rem;
}
.calendar-placeholder p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  line-height: 1.7;
  margin-bottom: 1.5rem;
}
.calendar-placeholder .integration-note {
  font-size: 0.75rem;
  color: var(--muted-fg);
  background: var(--accent-soft);
  border-radius: var(--radius);
  padding: 1rem;
  margin-bottom: 1.5rem;
  text-align: left;
}
.calendar-placeholder .integration-note p { margin-bottom: 0.25rem; }
.calendar-placeholder .integration-note p:first-child {
  font-weight: 500;
  color: var(--fg);
}

/* ---------- Studio rental layout ---------- */
.studio-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: start;
}
@media (min-width: 1024px) { .studio-grid { grid-template-columns: 1fr 1fr; } }
.studio-grid h2 {
  font-family: var(--font-serif);
  font-size: 1.875rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
}
.studio-grid .copy {
  color: var(--muted-fg);
  font-size: 0.875rem;
  line-height: 1.7;
  margin-bottom: 1rem;
}
.studio-includes h3 {
  font-family: var(--font-serif);
  font-size: 1.125rem;
  font-weight: 500;
  margin: 2rem 0 0.75rem;
}
.studio-includes ul li {
  display: flex; align-items: flex-start; gap: 0.625rem;
  font-size: 0.875rem; color: var(--muted-fg);
  margin-bottom: 0.625rem;
}
.studio-includes svg {
  width: 1rem; height: 1rem;
  color: var(--primary); flex-shrink: 0; margin-top: 0.125rem;
}
.studio-rates {
  margin-top: 1.5rem;
  background: var(--accent-soft);
  border-radius: var(--radius);
  padding: 1.5rem;
}
.studio-rates h4 {
  font-family: var(--font-serif);
  font-size: 1rem; font-weight: 500;
  margin-bottom: 0.75rem;
}
.studio-rates p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  margin-bottom: 1rem;
}
.studio-rates p.italic {
  font-style: italic;
  font-size: 0.75rem;
  margin-bottom: 0;
}

/* ---------- Contact page ---------- */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
@media (min-width: 1024px) { .contact-grid { grid-template-columns: 1fr 2fr; } }
.contact-info .row {
  display: flex; align-items: flex-start; gap: 0.75rem;
  margin-bottom: 1rem;
}
.contact-info .row:last-of-type { margin-bottom: 0; }
.contact-info .row svg {
  width: 1rem; height: 1rem;
  color: var(--primary);
  margin-top: 0.125rem;
  flex-shrink: 0;
}
.contact-info .label { font-size: 0.875rem; font-weight: 500; }
.contact-info .value { font-size: 0.875rem; color: var(--muted-fg); }
.contact-info .follow {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border-soft);
}
.contact-info .follow p { font-size: 0.875rem; font-weight: 500; margin-bottom: 0.75rem; }

.contact-form-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem;
}
@media (min-width: 640px) { .contact-form-card { padding: 2rem; } }

/* ---------- Page-specific section CTAs ---------- */
.cta-section {
  background: var(--card);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 4rem 1rem;
  text-align: center;
}
.cta-section h2 {
  font-family: var(--font-serif);
  font-size: 1.875rem;
  font-weight: 600;
  margin-bottom: 1rem;
}
.cta-section p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  max-width: 32rem;
  margin: 0 auto 2rem;
  line-height: 1.7;
}
.cta-section .actions {
  display: flex; flex-direction: column; gap: 1rem; justify-content: center;
}
@media (min-width: 640px) { .cta-section .actions { flex-direction: row; } }

/* ---------- Page heading (non-hero pages) ---------- */
.page-heading {
  text-align: center;
  margin-bottom: 3rem;
}
.page-heading h1 {
  font-family: var(--font-serif);
  font-size: 2.25rem;
  font-weight: 600;
  margin-bottom: 1rem;
}
@media (min-width: 640px) { .page-heading h1 { font-size: 3rem; } }
.page-heading p {
  color: var(--muted-fg);
  font-size: 0.875rem;
  max-width: 36rem;
  margin: 0 auto;
  line-height: 1.7;
}
