/* ==========================================================================
   Dra. Mira Zlotnik — Mockup
   Identidade visual: chocolate · camel · cream · nude
   Tokens base: brand-source/brand/tokens.css
   ========================================================================== */

:root {
  /* ---- Color: Primary (Chocolate) ---- */
  --mz-navy:        #3D2E26;   /* Chocolate */
  --mz-navy-deep:   #2A1F18;   /* Espresso */
  --mz-navy-soft:   #5A4438;   /* Mocha */

  /* ---- Color: Accent (Camel) ---- */
  --mz-gold:        #A67B5B;   /* Camel */
  --mz-gold-light:  #C49775;   /* Camel claro */
  --mz-gold-deep:   #8A5F42;   /* Camel bronze */
  --mz-cafe:        #735846;   /* Café com leite */

  /* ---- Color: Neutrals ---- */
  --mz-cream:       #F4ECE0;
  --mz-cream-light: #F9F2E8;
  --mz-cream-deep:  #E8DCC8;
  --mz-bone:        #FAF4EB;
  --mz-blush:       #EFD9C4;   /* Nude pêssego */

  /* ---- Color: Functional ---- */
  --mz-ink:         #1A1410;
  --mz-paper:       #FFFFFF;
  --mz-line:        rgba(61, 46, 38, 0.14);
  --mz-line-gold:   rgba(166, 123, 91, 0.45);

  /* ---- Type ---- */
  --mz-serif:       'Cormorant Garamond', 'Cormorant', Georgia, serif;
  --mz-sans:        'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  /* ---- Layout ---- */
  --mz-max:         1280px;
  --mz-gutter:      clamp(24px, 5vw, 80px);
  --mz-pad-y:       clamp(80px, 11vw, 160px);

  /* ---- Motion ---- */
  --ease:           cubic-bezier(.2,.7,.2,1);
}

/* Reset
   ----------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  scroll-behavior: smooth;
}
body {
  margin: 0;
  font-family: var(--mz-sans);
  font-weight: 400;
  font-size: 16px;
  line-height: 1.65;
  color: var(--mz-navy);
  background: var(--mz-cream);
}
img, svg { display: block; max-width: 100%; }
a {
  color: inherit;
  text-decoration: none;
  transition: color .3s var(--ease), opacity .3s var(--ease);
}
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
ul { list-style: none; padding: 0; margin: 0; }
input, textarea, select { font: inherit; color: inherit; }

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

/* Type scale
   ----------------------------------- */
.eyebrow {
  font-family: var(--mz-sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--mz-cafe);
  margin: 0 0 20px;
}
.eyebrow--gold { color: var(--mz-gold-deep); }
.eyebrow--light { color: var(--mz-gold-light); }

.display {
  font-family: var(--mz-serif);
  font-weight: 400;
  font-style: italic;
  font-size: clamp(48px, 7.4vw, 104px);
  line-height: 1.02;
  letter-spacing: -0.005em;
  margin: 0 0 28px;
  color: var(--mz-navy-deep);
}
.display em {
  font-style: italic;
  font-weight: 400;
  color: var(--mz-gold-deep);
}
.display--md {
  font-size: clamp(36px, 5vw, 60px);
  line-height: 1.06;
}
.display--upright { font-style: normal; }

p {
  margin: 0 0 1.1em;
  color: var(--mz-navy-soft);
  max-width: 56ch;
}

.section-head { margin-bottom: clamp(40px, 6vw, 80px); max-width: 760px; }
.section-head--row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 32px;
  max-width: none;
  flex-wrap: wrap;
}
.section-head--center { margin-inline: auto; text-align: center; }
.section-head--center p { margin-inline: auto; }

/* Ornament (linha-ponto-linha característica da marca) */
.ornament {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--mz-gold);
}
.ornament::before,
.ornament::after {
  content: "";
  height: 1px;
  width: 32px;
  background: currentColor;
}
.ornament::after { background: currentColor; }
.ornament span {
  width: 4px; height: 4px; border-radius: 50%; background: currentColor;
}

