/*
 * MMP — Our Story page styles
 * File: mmp-astra-child/assets/css/our-story.css
 */

/* ── OPENING STATEMENT ──────────────────────────────────────── */

.mmp-os-opening {
  background: var(--mmp-page-paper);
  padding: 72px 40px 64px;
  border-bottom: 1px solid var(--mmp-page-border);
}

.mmp-os-opening-inner {
  gap: 64px !important;
  align-items: flex-end;
}

.mmp-os-opening-label {
  font-family: var(--mmp-font-body);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(48, 43, 40, 0.5);
  margin: 0 0 24px !important;
}

.mmp-os-opening-h1 {
  font-family: var(--mmp-font-heading) !important;
  font-weight: 800 !important;
  font-size: 52px !important;
  line-height: 1.04 !important;
  color: var(--mmp-page-ink) !important;
  letter-spacing: -0.02em !important;
  margin: 0 0 28px !important;
}

.mmp-os-opening-lead {
  font-family: var(--mmp-font-editorial);
  font-size: 18px;
  line-height: 1.7;
  color: var(--mmp-page-muted);
  margin: 0 !important;
}

.mmp-os-opening-aside {
  padding: 28px 0 0;
  border-top: 2px solid var(--mmp-page-border);
  align-self: flex-end;
}

.mmp-os-aside-label {
  font-family: var(--mmp-font-body);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(48, 43, 40, 0.45);
  margin: 0 0 16px !important;
}

.mmp-os-aside-quote {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.mmp-os-aside-quote p {
  font-family: var(--mmp-font-editorial);
  font-size: 14px;
  line-height: 1.7;
  color: var(--mmp-page-muted);
  font-style: italic;
  margin: 0 !important;
}

.mmp-os-aside-quote cite {
  display: none;
}

/* ── SHARED UTILITIES ───────────────────────────────────────── */

.mmp-os-section-label {
  font-family: var(--mmp-font-body);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mmp-page-sage);
  margin: 0 !important;
}

/* ── ORIGIN ─────────────────────────────────────────────────── */

.mmp-os-origin {
  background: var(--mmp-white);
  border-bottom: 1px solid var(--mmp-page-border-light);
}

.mmp-os-origin-inner {
  gap: 0 !important;
}

.mmp-os-origin-img-col {
  padding: 0 !important;
}

.mmp-os-origin-photo {
  margin: 0 !important;
  height: 100%;
}

.mmp-os-origin-photo img {
  width: 100%;
  min-height: 420px;
  height: 100%;
  object-fit: cover;
  display: block;
  background: var(--mmp-page-ink);
}

.mmp-os-origin-photo img[src=""] {
  background: linear-gradient(135deg, var(--mmp-page-blue), var(--mmp-page-clay));
  min-height: 420px;
}

.mmp-os-origin-text {
  padding: 56px 48px !important;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.mmp-os-origin-h2 {
  font-family: var(--mmp-font-heading) !important;
  font-weight: 800 !important;
  font-size: 34px !important;
  line-height: 1.1 !important;
  color: var(--mmp-page-ink) !important;
  letter-spacing: -0.01em !important;
  margin: 0 0 20px !important;
}

.mmp-os-origin-body {
  font-family: var(--mmp-font-editorial);
  font-size: 15px;
  line-height: 1.8;
  color: var(--mmp-page-muted);
  margin: 0 0 16px !important;
}

.mmp-os-origin-text .mmp-os-section-label {
  margin: 0 0 16px !important;
}

/* ── BELIEF STRIP ───────────────────────────────────────────── */

.mmp-os-belief {
  background: var(--mmp-page-blue);
  padding: 48px 40px;
  border-bottom: 1px solid var(--mmp-page-border);
}

.mmp-os-belief-inner {
  gap: 0 !important;
  border: 1px solid rgba(255, 250, 241, 0.15);
}

.mmp-os-belief-item {
  padding: 28px 28px 32px !important;
  border-right: 1px solid rgba(255, 250, 241, 0.15);
}

.mmp-os-belief-item:last-child {
  border-right: none;
}

.mmp-os-belief-num {
  font-family: var(--mmp-font-heading);
  font-weight: 800;
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--mmp-page-gold);
  opacity: 0.65;
  margin: 0 0 14px !important;
}

