/* =========================================================================
   aarav.me  ·  Atelier (V5 — architectural studio)
   "concrete + oak. one building at a time."
   ========================================================================= */

:root {
  --concrete:      #E8E6E1;
  --concrete-deep: #D9D6CF;
  --concrete-warm: #EFEDE7;
  --ink:           #0F0F0E;
  --ink-soft:      #3A3A37;
  --ink-muted:     #8A8780;
  --rule:          #BFBCB3;
  --oak:           #7A5D3F;
  --oak-deep:      #5A442D;

  --sans:    'Inter Tight', 'Inter', system-ui, sans-serif;
  --sans-b:  'Inter', system-ui, sans-serif;
  --mono:    'Geist Mono', ui-monospace, Menlo, Consolas, monospace;

  --container: 980px;
}

*, *::before, *::after { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--concrete);
  color: var(--ink);
  font-family: var(--sans-b);
  font-size: 16px;
  line-height: 1.7;
  font-feature-settings: "kern", "liga", "ss03";
  -webkit-font-smoothing: antialiased;
}

img, svg { max-width: 100%; display: block; }
ul, ol, dl { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, p, dt, dd { margin: 0; }

a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--oak);
  padding-bottom: 1px;
  transition: color 160ms linear, border-color 160ms linear;
}
a:hover { color: var(--oak-deep); border-bottom-color: var(--oak-deep); }

/* ============================ BAR ============================ */

.bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 14px 40px;
  border-bottom: 1px solid var(--ink);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--concrete-warm);
  flex-wrap: wrap;
}
.bar__name { font-weight: 500; letter-spacing: 0.18em; }
.bar__sub  { color: var(--ink-muted); letter-spacing: 0.20em; }
.bar__year { color: var(--ink); letter-spacing: 0.06em; font-variant-numeric: tabular-nums; }

/* ============================ HERO ============================ */

.hero {
  max-width: var(--container);
  margin: 0 auto;
  padding: 100px 40px 80px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: end;
}

.hero__no {
  grid-column: 1 / -1;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.10em;
  color: var(--ink-muted);
  text-transform: uppercase;
  margin-bottom: 28px;
}

.hero__line {
  font-family: var(--sans);
  font-weight: 600;
  font-size: clamp(56px, 9vw, 124px);
  letter-spacing: -0.045em;
  line-height: 0.92;
  color: var(--ink);
  text-wrap: balance;
}
.hero__line--ghost {
  color: var(--ink-muted);
  font-weight: 300;
}

.hero__intro p {
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 36ch;
}

@media (max-width: 760px) {
  .hero {
    grid-template-columns: 1fr;
    gap: 36px;
    padding: 64px 32px 56px;
  }
}

/* ============================ WORKS HEAD ============================ */

.works,
.texts,
.contact {
  max-width: var(--container);
  margin: 0 auto;
  padding: 80px 40px;
  border-top: 1px solid var(--ink);
}

.works__head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  align-items: baseline;
  margin-bottom: 48px;
}

.kicker {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.works__title {
  font-family: var(--sans);
  font-weight: 500;
  font-size: clamp(40px, 5vw, 64px);
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--ink);
}

/* ============================ WORK ============================ */

.work {
  display: grid;
  grid-template-columns: 80px 1fr 1.3fr;
  gap: 24px 40px;
  padding: 36px 0;
  border-top: 1px solid var(--rule);
}
.work:first-of-type { border-top: 1px solid var(--ink); }

.work__no {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--oak);
  font-variant-numeric: tabular-nums;
}

.work__name {
  font-family: var(--sans);
  font-weight: 500;
  font-size: clamp(24px, 2.6vw, 32px);
  letter-spacing: -0.022em;
  line-height: 1.1;
  color: var(--ink);
  text-wrap: balance;
}

.work__spec {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 6px 16px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  align-content: start;
}
.work__spec dt {
  color: var(--ink-muted);
  text-transform: uppercase;
  font-size: 10.5px;
  letter-spacing: 0.08em;
  padding-top: 3px;
}
.work__spec dd { margin: 0; }

.work__desc {
  grid-column: 2 / -1;
  font-size: 16px;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 60ch;
  margin-top: 6px;
}

@media (max-width: 760px) {
  .work {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .work__desc { grid-column: 1 / -1; }
}

/* ============================ TEXT LIST ============================ */

.text-list { display: flex; flex-direction: column; }
.text-list li {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 24px;
  padding: 22px 0;
  border-top: 1px solid var(--rule);
  align-items: baseline;
}
.text-list li:first-child { border-top: 1px solid var(--ink); }

.text-list__date {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--ink-muted);
  font-variant-numeric: tabular-nums;
}

.text-list__title {
  font-family: var(--sans);
  font-weight: 500;
  font-size: clamp(20px, 2.2vw, 26px);
  letter-spacing: -0.022em;
  line-height: 1.2;
  color: var(--ink);
  border-bottom: 0;
}
.text-list__title:hover { color: var(--oak-deep); }

/* ============================ CONTACT ============================ */

.contact__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  border-top: 1px solid var(--ink);
  padding-top: 36px;
}

.contact__col {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 14px 28px;
  font-family: var(--sans-b);
  font-size: 16px;
}
.contact__col dt {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ink-muted);
  padding-top: 3px;
}
.contact__col dd { color: var(--ink); }

@media (max-width: 600px) {
  .contact__grid { grid-template-columns: 1fr; gap: 36px; }
}

/* ============================ ENDBAR ============================ */

.endbar {
  padding: 16px 40px;
  border-top: 1px solid var(--ink);
  background: var(--concrete-warm);
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--ink-muted);
  display: flex;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.endbar p { margin: 0; }

::selection { background: var(--ink); color: var(--concrete-warm); }