/* Buttons & links
   ----------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 18px 36px;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .24em;
  text-transform: uppercase;
  border: 1px solid currentColor;
  border-radius: 0; /* identidade institucional, sem cantos arredondados */
  transition: background .3s var(--ease), color .3s var(--ease), transform .3s var(--ease), border-color .3s var(--ease);
}
.btn--primary {
  background: var(--mz-navy);
  color: #fff;
  border-color: var(--mz-navy);
}
.btn--primary:hover {
  background: var(--mz-navy-deep);
  border-color: var(--mz-gold);
  transform: translateY(-1px);
}
.btn--ghost {
  background: transparent;
  color: var(--mz-navy);
  border-color: var(--mz-line);
}
.btn--ghost:hover {
  background: var(--mz-navy);
  color: #fff;
  border-color: var(--mz-navy);
}
.btn--gold {
  background: var(--mz-gold);
  color: var(--mz-navy-deep);
  border-color: var(--mz-gold);
}
.btn--gold:hover {
  background: var(--mz-gold-deep);
  border-color: var(--mz-gold-deep);
  color: #fff;
}
.btn--light {
  background: #fff;
  color: var(--mz-navy);
  border-color: #fff;
}
.btn--light:hover { background: var(--mz-gold); border-color: var(--mz-gold); color: var(--mz-navy-deep); }
.btn--full { width: 100%; }

.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mz-navy);
  border-bottom: 1px solid var(--mz-line);
  padding-bottom: 5px;
  transition: border-color .3s var(--ease), gap .3s var(--ease), color .3s var(--ease);
}
.link-arrow:hover {
  border-color: var(--mz-gold);
  color: var(--mz-gold-deep);
  gap: 12px;
}
.link-arrow--lg { font-size: 13px; padding-bottom: 6px; }

/* Topbar
   ----------------------------------- */
.topbar {
  background: var(--mz-navy-deep);
  color: rgba(244,236,224,.78);
  font-size: 10.5px;
  letter-spacing: .25em;
  text-transform: uppercase;
}
.topbar__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 11px var(--mz-gutter);
  gap: 24px;
}
.topbar__item--center { color: var(--mz-gold-light); }
.topbar__item--right { text-align: right; }
.topbar__item--right a {
  color: #fff;
  border-bottom: 1px solid var(--mz-gold);
  padding-bottom: 2px;
}
.topbar__item--right a:hover { color: var(--mz-gold-light); }

@media (max-width: 760px) {
  .topbar__inner { grid-template-columns: 1fr 1fr; }
  .topbar__item--center { display: none; }
}

/* Header / Nav
   ----------------------------------- */
.header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(244, 236, 224, .92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 0.5px solid var(--mz-line-gold);
  transition: padding .3s var(--ease), background .3s var(--ease);
}
.header.is-scrolled { background: rgba(249, 242, 232, .96); }
.header__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 14px clamp(20px, 4vw, 48px);
  gap: clamp(20px, 3vw, 48px);
  max-width: 1080px;          /* compacta — não estica de borda a borda */
  margin: 0 auto;
}
.header.is-scrolled .header__inner { padding-top: 10px; padding-bottom: 10px; }
.header__menu-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  width: 26px;
}
.header__menu-toggle span {
  height: 1px; background: var(--mz-navy);
  transition: transform .3s var(--ease), opacity .3s var(--ease);
}

