/**
 * Block Pattern Styles — Masters AI
 *
 * Front-end styles for CSS classes used inside Gutenberg block patterns.
 * These mirror editor.css but without the .editor-styles-wrapper scope.
 */

/* ── Gutenberg layout resets for block pages ────────────── */
/*
 * ROOT CAUSE: Sections use layout:constrained, which makes WP core inject
 *   .is-layout-constrained > :where(...) { max-width:...; margin:auto !important }
 * on ALL children — centering them at ~240px from left instead of our 48px.
 *
 * :where() has zero specificity, so a 3-class chain beats it even with !important.
 *
 * .mai-section padding: 48px is the alignment anchor matching the nav logo.
 * CTAs that need centering use .mai-cta-inner { margin: 0 auto } instead.
 */

/* 1. Reset top-level section groups — no auto margins, full width */
.site-main .entry-content > * {
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* 2. Kill constrained-layout centering INSIDE content sections.
      Covers both the section itself being constrained AND nested constrained groups
      (e.g. blockquote, columns wrapper). Excludes .mai-cta-section which intentionally
      uses its own .mai-cta-inner max-width centering. */
.site-main .mai-section:not(.mai-cta-section).is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)),
.site-main .mai-section:not(.mai-cta-section) .is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* 3. Restore block-level flow display so sections stack */
.site-main .entry-content {
  display: block;
}

