/* ==========================================================================
   BARE — Page-specific styles
   ========================================================================== */

/* Page padding for sticky header offset */
main { padding-top: 96px; }

/* ----- HERO ----- */
.hero {
  position: relative;
  min-height: 92vh;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: clamp(var(--space-8), 6vw, var(--space-20));
  align-items: center;
  padding-block: var(--space-16) var(--space-20);
}

.hero__content { position: relative; z-index: 2; }
.hero__eyebrow { margin-bottom: var(--space-6); }

.hero__title {
  font-size: clamp(3rem, 7vw, 6.5rem);
  line-height: 0.96;
  letter-spacing: -0.025em;
  margin-bottom: var(--space-8);
}
.hero__title em { font-style: italic; color: var(--color-text-muted); font-weight: 300; }

.hero__lead {
  font-size: var(--text-lg);
  line-height: 1.55;
  color: var(--color-text-muted);
  max-width: 48ch;
  margin-bottom: var(--space-10);
}

.hero__actions { display: flex; gap: var(--space-4); flex-wrap: wrap; }

.hero__visual {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--color-surface-alt);
}
.hero__visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 1.4s var(--ease-out);
}
.hero__visual:hover img { transform: scale(1.04); }

.hero__visual-meta {
  position: absolute;
  right: var(--space-6);
  bottom: var(--space-6);
  max-width: calc(100% - var(--space-12));
  background: var(--color-bg);
  padding: var(--space-4) var(--space-5);
  text-align: right;
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  white-space: nowrap;
}
.hero__visual-meta strong {
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--text-base);
  text-transform: none;
  letter-spacing: 0;
  color: var(--color-ink);
  margin-top: 4px;
}

@media (max-width: 980px) {
  .hero {
    grid-template-columns: 1fr;
    min-height: auto;
    padding-block: var(--space-12) var(--space-16);
  }
  .hero__visual { aspect-ratio: 4 / 5; max-width: 560px; }
}

/* ----- MARQUEE / RUNNING TEXT ----- */
.marquee {
  border-block: 1px solid var(--color-border);
  padding-block: var(--space-6);
  overflow: hidden;
  white-space: nowrap;
}
.marquee__track {
  display: inline-flex;
  gap: var(--space-12);
  animation: scroll 38s linear infinite;
  align-items: center;
}
.marquee__item {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-xl);
  color: var(--color-text-muted);
}
.marquee__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--color-accent);
  flex-shrink: 0;
}

@keyframes scroll {
  to { transform: translateX(-50%); }
}

/* ----- PROJECT FEATURES (alternating, editorial) ----- */
.featured-projects { padding-block: var(--space-32) var(--space-24); }
.featured-projects__intro {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-12);
  align-items: end;
  margin-bottom: var(--space-20);
  padding-bottom: var(--space-12);
  border-bottom: 1px solid var(--color-border);
}
.featured-projects__intro h2 { font-size: var(--text-3xl); max-width: 16ch; }
.featured-projects__intro p {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 56ch;
  margin: 0;
}

@media (max-width: 880px) {
  .featured-projects__intro { grid-template-columns: 1fr; gap: var(--space-6); }
}

.feature {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: clamp(var(--space-8), 6vw, var(--space-16));
  align-items: center;
  margin-bottom: var(--space-32);
}
.feature:last-child { margin-bottom: 0; }
.feature--reverse { grid-template-columns: 5fr 7fr; }
.feature--reverse .feature__media { order: 2; }
.feature--reverse .feature__content { order: 1; }

.feature__media {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.feature--tall .feature__media { aspect-ratio: 4 / 5; }

.feature__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.4s var(--ease-out);
}
.feature__media:hover img { transform: scale(1.05); }

.feature__index {
  position: absolute;
  inset: var(--space-4) var(--space-4) auto auto;
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  background: var(--color-bg);
  padding: 6px 14px;
  letter-spacing: 0.05em;
}