.nav { display: flex; gap: clamp(14px, 1.8vw, 28px); }
.nav--left { justify-content: flex-end; padding-right: 8px; }
.nav--right { justify-content: flex-start; padding-left: 8px; }
.nav a {
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--mz-navy);
  position: relative;
  padding: 4px 0;
}
.nav a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 1px; background: var(--mz-gold);
  transform: scaleX(0); transform-origin: left;
  transition: transform .35s var(--ease);
}
.nav a:hover { color: var(--mz-navy-deep); }
.nav a:hover::after { transform: scaleX(1); }
.nav__cta {
  border: 1px solid var(--mz-gold);
  padding: 10px 18px !important;
  color: var(--mz-navy) !important;
}
.nav__cta::after { display: none; }
.nav__cta:hover { background: var(--mz-navy); color: #fff !important; border-color: var(--mz-navy); }

.logo {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: var(--mz-navy);
  transition: opacity .3s var(--ease);
}
.logo:hover { opacity: .75; }
.logo__mark {
  width: 64px;
  height: 64px;
  display: block;
}
.logo__mark .mg-ink    { fill: var(--mz-navy-deep); }
.logo__mark .mg-accent { color: var(--mz-gold); }
.header.is-scrolled .logo__mark { width: 52px; height: 52px; transition: width .3s var(--ease), height .3s var(--ease); }

@media (max-width: 980px) {
  .header__inner {
    grid-template-columns: auto 1fr auto;
    padding: 12px clamp(20px, 4vw, 32px);
  }
  .header__menu-toggle { display: flex; }
  .logo { justify-content: flex-start; }
  .logo__mark { width: 52px; height: 52px; }
  .nav--left, .nav--right { display: none; }
}

/* Mobile drawer */
.mdrawer {
  position: fixed;
  inset: 0;
  background: var(--mz-cream);
  z-index: 60;
  display: flex;
  flex-direction: column;
  padding: 100px var(--mz-gutter) 48px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-16px);
  transition: opacity .4s var(--ease), transform .4s var(--ease);
  overflow-y: auto;
}
.mdrawer a {
  display: block;
  padding: 18px 0;
  font-family: var(--mz-serif);
  font-style: italic;
  font-size: 28px;
  color: var(--mz-navy);
  border-bottom: 1px solid var(--mz-line);
}
.mdrawer a:last-child { border-bottom: none; }
.mdrawer__close {
  position: absolute;
  top: 28px; right: var(--mz-gutter);
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--mz-navy);
}
body.nav-open .mdrawer {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
body.nav-open { overflow: hidden; }

/* Hero — tipografia editorial pura (sem foto)
   ----------------------------------- */
.hero {
  position: relative;
  display: grid;
  place-items: center;
  padding: clamp(48px, 7vh, 96px) 0 clamp(72px, 11vh, 140px);
  overflow: hidden;
  background:
    radial-gradient(ellipse at 70% 30%, var(--mz-cream-light) 0%, var(--mz-cream) 55%, var(--mz-cream-deep) 110%);
}
.hero__watermark {
  position: absolute;
  right: -6%;
  bottom: -10%;
  width: clamp(420px, 55vw, 760px);
  height: auto;
  opacity: .07;
  color: var(--mz-gold-deep);
  pointer-events: none;
}
.hero__watermark .mg-ink    { fill: currentColor; }
.hero__watermark .mg-accent { color: currentColor; }

.hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  display: grid;
  justify-items: center;
  gap: 0;
}
.hero__tag {
  display: inline-flex;
  align-items: center;
  gap: 18px;
  font-family: var(--mz-sans);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--mz-cafe);
  margin: 0 0 32px;
}
.hero__tag-rule {
  display: inline-block;
  height: 0.5px;
  width: clamp(40px, 8vw, 80px);
  background: var(--mz-gold);
}
.hero__title {
  font-family: var(--mz-serif);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(56px, 11vw, 156px);
  line-height: 0.94;
  letter-spacing: -0.015em;
  color: var(--mz-navy-deep);
  margin: 0 0 28px;
  text-wrap: balance;
}
.hero__title em {
  font-style: italic;
  font-weight: 300;
  color: var(--mz-gold-deep);
}
.hero__name {
  font-family: var(--mz-serif);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(20px, 2vw, 26px);
  color: var(--mz-navy-soft);
  margin: 0 0 28px;
  position: relative;
  padding: 18px 0 0;
}
.hero__name::before {
  content: "";
  position: absolute;
  top: 0; left: 50%;
  transform: translateX(-50%);
  width: 32px; height: 0.5px;
  background: var(--mz-gold);
}
.hero__lede {
  font-family: var(--mz-serif);
  font-size: clamp(17px, 1.4vw, 20px);
  line-height: 1.55;
  font-style: italic;
  font-weight: 300;
  color: var(--mz-navy-soft);
  max-width: 52ch;
  margin: 0 auto 44px;
  text-wrap: pretty;
}
.hero__actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  justify-content: center;
}
.hero__scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  font-size: 9.5px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--mz-cafe);
  z-index: 2;
}
.hero__scroll-line {
  width: 1px; height: 48px;
  background: linear-gradient(to bottom, var(--mz-gold), transparent);
  animation: scrollHint 2.4s var(--ease) infinite;
}
@keyframes scrollHint {
  0%   { transform: scaleY(0); transform-origin: top; }
  50%  { transform: scaleY(1); transform-origin: top; }
  51%  { transform-origin: bottom; }
  100% { transform: scaleY(0); transform-origin: bottom; }
}

@media (max-width: 760px) {
  .hero { padding: 40px 0 80px; }
  .hero__tag { gap: 10px; font-size: 9px; letter-spacing: .3em; }
  .hero__tag-rule { width: 28px; }
}

/* Pillars
   ----------------------------------- */
