/* ──────────────────────────────────────────────────────────────
   Inga Tchalaia — editorial minimalism, soft neobrutalist edges
   Brand colors: #d8d6ce (paper) / #111 (ink)
   Typography: Outfit (uppercase only) + Nunito Sans (body, headings)
   ────────────────────────────────────────────────────────────── */

@import url("https://fonts.googleapis.com/css2?family=Nunito+Sans:opsz,wght@6..12,200;6..12,300;6..12,400;6..12,600;6..12,800&display=swap");

@font-face {
  font-family: "Outfit";
  src: url("assets/fonts/Outfit.ttf") format("truetype-variations");
  font-weight: 100 900;
  font-display: swap;
}

:root {
  --paper: #d8d6ce;
  --paper-dim: #cbc9c1;
  --ink: #111111;
  --ink-soft: #2b2b2b;
  --ink-mute: #6e6c66;
  --rule: 1.5px;
  --max: 1320px;
  --gutter: clamp(20px, 4vw, 64px);
  --shadow-brut: 8px 8px 0 var(--ink);
  --shadow-brut-sm: 4px 4px 0 var(--ink);
  --tr: 220ms cubic-bezier(.2,.7,.2,1);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: "Nunito Sans", system-ui, -apple-system, sans-serif;
  font-weight: 300;
  background: var(--paper);
  color: var(--ink);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Anything UPPERCASE goes Outfit. Anything in normal case goes Nunito Sans. */
.kicker,
.topbar__nav,
.hero__sub,
.piece__sub,
.specs dt,
.contact__label,
.foot__inner,
.badge {
  font-family: "Outfit", system-ui, sans-serif;
}

img { display: block; max-width: 100%; height: auto; }

a {
  color: inherit;
  text-decoration: none;
  border-bottom: var(--rule) solid currentColor;
  padding-bottom: 1px;
  transition: opacity var(--tr);
}
a:hover { opacity: .55; }

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

/* ── Top bar ─────────────────────────────────────────────────── */

.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px var(--gutter);
  background: var(--paper);
  border-bottom: var(--rule) solid var(--ink);
}
.topbar__mark {
  border: 0;
  display: inline-flex;
  align-items: center;
  padding-bottom: 0;
}
.topbar__mark img {
  height: 38px;
  width: auto;
  display: block;
}
.topbar__nav {
  display: flex; gap: clamp(18px, 2.4vw, 36px);
  font-size: 13px;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 500;
}
.topbar__nav a { border: 0; padding-bottom: 0; }
.topbar__nav a:hover { opacity: 1; text-decoration: underline; text-underline-offset: 6px; }

/* ── Hero (full-bleed, overlapping cards, expanding) ─────────── */

.hero {
  position: relative;
  padding: 0;
  margin: 0;
  max-width: none;
  background: var(--paper);
  height: calc(100vh - 70px);
  min-height: 620px;
  display: flex;
  flex-direction: column;
}
.hero__grid {
  flex: 1;
  display: flex;
  align-items: stretch;
  padding: clamp(28px, 5vh, 56px) clamp(28px, 5vw, 64px);
  gap: 0;
}
.card {
  position: relative;
  flex: 1 1 0;
  margin-left: clamp(-32px, -2vw, -18px);
  border: 1.5px solid var(--ink);
  background: var(--ink);
  overflow: hidden;
  cursor: pointer;
  font: inherit;
  color: inherit;
  padding: 0;
  box-shadow:
    0 28px 60px -18px rgba(17,17,17,.45),
    0 12px 30px -10px rgba(17,17,17,.35);
  transition:
    transform 380ms cubic-bezier(.2,.7,.2,1),
    box-shadow 380ms cubic-bezier(.2,.7,.2,1),
    flex-grow 380ms cubic-bezier(.2,.7,.2,1);
  will-change: transform, box-shadow;
}
.card:first-child { margin-left: 0; }
.card:nth-child(1) { z-index: 4; }
.card:nth-child(2) { z-index: 3; }
.card:nth-child(3) { z-index: 2; }
.card:nth-child(4) { z-index: 1; }

.card:hover,
.card:focus-visible {
  transform: translateY(-14px) scale(1.015);
  z-index: 10;
  box-shadow:
    0 40px 80px -20px rgba(17,17,17,.55),
    0 20px 40px -12px rgba(17,17,17,.4);
  outline: none;
}

.card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 700ms cubic-bezier(.2,.7,.2,1);
}
.card:hover img { transform: scale(1.05); }