.feature__eyebrow { margin-bottom: var(--space-4); }
.feature__title {
  font-size: var(--text-3xl);
  line-height: 1;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-6);
}
.feature__location {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: var(--space-6);
}
.feature__location::before {
  content: '';
  width: 30px; height: 1px;
  background: var(--color-text-muted);
}
.feature__description {
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--color-text);
  margin-bottom: var(--space-6);
  max-width: 50ch;
}
.feature__credit {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-text-muted);
  font-size: var(--text-base);
  margin-bottom: var(--space-8);
}

@media (max-width: 880px) {
  .feature, .feature--reverse {
    grid-template-columns: 1fr;
    margin-bottom: var(--space-20);
  }
  .feature--reverse .feature__media { order: 1; }
  .feature--reverse .feature__content { order: 2; }
}

/* ----- ETHOS / VALUES BAND ----- */
.ethos {
  background: var(--color-ink);
  color: var(--color-bg);
  padding-block: var(--space-32);
}
.ethos h2 { color: var(--color-bg); font-size: var(--text-3xl); max-width: 22ch; margin-bottom: var(--space-16); }
.ethos h2 em { font-style: italic; color: color-mix(in srgb, var(--color-bg) 50%, transparent); font-weight: 300; }

.ethos__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-12);
}
.ethos__item h3 {
  color: var(--color-bg);
  font-size: var(--text-2xl);
  margin-bottom: var(--space-4);
}
.ethos__item p {
  color: color-mix(in srgb, var(--color-bg) 65%, transparent);
  font-size: var(--text-base);
  line-height: 1.65;
  max-width: 36ch;
}
.ethos__num {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-accent);
  font-size: var(--text-base);
  display: block;
  margin-bottom: var(--space-4);
  letter-spacing: 0.05em;
}

@media (max-width: 880px) {
  .ethos__grid { grid-template-columns: 1fr; gap: var(--space-10); }
}

/* ----- COLLABORATORS ----- */
.collaborators { padding-block: var(--space-24); border-block: 1px solid var(--color-border); }
.collaborators__head {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-12);
  align-items: end;
  margin-bottom: var(--space-12);
}
.collaborators__head h2 { font-size: var(--text-2xl); max-width: 16ch; }
.collaborators__head p { color: var(--color-text-muted); max-width: 56ch; margin: 0; font-size: var(--text-base); }

.collaborators__list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-2) var(--space-12);
  list-style: none;
  margin: 0;
  padding: 0;
}
.collaborators__list li {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  padding-block: var(--space-4);
  border-bottom: 1px solid var(--color-border-light);
  color: var(--color-ink);
}
.collaborators__list li em {
  display: block;
  font-style: italic;
  font-size: var(--text-sm);
  font-family: var(--font-body);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-top: 4px;
}

@media (max-width: 880px) {
  .collaborators__head { grid-template-columns: 1fr; gap: var(--space-4); }
}

/* ----- CTA / END BAND ----- */
.cta-band {
  padding-block: clamp(var(--space-20), 12vw, var(--space-40));
  text-align: center;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
}
.cta-band .eyebrow { display: block; margin-bottom: var(--space-6); }
.cta-band h2 {
  font-size: clamp(2.5rem, 6vw, 5.5rem);
  line-height: 1;
  letter-spacing: -0.02em;
  max-width: 16ch;
  margin: 0 auto var(--space-10);
}
.cta-band h2 em { font-style: italic; color: var(--color-text-muted); font-weight: 300; }

/* ----- PAGE HEADERS (interior pages) ----- */
.page-header {
  padding-block: clamp(var(--space-20), 12vw, var(--space-32)) clamp(var(--space-12), 8vw, var(--space-20));
  border-bottom: 1px solid var(--color-border);
}
.page-header__eyebrow { margin-bottom: var(--space-6); }
.page-header h1 {
  font-size: clamp(3rem, 8vw, 7rem);
  line-height: 0.95;
  letter-spacing: -0.025em;
  margin: 0 0 var(--space-8);
  max-width: 14ch;
}
.page-header h1 em { font-style: italic; color: var(--color-text-muted); font-weight: 300; }
.page-header__lead {
  font-size: var(--text-lg);
  color: var(--color-text-muted);
  max-width: 60ch;
  line-height: 1.55;
}

/* ----- PROJECT GRID PAGE ----- */
.projects-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6) var(--space-5);
  padding-block: var(--space-10) var(--space-24);
}