.pillars {
  background: var(--mz-cream-deep);
  padding: clamp(48px, 6vw, 80px) 0;
  border-top: 1px solid var(--mz-line-gold);
  border-bottom: 1px solid var(--mz-line-gold);
}
.pillars__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.pillar {
  display: flex; flex-direction: column; gap: 10px;
  padding-right: 24px;
  border-right: 1px solid var(--mz-line);
}
.pillar:last-child { border-right: none; }
.pillar__num {
  font-family: var(--mz-serif);
  font-style: italic;
  font-size: clamp(36px, 4.4vw, 56px);
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--mz-navy-deep);
}
.pillar__label {
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--mz-cafe);
}
@media (max-width: 760px) {
  .pillars__grid { grid-template-columns: repeat(2, 1fr); }
  .pillar:nth-child(2) { border-right: none; }
}

/* About
   ----------------------------------- */
.about {
  padding: var(--mz-pad-y) 0;
  background: var(--mz-cream);
}
.about__grid {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: clamp(40px, 7vw, 100px);
  align-items: center;
}
.about__media {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 18px;
  aspect-ratio: 4 / 5;
}
.about__photo {
  position: relative;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: 18px;
}
.about__photo img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 65%;
  z-index: 1;
}
.about__photo::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 0.5px solid rgba(255,255,255,.45);
  z-index: 2;
  pointer-events: none;
}
.about__photo-caption {
  position: relative;
  z-index: 3;
  font-size: 10px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: rgba(255,255,255,.85);
  text-shadow: 0 1px 6px rgba(0,0,0,.4);
}
.about__photo--main {
  grid-column: 1 / 2;
  grid-row: 1 / 3;
  background: linear-gradient(135deg, var(--mz-navy-soft), var(--mz-navy-deep));
}
.about__photo--secondary {
  grid-column: 2 / 3;
  grid-row: 2 / 3;
  background:
    linear-gradient(160deg, rgba(166,123,91,.25), transparent 60%),
    linear-gradient(135deg, var(--mz-blush), var(--mz-cream-deep));
}
.about__photo--secondary img {
  /* mira-laptop.jpg: Dra. de perfil com laptop, fundo blush */
  object-position: 70% center;
}
.about__photo--secondary.about__photo--fallback .about__photo-caption {
  color: rgba(61,46,38,.5);
  text-shadow: none;
}
.about__photo--main.about__photo--fallback {
  background:
    linear-gradient(160deg, rgba(42,31,24,.25), transparent 60%),
    linear-gradient(135deg, var(--mz-navy-soft), var(--mz-navy-deep));
}
.about__list {
  margin: 28px 0 36px;
  display: grid;
  gap: 12px;
}
.about__list li {
  font-size: 14px;
  color: var(--mz-navy-soft);
  display: flex;
  gap: 12px;
  align-items: baseline;
}
.about__list li span {
  color: var(--mz-gold-deep);
  font-family: var(--mz-serif);
  font-style: italic;
}
@media (max-width: 880px) {
  .about__grid { grid-template-columns: 1fr; }
  .about__media { aspect-ratio: 3 / 2; max-height: 480px; }
}

/* Specialties
   ----------------------------------- */
.specialties {
  padding: var(--mz-pad-y) 0;
  background: var(--mz-bone);
  border-top: 1px solid var(--mz-line-gold);
}
.specialties__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 3vw, 40px);
}
.specialty {
  background: var(--mz-paper);
  border: 0.5px solid var(--mz-line);
  overflow: hidden;
  transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s var(--ease);
}
.specialty:hover {
  transform: translateY(-6px);
  border-color: var(--mz-gold);
  box-shadow: 0 30px 60px -30px rgba(42,31,24,.18);
}
.specialty__media {
  aspect-ratio: 16 / 9;
  position: relative;
  overflow: hidden;
}
.specialty__media img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
}
.specialty__media::after {
  content: "";
  position: absolute;
  left: 24px; right: 24px; bottom: 24px; top: 24px;
  border: 0.5px solid rgba(255,255,255,.35);
  z-index: 2;
  pointer-events: none;
}
.specialty__media--1 { background: linear-gradient(135deg, var(--mz-blush), var(--mz-cream-deep)); }
.specialty__media--2 { background: linear-gradient(135deg, var(--mz-cream-deep), var(--mz-gold-light)); }
.specialty__media--3 { background: linear-gradient(135deg, var(--mz-navy-soft), var(--mz-navy-deep)); }
.specialty__media--4 { background: linear-gradient(135deg, var(--mz-cream), var(--mz-gold)); }
.specialty__media--3.specialty__media--fallback {
  background: linear-gradient(135deg, var(--mz-navy-soft), var(--mz-navy-deep));
}
.specialty__body {
  padding: clamp(28px, 3.5vw, 44px);
}
.specialty__body h3 {
  font-family: var(--mz-serif);
  font-style: italic;
  font-size: clamp(28px, 3vw, 38px);
  font-weight: 400;
  margin: 0 0 14px;
  letter-spacing: -0.005em;
  color: var(--mz-navy-deep);
}
.specialty__body p {
  font-size: 15px;
  margin-bottom: 24px;
}
@media (max-width: 760px) {
  .specialties__grid { grid-template-columns: 1fr; }
}