.mmp-os-belief-quote {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.mmp-os-belief-quote p {
  font-family: var(--mmp-font-editorial);
  font-size: 15px;
  line-height: 1.65;
  color: rgba(255, 250, 241, 0.85);
  font-style: italic;
  margin: 0 !important;
}

.mmp-os-belief-quote cite {
  display: none;
}

/* ── TIMELINE ───────────────────────────────────────────────── */

.mmp-os-timeline {
  padding: 64px 40px;
  background: var(--mmp-page-cream);
  border-bottom: 1px solid var(--mmp-page-border-light);
}

.mmp-os-timeline-header {
  display: flex !important;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 48px !important;
}

.mmp-os-timeline-h2 {
  font-family: var(--mmp-font-heading) !important;
  font-weight: 700 !important;
  font-size: 28px !important;
  color: var(--mmp-page-ink) !important;
  letter-spacing: -0.01em !important;
  margin: 0 !important;
}

.mmp-os-thread-wrap {
  padding: 0 !important;
  position: relative;
}

.mmp-os-thread-entry {
  display: grid !important;
  grid-template-columns: 80px 1fr !important;
  gap: 0 !important;
  position: relative;
  padding: 0 0 40px !important;
}

.mmp-os-thread-entry:last-child {
  padding-bottom: 0 !important;
}

.mmp-os-thread-entry::before {
  content: '';
  position: absolute;
  left: 73px;
  top: 10px;
  bottom: -10px;
  width: 2px;
  background: var(--mmp-page-border-light);
}

.mmp-os-thread-entry:last-child::before {
  display: none;
}

.mmp-os-thread-entry::after {
  content: '';
  position: absolute;
  left: 68px;
  top: 4px;
  width: 10px;
  height: 10px;
  background: var(--mmp-page-gold);
  border: 2px solid var(--mmp-page-blue);
}

.mmp-os-thread-now::after {
  background: var(--mmp-page-blue);
}

.mmp-os-thread-year {
  font-family: var(--mmp-font-heading);
  font-weight: 800;
  font-size: 14px;
  color: var(--mmp-page-blue);
  padding: 0 24px 0 0 !important;
  text-align: right;
  letter-spacing: 0.02em;
  padding-top: 2px !important;
  margin: 0 !important;
}

.mmp-os-thread-body {
  padding: 0 0 0 28px !important;
}

.mmp-os-thread-title {
  font-family: var(--mmp-font-heading) !important;
  font-weight: 700 !important;
  font-size: 17px !important;
  color: var(--mmp-page-ink) !important;
  margin: 0 0 8px !important;
  letter-spacing: 0.01em !important;
}

.mmp-os-thread-text {
  font-family: var(--mmp-font-body);
  font-size: 14px;
  line-height: 1.65;
  color: var(--mmp-page-sage);
  margin: 0 !important;
}

/* ── MISSION STATEMENT ──────────────────────────────────────── */

.mmp-os-mission {
  background: var(--mmp-page-ink);
  padding: 72px 40px;
  border-bottom: 1px solid var(--mmp-page-border);
}

.mmp-os-mission-inner {
  gap: 64px !important;
  align-items: center;
}

.mmp-os-mission-mark {
  font-family: var(--mmp-font-heading);
  font-weight: 800;
  font-size: 72px;
  line-height: 0.8;
  color: var(--mmp-page-gold);
  opacity: 0.25;
  margin: 0 0 -20px !important;
  display: block;
}

.mmp-os-mission-quote {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.mmp-os-mission-quote p {
  font-family: var(--mmp-font-editorial);
  font-size: 24px;
  line-height: 1.55;
  color: var(--mmp-page-paper);
  font-style: italic;
  margin: 0 !important;
}

.mmp-os-mission-quote cite {
  display: none;
}

.mmp-os-mission-label {
  font-family: var(--mmp-font-body);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255, 250, 241, 0.35);
  margin: 0 0 20px !important;
}

.mmp-os-mission-body {
  font-family: var(--mmp-font-editorial);
  font-size: 15px;
  line-height: 1.75;
  color: rgba(255, 250, 241, 0.62);
  margin: 0 0 28px !important;
}

.mmp-os-values {
  border-top: 1px solid rgba(255, 250, 241, 0.1);
  padding: 0 !important;
}

.mmp-os-value {
  padding: 14px 0 !important;
  border-bottom: 1px solid rgba(255, 250, 241, 0.08);
  display: flex !important;
  align-items: center;
  gap: 14px;
}

.mmp-os-value:last-child {
  border-bottom: none;
}

.mmp-os-value::before {
  content: '';
  width: 5px;
  height: 5px;
  background: var(--mmp-page-gold);
  opacity: 0.7;
  flex-shrink: 0;
  display: block;
}

.mmp-os-value-text {
  font-family: var(--mmp-font-heading);
  font-weight: 700;
  font-size: 14px;
  color: rgba(255, 250, 241, 0.78);
  margin: 0 !important;
  letter-spacing: 0.02em;
}

/* ── IMAGE STRIP ────────────────────────────────────────────── */

.mmp-os-strip {
  border-bottom: 1px solid var(--mmp-page-border-light);
}

.mmp-os-strip-inner {
  gap: 0 !important;
}

.mmp-os-strip-item {
  padding: 0 !important;
  min-height: 260px;
  position: relative;
  border-right: 1px solid var(--mmp-page-border-light);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.mmp-os-strip-item:last-child {
  border-right: none;
}

.mmp-os-strip-dark {
  background: var(--mmp-page-ink);
}

.mmp-os-strip-warm {
  background: var(--mmp-page-gold);
}

.mmp-os-strip-mid {
  background: var(--mmp-page-blue);
}

.mmp-os-strip-photo {
  position: absolute;
  inset: 0;
  margin: 0 !important;
}

.mmp-os-strip-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.mmp-os-strip-photo img[src=""] {
  display: none;
}

.mmp-os-strip-cap,
.mmp-os-strip-label {
  position: relative;
  z-index: 1;
  padding: 0 20px !important;
}

.mmp-os-strip-cap {
  font-family: var(--mmp-font-body);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 250, 241, 0.35);
  margin: 0 0 6px !important;
}

.mmp-os-strip-cap-warm {
  color: rgba(48, 43, 40, 0.45) !important;
}

.mmp-os-strip-label {
  font-family: var(--mmp-font-heading);
  font-weight: 700;
  font-size: 16px;
  line-height: 1.2;
  color: rgba(255, 250, 241, 0.82);
  margin: 0 0 20px !important;
}

.mmp-os-strip-label-warm {
  color: rgba(48, 43, 40, 0.78) !important;
}

/* ── PEOPLE ─────────────────────────────────────────────────── */

.mmp-os-people {
  background: var(--mmp-white);
  padding: 64px 40px;
  border-bottom: 1px solid var(--mmp-page-border-light);
}

.mmp-os-people-header {
  display: flex !important;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 40px !important;
}

.mmp-os-people-h2 {
  font-family: var(--mmp-font-heading) !important;
  font-weight: 700 !important;
  font-size: 28px !important;
  color: var(--mmp-page-ink) !important;
  letter-spacing: -0.01em !important;
  margin: 0 !important;
}

.mmp-os-people-grid {
  gap: 0 !important;
  border: 1px solid var(--mmp-page-border-light);
}

.mmp-os-person {
  border-right: 1px solid var(--mmp-page-border-light);
  padding: 0 0 24px !important;
}

.mmp-os-person:last-child {
  border-right: none;
}

.mmp-os-person-img {
  margin: 0 0 20px !important;
}

.mmp-os-person-img img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
}

