/* ========================================= */
/* ABOUT PAGE CONFIGURATIONS                 */
/* ========================================= */
:root {
  /* Hero */
  --about-hero-min-height: 60vh;
  --about-hero-padding-top: calc(var(--nav-height) + 60px);
  --about-hero-padding-bottom: 80px;
  --about-hero-overlay: linear-gradient(135deg, rgba(0, 0, 0, 0.75) 0%, rgba(0, 0, 0, 0.4) 100%);
  --about-hero-overlay-desktop: linear-gradient(to right, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 0.2) 100%);

  /* Story */
  --story-image-radius: 16px;
  --story-image-shadow: 0 20px 50px var(--shadow-dark);
  --story-image-height: 370px;
  --story-image-height-tablet: 350px;
  --story-image-height-mobile: 280px;

  /* Shared Section Spacing */
  --section-padding-y: clamp(4rem, 8vh, 7rem);

  /* Body Text - Matching Bootstrap secondary */
  --body-text-color: rgba(33, 37, 41, 0.75);
  --body-text-size: clamp(1rem, 0.5vw + 0.65rem, 1.25rem);
  --body-line-height: 1.7;

  /* Cards */
  --card-radius: 1rem;
  --card-padding: 2rem 1.5rem;
  --card-gap: 1.5rem;
  --card-bg: var(--bg-white);
  --card-bg-alt: var(--bg-light);
  --card-border: rgba(0, 0, 0, 0.03);
  --card-shadow: 0 4px 15px var(--shadow-light);
  --card-shadow-hover: 0 15px 30px var(--shadow-light);
  --card-transform-hover: translateY(-10px);
  --card-transition: 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);

  /* Icons */
  --icon-size: 70px;
  --icon-font-size: 1.8rem;
  --icon-bg: rgba(113, 159, 183, 0.1);
  --icon-bg-hover: var(--primary-light);
  --icon-color: var(--primary-light);
  --icon-color-hover: var(--text-white);
  --icon-transition: 0.4s ease;

  /* Typography */
  --section-title-size: clamp(1.75rem, 3.5vw, 2.4rem);
  --card-title-size: 1.25rem;
}

/* ========================================= */
/* HERO SECTION                              */
/* ========================================= */
.about-hero {
  position: relative;
  min-height: var(--about-hero-min-height);
  padding: var(--about-hero-padding-top) 0 var(--about-hero-padding-bottom);
  color: var(--text-white);
}

.about-hero .hero-bg-picture {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.about-hero .hero-bg-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 60%;
}

.about-hero .hero-overlay {
  z-index: 2;
  background: var(--about-hero-overlay);
}

.about-hero .hero-eyebrow {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 3px;
  opacity: 0.9;
}

.about-hero .hero-title {
  font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: 700;
  line-height: 1.1;
}

.about-hero .hero-subtitle {
  font-size: clamp(1rem, 0.5vw + 0.9rem, 1.2rem);
  max-width: 600px;
  line-height: var(--body-line-height);
  padding-inline-start: 20px;
  border-inline-start: 3px solid rgba(255, 255, 255, 0.5);
}

@media (min-width: 992px) {
  .about-hero .hero-overlay {
    background: var(--about-hero-overlay-desktop);
  }
}

@media (max-width: 991.98px) {
  .about-hero {
    min-height: 55vh;
    padding: calc(var(--mobile-nav-height) + 50px) 0 60px;
  }

  .about-hero .hero-title {
    font-size: clamp(2rem, 5vw, 3rem);
  }
}

@media (max-width: 767.98px) {
  .about-hero {
    min-height: 50vh;
    padding: calc(var(--mobile-nav-height) + 40px) 0 50px;
    text-align: center;
  }

  .about-hero .hero-eyebrow {
    font-size: 0.9rem;
    letter-spacing: 2px;
  }

  .about-hero .hero-subtitle {
    padding-inline-start: 0;
    border-inline-start: none;
    padding-top: 16px;
    border-top: 2px solid rgba(255, 255, 255, 0.3);
    max-width: 100%;
  }
}

/* ========================================= */
/* STORY SECTION                             */
/* ========================================= */
.about-story-section {
  background: var(--bg-white);
  padding: var(--section-padding-y) 0;
}

.about-story-section .row {
  flex-direction: row-reverse;
}

.story-image-wrapper {
  border-radius: var(--story-image-radius);
  overflow: hidden;
  box-shadow: var(--story-image-shadow);
}