.card__overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: clamp(16px, 1.6vw, 26px);
  background:
    linear-gradient(to top, rgba(17,17,17,.88) 0%, rgba(17,17,17,0) 42%),
    linear-gradient(to bottom, rgba(17,17,17,.45) 0%, rgba(17,17,17,0) 22%);
  color: var(--paper);
  text-align: left;
  pointer-events: none;
}
.card__index {
  font-family: "Outfit", system-ui, sans-serif;
  font-size: 10px;
  letter-spacing: .28em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--paper);
}
.card__bottom { display: block; }
.card__title {
  display: block;
  font-family: "Outfit", system-ui, sans-serif;
  font-size: clamp(13px, 1.1vw, 17px);
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  line-height: 1.2;
  margin-bottom: 6px;
}
.card__sub {
  display: block;
  font-family: "Outfit", system-ui, sans-serif;
  font-size: 10px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--paper-dim);
}

/* Sold marker */
.card__sold {
  position: absolute;
  top: clamp(14px, 1.4vw, 22px);
  right: clamp(14px, 1.4vw, 22px);
  z-index: 3;
  font-family: "Outfit", system-ui, sans-serif;
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--paper);
  background: var(--ink);
  border: 1.5px solid var(--paper);
  padding: 6px 12px 5px;
  pointer-events: none;
  box-shadow: 0 4px 12px rgba(17,17,17,.35);
}
.card.is-expanded .card__sold {
  top: clamp(20px, 2vw, 32px);
  right: clamp(70px, 6vw, 92px);
  font-size: 13px;
  padding: 8px 16px 7px;
}

/* Expansion (positioning controlled by JS for FLIP) */
.card.is-expanded {
  border: 0;
  box-shadow: none;
  cursor: default;
}
.card.is-expanded img { transform: none; }
.card.is-expanded:hover img { transform: none; }
.card.is-expanded .card__overlay {
  background: linear-gradient(to top, rgba(17,17,17,.92) 0%, rgba(17,17,17,.4) 30%, rgba(17,17,17,.1) 60%);
  padding: clamp(28px, 4vw, 56px);
  pointer-events: auto;
}
.card.is-expanded .card__index { font-size: 13px; }
.card.is-expanded .card__title { font-size: clamp(28px, 3.4vw, 48px); margin-bottom: 14px; }
.card.is-expanded .card__sub { font-size: 13px; }

.card.is-expanded .card__expanded-body {
  display: block;
  margin-top: 18px;
  max-width: 60ch;
  font-family: "Nunito Sans", system-ui, sans-serif;
  font-size: 17px;
  line-height: 1.6;
  font-weight: 400;
  color: var(--paper);
  text-transform: none;
  letter-spacing: 0;
}
.card.is-expanded .card__inquire {
  display: inline-block;
  margin-top: 22px;
  font-family: "Outfit", system-ui, sans-serif;
  font-size: 12px;
  letter-spacing: .24em;
  text-transform: uppercase;
  font-weight: 600;
  border: 1.5px solid var(--paper);
  padding: 12px 22px;
  text-decoration: none;
  color: var(--paper);
  transition: background var(--tr), color var(--tr);
}
.card.is-expanded .card__inquire:hover { background: var(--paper); color: var(--ink); }
.card.is-expanded .card__close {
  position: absolute; top: 18px; right: 22px;
  background: transparent; border: 0;
  font-size: 36px; line-height: 1;
  color: var(--paper);
  cursor: pointer;
  width: 44px; height: 44px;
  z-index: 5;
}

.hero.is-locked .card:not(.is-expanded) {
  opacity: 0;
  transform: scale(.98);
  transition: opacity 260ms ease, transform 260ms ease;
  pointer-events: none;
}

.hero__caption {
  padding: clamp(18px, 3vh, 32px) clamp(28px, 5vw, 64px) clamp(20px, 3vh, 36px);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 24px;
  border-top: var(--rule) solid var(--ink);
}
.hero__tagline {
  margin: 0;
  font-family: "Outfit", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(12px, 1vw, 15px);
  letter-spacing: .22em;
  text-transform: uppercase;
}
.hero__sub {
  margin: 0;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

/* ── Featured work ───────────────────────────────────────────── */

.featured {
  display: grid;
  grid-template-columns: 1.4fr .9fr;
  gap: clamp(24px, 4vw, 64px);
  max-width: var(--max);
  margin: clamp(40px, 8vh, 80px) auto;
  padding: 0 var(--gutter);
  align-items: end;
}
.featured__frame {
  margin: 0;
  border: 1.5px solid var(--ink);
  background: var(--paper-dim);
  box-shadow: var(--shadow-brut);
  transform: translate(-2px, -2px);
  transition: transform var(--tr), box-shadow var(--tr);
}
.featured__frame:hover {
  transform: translate(0,0);
  box-shadow: 0 0 0 var(--ink);
}
.featured__frame img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
}
.featured__meta { padding-bottom: 12px; }
.featured__title {
  margin: 8px 0 24px;
  font-family: "Outfit", system-ui, sans-serif;
  font-size: clamp(20px, 2.6vw, 32px);
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.featured__note {
  margin: 24px 0 0;
  font-size: 17px;
  line-height: 1.55;
  max-width: 38ch;
  color: var(--ink-soft);
  font-weight: 400;
}

/* ── Generic kicker + section title ──────────────────────────── */

.kicker {
  margin: 0 0 16px;
  font-size: 12px;
  letter-spacing: .26em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--ink-mute);
  display: inline-flex; align-items: center;
  gap: 10px;
}
.kicker::before {
  content: "";
  width: 28px; height: var(--rule);
  background: var(--ink-mute);
}