.mmp-os-person-img-a img[src=""] {
  background: var(--mmp-page-ink);
  height: 200px;
  display: block;
}

.mmp-os-person-img-b img[src=""] {
  background: #3a3530;
  height: 200px;
  display: block;
}

.mmp-os-person-img-c img[src=""] {
  background: linear-gradient(135deg, var(--mmp-page-blue), var(--mmp-page-clay));
  height: 200px;
  display: block;
}

.mmp-os-person-info {
  padding: 0 24px !important;
}

.mmp-os-person-name {
  font-family: var(--mmp-font-heading) !important;
  font-weight: 700 !important;
  font-size: 17px !important;
  color: var(--mmp-page-ink) !important;
  margin: 0 0 4px !important;
}

.mmp-os-person-role {
  font-family: var(--mmp-font-body);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mmp-page-sage);
  margin: 0 0 12px !important;
}

.mmp-os-person-bio {
  font-family: var(--mmp-font-editorial);
  font-size: 13px;
  line-height: 1.65;
  color: var(--mmp-page-muted);
  margin: 0 !important;
}

/* ── CTA ────────────────────────────────────────────────────── */

.mmp-os-cta {
  background: var(--mmp-page-cream);
  padding: 72px 40px;
}

.mmp-os-cta-inner {
  gap: 48px !important;
  align-items: center;
}

.mmp-os-cta-h2 {
  font-family: var(--mmp-font-heading) !important;
  font-weight: 800 !important;
  font-size: 36px !important;
  color: var(--mmp-page-ink) !important;
  margin: 0 0 16px !important;
  letter-spacing: -0.01em !important;
  line-height: 1.1 !important;
}

.mmp-os-cta-body {
  font-family: var(--mmp-font-editorial);
  font-size: 15px;
  line-height: 1.65;
  color: var(--mmp-page-muted);
  margin: 0 !important;
}

