.about-hero { background: #F4FAF8; padding: 4rem 2rem 3rem; border-bottom: 1px solid #C8E6D5; }
.about-hero-inner { max-width: 860px; margin: 0 auto; }
.about-hero-title { font-size: clamp(2rem, 4vw, 3rem); font-weight: 800; color: #0A2E22; line-height: 1.2; margin-bottom: 1rem; }
.about-hero-sub { font-size: 1.05rem; color: #4A6655; line-height: 1.7; max-width: 680px; }

.about-mission { background: #fff; padding: 4rem 2rem; border-bottom: 1px solid #E8F5EE; }
.about-mission-inner { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.about-mission-text h2 { font-size: 1.6rem; font-weight: 700; color: #0A2E22; margin-bottom: 1rem; }
.about-mission-text p { font-size: 0.95rem; color: #4A6655; line-height: 1.75; margin-bottom: 1rem; }
.about-mission-text p:last-child { margin-bottom: 0; }
.about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.about-stat { background: #F4FAF8; border: 1px solid #C8E6D5; border-radius: 10px; padding: 1.5rem; text-align: center; }
.about-stat-num { font-size: 2.2rem; font-weight: 800; color: #0A2E22; line-height: 1; margin-bottom: 0.4rem; }
.about-stat-label { font-size: 0.72rem; font-weight: 600; color: #4A6655; text-transform: uppercase; letter-spacing: 0.08em; }

.about-photo { position: relative; overflow: hidden; max-height: 480px; }
.about-photo img { width: 100%; height: 480px; object-fit: cover; object-position: center; display: block; }
.about-photo-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 2rem; background: linear-gradient(transparent, rgba(10,46,34,0.88)); }
.about-photo-quote { font-size: 0.95rem; color: rgba(255,255,255,0.9); line-height: 1.65; font-style: italic; max-width: 800px; }
.about-photo-attr { font-size: 0.8rem; color: #9ECFBF; font-weight: 600; margin-top: 0.5rem; font-style: normal; }

.about-care { background: #F4FAF8; padding: 3rem 2rem; border-top: 1px solid #C8E6D5; border-bottom: 1px solid #C8E6D5; }
.about-care-inner { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: auto 1fr; gap: 2.5rem; align-items: start; }
.about-care-badge { background: #0A2E22; border-radius: 12px; padding: 1.5rem 1.25rem; display: flex; flex-direction: column; align-items: center; gap: 0.4rem; min-width: 120px; text-align: center; }
.about-care-badge-year { font-size: 0.75rem; color: #9ECFBF; font-weight: 600; letter-spacing: 0.06em; }
.about-care-badge-label { font-size: 0.8rem; color: #2BCFC3; font-weight: 700; line-height: 1.3; }
.about-care-tag { display: inline-block; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: #0D7A45; background: #E8F5EE; padding: 0.2rem 0.6rem; border-radius: 4px; margin-bottom: 0.75rem; }
.about-care-text h3 { font-size: 1.3rem; font-weight: 700; color: #0A2E22; margin-bottom: 0.75rem; line-height: 1.3; }
.about-care-text p { font-size: 0.9rem; color: #4A6655; line-height: 1.7; margin-bottom: 1rem; }
.about-care-logo { display: inline-flex; align-items: center; gap: 8px; }
.about-care-logo img { height: 36px; width: auto; }
.about-care-logo-text { font-size: 0.82rem; font-weight: 600; color: #0D7A45; }

.about-capabilities { background: #fff; padding: 4rem 2rem; border-bottom: 1px solid #E8F5EE; }
.about-capabilities-inner { max-width: 1100px; margin: 0 auto; }
.about-capabilities h2 { font-size: 1.5rem; font-weight: 700; color: #0A2E22; margin-bottom: 0.5rem; }
.about-capabilities-sub { font-size: 0.95rem; color: #4A6655; margin-bottom: 2rem; }
.caps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-bottom: 1rem; }
.cap-card { background: #F4FAF8; border: 1px solid #C8E6D5; border-radius: 10px; padding: 1.25rem; }
.cap-icon { font-size: 1.5rem; margin-bottom: 0.6rem; }
.cap-title { font-size: 0.9rem; font-weight: 700; color: #0A2E22; margin-bottom: 0.4rem; }
.cap-desc { font-size: 0.82rem; color: #4A6655; line-height: 1.6; }

.about-process { background: #0A2E22; padding: 4rem 2rem; }
.about-process-inner { max-width: 1100px; margin: 0 auto; }
.about-process h2 { font-size: 1.5rem; font-weight: 700; color: #fff; margin-bottom: 0.5rem; text-align: center; }
.about-process-sub { font-size: 0.95rem; color: #9ECFBF; text-align: center; margin-bottom: 2.5rem; }
.process-steps { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; gap: 1rem; align-items: center; }
.process-step { background: #0D3D2A; border: 1px solid #1a5c3a; border-radius: 10px; padding: 1.5rem; text-align: center; }
.process-step-num { font-size: 1.75rem; font-weight: 800; color: #2BCFC3; margin-bottom: 0.5rem; }
.process-step-title { font-size: 0.9rem; font-weight: 700; color: #fff; margin-bottom: 0.4rem; }
.process-step-desc { font-size: 0.8rem; color: #9ECFBF; line-height: 1.55; }
.process-arrow { color: #2BCFC3; font-size: 1.5rem; text-align: center; }

.about-partners { background: #F4FAF8; padding: 3rem 2rem; border-top: 1px solid #C8E6D5; text-align: center; }
.about-partners-inner { max-width: 1100px; margin: 0 auto; }
.about-partners-label { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: #4A6655; margin-bottom: 1.5rem; }
.partner-logos-row { display: flex; gap: 1.5rem; justify-content: center; align-items: center; flex-wrap: wrap; }
.partner-logo-item { background: #fff; border: 1px solid #C8E6D5; border-radius: 8px; padding: 0.75rem 1.5rem; display: flex; align-items: center; }
.partner-logo-item img { height: 40px; width: auto; }

@media (max-width: 860px) {
  .about-mission-inner { grid-template-columns: 1fr; }
  .about-care-inner { grid-template-columns: 1fr; }
  .about-care-badge { flex-direction: row; min-width: unset; width: fit-content; }
  .caps-grid { grid-template-columns: 1fr 1fr; }
  .process-steps { grid-template-columns: 1fr; }
  .process-arrow { transform: rotate(90deg); }
}
@media (max-width: 600px) {
  .caps-grid { grid-template-columns: 1fr; }
  .about-stats { grid-template-columns: 1fr 1fr; }
}