.section-title {
  margin: 0;
  font-family: "Outfit", system-ui, sans-serif;
  font-weight: 600;
  font-size: clamp(24px, 3.6vw, 48px);
  line-height: 1.18;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.piece__meta h3 {
  font-family: "Outfit", system-ui, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: clamp(15px, 1.3vw, 18px);
}

.story__pull {
  font-family: "Outfit", system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .12em;
}

/* ── Specs list (under featured) ─────────────────────────────── */

.specs {
  margin: 0;
  display: grid;
  grid-template-columns: repeat(3, auto);
  gap: 12px 32px;
  border-top: var(--rule) solid var(--ink);
  border-bottom: var(--rule) solid var(--ink);
  padding: 18px 0;
}
.specs > div { display: flex; flex-direction: column; }
.specs dt {
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 600;
  margin-bottom: 4px;
}
.specs dd {
  margin: 0;
  font-weight: 600;
  font-size: 16px;
}

/* ── Work grid ───────────────────────────────────────────────── */

.work {
  max-width: var(--max);
  margin: clamp(80px, 14vh, 160px) auto;
  padding: 0 var(--gutter);
}
.work__head {
  display: grid;
  gap: 20px;
  max-width: 900px;
  margin-bottom: clamp(40px, 7vh, 80px);
}
.work__grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(28px, 4vw, 56px);
}
.piece {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.piece figure {
  margin: 0;
  border: 1.5px solid var(--ink);
  background: var(--paper-dim);
  overflow: hidden;
  transition: transform var(--tr), box-shadow var(--tr);
}
.piece figure:hover {
  transform: translate(-3px, -3px);
  box-shadow: var(--shadow-brut-sm);
}
.piece img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4/5;
}
.piece__meta h3 {
  margin: 0;
  font-size: clamp(20px, 1.7vw, 26px);
  font-weight: 700;
  letter-spacing: -.01em;
}
.piece__sub {
  margin: 6px 0 8px;
  font-size: 13px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.piece__note {
  margin: 0;
  color: var(--ink-soft);
  max-width: 42ch;
  font-size: 16px;
  line-height: 1.55;
  font-weight: 400;
}
.piece--lg {
  grid-column: span 12;
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: end;
}
.piece--lg figure { margin: 0; }
.piece--lg .piece__meta { padding: 0 0 18px; }
.piece--lg .piece__note { font-size: 17px; }
.piece--md { grid-column: span 6; }

.badge {
  display: inline-block;
  margin-left: 8px;
  padding: 3px 8px;
  border: 1.5px solid var(--ink);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 600;
  vertical-align: middle;
  transform: translateY(-2px);
}

/* ── Story ───────────────────────────────────────────────────── */

.story {
  background: var(--ink);
  color: var(--paper);
  padding: clamp(80px, 14vh, 160px) var(--gutter);
  margin-top: clamp(80px, 14vh, 160px);
  border-top: var(--rule) solid var(--ink);
  border-bottom: var(--rule) solid var(--ink);
}
.story__head {
  max-width: var(--max);
  margin: 0 auto clamp(40px, 7vh, 80px);
  display: grid;
  gap: 20px;
}
.story .kicker { color: var(--paper-dim); }
.story .kicker::before { background: var(--paper-dim); }
.story__body {
  max-width: 720px;
  margin: 0 auto;
  font-size: clamp(17px, 1.3vw, 20px);
  line-height: 1.65;
}
.story__body p {
  margin: 0 0 1.4em;
  color: var(--paper);
  font-weight: 400;
}
.story__pull {
  font-size: clamp(22px, 3.4vw, 38px) !important;
  font-weight: 600;
  line-height: 1.18;
  letter-spacing: .12em !important;
  text-transform: uppercase;
  margin: 1em 0 1em !important;
}

/* ── Contact ─────────────────────────────────────────────────── */

.contact {
  max-width: var(--max);
  margin: clamp(80px, 14vh, 160px) auto;
  padding: 0 var(--gutter);
}
.contact__inner {
  display: grid;
  gap: clamp(28px, 5vh, 56px);
}
.contact__list {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  gap: 0;
  border-top: var(--rule) solid var(--ink);
}
.contact__list li {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) 4fr;
  align-items: center;
  gap: 24px;
  padding: 22px 0;
  border-bottom: var(--rule) solid var(--ink);
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 600;
}
.contact__label {
  font-size: 12px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 600;
}
.contact__list a { font-weight: 600; }