.project-card {
  position: relative;
  display: block;
  overflow: hidden;
  background: var(--color-surface-alt);
}
.project-card__media {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
}

.project-card__media img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.2s var(--ease-out);
}
.project-card:hover .project-card__media img { transform: scale(1.04); }

.project-card__caption {
  padding: var(--space-3) var(--space-1) var(--space-2);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.project-card__caption h3 {
  font-size: var(--text-lg);
  letter-spacing: -0.01em;
  line-height: 1.2;
  margin: 0;
}
.project-card__meta {
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-text-muted);
}
.project-card__type {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  text-transform: none;
  letter-spacing: 0;
  display: none;
}

/* Legacy span classes — ignored ONLY in uniform projects grid (gallery still uses them) */
.projects-grid .span-3, .projects-grid .span-4, .projects-grid .span-5,
.projects-grid .span-6, .projects-grid .span-7, .projects-grid .span-8 { grid-column: auto; }

@media (max-width: 880px) {
  .projects-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-5) var(--space-4); }
}
@media (max-width: 520px) {
  .projects-grid { grid-template-columns: 1fr; gap: var(--space-6); }
  .project-card__caption { padding-top: var(--space-3); }
}

/* Filter bar */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  padding: var(--space-8) 0;
  border-bottom: 1px solid var(--color-border);
}
.filter-bar__chip {
  font-size: var(--text-xs);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: var(--space-2) var(--space-5);
  border: 1px solid var(--color-border);
  background: transparent;
  color: var(--color-text);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
}
.filter-bar__chip:hover { border-color: var(--color-ink); }
.filter-bar__chip.is-active {
  background: var(--color-ink);
  color: var(--color-bg);
  border-color: var(--color-ink);
}

/* ----- PROJECT DETAIL PAGE ----- */
.project-detail-hero {
  padding-block: clamp(var(--space-12), 6vw, var(--space-20));
}
.project-detail-hero__intro {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: end;
  padding-bottom: var(--space-12);
  border-bottom: 1px solid var(--color-border);
}
.project-detail-hero__intro h1 {
  font-size: clamp(2.75rem, 6vw, 5.5rem);
  line-height: 0.95;
  letter-spacing: -0.025em;
  margin: var(--space-6) 0 0;
}

.project-meta {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--space-4);
}
.project-meta li {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border-light);
  font-size: var(--text-sm);
}
.project-meta dt, .project-meta strong {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-text-muted);
  font-weight: 500;
}

.project-hero-image {
  margin-block: var(--space-12);
  aspect-ratio: 16 / 10;
  overflow: hidden;
}
.project-hero-image img { width: 100%; height: 100%; object-fit: cover; }

.project-prose {
  max-width: 64ch;
  margin: 0 auto;
  padding-block: var(--space-12);
}
.project-prose p {
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--color-text);
  margin-bottom: var(--space-6);
}
.project-prose p:first-of-type::first-letter {
  font-family: var(--font-display);
  font-size: 5em;
  float: left;
  line-height: 0.85;
  padding-right: 12px;
  padding-top: 6px;
  color: var(--color-ink);
}

.project-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-5);
  padding-block: var(--space-10) var(--space-16);
}
.project-gallery figure { margin: 0; cursor: zoom-in; overflow: hidden; background: var(--color-surface-alt); }
.project-gallery img {
  width: 100%; height: auto; display: block;
  aspect-ratio: 4 / 3; object-fit: cover;
  transition: transform 0.8s var(--ease-out), opacity 0.4s var(--ease-out);
}
.project-gallery figure:hover img { transform: scale(1.02); }
/* First image (hero) spans full width */
.project-gallery figure:first-child { grid-column: 1 / -1; }
.project-gallery figure:first-child img { aspect-ratio: 16 / 9; }
/* Reset all old span classes inside the gallery — uniform 2-col now */
.project-gallery .span-3, .project-gallery .span-4, .project-gallery .span-5,
.project-gallery .span-6, .project-gallery .span-7, .project-gallery .span-8,
.project-gallery .span-12 { grid-column: auto; }
.project-gallery .span-12:first-child { grid-column: 1 / -1; }

