/* =============================================================
   Vedika Bhasin — About page
   Page-specific layout. Builds on colors_and_type.css + styles.css.
   Scoped class prefixes (ab-*, skill*, award*) so nothing leaks
   into Index / Work / Contact.
   ============================================================= */

/* ---------- HERO ("About me") -------------------------------- */

.ab-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.ab-eyebrow {
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--color-success);
  margin: 0 0 28px;
}
.ab-intro {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: clamp(22px, 2.6vw, 30px);
  line-height: 1.35;
  color: var(--color-ink);
  max-width: 18ch;
  margin: 0;
}
.ab-figure {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  background:
    repeating-linear-gradient(135deg,
      rgba(255,255,255,0.022) 0 14px,
      rgba(255,255,255,0.000) 14px 28px),
    var(--color-surface-card);
  border: 1px solid var(--color-hairline);
}
.ab-figure__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover; display: block;
}
.ab-figure__cap {
  position: absolute; top: 20px; right: 24px; z-index: 2;
  color: var(--color-muted);
}

/* ---------- DISPLAY HEADLINE --------------------------------- */

.ab-headline {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(56px, 11vw, 150px);
  line-height: 0.92;
  letter-spacing: -2px;
  color: var(--color-ink);
  margin: 0;
}
.ab-headline .line { display: block; }
.ab-headline .accent { color: var(--color-success); }

/* ---------- STATS + BIO -------------------------------------- */

.ab-cols {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 64px;
  align-items: start;
}
.ab-stats { display: flex; flex-direction: column; gap: 40px; }
.ab-stat__num {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(48px, 6vw, 72px);
  line-height: 1;
  letter-spacing: -1px;
  color: var(--color-ink);
}
.ab-stat__num small {
  font-size: 0.42em;
  color: var(--color-muted);
  margin-left: 2px;
}
.ab-stat__lbl {
  margin-top: 12px;
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.45;
  color: var(--color-muted);
  max-width: 26ch;
}
.ab-bio {
  display: flex; flex-direction: column; gap: 20px;
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.65;
  color: var(--color-body);
  max-width: 62ch;
}
.ab-bio strong { color: var(--color-ink); font-weight: 500; }

/* ---------- SECTION HEADINGS (Skills / Awards) -------------- */

.ab-section-title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(48px, 7vw, 88px);
  line-height: 1;
  letter-spacing: -1.5px;
  color: var(--color-ink);
  margin: 0;
}
.ab-section-title .accent { color: var(--color-success); }

/* ---------- REACH OUT --------------------------------------- */

.ab-reach__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(44px, 5.5vw, 72px);
  line-height: 1;
  letter-spacing: -1px;
  color: var(--color-ink);
  margin: 0 0 56px;
}
.ab-reach__cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
.ab-reach__label {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.4;
  color: var(--color-muted);
  margin: 0 0 16px;
}
.ab-reach__link {
  font-family: var(--font-body);
  font-size: clamp(16px, 1.4vw, 19px);
  line-height: 1.4;
  color: var(--color-success);
  text-decoration: none;
  word-break: break-word;
}
.ab-reach__link:hover { opacity: .75; }

/* ---------- SKILLS ------------------------------------------- */

.ab-skills {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 64px;
  align-items: start;
}
.ab-skills__list { display: flex; flex-direction: column; }
.skill {
  padding: 22px 0;
  border-top: 1px solid var(--color-hairline);
}
.skill__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(20px, 2.2vw, 26px);
  line-height: 1.1;
  letter-spacing: -0.2px;
  color: var(--color-ink);
  margin: 0 0 10px;
}
.skill__desc {
  font-family: var(--font-body);
  font-size: 14px;
  line-height: 1.55;
  color: var(--color-body);
  max-width: 56ch;
  margin: 0;
}

/* ---------- AWARDS & RECOGNITION ---------------------------- */

.ab-awards__head { margin-bottom: 48px; }
.ab-awards__list { display: flex; flex-direction: column; }
.award {
  display: grid;
  grid-template-columns: 64px minmax(180px, 1fr) 1.3fr;
  gap: 32px;
  align-items: baseline;
  padding: 24px 0;
  border-top: 1px solid var(--color-hairline);
}
.award:last-child { border-bottom: 1px solid var(--color-hairline); }
.award__year {
  font-family: var(--font-mono);
  font-size: 12px;
  line-height: 1.6;
  color: var(--color-muted-soft);
}
.award__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(18px, 2vw, 24px);
  line-height: 1.1;
  letter-spacing: -0.2px;
  color: var(--color-ink);
}
.award__desc {
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.5;
  color: var(--color-body);
  max-width: 50ch;
}

/* ---------- RESPONSIVE -------------------------------------- */

@media (max-width: 900px) {
  .ab-hero,
  .ab-cols,
  .ab-skills { grid-template-columns: 1fr; gap: 36px; }
  .ab-reach__cols { grid-template-columns: 1fr; gap: 28px; }
  .ab-figure { aspect-ratio: 4 / 3; }
  .award {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .award__title { margin-top: 4px; }
}
