/* ==========================================================================
   ABOUT PAGE — css/pages/about.css
   Page-specific styles for about.html only.
   ========================================================================== */

/* About Main */
.about-main { padding: 20px 0 80px; }
.about-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 60px; align-items: start; }
.about-photo-col { position: sticky; top: 120px; max-width: 380px; width: 100%; }
.about-photo { position: relative; }
.about-photo__image { border-radius: var(--radius-lg); width: 100%; object-fit: cover; aspect-ratio: 4/5; object-position: center top; box-shadow: var(--shadow-lg); }
.about-photo::after { content: ''; position: absolute; top: 16px; left: 16px; right: -16px; bottom: -16px; border: 2px solid var(--sage-light); border-radius: var(--radius-lg); z-index: -1; opacity: 0.4; }
.credentials-badge { margin-top: 24px; padding: 20px 24px; background: var(--warm-white); border-radius: var(--radius-md); border: 1px solid var(--border-light); text-align: center; }
.credentials-badge h4 { font-size: 1rem; color: var(--sage-dark); margin-bottom: 4px; }
.credentials-badge p { font-size: 0.88rem; color: var(--text-secondary); }
.about-content h2 { margin-bottom: 20px; }
.about-content p { color: var(--text-secondary); margin-bottom: 18px; font-size: 1.02rem; }
.about-content .lead { font-size: 1.15rem; color: var(--text-primary); font-weight: 400; line-height: 1.7; }
.about-content .quote-block { font-family: var(--font-heading); font-size: 1.25rem; font-style: italic; color: var(--sage-dark); border-left: 3px solid var(--lilac); padding: 16px 0 16px 24px; margin: 32px 0; line-height: 1.6; }
.about-divider { width: 60px; height: 2px; background: linear-gradient(to right, var(--sage), var(--lilac)); border-radius: 2px; margin: 36px 0; }

/* About page hero — main title and italic subtitle */
.about-hero__title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 600;
  color: var(--sage);
  margin-bottom: 20px;
  text-align: center;
}
.page-hero .page-subtitle--italic { font-style: italic; }

/* Tighten the hero-to-content gap on the about page */
.page-hero { padding-bottom: 20px; }
.page-hero + .path-line { padding: 8px 0; }

/* Approach Cards */
.approach-section { background: var(--warm-white); padding: 80px 0; }
.approach-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 32px; margin-top: 48px; }
.approach-card { padding: 32px 28px; background: var(--cream); border-radius: var(--radius-md); border: 1px solid var(--border-light); transition: all var(--transition); }
.approach-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.approach-card h3 { font-size: 1.15rem; margin-bottom: 12px; color: var(--sage-dark); }
.approach-card p { font-size: 0.95rem; color: var(--text-secondary); line-height: 1.7; }

/* Modalities tags */
.modalities-section { padding: 80px 0; }
.modalities-list { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; max-width: 800px; margin: 0 auto; }
.modality-tag { padding: 10px 22px; background: var(--warm-white); border: 1px solid var(--border-light); border-radius: 50px; font-family: var(--font-body); font-size: 0.92rem; color: var(--text-secondary); transition: all var(--transition); }
.modality-tag.primary { background: var(--sage); color: white; border-color: var(--sage); font-weight: 600; }
.modality-tag:hover { transform: translateY(-2px); box-shadow: var(--shadow-sm); }

/* About responsive */
@media (max-width: 900px) {
  .about-grid { grid-template-columns: 1fr; gap: 40px; }
  .about-photo-col { position: static; max-width: 400px; margin: 0 auto; }
}
@media (max-width: 768px) {
  .approach-grid { grid-template-columns: 1fr; }
}