@media (max-width: 600px) {
  .project-gallery { grid-template-columns: 1fr; gap: var(--space-4); }
}

/* Lightbox overlay */
.lightbox {
  position: fixed; inset: 0;
  background: rgba(20, 18, 14, 0.96);
  display: none;
  align-items: center; justify-content: center;
  z-index: 9999;
  padding: var(--space-6);
  cursor: zoom-out;
  opacity: 0;
  transition: opacity 0.25s var(--ease-out);
}
.lightbox.is-open { display: flex; opacity: 1; }
.lightbox img {
  max-width: calc(100% - 100px); max-height: calc(100vh - 120px);
  object-fit: contain;
  box-shadow: 0 30px 80px rgba(0,0,0,0.6);
}
.lightbox__close {
  position: absolute; top: var(--space-5); right: var(--space-5);
  background: transparent; border: 0; color: #F7F6F2;
  font-size: 28px; cursor: pointer; line-height: 1;
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-display);
}
.lightbox__nav {
  position: absolute; top: 50%; transform: translateY(-50%);
  background: transparent; border: 0; color: #F7F6F2;
  font-size: 32px; cursor: pointer; line-height: 1;
  padding: var(--space-4) var(--space-5);
  font-family: var(--font-display);
  opacity: 0.7; transition: opacity var(--duration) var(--ease-out);
}
.lightbox__nav:hover { opacity: 1; }
.lightbox__prev { left: var(--space-4); }
.lightbox__next { right: var(--space-4); }
.lightbox__counter {
  position: absolute; bottom: var(--space-5); left: 50%; transform: translateX(-50%);
  color: rgba(247,246,242,0.7);
  font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase;
}

@media (max-width: 880px) {
  .project-detail-hero__intro { grid-template-columns: 1fr; gap: var(--space-8); }
  .project-meta li { grid-template-columns: 100px 1fr; }
}

/* Project nav (next/prev) */
.project-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--color-border);
}
.project-nav a {
  padding: var(--space-12) var(--gutter);
  display: block;
  transition: background var(--duration) var(--ease-out);
}
.project-nav a:first-child { border-right: 1px solid var(--color-border); }
.project-nav a:hover { background: var(--color-surface); }
.project-nav__label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-text-muted);
  margin-bottom: var(--space-3);
  display: block;
}
.project-nav__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  color: var(--color-ink);
}
.project-nav a:last-child { text-align: right; }

@media (max-width: 700px) { .project-nav { grid-template-columns: 1fr; } .project-nav a:first-child { border-right: 0; border-bottom: 1px solid var(--color-border); } }

/* ----- SERVICES ----- */
.services-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--color-border);
  border-left: 1px solid var(--color-border);
}
.service {
  padding: var(--space-12) var(--space-10);
  border-right: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  background: var(--color-bg);
  transition: background var(--duration) var(--ease-out);
  position: relative;
}
.service:hover { background: var(--color-surface); }

.service__num {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--color-accent);
  font-size: var(--text-base);
  letter-spacing: 0.08em;
}
.service h3 {
  font-size: var(--text-2xl);
  margin: var(--space-4) 0 var(--space-4);
}
.service p {
  color: var(--color-text-muted);
  font-size: var(--text-base);
  line-height: 1.6;
  max-width: 44ch;
  margin-bottom: var(--space-6);
}
.service ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 6px;
}
.service li {
  font-size: var(--text-sm);
  color: var(--color-text);
  padding-left: var(--space-4);
  position: relative;
}
.service li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.65em;
  width: 8px;
  height: 1px;
  background: var(--color-accent);
}

@media (max-width: 880px) { .services-grid { grid-template-columns: 1fr; } }

