/* ═══════════════════════════════════════════════
   LA CIMA — about-page.css
   Uses: variable.css → index.css → about-page.css
   ═══════════════════════════════════════════════ */

/* ══ HERO ═══════════════════════════════════════ */
.ab-hero {
  min-height: 60vh;
  display: flex;
  align-items: flex-end;
  padding-bottom: 64px;
  padding-inline: var(--gutter);
  position: relative;
  overflow: hidden;
}
.ab-hero-bg {
  position: absolute; inset: 0; z-index: 0;
  background: url('../imgs/neveria_la_cima_madison-Ice-cream.jpg') center 30% / cover no-repeat;
  transform: scale(1.05);
  will-change: transform;
}
.ab-hero-bg::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(10,10,28,.30) 0%,
    rgba(10,10,28,.55) 50%,
    rgba(10,10,28,.88) 100%
  );
}
.ab-hero-inner {
  max-width: var(--max-width);
  margin-inline: auto; width: 100%;
  position: relative; z-index: 1;
}
.ab-hero-tag {
  font-family: var(--font-accent);
  font-size: 10px; font-weight: 200;
  letter-spacing: .20em; text-transform: uppercase;
  color: rgba(255,255,255,.65);
  margin-bottom: var(--sp-4); display: block;
}
.ab-hero-h1 {
  font-family: var(--font-display);
  font-size: clamp(40px, 6vw, 72px); font-weight: 400;
  color: var(--color-white); line-height: 1.05;
  margin-bottom: var(--sp-5);
}
.ab-hero-h1 em { font-style: italic; color: var(--color-blue); }
.ab-hero-sub {
  font-family: var(--font-body);
  font-size: 17px; font-weight: 300;
  color: rgba(255,255,255,.80);
  max-width: 560px; line-height: 1.7;
}

/* ══ STATS BAR ══════════════════════════════════ */
.ab-stats {
  background: var(--color-dark);
  padding: var(--sp-8) var(--gutter);
}
.ab-stats-inner {
  max-width: var(--max-width); margin-inline: auto;
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1px; background: rgba(255,255,255,.08);
}
.ab-stat {
  padding: var(--sp-6) var(--sp-8);
  background: var(--color-dark);
  text-align: center;
}
.ab-stat-num {
  font-family: var(--font-display);
  font-size: clamp(32px, 4vw, 48px); font-weight: 400;
  color: var(--color-blue); line-height: 1;
  margin-bottom: var(--sp-2);
}
.ab-stat-label {
  font-family: var(--font-body);
  font-size: 14px; font-weight: 300;
  color: rgba(255,255,255,.65);
  letter-spacing: .02em;
}

/* ══ STORY SECTION ══════════════════════════════ */
.ab-story {
  background: var(--color-cream);
  padding-block: var(--sp-24);
  padding-inline: var(--gutter);
}
.ab-story-inner {
  max-width: var(--max-width); margin-inline: auto;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--sp-16); align-items: center;
}
.ab-story-img {
  border-radius: var(--r-lg); overflow: hidden;
  height: 500px; position: relative;
  background: linear-gradient(135deg, var(--color-sky-blue), var(--color-blue-light));
  display: flex; align-items: center; justify-content: center; font-size: 100px;
  box-shadow: var(--shadow-lg);
}
.ab-story-img img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
}
.ab-story-badge {
  position: absolute; bottom: 20px; left: 20px;
  background: var(--color-white); border-radius: var(--r-md);
  padding: 12px 18px; box-shadow: var(--shadow-md);
}
.ab-story-badge-year {
  font-family: var(--font-display);
  font-size: 28px; font-weight: 400; color: var(--color-dark); line-height: 1;
}
.ab-story-badge-label {
  font-family: var(--font-body);
  font-size: 12px; font-weight: 300; color: var(--color-dark-mid);
}
.ab-story-content {}
.ab-story-text {
  font-family: var(--font-body);
  font-size: 16px; font-weight: 300;
  color: var(--color-dark-mid); line-height: 1.85;
  margin-bottom: var(--sp-5);
}
.ab-story-text strong { color: var(--color-dark); font-weight: 500; }