/* Clinic (full-bleed navy)
   ----------------------------------- */
.clinic {
  position: relative;
  padding: clamp(120px, 16vw, 220px) 0;
  color: var(--mz-cream);
  overflow: hidden;
  background: var(--mz-navy-deep);
}
.clinic__media {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, rgba(42,31,24,.92) 0%, rgba(42,31,24,.6) 100%),
    linear-gradient(45deg, var(--mz-navy-deep), var(--mz-navy-soft) 60%, var(--mz-cafe));
}
.clinic__crest {
  position: absolute;
  right: -80px;
  bottom: -80px;
  width: 480px;
  opacity: .06;
  color: var(--mz-gold);
}
.clinic__content {
  position: relative;
  z-index: 2;
  max-width: 640px;
}
.clinic__content h2 { color: var(--mz-cream); }
.clinic__content p { color: rgba(244,236,224,.78); max-width: 52ch; }
.clinic__features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin: 36px 0 40px;
  padding: 32px 0;
  border-top: 0.5px solid var(--mz-line-gold);
  border-bottom: 0.5px solid var(--mz-line-gold);
}
.clinic__features div { display: flex; flex-direction: column; gap: 6px; }
.clinic__features strong {
  font-family: var(--mz-serif);
  font-style: italic;
  font-weight: 400;
  font-size: 20px;
  color: var(--mz-cream);
}
.clinic__features span {
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--mz-gold-light);
}
@media (max-width: 760px) {
  .clinic__features { grid-template-columns: 1fr; gap: 16px; padding: 24px 0; }
}

/* Journal / Blog
   ----------------------------------- */
.journal {
  padding: var(--mz-pad-y) 0;
  background: var(--mz-cream);
}
.journal__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 3vw, 44px);
}
.post { display: flex; flex-direction: column; gap: 14px; }
.post__media {
  aspect-ratio: 4 / 5;
  margin-bottom: 12px;
  transition: transform .6s var(--ease);
  position: relative;
}
.post__media::after {
  content: "";
  position: absolute;
  inset: 18px;
  border: 0.5px solid rgba(255,255,255,.2);
}
.post__media--1 { background: linear-gradient(135deg, var(--mz-blush), var(--mz-cream-deep)); }
.post__media--2 { background: linear-gradient(135deg, var(--mz-cream-deep), var(--mz-gold-light)); }
.post__media--3 { background: linear-gradient(135deg, var(--mz-navy-soft), var(--mz-navy-deep)); }
.post:hover .post__media { transform: scale(1.02); }
.post__meta {
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--mz-cafe);
}
.post__meta span { color: var(--mz-gold-deep); }
.post h3 {
  font-family: var(--mz-serif);
  font-style: italic;
  font-size: clamp(22px, 2.2vw, 28px);
  font-weight: 400;
  line-height: 1.22;
  margin: 0;
  letter-spacing: -0.005em;
  color: var(--mz-navy-deep);
}
.post p { font-size: 15px; margin: 0; }
.post .link-arrow { align-self: flex-start; margin-top: 8px; }
@media (max-width: 880px) {
  .journal__grid { grid-template-columns: 1fr; }
}

/* Testimonials
   ----------------------------------- */
.testimonials {
  padding: var(--mz-pad-y) 0;
  background: var(--mz-cream-deep);
  border-top: 1px solid var(--mz-line-gold);
  border-bottom: 1px solid var(--mz-line-gold);
}
.testimonials__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(24px, 3vw, 44px);
}
.quote {
  margin: 0;
  padding: 40px 36px;
  background: var(--mz-cream-light);
  border: 0.5px solid var(--mz-line-gold);
  position: relative;
}
.quote::before {
  content: "“";
  position: absolute;
  top: 4px; left: 24px;
  font-family: var(--mz-serif);
  font-style: italic;
  font-size: 110px;
  line-height: 1;
  color: var(--mz-gold);
}
.quote blockquote {
  margin: 28px 0 24px;
  font-family: var(--mz-serif);
  font-size: clamp(18px, 1.6vw, 22px);
  font-style: italic;
  font-weight: 400;
  line-height: 1.5;
  color: var(--mz-navy-deep);
}
.quote figcaption {
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--mz-cafe);
}
@media (max-width: 880px) {
  .testimonials__grid { grid-template-columns: 1fr; }
}