/* ── Section wrapper ────────────────────────────────────── */
.mai-section {
  padding: 80px 48px;
  border-bottom: 1px solid var(--border, #e8e6e2);
}

/* ── Inner block spacing — override theme.json blockGap:0 ── */
/* Gutenberg strips all gaps; restore breathing room inside sections */
.site-main .mai-section > * + * {
  margin-top: 32px !important;
}
.site-main .mai-section > .mai-kicker + * {
  margin-top: 16px !important;
}
.site-main .mai-section > .wp-block-heading + * {
  margin-top: 40px !important;
}
/* Tighter gap between kicker and the heading that follows */
.site-main .mai-section > .mai-kicker + .wp-block-heading {
  margin-top: 12px !important;
}
/* Values / team grids — extra breathing room above */
.site-main .mai-section > .wp-block-group + .wp-block-group {
  margin-top: 40px !important;
}
.mai-section--surface {
  background: var(--bg-surface, #f5f4f2);
}
.mai-section--center {
  text-align: center;
}
.mai-section--no-border {
  border-bottom: none;
}

/* ── Kicker label ───────────────────────────────────────── */
.mai-kicker {
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  color: var(--crimson, #1BBDC4) !important;
  font-weight: 600 !important;
  margin-bottom: 20px !important;
  display: flex;
  align-items: center;
  gap: 14px;
}
.mai-kicker::before {
  content: '';
  display: inline-block;
  width: 32px;
  height: 2px;
  background: linear-gradient(90deg, var(--crimson-light, #2DCDD4), var(--crimson-deep, #096165));
  flex-shrink: 0;
}

/* ── Page hero ──────────────────────────────────────────── */
.mai-page-hero-section {
  padding: 68px 48px 80px; /* .site-main already accounts for 72px nav height */
  border-bottom: 1px solid var(--border, #e8e6e2);
  min-height: 320px;
}
.mai-page-title {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: clamp(32px, 4.5vw, 56px) !important;
  font-weight: 800 !important;
  letter-spacing: -2px !important;
  line-height: 1.05 !important;
  margin-bottom: 20px !important;
}
.mai-page-subtitle {
  font-family: 'Instrument Serif', Georgia, serif !important;
  font-style: italic !important;
  font-size: clamp(16px, 2vw, 21px) !important;
  color: var(--text-secondary, #2a2a2a) !important;
  max-width: 560px;
  line-height: 1.5 !important;
}

/* ── Mission / blockquote ───────────────────────────────── */
.mai-mission-quote {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  max-width: 900px;
}
.mai-mission-quote p {
  font-family: 'Source Serif 4', Georgia, serif !important;
  font-size: clamp(20px, 2.5vw, 28px) !important;
  color: var(--text-primary, #0a0a0a) !important;
  line-height: 1.6 !important;
  font-weight: 300 !important;
}

/* ── Story section ──────────────────────────────────────── */
.mai-story-headline {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: clamp(28px, 3.5vw, 44px) !important;
  font-weight: 800 !important;
  letter-spacing: -1px !important;
  line-height: 1.1 !important;
}
.mai-story-headline .accent { color: var(--crimson-light, #2DCDD4); }
.mai-story-text p {
  font-size: 16px !important;
  color: var(--text-secondary, #2a2a2a) !important;
  line-height: 1.7 !important;
  font-weight: 300 !important;
  margin-bottom: 1em !important;
}

/* ── Values grid ────────────────────────────────────────── */
.mai-values-grid.wp-block-group {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 1px !important;
}
.mai-values-card.wp-block-group {
  padding: 40px 36px !important;
  border: 1px solid var(--border, #e8e6e2) !important;
  margin: -0.5px !important;
  transition: background 0.3s;
}
.mai-values-card.wp-block-group:hover { background: var(--card-hover, rgba(0,0,0,0.02)); }
.mai-values-number {
  font-family: 'Inter', sans-serif !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  color: var(--crimson, #1BBDC4) !important;
  font-weight: 600 !important;
  margin-bottom: 16px !important;
}
.mai-values-card h3 {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--text-primary, #0a0a0a) !important;
  margin-bottom: 12px !important;
  line-height: 1.25 !important;
}
.mai-values-card p {
  font-size: 14px !important;
  color: var(--text-secondary, #2a2a2a) !important;
  line-height: 1.6 !important;
  font-weight: 300 !important;
}

/* ── Team card ──────────────────────────────────────────── */
.mai-team-card.wp-block-group {
  display: grid !important;
  grid-template-columns: 300px 1fr !important;
  gap: 60px !important;
  align-items: start !important;
}
.mai-team-photo img,
.mai-team-photo figure img {
  width: 300px !important;
  height: 380px !important;
  object-fit: cover !important;
  filter: grayscale(100%) !important;
  display: block;
}
.mai-team-name.wp-block-heading {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 32px !important;
  font-weight: 800 !important;
  margin-bottom: 8px !important;
}
.mai-team-role {
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--crimson, #1BBDC4) !important;
  font-weight: 600 !important;
  display: block !important;
  margin-bottom: 24px !important;
}
.mai-team-bio p {
  font-size: 16px !important;
  color: var(--text-secondary, #2a2a2a) !important;
  line-height: 1.7 !important;
  font-weight: 300 !important;
  margin-bottom: 1em !important;
}

/* ── CTA section ────────────────────────────────────────── */
.mai-cta-section {
  text-align: center !important;
  background: var(--bg-surface, #f5f4f2) !important;
  border-bottom: 1px solid var(--border, #e8e6e2) !important;
}
.mai-cta-section h2 {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: clamp(28px, 4vw, 48px) !important;
  font-weight: 800 !important;
  letter-spacing: -1.5px !important;
  margin-bottom: 16px !important;
}
.mai-cta-section p {
  font-size: 18px !important;
  color: var(--text-secondary, #2a2a2a) !important;
  max-width: 560px;
  margin: 0 auto 40px !important;
  line-height: 1.6 !important;
}
.mai-cta-inner {
  max-width: 600px;
  margin: 0 auto;
}

/* ── Founder hero ───────────────────────────────────────── */
.mai-founder-hero-inner.wp-block-group {
  display: grid !important;
  grid-template-columns: 1fr 420px !important;
  gap: 80px !important;
  align-items: center !important;
  max-width: 1100px;
  margin: 0 auto;
}
.mai-founder-name.wp-block-heading {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: clamp(40px, 5vw, 64px) !important;
  font-weight: 800 !important;
  letter-spacing: -2px !important;
  line-height: 1.05 !important;
  margin-bottom: 8px !important;
}
.mai-founder-role {
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color: var(--text-muted, #8a8a8a) !important;
  font-weight: 500 !important;
  margin-bottom: 32px !important;
  display: block !important;
}
.mai-founder-photo {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
}
.mai-founder-photo img,
.mai-founder-photo figure img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: top !important;
  filter: contrast(1.05) brightness(0.9) !important;
}
.mai-founder-bio p {
  font-family: 'Inter', sans-serif !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
  color: var(--text-secondary, #2a2a2a) !important;
  margin-bottom: 20px !important;
}

/* ── Credentials grid ───────────────────────────────────── */
.mai-creds-grid.wp-block-group {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 32px !important;
}
.mai-cred-card.wp-block-group {
  padding: 28px !important;
  border: 1px solid var(--border, #e8e6e2) !important;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.mai-cred-title.wp-block-heading {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--text-primary, #0a0a0a) !important;
}
.mai-cred-card p {
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  color: var(--text-secondary, #2a2a2a) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

/* ── Coming soon ────────────────────────────────────────── */
.mai-coming-soon.wp-block-group {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  gap: 20px !important;
  padding: 80px 24px !important;
  border: 1px solid var(--border, #e8e6e2) !important;
  background: var(--bg-surface, #f5f4f2) !important;
}
.mai-coming-soon h2 {
  font-family: 'Plus Jakarta Sans', sans-serif !important;
  font-size: 32px !important;
  font-weight: 800 !important;
  color: var(--text-primary, #0a0a0a) !important;
}
.mai-coming-soon p {
  font-family: 'Inter', sans-serif !important;
  font-size: 15px !important;
  color: var(--text-secondary, #2a2a2a) !important;
  max-width: 420px;
  line-height: 1.6 !important;
  margin: 0 !important;
}

/* ── Buttons ────────────────────────────────────────────── */
/* Only style the actual link/button element, not the wp-block-button wrapper div */
a.mai-btn-primary,
button.mai-btn-primary,
.wp-block-button__link.mai-btn-primary,
.wp-block-button.mai-btn-primary > .wp-block-button__link {
  display: inline-block;
  padding: 14px 28px;
  background: linear-gradient(135deg, var(--crimson-light, #2DCDD4), var(--crimson, #1BBDC4));
  color: #fff !important;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  text-decoration: none;
  border: none;
  border-radius: 0;
  transition: opacity 0.2s;
}
a.mai-btn-primary:hover,
button.mai-btn-primary:hover,
.wp-block-button__link.mai-btn-primary:hover,
.wp-block-button.mai-btn-primary > .wp-block-button__link:hover { opacity: 0.85; }
/* Reset the wrapper div — no button styling on the container */
div.wp-block-button.mai-btn-primary {
  background: none !important;
  padding: 0 !important;
  border: none !important;
}

a.mai-btn-ghost,
button.mai-btn-ghost,
.wp-block-button__link.mai-btn-ghost,
.wp-block-button.mai-btn-ghost > .wp-block-button__link {
  display: inline-block;
  padding: 14px 28px;
  border: 1px solid var(--border, #e8e6e2);
  color: var(--text-secondary, #2a2a2a) !important;
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  text-decoration: none;
  background: none;
  border-radius: 0;
  transition: all 0.2s;
}
a.mai-btn-ghost:hover,
button.mai-btn-ghost:hover,
.wp-block-button__link.mai-btn-ghost:hover,
.wp-block-button.mai-btn-ghost > .wp-block-button__link:hover {
  border-color: var(--text-muted, #8a8a8a);
  color: var(--text-primary, #0a0a0a) !important;
}
div.wp-block-button.mai-btn-ghost {
  background: none !important;
  padding: 0 !important;
}

/* ── Lists inside block sections ───────────────────────── */
.mai-section .wp-block-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.mai-section .wp-block-list li {
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  color: var(--text-secondary, #2a2a2a);
  line-height: 1.6;
  font-weight: 300;
  padding: 14px 0 14px 20px;
  border-bottom: 1px solid var(--border, #e8e6e2);
  position: relative;
}
.mai-section .wp-block-list li:last-child { border-bottom: none; }
.mai-section .wp-block-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--crimson, #1BBDC4);
}

/* ── Image blocks — clean rendering ─────────────────────── */
.mai-section .wp-block-image {
  margin: 0;
}
.mai-section .wp-block-image img {
  max-width: 100%;
  height: auto;
}

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 1024px) {
  .mai-founder-hero-inner.wp-block-group {
    grid-template-columns: 1fr !important;
    gap: 48px !important;
  }
  .mai-creds-grid.wp-block-group {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .mai-team-card.wp-block-group {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
  .mai-values-grid.wp-block-group {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 768px) {
  .mai-section { padding: 48px 24px !important; }
  .mai-page-hero-section { padding: 48px 24px !important; }
  .mai-values-grid.wp-block-group {
    grid-template-columns: 1fr !important;
  }
  .mai-creds-grid.wp-block-group {
    grid-template-columns: 1fr !important;
  }
}
