/* ============================================================
   IQRAM AHMED PORTFOLIO — about.css
   ============================================================ */


/* ----------------------------------------------------------
   PAGE HEADER
   Default: left side rail | text | right side rail
   With photo: left side rail | text | portrait photo
---------------------------------------------------------- */
.about-header {
  display: grid;
  grid-template-columns: var(--hero-side-width) 1fr var(--hero-side-width);
  border-bottom: var(--border-default);
  min-height: 320px;
}

/* When a portrait is set the right column becomes the photo */
.about-header--has-photo {
  grid-template-columns: var(--hero-side-width) 1fr 360px;
}

.about-header__side {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-4) 0;
  border-right: var(--border-default);
}

.about-header__side--right {
  border-right: none;
  border-left: var(--border-default);
}

.about-header__main {
  padding: var(--space-7) var(--space-8) var(--space-7);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-5);
}

.about-header__kicker {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.about-header__kicker-line {
  width: 32px;
  height: 1px;
  background: var(--color-accent);
  flex-shrink: 0;
}

.about-header__kicker-text {
  font-size: var(--text-xs);
  color: var(--color-accent);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
}

.about-header__h1 {
  font-family: var(--font-display);
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  font-weight: 300;
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--color-text-primary);
  max-width: 680px;
}

.about-header__h1 em {
  font-style: italic;
  color: var(--color-accent);
}

/* Portrait photo column */
.about-header__photo {
  position: relative;
  overflow: hidden;
  background: var(--color-bg-raised);
}

.about-header__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  filter: grayscale(100%) contrast(1.05) brightness(0.88);
}

/* Bottom gradient — dissolves photo into page */
.about-header__photo-fade {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 120px;
  background: linear-gradient(
    to top,
    var(--color-bg-primary) 0%,
    rgba(10, 10, 10, 0.5) 55%,
    transparent 100%
  );
  pointer-events: none;
}


/* ----------------------------------------------------------
   ABOUT BODY — content sections
---------------------------------------------------------- */
.about-body {
  display: grid;
  grid-template-columns: var(--hero-side-width) 1fr var(--hero-side-width);
  border-bottom: var(--border-default);
}

.about-body__side {
  border-right: var(--border-default);
}

.about-body__side--right {
  border-right: none;
  border-left: var(--border-default);
}

.about-body__content {
  padding: var(--space-8) var(--space-8);
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  max-width: 760px;
}

/* Opening paragraph — larger display size */
.about-body__opening {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2vw, 1.5rem);
  font-weight: 300;
  line-height: 1.65;
  color: var(--color-text-primary);
  letter-spacing: var(--tracking-snug);
}

.about-body__opening em {
  font-style: italic;
  color: var(--color-accent);
}

/* Body paragraphs */
.about-body__text {
  font-size: 1rem;
  line-height: var(--leading-loose);
  color: var(--color-text-secondary);
}

/* Section break with label */
.about-body__break {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) 0;
}

.about-body__break-label {
  font-size: var(--text-xs);
  color: var(--color-accent);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  white-space: nowrap;
}

.about-body__break-line {
  flex: 1;
  height: 1px;
  background: var(--color-border);
}


/* ----------------------------------------------------------
   WHAT I DO — four pillars
---------------------------------------------------------- */
.about-pillars {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: var(--border-default);
}

.about-pillar {
  padding: var(--space-6) var(--space-7);
  border-right: var(--border-default);
  border-bottom: var(--border-default);
}

.about-pillar:nth-child(2),
.about-pillar:nth-child(4) {
  border-right: none;
}

.about-pillar:nth-child(3),
.about-pillar:nth-child(4) {
  border-bottom: none;
}

.about-pillar__num {
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: 200;
  color: #1A1A1A;
  line-height: 1;
  margin-bottom: var(--space-2);
  letter-spacing: var(--tracking-tight);
}

.about-pillar__title {
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 300;
  color: var(--color-text-primary);
  line-height: 1.3;
  letter-spacing: var(--tracking-snug);
  margin-bottom: var(--space-2);
}

.about-pillar__body {
  font-size: 1rem;
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
}


/* ----------------------------------------------------------
   FACTS STRIP
---------------------------------------------------------- */
.about-facts {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-bottom: var(--border-default);
}

.about-fact {
  padding: var(--space-5);
  border-right: var(--border-default);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.about-fact:last-child {
  border-right: none;
}

.about-fact__label {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
}

.about-fact__value {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 300;
  color: var(--color-text-primary);
  line-height: 1.4;
  letter-spacing: var(--tracking-snug);
}


/* ----------------------------------------------------------
   RESPONSIVE — TABLET
---------------------------------------------------------- */
@media (max-width: 1024px) {
  .about-header--has-photo {
    grid-template-columns: var(--hero-side-width) 1fr 280px;
  }

  .about-facts {
    grid-template-columns: 1fr 1fr;
  }

  .about-fact:nth-child(2) {
    border-right: none;
  }

  .about-fact:nth-child(1),
  .about-fact:nth-child(2) {
    border-bottom: var(--border-default);
  }

  .about-body__content {
    padding: var(--space-7) var(--space-6);
  }
}

/* ----------------------------------------------------------
   RESPONSIVE — MOBILE
---------------------------------------------------------- */
@media (max-width: 768px) {
  .about-header,
  .about-header--has-photo {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .about-header__side {
    display: none;
  }

  .about-header__main {
    padding: var(--space-5) var(--space-3);
  }

  /* Portrait stacks above the text on mobile */
  .about-header__photo {
    order: -1;
    height: 280px;
  }

  .about-body {
    grid-template-columns: 1fr;
  }

  .about-body__side {
    display: none;
  }

  .about-body__content {
    padding: var(--space-5) var(--space-3);
    gap: var(--space-5);
  }

  .about-body__opening {
    font-size: 1.1875rem;
    line-height: 1.6;
  }

  .about-body__text {
    font-size: 1rem;
    line-height: 1.75;
  }

  .about-pillars {
    grid-template-columns: 1fr;
  }

  .about-pillar {
    border-right: none;
    border-bottom: var(--border-default);
    padding: var(--space-4) var(--space-3);
  }

  .about-pillar:last-child {
    border-bottom: none;
  }

  .about-pillar__body {
    font-size: 1rem;
    line-height: 1.65;
  }

  .about-facts {
    grid-template-columns: 1fr 1fr;
  }

  .about-fact {
    padding: var(--space-3);
  }

  .about-fact:nth-child(odd) {
    border-right: var(--border-default);
  }

  .about-fact:nth-child(even) {
    border-right: none;
  }

  .about-fact:nth-child(1),
  .about-fact:nth-child(2) {
    border-bottom: var(--border-default);
  }
}

/* ----------------------------------------------------------
   RESPONSIVE — SMALL MOBILE
---------------------------------------------------------- */
@media (max-width: 430px) {
  .about-header__main {
    padding: var(--space-4) var(--space-3);
  }

  .about-body__opening {
    font-size: 1.125rem;
  }

  .about-header__photo {
    height: 220px;
  }
}