/* ── Footer ──────────────────────────────────────────────────── */

.foot {
  border-top: var(--rule) solid var(--ink);
  padding: 24px var(--gutter);
  background: var(--paper);
}
.foot__inner {
  max-width: var(--max);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}

/* ── Modal lightbox ──────────────────────────────────────────── */

.modal {
  position: fixed; inset: 0; z-index: 100;
  display: flex; align-items: center; justify-content: center;
  padding: clamp(16px, 4vh, 48px);
  opacity: 0;
  transition: opacity 220ms ease;
}
.modal.is-open { opacity: 1; }
.modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(17,17,17,.86);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 0; padding: 0; cursor: pointer;
}
.modal__panel {
  position: relative;
  background: var(--paper);
  border: 1.5px solid var(--ink);
  box-shadow: var(--shadow-brut);
  max-width: 1180px;
  width: 100%;
  max-height: 88vh;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  overflow: hidden;
}
.modal__close {
  position: absolute; top: 10px; right: 14px;
  z-index: 2;
  font-size: 32px; line-height: 1;
  background: transparent; border: 0;
  cursor: pointer;
  width: 40px; height: 40px;
  color: var(--paper);
  text-shadow: 0 1px 6px rgba(0,0,0,.4);
  transition: opacity var(--tr);
}
.modal__close:hover { opacity: .65; }
.modal__figure {
  margin: 0;
  background: var(--ink);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.modal__figure img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: var(--ink);
}
.modal__meta {
  padding: clamp(28px, 4vw, 48px);
  display: flex; flex-direction: column; gap: 16px;
  overflow: auto;
}
.modal__title {
  margin: 0;
  font-family: "Outfit", system-ui, sans-serif;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.18;
}
.modal__spec {
  margin: 0;
  font-family: "Outfit", system-ui, sans-serif;
  font-size: 11px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 600;
}
.modal__desc {
  margin: 0;
  font-weight: 400;
  color: var(--ink-soft);
  font-size: 16px;
  line-height: 1.6;
}
.modal__inquire {
  align-self: flex-start;
  margin-top: 16px;
  font-family: "Outfit", system-ui, sans-serif;
  font-size: 12px;
  letter-spacing: .24em;
  text-transform: uppercase;
  font-weight: 600;
  border: 1.5px solid var(--ink);
  padding: 12px 22px;
  text-decoration: none;
  background: var(--paper);
  transition: background var(--tr), color var(--tr);
}
.modal__inquire:hover { background: var(--ink); color: var(--paper); opacity: 1; }

/* ── Mobile / tablet ─────────────────────────────────────────── */

@media (max-width: 880px) {
  .topbar { padding: 14px 20px; }
  .topbar__nav { gap: 14px; font-size: 11px; }
  .hero__grid { grid-template-columns: repeat(2, 1fr); height: auto; min-height: 0; }
  .card { aspect-ratio: 3/4; }
  .hero__caption { grid-template-columns: 1fr; text-align: left; }
  .hero__copy { text-align: left; }
  .featured { grid-template-columns: 1fr; gap: 28px; }
  .featured__frame { transform: translate(0,0); box-shadow: var(--shadow-brut-sm); }
  .work__grid { gap: 36px; }
  .piece--md, .piece--lg { grid-column: span 12; grid-template-columns: 1fr; }
  .specs { grid-template-columns: repeat(2, auto); }
  .foot__inner { flex-direction: column; gap: 8px; }
  .modal__panel { grid-template-columns: 1fr; max-height: 92vh; }
  .modal__figure img { max-height: 50vh; }
}

@media (max-width: 520px) {
  .hero__tagline { font-size: 32px; }
  .section-title { font-size: 38px; }
  .story__pull { font-size: 36px !important; }
  .contact__list li { grid-template-columns: 1fr; gap: 4px; padding: 16px 0; }
}
