/* ============================================================
   INDEX — homepage: hero, projects, about, site footer
   ============================================================ */

/* ── Section label (eyebrow text above headings) ── */
.section-label {
  font-size: 10.4px;
  font-weight: 500;
  letter-spacing: 3.64px;
  text-transform: uppercase;
  color: var(--color-muted);
}

/* ── Hero ── */
.hero {
  padding: 160px var(--page-pad) 80px;
}

.hero-heading {
  margin-top: 24px;
  font-size: 109.7px;
  font-weight: 300;
  line-height: 1;
  letter-spacing: -2.194px;
  color: var(--color-primary);
}

.hero-heading em {
  font-style: italic;
}

.hero-footer {
  margin-top: 40px;
  padding-top: 33px;
  border-top: 1px solid var(--border-light);
  display: flex;
  align-items: flex-start;
  gap: 24px;
}

.hero-description {
  font-size: 12.8px;
  font-weight: 300;
  line-height: 1.7;
  letter-spacing: 1.024px;
  color: var(--color-muted);
  max-width: 384px;
  flex-shrink: 0;
}

.hero-cta-wrap {
  flex: 1;
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
}

.hero-cta {
  font-size: 10.4px;
  font-weight: 500;
  letter-spacing: 3.12px;
  text-transform: uppercase;
  color: var(--color-primary);
  text-decoration: none;
  white-space: nowrap;
  transition: opacity var(--transition);
}

.hero-cta:hover {
  opacity: 0.7;
}

/* ── Projects section ── */
.projects {
  padding: var(--page-pad);
}

.projects-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.projects-date {
  font-size: 10.4px;
  font-weight: 500;
  letter-spacing: 2.08px;
  color: var(--color-muted);
}

.projects-list {
  margin-top: 48px;
  display: flex;
  flex-direction: column;
}

.project-item {
  border-top: 1px solid var(--border-light);
  padding: 32px 0;
  display: flex;
  gap: 32px;
  align-items: flex-start;
}

.project-main {
  flex: 1;
  min-width: 0;
}

.project-meta {
  display: flex;
  gap: 24px;
  align-items: center;
}

.project-number {
  font-size: 9.6px;
  font-weight: 500;
  letter-spacing: 2.88px;
  text-transform: uppercase;
  color: var(--color-muted);
}

.project-type {
  font-size: 9.6px;
  font-weight: 500;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--color-muted);
}

.project-title {
  margin-top: 16px;
  font-size: 54.85px;
  font-weight: 300;
  line-height: 1.05;
  letter-spacing: -0.5485px;
  color: var(--color-primary);
}

.project-title em {
  font-style: italic;
}

.project-title--ghost {
  color: rgba(245, 245, 240, 0.2);
}

.project-description {
  margin-top: 16px;
  font-size: 12.8px;
  font-weight: 300;
  line-height: 1.8;
  letter-spacing: 0.64px;
  color: var(--color-muted);
  max-width: 448px;
}

.project-description--ghost {
  opacity: 0.5;
  max-width: 384px;
}

.project-tags {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.project-action {
  margin-top: 32px;
}

.project-link {
  font-size: 10.4px;
  font-weight: 500;
  letter-spacing: 3.12px;
  text-transform: uppercase;
  color: var(--color-primary);
  text-decoration: none;
  transition: opacity var(--transition);
}

.project-link:hover {
  opacity: 0.7;
}

/* Coming soon indicator */
.coming-soon {
  display: flex;
  align-items: center;
  gap: 12px;
}

.coming-soon-dot {
  width: 6px;
  height: 6px;
  border-radius: 3px;
  background: rgba(245, 245, 240, 0.3);
  flex-shrink: 0;
}

.coming-soon-label {
  font-size: 9.6px;
  font-weight: 500;
  letter-spacing: 2.688px;
  text-transform: uppercase;
  color: rgba(245, 245, 240, 0.3);
}

/* Project sidebar (role / model / year) */
.project-sidebar {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
  padding-top: 4px;
  flex-shrink: 0;
  min-width: 100px;
}

.sidebar-label {
  font-size: 9.6px;
  font-weight: 500;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--color-muted);
}

.sidebar-values {
  text-align: right;
  font-size: 12px;
  font-weight: 300;
  line-height: 1.5;
  letter-spacing: 1.2px;
  color: var(--color-primary);
}

.sidebar-spacer {
  margin-top: 16px;
}

.projects-divider {
  border: none;
  border-top: 1px solid var(--border-light);
  margin: 0;
}

/* ── About ── */
.about {
  border-top: 1px solid var(--border-subtle);
  padding: 97px var(--page-pad) 96px;
}

.about-inner {
  display: flex;
  gap: 96px;
  align-items: flex-end;
}

.about-left {
  flex: 0 0 436.5px;
}

.about-heading {
  margin-top: 32px;
  font-size: 43.88px;
  font-weight: 300;
  line-height: 1.1;
  letter-spacing: -0.4388px;
  color: var(--color-primary);
}

.about-heading em {
  font-style: italic;
}

.about-right {
  flex: 0 0 436.5px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.about-text {
  font-size: 13.6px;
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0.544px;
  color: var(--color-muted);
}

/* ── Site footer ── */
.site-footer {
  border-top: 1px solid var(--border-light);
  padding: 65px var(--page-pad) 64px;
}

.site-footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.footer-contact-label {
  font-size: 10.4px;
  font-weight: 500;
  letter-spacing: 3.64px;
  text-transform: uppercase;
  color: var(--color-muted);
  padding-bottom: 16px;
}

.footer-email {
  font-size: 32.91px;
  font-weight: 300;
  letter-spacing: -0.3291px;
  color: var(--color-primary);
  text-decoration: none;
  white-space: nowrap;
  transition: opacity var(--transition);
}

.footer-email:hover {
  opacity: 0.7;
}

.footer-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 16px;
}

.footer-social {
  display: flex;
  gap: 32px;
}

.footer-social a {
  font-size: 10.4px;
  font-weight: 500;
  letter-spacing: 2.288px;
  text-transform: uppercase;
  color: var(--color-muted);
  text-decoration: none;
  transition: color var(--transition);
}

.footer-social a:hover {
  color: var(--color-primary);
}

.footer-copy {
  font-size: 9.28px;
  font-weight: 500;
  letter-spacing: 1.856px;
  text-transform: uppercase;
  color: var(--color-muted);
}
