/* Mon Site Elementor — Hero V2 */
.ms-hero-v2 {
  min-height: 100vh; display: grid; grid-template-columns: 1fr 1fr;
  padding-top: 80px; background: var(--ms-cream); position: relative; overflow: hidden;
}
.ms-hero-v2__bg-text {
  position: absolute; font-family: var(--ms-serif);
  font-size: clamp(120px,18vw,240px); font-weight: 900;
  color: rgba(15,15,14,0.04); white-space: nowrap;
  top: 50%; left: -2%; transform: translateY(-50%);
  pointer-events: none; user-select: none; letter-spacing: -0.04em;
}
.ms-hero-v2__left {
  display: flex; flex-direction: column; justify-content: center;
  padding: 6rem 3rem 6rem 4rem; position: relative; z-index: 2;
}
.ms-hero-v2__eyebrow {
  font-size: 0.75rem; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ms-terracotta); margin-bottom: 2rem;
  display: flex; align-items: center; gap: 0.75rem;
}
.ms-hero-v2__eyebrow::before {
  content: ''; display: block; width: 32px; height: 1px; background: var(--ms-terracotta);
}
.ms-hero-v2__headline {
  font-family: var(--ms-serif);
  font-size: clamp(2.6rem,5vw,4.2rem); font-weight: 900; line-height: 1.08;
  letter-spacing: -0.02em; color: var(--ms-ink); margin: 0 0 1.5rem; max-width: 520px;
}
.ms-hero-v2__headline em { font-style: italic; color: var(--ms-terracotta); }
.ms-hero-v2__sub { font-size: 1.05rem; font-weight: 300; color: #3a3734; max-width: 460px; line-height: 1.75; margin: 0 0 1.5rem; }
.ms-hero-v2__credline { font-size: 0.82rem; color: var(--ms-ash); letter-spacing: 0.04em; margin: 0 0 2.5rem; font-style: italic; }
.ms-hero-v2__actions { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }
/* Right */
.ms-hero-v2__right {
  position: relative; display: flex; align-items: center; justify-content: center;
  padding: 4rem 4rem 4rem 2rem; z-index: 2;
}
.ms-hero-v2__portrait {
  width: 100%; max-width: 420px; aspect-ratio: 3/4;
  background: var(--ms-forest); position: relative; overflow: hidden;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
}
.ms-hero-v2__portrait-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ms-hero-v2__portrait-placeholder {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: flex-end; padding: 2rem;
  background: linear-gradient(0deg,rgba(15,15,14,0.6) 0%,transparent 60%);
}
.ms-hero-v2__portrait-name { color: rgba(247,244,239,0.9); font-family: var(--ms-serif); font-size: 1.4rem; font-weight: 700; text-align: center; }
.ms-hero-v2__portrait-sub { color: rgba(247,244,239,0.6); font-size: 0.78rem; letter-spacing: 0.1em; text-transform: uppercase; text-align: center; margin-top: 0.4rem; }
/* Accent card */
.ms-hero-v2__card {
  position: absolute; bottom: 3rem; left: -1.5rem;
  background: var(--ms-warm-white); border: 1px solid var(--ms-light-rule);
  padding: 1.2rem 1.5rem; box-shadow: 0 8px 32px rgba(0,0,0,0.08); max-width: 220px; z-index: 3;
}
.ms-hero-v2__card-num { font-family: var(--ms-serif); font-size: 2.2rem; font-weight: 900; color: var(--ms-terracotta); line-height: 1; }
.ms-hero-v2__card-label { font-size: 0.78rem; color: var(--ms-ash); letter-spacing: 0.04em; margin-top: 0.3rem; line-height: 1.4; }

@media (max-width: 900px) {
  .ms-hero-v2 { grid-template-columns: 1fr; min-height: auto; padding: 100px 1.5rem 3rem; }
  .ms-hero-v2__left { padding: 0; }
  .ms-hero-v2__right { display: none; }
}