/* Process timeline */
.process {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--space-8);
  padding-block: var(--space-12);
}
.process__step h4 {
  font-size: var(--text-xl);
  margin: var(--space-4) 0 var(--space-3);
}
.process__step p {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: 1.6;
}
.process__step .num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border: 1px solid var(--color-border);
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--text-base);
  color: var(--color-accent);
}
@media (max-width: 980px) { .process { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .process { grid-template-columns: 1fr; } }

/* ----- ABOUT ----- */
.about-lead {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  padding-block: var(--space-16);
  align-items: start;
}
.about-lead h2 {
  font-size: var(--text-3xl);
  line-height: 1.05;
  max-width: 16ch;
}
.about-lead h2 em { font-style: italic; color: var(--color-text-muted); font-weight: 300; }
.about-lead p { font-size: var(--text-lg); color: var(--color-text-muted); line-height: 1.65; max-width: 56ch; }

@media (max-width: 880px) { .about-lead { grid-template-columns: 1fr; gap: var(--space-8); } }

.about-image {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  margin-block: var(--space-12);
}
.about-image img { width: 100%; height: 100%; object-fit: cover; }

.principal {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-16);
  align-items: start;
  padding-block: var(--space-16);
  border-top: 1px solid var(--color-border);
}
.principal__photo { aspect-ratio: 4 / 5; overflow: hidden; }
.principal__photo img { width: 100%; height: 100%; object-fit: cover; }
.principal h3 { font-size: var(--text-2xl); margin-bottom: var(--space-3); }
.principal__role {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-accent);
  margin-bottom: var(--space-8);
}
.principal p { font-size: var(--text-base); line-height: 1.7; color: var(--color-text); margin-bottom: var(--space-4); max-width: 56ch; }

@media (max-width: 880px) { .principal { grid-template-columns: 1fr; gap: var(--space-8); } }

/* Stat strip */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-block: 1px solid var(--color-border);
  margin-block: var(--space-16);
}
.stat {
  padding: var(--space-12) var(--space-8);
  border-right: 1px solid var(--color-border);
  text-align: left;
}
.stat:last-child { border-right: 0; }
.stat__num {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1;
  color: var(--color-ink);
  display: block;
  margin-bottom: var(--space-2);
}
.stat__label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-text-muted);
}
@media (max-width: 880px) {
  .stats { grid-template-columns: 1fr 1fr; }
  .stat { border-bottom: 1px solid var(--color-border); }
  .stat:nth-child(2) { border-right: 0; }
}

/* ----- CONTACT ----- */
.contact-grid {
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: var(--space-16);
  padding-block: var(--space-12) var(--space-32);
}

.contact-info h3 { font-family: var(--font-body); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.22em; color: var(--color-text-muted); margin-bottom: var(--space-3); font-weight: 500; }
.contact-info__block { padding-bottom: var(--space-8); margin-bottom: var(--space-8); border-bottom: 1px solid var(--color-border-light); }
.contact-info__block:last-child { border-bottom: 0; }
.contact-info p, .contact-info a {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--color-ink);
  line-height: 1.4;
  margin: 0;
}
.contact-info a:hover { color: var(--color-accent); }

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
}
.form-grid .field--full { grid-column: span 2; }

.field { display: flex; flex-direction: column; gap: var(--space-2); }
.field label {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--color-text-muted);
  font-weight: 500;
}
.field input,
.field select,
.field textarea {
  padding: var(--space-4) 0;
  border: 0;
  border-bottom: 1px solid var(--color-border);
  background: transparent;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-ink);
  border-radius: 0;
  transition: border-color var(--duration-fast) var(--ease-out);
}
.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: 0;
  border-bottom-color: var(--color-ink);
}
.field textarea { resize: vertical; min-height: 140px; }

.contact-form button[type="submit"] { margin-top: var(--space-8); }

.form-success {
  display: none;
  padding: var(--space-6);
  background: var(--color-surface);
  border-left: 3px solid var(--color-accent);
  margin-top: var(--space-6);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-style: italic;
  color: var(--color-ink);
}
.form-success.is-visible { display: block; }

@media (max-width: 880px) {
  .contact-grid { grid-template-columns: 1fr; gap: var(--space-10); }
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .field--full { grid-column: span 1; }
}

/* ----- TRADE / DESIGNER NOTE ----- */
.trade-note {
  background: var(--color-surface-alt);
  padding: var(--space-12);
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-8);
  align-items: center;
  margin-top: var(--space-12);
}
.trade-note h3 { font-size: var(--text-2xl); }
.trade-note p { color: var(--color-text-muted); margin: 0; max-width: 50ch; }
@media (max-width: 880px) { .trade-note { grid-template-columns: 1fr; } }
