/* ============================================================
   home.css — home page only (hero, timeline, cards, about, light footer)
   Shared tokens/reset/nav-chrome live in base.css.
   ============================================================ */

/* NAV (home variant) */
.nav-inner { gap: 24px; }
.brand .nm { font-weight: 700; }
.brand .rl { color: var(--ink-faint); }
@media (max-width: 760px) { .brand .rl { display: none; } }
.nav-mid ul { display: flex; gap: 26px; }
.nav-mid a { color: var(--ink-soft); transition: color .15s ease; }
.nav-mid a:hover, .nav-mid a.active { color: var(--accent); }
.nav-right a { color: var(--ink-soft); }
.nav-right a:hover { color: var(--ink); }
@media (max-width: 640px) { .nav-mid a.hide-sm { display: none; } .nav-mid ul { gap: 18px; } }

/* HERO */
.hero { padding: 150px 0 70px; }
@media (max-width: 900px) { .hero { padding: 90px 0 48px; } }
.hero-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 56px; align-items: start; }
@media (max-width: 900px) { .hero-grid { grid-template-columns: 1fr; gap: 40px; } }
/* timeline hidden → single column so the headline doesn't sit beside empty space */
.hero-grid.no-timeline { grid-template-columns: 1fr; }
.hero-grid.no-timeline h1 { max-width: 20ch; }
.hero h1 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(40px, 6vw, 68px); line-height: 1.06; letter-spacing: -0.015em;
}
.hero h1 em { font-style: italic; }
.timeline { padding-top: 10px; }
.timeline li {
  display: grid; grid-template-columns: 64px 1fr 1fr; gap: 16px;
  padding: 7px 0; align-items: baseline; font-size: 15px;
}
.timeline .yr { color: var(--ink-faint); font-variant-numeric: tabular-nums; }
.timeline .org { color: var(--ink); }
.timeline .role { color: var(--ink-faint); }
@media (max-width: 520px) {
  .timeline li { grid-template-columns: 52px 1fr; }
  .timeline .role { grid-column: 2; }
}

/* PROJECT GRID */
.work { padding: 30px 0 60px; }
.cards { display: grid; grid-template-columns: 1fr 1fr; gap: 56px 40px; }
@media (max-width: 820px) { .cards { grid-template-columns: 1fr; gap: 44px; } }
.card { display: block; }
.card .art {
  position: relative; width: 100%; aspect-ratio: 16/10; border-radius: 14px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  transition: transform .4s cubic-bezier(.2,.8,.2,1); will-change: transform;
}
.card:hover .art { transform: scale(1.012); }
.card .art .title {
  font-family: var(--serif); font-weight: 400; font-size: clamp(24px, 3vw, 34px);
  color: #fff; text-align: center; padding: 0 24px; line-height: 1.1;
  text-shadow: 0 1px 30px rgba(0,0,0,.18);
}
.card .art .title.dark { color: #1a1a1a; text-shadow: none; }
.card .view {
  position: absolute; right: 14px; bottom: 14px;
  border: 1px solid rgba(255,255,255,.8); color: #fff;
  padding: 3px 12px; border-radius: 999px; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  opacity: 0; transform: translateY(6px); transition: opacity .25s ease, transform .25s ease;
  backdrop-filter: blur(2px);
}
.card .view.dark { border-color: rgba(0,0,0,.35); color: #1a1a1a; }
.card:hover .view { opacity: 1; transform: translateY(0); }
.card .meta {
  display: flex; justify-content: space-between; align-items: baseline; gap: 16px;
  margin-top: 14px;
}
.card .meta .cap { color: var(--ink-soft); font-size: 15px; }
.card .meta .tag { color: var(--ink-faint); font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; white-space: nowrap; }

/* ABOUT */
.about { padding: 70px 0; border-top: 1px solid var(--line); }
.about-grid { display: grid; grid-template-columns: 90px 1fr; gap: 40px; }
@media (max-width: 760px) { .about-grid { grid-template-columns: 1fr; gap: 18px; } }
.about .lbl { color: var(--ink-faint); }
.about p { font-family: var(--serif); font-size: clamp(22px, 2.6vw, 30px); line-height: 1.4; letter-spacing: -0.01em; max-width: 26ch; }
.about p .soft { color: var(--ink-faint); }
.about-info { margin-top: 36px; display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
@media (max-width: 640px) { .about-info { grid-template-columns: 1fr 1fr; } }
.about-info .k { color: var(--ink-faint); font-size: 12.5px; text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: 6px; font-family: var(--mono); }
.about-info .v { font-size: 15px; }

/* FOOTER (light) */
footer.foot { padding: 64px 0 48px; border-top: 1px solid var(--line); }
footer.foot h2 { font-family: var(--serif); font-weight: 400; font-size: clamp(28px, 4.4vw, 46px); line-height: 1.1; letter-spacing: -0.015em; max-width: 16ch; }
footer.foot h2 a { color: var(--accent); font-style: italic; }
.foot-row { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 24px; margin-top: 40px; align-items: baseline; }
.foot-links { display: flex; flex-wrap: wrap; gap: 22px; }
.foot-links a { color: var(--ink-soft); font-size: 15px; }
.foot-links a:hover { color: var(--accent); }
.foot-copy { color: var(--ink-faint); font-size: 13px; }