/* Contact
   ----------------------------------- */
.contact {
  padding: var(--mz-pad-y) 0;
  background: var(--mz-bone);
}
.contact__grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
.contact__info {
  margin-top: 32px;
  display: grid;
  gap: 22px;
}
.contact__info li {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-bottom: 18px;
  border-bottom: 0.5px solid var(--mz-line);
}
.contact__info strong {
  font-size: 10.5px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--mz-cafe);
  font-weight: 500;
}
.contact__info span {
  font-family: var(--mz-serif);
  font-style: italic;
  font-size: 19px;
  color: var(--mz-navy-deep);
}
.contact__form {
  background: var(--mz-cream-light);
  padding: clamp(28px, 4vw, 48px);
  border: 0.5px solid var(--mz-line-gold);
  display: grid;
  gap: 22px;
  position: relative;
}
.contact__form::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 4px;
  height: 100%;
  background: var(--mz-navy);
}
.contact__form::after {
  content: "";
  position: absolute;
  top: 0; left: 6px;
  width: 1px;
  height: 100%;
  background: var(--mz-gold);
}
.field { display: flex; flex-direction: column; gap: 8px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field label {
  font-size: 10.5px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--mz-cafe);
  font-weight: 500;
}
.field input,
.field textarea,
.field select {
  background: transparent;
  border: none;
  border-bottom: 0.5px solid var(--mz-line);
  padding: 10px 0;
  font-size: 15px;
  outline: none;
  color: var(--mz-navy-deep);
  transition: border-color .3s var(--ease);
}
.field input:focus,
.field textarea:focus,
.field select:focus { border-color: var(--mz-gold); }
.field textarea { resize: vertical; }
.contact__disclaimer {
  font-size: 11px;
  letter-spacing: .15em;
  color: var(--mz-cafe);
  margin: 8px 0 0;
  text-align: center;
  text-transform: uppercase;
}
@media (max-width: 880px) {
  .contact__grid { grid-template-columns: 1fr; }
  .field-row { grid-template-columns: 1fr; }
}

/* Footer
   ----------------------------------- */
.footer {
  background: var(--mz-navy-deep);
  color: rgba(244,236,224,.7);
  padding: clamp(60px, 8vw, 100px) 0 32px;
  position: relative;
  overflow: hidden;
}
.footer__crest {
  position: absolute;
  right: -100px;
  top: -100px;
  width: 380px;
  opacity: .05;
  color: var(--mz-gold);
}
.footer__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: clamp(28px, 4vw, 64px);
  padding-bottom: 56px;
  border-bottom: 0.5px solid var(--mz-line-gold);
  position: relative;
  z-index: 1;
}
.footer__brand .footer__logo {
  width: 100%;
  max-width: 320px;
  height: auto;
  color: var(--mz-cream);
  display: block;
}
.footer__sig {
  font-family: var(--mz-serif);
  font-style: italic;
  font-size: 15px;
  line-height: 1.7;
  color: rgba(244,236,224,.78);
  margin-top: 28px;
  padding-top: 20px;
  border-top: 0.5px solid rgba(166,123,91,.35);
}
.footer__sig strong {
  font-weight: 500;
  color: var(--mz-cream);
  font-style: italic;
}
.footer__col h4 {
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--mz-gold-light);
  margin: 0 0 22px;
}
.footer__col a {
  display: block;
  padding: 6px 0;
  font-size: 14px;
  color: rgba(244,236,224,.78);
}
.footer__col a:hover { color: var(--mz-gold); }
.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 28px;
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(244,236,224,.4);
  flex-wrap: wrap;
  gap: 12px;
  position: relative;
  z-index: 1;
}
@media (max-width: 760px) {
  .footer__grid { grid-template-columns: 1fr 1fr; }
  .footer__brand { grid-column: 1 / -1; }
}

/* Reveal on scroll
   ----------------------------------- */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .9s var(--ease), transform .9s var(--ease);
}
.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Selection */
::selection { background: var(--mz-gold); color: var(--mz-navy-deep); }
