/* ============================================================================
   main.css — single-screen bento landing. References tokens.css only.
   Structure: nav · braid band · 2×2 content grid (hero, studio card, founder
   card, CTA card) · footer. Vertically centered to sit above the fold.
   ========================================================================== */

.page { min-height: 100dvh; display: flex; flex-direction: column; }
.container { width: 100%; max-width: var(--container); margin-inline: auto; padding-inline: var(--space-5); }

.skip-link {
  position: absolute; left: var(--space-3); top: -4rem; z-index: 10;
  padding: var(--space-2) var(--space-4);
  background: var(--c-ink); color: var(--c-cream);
  border-radius: var(--radius-sm); text-decoration: none;
  transition: top var(--transition-fast);
}
.skip-link:focus { top: var(--space-3); }

/* ---- Eyebrows ------------------------------------------------------------ */
.eyebrow {
  margin: 0;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-caps);
  line-height: var(--leading-snug);
}
.eyebrow--rust  { color: var(--c-rust); }
.eyebrow--muted { color: var(--c-ink-soft); }
.eyebrow--gold  { color: var(--c-gold); }

/* ---- Nav ----------------------------------------------------------------- */
.nav__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding-block: var(--space-4); }
.brand { display: inline-flex; align-items: center; gap: var(--space-3); text-decoration: none; color: var(--c-ink); }
.brand__mark { width: 1.75rem; height: 1.75rem; flex: none; border-radius: var(--radius-sm); background: var(--c-ink) url("../assets/braids/braid-mark.webp") center / cover; }
.brand__name { font-family: var(--font-head); font-weight: var(--weight-medium); font-size: var(--text-lg); letter-spacing: -0.01em; }
.nav__links { display: flex; align-items: center; gap: var(--space-5); }
.nav__link { color: var(--c-ink-soft); text-decoration: none; font-size: var(--text-sm); font-weight: var(--weight-medium); }
.nav__link:hover { color: var(--c-ink); }

/* ---- Braid band (decorative; edges feathered into the page) -------------- */
.braid-strip {
  height: var(--braid-strip-h);
  background: var(--c-ink) url("../assets/braids/braid-strip.webp") center / cover;
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 16%, #000 84%, transparent 100%);
          mask-image: linear-gradient(to bottom, transparent 0%, #000 16%, #000 84%, transparent 100%);
}

/* ---- Content grid -------------------------------------------------------- */
.main { flex: 1 1 auto; display: flex; flex-direction: column; justify-content: center; gap: var(--space-5); padding-block: var(--space-6); }
.row { display: grid; gap: var(--space-5); }
.row--top    { grid-template-columns: 1.35fr 1fr; align-items: start; }
.row--bottom { grid-template-columns: 1fr 1fr; align-items: stretch; }

/* ---- Hero ---------------------------------------------------------------- */
.hero__title {
  font-family: var(--font-head);
  font-weight: var(--weight-bold);
  font-size: var(--text-hero);
  line-height: var(--leading-tight);
  letter-spacing: -0.02em;
  color: var(--c-ink);
  margin-block: var(--space-4) var(--space-5);
}
.hero__desc { font-size: var(--text-lg); color: var(--c-ink-soft); max-width: 34ch; }
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-5); }
.hero__note { font-size: var(--text-sm); color: var(--c-ink-soft); margin-top: var(--space-4); }
.hero__note a { color: var(--c-rust); }