.mmp-os-cta-actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 0 !important;
}

.mmp-os-btn-primary .wp-block-button__link {
  background: var(--mmp-page-ink) !important;
  color: var(--mmp-page-paper) !important;
  border: none !important;
  border-radius: 0 !important;
  font-family: var(--mmp-font-heading);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.04em;
  padding: 16px 24px;
  width: 100%;
  text-align: left;
  display: flex;
  justify-content: space-between;
}

.mmp-os-btn-primary .wp-block-button__link::after {
  content: '→';
  opacity: 0.5;
}

.mmp-os-btn-primary .wp-block-button__link:hover {
  background: #4a4440 !important;
}

.mmp-os-cta-links {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 0 !important;
}

.mmp-os-cta-link {
  border: 1px solid var(--mmp-page-border);
  border-top: none;
  padding: 0 !important;
}

.mmp-os-cta-link:first-child {
  border-top: 1px solid var(--mmp-page-border);
}

.mmp-os-cta-link:hover {
  background: rgba(48, 43, 40, 0.04);
}

.mmp-os-cta-link-text {
  margin: 0 !important;
}

.mmp-os-cta-link-text a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  font-family: var(--mmp-font-heading);
  font-weight: 700;
  font-size: 14px;
  color: var(--mmp-page-ink);
  text-decoration: none;
  letter-spacing: 0.02em;
}

.mmp-os-cta-link-text a::after {
  content: '→';
  opacity: 0.35;
  font-family: sans-serif;
  font-weight: 400;
}

/* ── RESPONSIVE ─────────────────────────────────────────────── */

@media (max-width: 768px) {
  .mmp-os-opening,
  .mmp-os-belief,
  .mmp-os-timeline,
  .mmp-os-mission,
  .mmp-os-people,
  .mmp-os-cta {
    padding-left: 20px;
    padding-right: 20px;
  }

  .mmp-os-opening-inner,
  .mmp-os-origin-inner,
  .mmp-os-mission-inner,
  .mmp-os-cta-inner {
    flex-direction: column !important;
  }

  .mmp-os-opening-h1 {
    font-size: 36px !important;
  }

  .mmp-os-origin-photo img,
  .mmp-os-origin-photo img[src=""] {
    min-height: 260px;
  }

  .mmp-os-origin-text {
    padding: 36px 24px !important;
  }

  .mmp-os-belief-inner {
    flex-direction: column !important;
  }

  .mmp-os-belief-item {
    border-right: none !important;
    border-bottom: 1px solid rgba(255, 250, 241, 0.15);
  }

  .mmp-os-belief-item:last-child {
    border-bottom: none;
  }

  .mmp-os-thread-entry {
    grid-template-columns: 56px 1fr !important;
  }

  .mmp-os-thread-entry::before {
    left: 49px;
  }

  .mmp-os-thread-entry::after {
    left: 44px;
  }

  .mmp-os-strip-inner {
    flex-direction: column !important;
  }

  .mmp-os-strip-item {
    border-right: none !important;
    border-bottom: 1px solid var(--mmp-page-border-light);
    min-height: 180px;
  }

  .mmp-os-people-grid {
    flex-direction: column !important;
  }

  .mmp-os-person {
    border-right: none !important;
    border-bottom: 1px solid var(--mmp-page-border-light);
  }

  .mmp-os-person:last-child {
    border-bottom: none;
  }

  .mmp-os-mission-quote p {
    font-size: 18px !important;
  }

  .mmp-os-cta-h2 {
    font-size: 28px !important;
  }
}
/* Square team images only */
.mmp-os-person-img {
  margin: 0 0 20px !important;
}

.mmp-os-person-img img {
  width: 100%;
  aspect-ratio: 1 / 1;
  height: auto;
  object-fit: cover;
  display: block;
}

/* Keep existing floated/3-column person layout */
.mmp-os-person {
  padding: 0 0 24px !important;
}

/* Bio toggle */
.mmp-os-person-details {
  margin-top: 14px;
}

.mmp-os-person-details summary {
  cursor: pointer;
  display: inline-block;
  padding: 9px 14px;
  border: 1px solid rgba(51, 46, 43, 0.18);
  background: var(--mmp-archive);
  color: var(--mmp-ink);
  font-family: var(--mmp-font-heading);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.mmp-os-person-details summary::-webkit-details-marker {
  display: none;
}

.mmp-os-person-details[open] summary {
  margin-bottom: 16px;
}

.mmp-os-person-bio {
  margin-bottom: 14px !important;
}

.mmp-os-person-bio:last-child {
  margin-bottom: 0 !important;
}