/* ══ VALUES SECTION ═════════════════════════════ */
.ab-values {
  background: var(--color-yellow-light);
  padding-block: var(--sp-24);
  padding-inline: var(--gutter);
}
.ab-values-inner { max-width: var(--max-width); margin-inline: auto; }
.ab-values-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-5); margin-top: var(--sp-12);
}
.ab-value-card {
  background: var(--color-white); border-radius: var(--r-lg);
  padding: var(--sp-8) var(--sp-6);
  border: 1px solid var(--color-border);
  transition: all var(--ease); text-align: center;
}
.ab-value-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); border-color: var(--color-blue-light); }
.ab-value-icon {
  width: 60px; height: 60px; border-radius: 50%;
  background: var(--color-sky-blue);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px; margin: 0 auto var(--sp-5);
}
.ab-value-title {
  font-family: var(--font-display);
  font-size: 20px; font-weight: 400; color: var(--color-dark);
  margin-bottom: var(--sp-3);
}
.ab-value-desc {
  font-family: var(--font-body);
  font-size: 14px; font-weight: 300;
  color: var(--color-dark-mid); line-height: 1.7;
}

/* ══ PROCESS SECTION ════════════════════════════ */
.ab-process {
  background: var(--color-white);
  padding-block: var(--sp-24);
  padding-inline: var(--gutter);
}
.ab-process-inner { max-width: var(--max-width); margin-inline: auto; }
.ab-process-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-5); margin-top: var(--sp-12);
  position: relative;
}
/* Connecting line */
.ab-process-grid::before {
  content: '';
  position: absolute;
  top: 32px; left: 80px; right: 80px;
  height: 2px;
  background: linear-gradient(to right, var(--color-blue-light), var(--color-blue), var(--color-blue-light));
  z-index: 0;
}
.ab-process-step {
  text-align: center; position: relative; z-index: 1;
}
.ab-process-num {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--color-dark); color: var(--color-white);
  font-family: var(--font-display);
  font-size: 24px; font-weight: 400;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto var(--sp-5);
  border: 4px solid var(--color-cream);
  box-shadow: var(--shadow-sm);
}
.ab-process-icon { font-size: 22px; margin-bottom: var(--sp-3); }
.ab-process-title {
  font-family: var(--font-display);
  font-size: 18px; font-weight: 400; color: var(--color-dark);
  margin-bottom: var(--sp-2);
}
.ab-process-desc {
  font-family: var(--font-body);
  font-size: 13px; font-weight: 300;
  color: var(--color-dark-mid); line-height: 1.65;
}

/* ══ TEAM / MISSION SECTION ═════════════════════ */
.ab-mission {
  background: linear-gradient(145deg, var(--color-dark) 0%, #3a3c62 100%);
  padding-block: var(--sp-20);
  padding-inline: var(--gutter);
}
.ab-mission-inner {
  max-width: var(--max-width); margin-inline: auto;
  display: grid; grid-template-columns: 1fr 1fr;
  gap: var(--sp-16); align-items: center;
}
.ab-mission-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--r-lg); padding: var(--sp-8);
}
.ab-mission-card-icon { font-size: 36px; margin-bottom: var(--sp-4); }
.ab-mission-card-title {
  font-family: var(--font-display);
  font-size: 24px; font-weight: 400;
  color: var(--color-white); margin-bottom: var(--sp-4);
}
.ab-mission-card-text {
  font-family: var(--font-body);
  font-size: 15px; font-weight: 300;
  color: rgba(255,255,255,.75); line-height: 1.75;
}

/* ══ CTA BANNER ══════════════════════════════════ */
.ab-cta {
  background: var(--color-sky-blue);
  padding: var(--sp-16) var(--gutter);
  text-align: center;
  border-top: 1px solid var(--color-blue-light);
}
.ab-cta-title {
  font-family: var(--font-display);
  font-size: clamp(26px, 4vw, 40px); font-weight: 400;
  color: var(--color-dark); margin-bottom: var(--sp-3);
}
.ab-cta-sub {
  font-family: var(--font-body);
  font-size: 16px; font-weight: 300;
  color: var(--color-dark-mid); margin-bottom: var(--sp-8);
  max-width: 440px; margin-inline: auto; line-height: 1.7;
}

/* ══ RESPONSIVE ═════════════════════════════════ */
@media (max-width: 1024px) {
  .ab-values-grid  { grid-template-columns: repeat(2, 1fr); }
  .ab-process-grid { grid-template-columns: repeat(2, 1fr); }
  .ab-process-grid::before { display: none; }
  .ab-stats-inner  { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .ab-story-inner   { grid-template-columns: 1fr; }
  .ab-story-img     { height: 320px; }
  .ab-mission-inner { grid-template-columns: 1fr; }
  .ab-hero          { min-height: 50vh; }
}
@media (max-width: 540px) {
  .ab-values-grid  { grid-template-columns: 1fr; }
  .ab-process-grid { grid-template-columns: 1fr; }
  .ab-stats-inner  { grid-template-columns: repeat(2, 1fr); }
}