/* ---- Buttons ------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-body); font-weight: var(--weight-semibold); font-size: var(--text-sm);
  border: 1px solid transparent; border-radius: var(--radius);
  text-decoration: none; white-space: nowrap;
  transition: transform var(--transition-fast), background var(--transition-fast), border-color var(--transition-fast);
}
.btn:hover { transform: translateY(-1px); }
.btn--gold    { background: var(--c-gold); color: var(--c-ink); }
.btn--gold:hover { background: color-mix(in srgb, var(--c-gold) 88%, #fff); }
.btn--dark    { background: var(--c-ink); color: var(--c-cream); }
.btn--dark:hover { background: color-mix(in srgb, var(--c-ink) 88%, #fff); }
.btn--outline { background: var(--c-card); color: var(--c-ink); border-color: var(--c-line-strong); }
.btn--outline:hover { border-color: var(--c-ink-soft); }
.btn__meta { font-size: var(--text-xs); font-weight: var(--weight-semibold); letter-spacing: 0.04em; color: var(--c-ink-soft); }

/* ---- Cards --------------------------------------------------------------- */
.card { border-radius: var(--radius-card); padding: var(--space-6); background: var(--c-card); box-shadow: var(--shadow-card); }

/* Studio-model card */
.studio__list { display: flex; flex-direction: column; gap: var(--space-4); margin-top: var(--space-4); }
.studio__item + .studio__item { border-top: 1px dashed var(--c-line-strong); padding-top: var(--space-4); }
.studio__h { font-family: var(--font-head); font-weight: var(--weight-bold); font-size: var(--text-2xl); line-height: 1.1; color: var(--c-ink); }
.studio__d { font-size: var(--text-sm); color: var(--c-ink-soft); margin-top: var(--space-1); }

/* Founder card (navy, braid-trimmed) */
.founder { position: relative; overflow: hidden; background: var(--c-ink); color: var(--c-on-navy); padding-top: var(--space-7); }
.founder__braid { position: absolute; inset: 0 0 auto 0; height: 0.5rem; background: url("../assets/braids/braid-strip.webp") center / cover; }
.founder__body { display: flex; gap: var(--space-4); }
.founder__mark { width: 3.5rem; height: 3.5rem; flex: none; border-radius: var(--radius); background: var(--c-ink) url("../assets/braids/braid-mark.webp") center / cover; }
.founder__name { font-weight: var(--weight-semibold); font-size: var(--text-lg); line-height: var(--leading-snug); margin-top: var(--space-2); color: var(--c-on-navy); }
.founder__sub { font-size: var(--text-sm); color: var(--c-on-navy-soft); margin-top: var(--space-3); }

/* CTA card */
.cta { display: flex; flex-direction: column; justify-content: center; }
.cta__title { font-family: var(--font-head); font-weight: var(--weight-bold); font-size: var(--text-2xl); line-height: 1.12; color: var(--c-ink); }
.cta__desc { font-size: var(--text-base); color: var(--c-ink-soft); max-width: 32ch; margin-block: var(--space-3) var(--space-5); }
.cta .btn { align-self: flex-start; }

/* ---- Footer -------------------------------------------------------------- */
.footer { border-top: var(--border-hairline); }
.footer__inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--space-3) var(--space-5); padding-block: var(--space-4); }
.footer__brand { display: inline-flex; align-items: center; gap: var(--space-3); text-decoration: none; color: var(--c-ink); }
.footer__mark { width: 1.75rem; height: 1.75rem; flex: none; border-radius: var(--radius-sm); background: var(--c-ink) url("../assets/braids/braid-mark.webp") center / cover; }
.footer__name { font-family: var(--font-head); font-weight: var(--weight-medium); font-size: var(--text-sm); line-height: 1.05; }
.footer__meta { display: flex; align-items: center; flex-wrap: wrap; gap: var(--space-2) var(--space-5); font-size: var(--text-sm); color: var(--c-ink-soft); }
.footer__meta a { color: var(--c-ink); text-decoration: none; }
.footer__meta a:hover { text-decoration: underline; }

/* ---- Responsive ---------------------------------------------------------- */
@media (max-width: 56rem) {
  .row--top, .row--bottom { grid-template-columns: 1fr; }
  .main { justify-content: flex-start; }
}
@media (max-width: 30rem) {
  .nav__links { gap: var(--space-3); }
  .nav__link { display: none; }   /* keep just the "Get in touch" button on small screens */
}