.story-image {
  width: 100%;
  height: var(--story-image-height);
  object-fit: cover;
  object-position: center 75%;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

@media (hover: hover) {
  .story-image-wrapper:hover .story-image {
    transform: scale(1.05);
  }
}

.story-content {
  padding-inline-end: 1.5rem;
}

.section-title {
  font-size: var(--section-title-size);
  font-weight: 700;
  color: var(--primary-dark);
  line-height: 1.25;
  position: relative;
  display: inline-block;
  margin-bottom: 1.5rem;
}

.section-title::after {
  content: '';
  position: absolute;
  bottom: -10px;
  inset-inline-start: 0;
  width: 60px;
  height: 3px;
  background: var(--primary-light);
  border-radius: 2px;
}

.story-text {
  font-size: var(--body-text-size);
  color: var(--body-text-color);
  line-height: var(--body-line-height);
}

.story-motto {
  font-size: var(--body-text-size);
  color: var(--primary);
  font-style: italic;
  padding-inline-start: 1rem;
  border-inline-start: 3px solid var(--primary-light);
}

@media (max-width: 991.98px) {
  .about-story-section .row {
    flex-direction: column-reverse;
  }

  .story-content {
    padding-inline-end: 0;
    margin-bottom: 2rem;
  }

  .story-image {
    height: var(--story-image-height-tablet);
  }
}

@media (max-width: 767.98px) {
  .story-image {
    height: var(--story-image-height-mobile);
  }

  .story-image-wrapper:hover .story-image {
    transform: none;
  }
}

/* ========================================= */
/* VISION & MISSION SECTION                  */
/* ========================================= */
.about-vm-section {
  background: var(--bg-light);
  padding: var(--section-padding-y) 0;
}

.vm-card {
  display: flex;
  align-items: center;
  gap: var(--card-gap);
  background: var(--card-bg);
  border-radius: var(--card-radius);
  padding: var(--card-padding);
  border: 1px solid var(--card-border);
  box-shadow: var(--card-shadow);
  transition: transform var(--card-transition), box-shadow var(--card-transition);
}

@media (hover: hover) {
  .vm-card:hover {
    transform: var(--card-transform-hover);
    box-shadow: var(--card-shadow-hover);
  }

  .vm-card:hover .vm-icon {
    background: var(--icon-bg-hover);
    color: var(--icon-color-hover);
  }
}

.vm-icon {
  width: var(--icon-size);
  height: var(--icon-size);
  min-width: var(--icon-size);
  border-radius: 50%;
  background: var(--icon-bg);
  color: var(--icon-color);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--icon-font-size);
  flex-shrink: 0;
  transition: all var(--icon-transition);
}

.vm-content {
  flex: 1;
}

.vm-title {
  font-size: var(--card-title-size);
  font-weight: 700;
  color: var(--primary-dark);
  margin-bottom: 0.5rem;
}

.vm-text {
  font-size: var(--body-text-size);
  color: var(--body-text-color);
  line-height: var(--body-line-height);
  margin: 0;
}

@media (max-width: 767.98px) {
  .vm-card {
    flex-direction: column;
    text-align: center;
    padding: 1.5rem;
  }

  .vm-card:hover {
    transform: none;
  }
}

/* ========================================= */
/* VALUES SECTION                            */
/* ========================================= */
.about-values-section {
  background: var(--bg-white);
  padding: var(--section-padding-y) 0;
}

.about-values-section .section-title {
  text-align: center;
  width: 100%;
}

.about-values-section .section-title::after {
  inset-inline-start: 50%;
  transform: translateX(-50%);
}

html[dir='rtl'] .about-values-section .section-title::after {
  transform: translateX(50%);
}

.value-card {
  display: flex;
  align-items: center;
  gap: var(--card-gap);
  background: var(--card-bg-alt);
  border-radius: var(--card-radius);
  padding: var(--card-padding);
  border: 1px solid var(--card-border);
  transition: transform var(--card-transition), box-shadow var(--card-transition), background-color var(--card-transition);
}

@media (hover: hover) {
  .value-card:hover {
    background: var(--card-bg);
    box-shadow: var(--card-shadow-hover);
    transform: var(--card-transform-hover);
  }

  .value-card:hover .value-icon {
    background: var(--icon-bg-hover);
    color: var(--icon-color-hover);
  }
}

.value-icon {
  width: var(--icon-size);
  height: var(--icon-size);
  min-width: var(--icon-size);
  border-radius: 50%;
  background: var(--icon-bg);
  color: var(--icon-color);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--icon-font-size);
  flex-shrink: 0;
  transition: all var(--icon-transition);
}

.value-content {
  flex: 1;
}

.value-title {
  font-size: var(--card-title-size);
  font-weight: 700;
  color: var(--primary-dark);
  margin-bottom: 0.5rem;
}

.value-desc {
  font-size: var(--body-text-size);
  color: var(--body-text-color);
  line-height: var(--body-line-height);
  margin: 0;
}

@media (max-width: 767.98px) {
  .value-card {
    flex-direction: column;
    text-align: center;
    padding: 1.5rem;
  }

  .value-card:hover {
    transform: none;
  }
}

/* ========================================= */
/* RTL SUPPORT                               */
/* ========================================= */
html[dir='rtl'] .about-hero .hero-eyebrow,
html[dir='rtl'] .about-hero .hero-title {
  letter-spacing: 0;
}

html[dir='rtl'] .about-hero .hero-bg-image {
  transform: scaleX(-1);
}

@media (min-width: 992px) {
  html[dir='rtl'] .about-hero .hero-overlay {
    background: linear-gradient(to left, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.5) 50%, rgba(0, 0, 0, 0.2) 100%);
  }
}
