/* Spool · A24 / Stability brutalist editorial.
   Off-black + bone + ember red. DM Serif Display at extreme size. Snap-scroll chapters. */

:root {
  --ink: #0E0E0E;
  --ink-2: #1B1B1B;
  --bone: #F0EAD9;
  --bone-soft: #C4BCA9;
  --bone-dim: #8C8676;
  --ember: #C1121F;
  --ember-deep: #6B1F23;

  --font-display: "DM Serif Display", "Playfair Display", Georgia, serif;
  --font-sans: "Inter", "Helvetica Neue", system-ui, sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, monospace;

  --pad: clamp(1.5rem, 6vw, 4rem);
  --pad-r: max(var(--pad), 9rem);
  --section-pad-y: clamp(3rem, 7vw, 5rem);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--ink);
  color: var(--bone);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--ember); text-decoration: none; border-bottom: 1px solid var(--ember); }
a:hover { color: var(--bone); border-bottom-color: var(--bone); }
p { margin: 0 0 1em; }

h1, h2, h3 { font-family: var(--font-display); font-weight: 400; line-height: 0.95; margin: 0; }
h1 { font-size: clamp(3rem, 14vw, 13rem); letter-spacing: -0.02em; }
h2 { font-size: clamp(2rem, 5vw, 3.6rem); letter-spacing: -0.01em; }
h3 { font-size: 1.4rem; }

/* Header */
.site-header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 50;
  padding: 1.9rem clamp(0.75rem, 1.6vw, 1.4rem) 1.2rem var(--pad);
  display: flex; justify-content: space-between; align-items: center;
  pointer-events: none;
}
.site-header > * { pointer-events: auto; }
.brand { display: inline-flex; align-items: center; gap: 0.85rem; color: var(--ember); border: 0; }
.brand__mark {
  width: auto; height: 56px;
  transition: transform 0.55s cubic-bezier(0.7, 0, 0.2, 1),
              opacity 0.45s ease,
              filter 0.45s ease;
  transform-origin: center;
}
.brand__name {
  font-family: "Big Shoulders Stencil Display", "Stencil Std", Impact, sans-serif;
  font-size: clamp(1.9rem, 3.4vw, 2.7rem);
  font-weight: 800;
  letter-spacing: 0.04em;
  line-height: 1;
  text-transform: uppercase;
  color: var(--ember);
  transition: opacity 0.4s ease 0.05s,
              transform 0.5s cubic-bezier(0.7, 0, 0.2, 1) 0.05s,
              letter-spacing 0.5s ease 0.05s;
}

/* Scroll-out animation: mark spins + shrinks + blurs, name dissolves while spreading apart. */
body[data-brand-out="true"] .brand { pointer-events: none; }
body[data-brand-out="true"] .brand__mark {
  transform: rotate(-220deg) scale(0.4);
  opacity: 0;
  filter: blur(3px);
}
body[data-brand-out="true"] .brand__name {
  opacity: 0;
  transform: translateX(-12px);
  letter-spacing: 0.4em;
}

@media (prefers-reduced-motion: reduce) {
  .brand__mark, .brand__name { transition-duration: 0.1s !important; }
  body[data-brand-out="true"] .brand__mark { transform: none; filter: none; }
  body[data-brand-out="true"] .brand__name { transform: none; letter-spacing: -0.005em; }
}

.nav-toggle {
  background: var(--bone); color: var(--ink);
  border: 0;
  border-radius: 999px;
  height: 46px;
  padding: 0 1.05rem;
  display: inline-flex; align-items: center; gap: 0.5rem;
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  outline: none;
  -webkit-tap-highlight-color: transparent;
}
.nav-toggle:focus { outline: none; }
.nav-toggle:focus-visible { outline: 2px solid var(--ember); outline-offset: 3px; }
.nav-toggle__icon {
  display: inline-block;
  position: relative;
  width: 15px; height: 11px;
}
.nav-toggle__icon::before,
.nav-toggle__icon::after {
  content: "";
  position: absolute; left: 0;
  height: 2.5px; background: currentColor;
}
.nav-toggle__icon::before { top: 0; width: 100%; }
.nav-toggle__icon::after { bottom: 0; width: 60%; }
.nav-toggle:hover { background: var(--ember); color: var(--bone); }
.nav-toggle[aria-expanded="true"] .nav-toggle__icon::before { width: 60%; left: 40%; }
.nav-toggle[aria-expanded="true"] .nav-toggle__icon::after { width: 100%; }

/* When the dropdown is open, the pill's bottom corners flatten so the panel below meshes into a single shape */
.nav-toggle[aria-expanded="true"] {
  border-radius: 18px 18px 0 0;
  background: var(--bone);
  color: var(--ink);
  min-width: 240px;
  justify-content: flex-end;
  padding-right: 1.15rem;
}
body[data-menu-minimal="true"] .nav-toggle[aria-expanded="true"] {
  height: 46px;
  background: var(--bone);
  color: var(--ink);
  padding: 0 1.15rem;
}
body[data-menu-minimal="true"] .nav-toggle[aria-expanded="true"] .nav-toggle__text {
  opacity: 1;
  width: 64px;
  letter-spacing: 0.2em;
  transform: translateX(0);
}

/* Minimal mode kicks in past the first section. A24-style: text dropped, pill dissolves,
   icon stays clickable as just two thin lines. */
.nav-toggle, .nav-toggle__text, .nav-toggle__icon::before, .nav-toggle__icon::after {
  transition: background 0.35s ease, color 0.35s ease, padding 0.35s ease,
              opacity 0.3s ease, transform 0.35s cubic-bezier(0.7, 0, 0.2, 1),
              width 0.35s ease, height 0.35s ease;
}
body[data-menu-minimal="true"] .nav-toggle {
  background: transparent;
  padding: 0.4rem 0.5rem;
  height: 32px;
  color: var(--bone);
}
body[data-menu-minimal="true"] .nav-toggle:hover {
  background: transparent;
  padding-right: 0.85rem;
}
body[data-menu-minimal="true"] .nav-toggle:hover .nav-toggle__text {
  opacity: 1;
  width: 64px;
  letter-spacing: 0.2em;
  transform: translateX(0);
}
body[data-menu-minimal="true"] .nav-toggle__text {
  white-space: nowrap;
}
body[data-menu-minimal="true"] .nav-toggle__text {
  opacity: 0;
  transform: translateX(8px);
  width: 0; overflow: hidden;
  letter-spacing: 0;
  display: inline-block;
}
body[data-menu-minimal="true"] .nav-toggle__icon {
  width: 22px; height: 12px;
}
body[data-menu-minimal="true"] .nav-toggle__icon::before,
body[data-menu-minimal="true"] .nav-toggle__icon::after {
  height: 1.5px;
}

/* On the bone chapter, flip icon color to ink so it stays visible. */
body[data-menu-minimal="true"][data-active-chapter="02"] .nav-toggle { color: var(--ink); }
.site-nav {
  position: fixed;
  top: calc(1.9rem + 46px);
  right: clamp(0.75rem, 1.6vw, 1.4rem);
  background: var(--bone); padding: 0.6rem 0; min-width: 240px; display: none; z-index: 49;
  mix-blend-mode: normal;
  border-radius: 0 0 18px 18px;
  overflow: hidden;
  box-shadow: 0 10px 28px rgba(14, 14, 14, 0.22);
}
.site-nav[data-open="true"] { display: block; }
.site-nav a {
  display: block; padding: 0.7rem 1.4rem;
  font-family: var(--font-mono);
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink); border: 0;
}
.site-nav a:hover { background: var(--ink); color: var(--bone); }
.site-nav a[aria-current="page"] { color: var(--ember); }

.var-tag {
  position: fixed; bottom: 12px; right: 12px;
  background: var(--bone); color: var(--ink);
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em;
  padding: 0.45rem 0.8rem; text-decoration: none; z-index: 30;
  border: 0;
}
.var-tag span { color: var(--ember); margin-left: 0.4rem; }

/* Reel chapters — snap on the actual scroll container (html), only when chapters are present */
html:has(.reel-chapters) { scroll-snap-type: y mandatory; }
html:has(.reel-chapters) .site-footer { scroll-snap-align: start; border-top: 0; }
.chapter {
  min-height: 100vh;
  scroll-snap-align: start;
  position: relative;
  padding: 8rem var(--pad-r) 4rem var(--pad);
  display: flex; flex-direction: column;
  overflow: hidden;
}

.chapter__num {
  position: absolute; top: 8rem; right: var(--pad);
  font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--bone-dim);
}

.chapter__title {
  font-family: var(--font-display);
  font-size: clamp(3.5rem, 13vw, 11rem);
  line-height: 0.9;
  letter-spacing: -0.02em;
  max-width: 18ch;
  margin-top: auto;
  color: var(--bone);
}

.chapter__title em {
  color: var(--ember);
  font-style: italic;
}
.chapter__title .ink { color: var(--ink); font-style: italic; }
.chapter--ember .chapter__title { line-height: 1.05; }
.chapter--ember .chapter__sub { margin-top: 0.5rem; }

.chapter__sub {
  margin-top: 3.5rem;
  max-width: 56ch;
  font-family: var(--font-sans);
  font-size: clamp(1.05rem, 1.45vw, 1.25rem);
  color: var(--bone);
  line-height: 1.55;
  text-shadow: 0 1px 18px rgba(14, 14, 14, 0.55);
}
.chapter--bone .chapter__sub {
  color: var(--ink);
  text-shadow: none;
}

.chapter__cta {
  display: inline-block;
  margin-top: 2rem;
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bone);
  border-bottom: 1px solid var(--ember);
  padding-bottom: 4px;
}
.chapter__cta:hover { color: var(--ember); }

/* Right-rail footnotes */
.footnotes {
  position: absolute;
  right: var(--pad-r);
  bottom: 4rem;
  max-width: 22rem;
  font-family: var(--font-mono);
  font-size: 0.74rem;
  line-height: 1.5;
  color: var(--bone-dim);
  letter-spacing: 0.04em;
}
.footnotes em { color: var(--ember); font-style: normal; }

/* Chapter background photo or video (ember tinted) */
.chapter__bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--ember-deep), var(--ink) 70%);
  z-index: 0;
  filter: contrast(1.1) saturate(0.6) sepia(0.18) hue-rotate(-25deg);
  opacity: 0.55;
  object-fit: cover;
}
.chapter:has(.chapter__bg)::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(14, 14, 14, 0) 35%, rgba(14, 14, 14, 0.55) 100%);
  z-index: 0;
  pointer-events: none;
}
.chapter__inner, .chapter__title, .chapter__sub, .chapter__cta,
.chapter [data-home-services], .chapter [data-home-featured] {
  position: relative; z-index: 1;
}
.chapter__num, .footnotes { z-index: 1; }

.chapter--bone {
  background: var(--bone); color: var(--ink);
}
.chapter--bone .chapter__num,
.chapter--bone .chapter__sub,
.chapter--bone .footnotes { color: var(--ink); }
.chapter--bone .chapter__title { color: var(--ink); }
.chapter--bone .chapter__cta { color: var(--ink); border-bottom-color: var(--ember); }
.chapter--bone .chapter__bg { display: none; }

.chapter--ember {
  background: var(--ember-deep);
  color: var(--bone);
}

/* Services rendered into chapter */
[data-home-services] {
  display: grid; grid-template-columns: 1fr; gap: 0;
  margin-top: 2rem;
  max-width: 800px;
}
@media (min-width: 720px) { [data-home-services] { grid-template-columns: repeat(3, 1fr); } }
.service {
  padding: 1.2rem 0;
  border-top: 1px solid var(--bone-dim);
}
.chapter--bone .service { border-top-color: var(--ink); }
.service__label { font-family: var(--font-display); font-size: 1.6rem; line-height: 1.05; margin-bottom: 0.5rem; }
.service__body { font-size: 0.95rem; color: var(--bone-soft); }
.chapter--bone .service__body { color: var(--ink); opacity: 0.7; }
.service__cta { display: inline-block; margin-top: 0.5rem; font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ember); border-bottom: 1px solid var(--ember); padding-bottom: 1px; }

/* Featured rendered as a 2-column poster grid */
[data-chapter="03"] {
  padding-top: 2.5rem;
}
[data-chapter="03"] .chapter__num { top: 2.5rem; }
[data-chapter="03"] .chapter__title {
  margin-top: 0;
  font-size: clamp(3.75rem, 10.5vw, 8.25rem);
  text-align: center;
  max-width: none;
}
[data-home-featured] {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(1.5rem, 3vw, 2.5rem);
  margin-top: 2.5rem;
}
@media (max-width: 720px) {
  [data-home-featured] { grid-template-columns: 1fr; }
}
.work-tile {
  display: flex; flex-direction: column;
  width: 81%;
  margin: 0 auto;
  color: var(--bone); border: 0;
}
.chapter--bone .work-tile { color: var(--ink); }
.work-tile:hover { color: var(--ember); }
.work-tile__frame {
  width: 100%;
  aspect-ratio: 2 / 3;
  background: linear-gradient(135deg, var(--ember-deep), var(--ember));
  filter: contrast(1.05);
  overflow: hidden;
  transition: transform 0.4s cubic-bezier(0.2, 0, 0.2, 1);
}
.work-tile:hover .work-tile__frame { transform: translateY(-4px); }
.work-tile__frame img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  filter: sepia(0.25) hue-rotate(-15deg) contrast(1.05);
}
.work-tile__caption { margin-top: 1rem; }
.work-tile__title { font-family: var(--font-display); font-size: clamp(1.6rem, 2.4vw, 2.4rem); line-height: 1.05; }
.work-tile__meta { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--bone-dim); margin-top: 0.4rem; }
.chapter--bone .work-tile__meta { color: var(--ink); opacity: 0.6; }

.featured-work__empty { padding: 2rem 0; border-top: 1px solid var(--bone-dim); border-bottom: 1px solid var(--bone-dim); font-family: var(--font-display); font-style: italic; }

/* Page header (other pages) */
.page-header {
  padding: 8rem var(--pad-r) 4rem var(--pad);
  max-width: 1300px; margin: 0 auto;
}
.page-header__title { font-family: var(--font-display); font-size: clamp(3rem, 9vw, 7rem); line-height: 0.92; letter-spacing: -0.02em; }
.page-header__lead { max-width: 60ch; color: var(--bone-soft); font-size: 1.15rem; margin-top: 1.5rem; }
.eyebrow { font-family: var(--font-mono); font-size: 1.1rem; letter-spacing: 0.32em; text-transform: uppercase; color: var(--ember); margin: 0 0 1rem; }

/* Category */
.category-grid { padding: 1rem var(--pad-r) 4rem var(--pad); max-width: 1300px; margin: 0 auto; }
.category-grid__inner { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.4rem; }
.project-tile {
  display: block; color: var(--bone); border: 0; padding-bottom: 1rem;
}
.project-tile:hover .project-tile__title { color: var(--ember); }
.project-tile__poster {
  aspect-ratio: 11 / 17; background: var(--ink-2); position: relative; overflow: hidden;
}
.project-tile__poster::before {
  content: attr(data-fallback-label); position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 1.05rem; color: var(--bone-dim); text-align: center; padding: 1rem; line-height: 1.1;
}
.project-tile__poster img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 2; filter: contrast(1.05) saturate(0.55) sepia(0.18) hue-rotate(-25deg); transition: filter 0.3s ease; }
.project-tile:hover .project-tile__poster img { filter: contrast(1.05) saturate(1) sepia(0); }
.project-tile__poster:has(img)::before { display: none; }
.project-tile__title { font-family: var(--font-display); font-size: 1.6rem; line-height: 1.05; margin-top: 0.6rem; transition: color 0.2s ease; }
.project-tile__meta { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--bone-dim); margin-top: 0.3rem; }

.category-grid__empty { grid-column: 1 / -1; padding: 3rem; border-top: 1px solid var(--bone-dim); border-bottom: 1px solid var(--bone-dim); font-family: var(--font-display); font-style: italic; color: var(--bone-soft); text-align: center; }

/* Documentary column layout — bottoms align because heights add up */
.doc-list {
  padding: 1rem var(--pad-r) 4rem var(--pad);
  max-width: 1300px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(1.5rem, 3vw, 2.5rem);
  align-items: end;
}
.doc-col {
  display: flex;
  flex-direction: column;
  gap: clamp(2rem, 4vw, 3rem);
}
.doc-tile {
  display: block;
  color: var(--bone);
  border: 0;
  transition: color 0.2s ease;
}
.doc-tile:hover { color: var(--ember); }
.doc-tile__media {
  position: relative;
  width: 100%;
  background: linear-gradient(135deg, var(--ember-deep), var(--ink) 80%);
  overflow: hidden;
  transition: transform 0.4s cubic-bezier(0.2, 0, 0.2, 1);
}
.doc-tile:hover .doc-tile__media { transform: translateY(-4px); }
.doc-tile__media--poster { aspect-ratio: 2 / 3; }
.doc-tile__media--square { aspect-ratio: 1 / 1; }
.doc-tile__placeholder {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--bone-dim);
}
.doc-tile__caption { margin-top: 1rem; }
.doc-tile__title { font-family: var(--font-display); font-size: clamp(1.6rem, 2.2vw, 2.2rem); line-height: 1.05; }
.doc-tile__meta { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--bone-dim); margin-top: 0.4rem; }

@media (max-width: 720px) {
  .doc-list { grid-template-columns: 1fr; }
}

/* Project detail */
.project-detail__hero {
  padding: 8rem var(--pad-r) 1rem var(--pad);
  max-width: 1300px; margin: 0 auto;
}
.project-detail__hero-eyebrow { font-family: var(--font-mono); font-size: 1.1rem; letter-spacing: 0.32em; text-transform: uppercase; color: var(--ember); margin: 0 0 1rem; }
.project-detail__hero-title { font-family: var(--font-display); font-size: clamp(3.4rem, 12vw, 9rem); line-height: 0.9; }
.project-detail__hero-tagline { font-family: var(--font-display); font-size: clamp(1.4rem, 2.6vw, 2.2rem); font-style: italic; color: var(--bone-soft); margin-top: 2rem; max-width: 60ch; }
.project-detail__hero-bg, .project-detail__hero-vignette, .project-detail__hero-placeholder { display: none; }

.project-detail__body { display: grid; grid-template-columns: 1fr; gap: 2rem; max-width: 1300px; margin: 0 auto; padding: 4rem var(--pad-r) 2rem var(--pad); border-top: 1px solid var(--bone-dim); }
@media (min-width: 768px) { .project-detail__body { grid-template-columns: 2fr 1fr; } }
.project-detail__synopsis p { font-size: 1.15rem; line-height: 1.65; }
.project-detail__credits { font-family: var(--font-mono); font-size: 1.05rem; }
.project-detail__credits-heading { font-family: var(--font-display); font-size: 1.8rem; margin-bottom: 1.2rem; color: var(--ember); }
.credit-row { display: flex; justify-content: space-between; gap: 1rem; padding: 0.65rem 0; border-bottom: 1px solid var(--bone-dim); }
.credit-row__role { color: var(--bone-dim); text-transform: uppercase; font-size: 0.85rem; letter-spacing: 0.14em; }
.credit-row__person { color: var(--bone); text-align: right; }

.project-detail__stills { max-width: 1300px; margin: 0 auto; padding: 1rem var(--pad-r) 2rem var(--pad); }
.project-detail__stills-heading { font-family: var(--font-display); font-size: 1.8rem; margin-bottom: 1rem; color: var(--ember); }
.stills-grid { column-width: 280px; column-gap: 0.5rem; }
.still { display: block; break-inside: avoid; margin: 0 0 0.5rem; background: var(--ink-2); position: relative; overflow: hidden; }
.still img { width: 100%; height: auto; display: block; }
.still--placeholder { aspect-ratio: 16 / 10; }
.still--placeholder::before { content: "[STILL]"; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.18em; color: var(--bone-dim); }

.feature-frame { max-width: 100%; }
.feature { margin: 0; }
.feature__video { width: 100%; height: auto; display: block; background: var(--ink-2); }

.project-detail__back, .team-detail__back { padding: 1rem var(--pad-r) 4rem var(--pad); max-width: 1300px; margin: 0 auto; }
.project-detail__back-link, .team-detail__back-link {
  font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ember); border-bottom: 1px solid var(--ember); padding-bottom: 4px;
}

/* Team */
.team-detail__hero { padding: 8rem var(--pad-r) 1rem var(--pad); max-width: 1300px; margin: 0 auto; }
.team-detail__hero-inner { display: flex; gap: 2.5rem; align-items: end; flex-wrap: wrap; }
.team-detail__portrait { width: 240px; height: 240px; background: var(--ink-2); position: relative; overflow: hidden; flex: 0 0 240px; }
.team-detail__portrait img { width: 100%; height: 100%; object-fit: cover; filter: contrast(1.05) saturate(0.55) sepia(0.18) hue-rotate(-25deg); }
.team-detail__portrait:not(:has(img))::before { content: attr(data-fallback-label); position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 1.05rem; color: var(--bone-dim); text-align: center; padding: 0.5rem; }
.team-detail__role { font-family: var(--font-mono); font-size: 1.1rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ember); }
.team-detail__name { font-family: var(--font-display); font-size: clamp(2.6rem, 7vw, 5rem); line-height: 0.95; margin-top: 0.6rem; }

.team-detail__body { display: grid; grid-template-columns: 1fr; gap: 2rem; max-width: 1300px; margin: 1.25rem auto 0; padding: 3.5rem var(--pad-r) 2rem var(--pad); border-top: 1px solid var(--bone-dim); }
@media (min-width: 768px) { .team-detail__body { grid-template-columns: 2fr 1fr; } }
.team-detail__bio p { font-size: 1.1rem; line-height: 1.65; }
.team-detail__contact-heading { font-family: var(--font-display); font-size: 1.4rem; margin-bottom: 1rem; color: var(--ember); }
.team-detail__contact-row { display: flex; justify-content: space-between; gap: 1rem; padding: 0.5rem 0; border-bottom: 1px solid var(--bone-dim); }
.team-detail__contact-label { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bone-dim); }
.team-detail__contact-value { color: var(--bone); }
main:has(.team-detail__hero) { min-height: 100vh; }

[data-about-team] { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 1.5rem; margin-top: 1.5rem; }
.team-card { display: block; color: var(--bone); border: 0; }
.team-card:hover .team-card__name { color: var(--ember); }
.team-card__headshot { aspect-ratio: 3 / 4; background: var(--ink-2); position: relative; overflow: hidden; }
.team-card__headshot img { width: 100%; height: 100%; object-fit: cover; filter: contrast(1.05) saturate(0.55) sepia(0.18) hue-rotate(-25deg); transition: filter 0.3s ease; }
.team-card:hover .team-card__headshot img { filter: contrast(1.05) saturate(1) sepia(0); }
.team-card__headshot::before { content: attr(data-fallback-label); position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-family: var(--font-display); font-size: 0.95rem; color: var(--bone-dim); text-align: center; padding: 0.5rem; }
.team-card__headshot:has(img)::before { display: none; }
.team-card__role { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--bone-dim); margin-top: 0.6rem; }
.team-card__name { font-family: var(--font-display); font-size: 1.5rem; line-height: 1.05; margin-top: 0.2rem; transition: color 0.2s ease; }

[data-about-stats] { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 0; margin: 2rem 0; border-top: 1px solid var(--bone-dim); border-bottom: 1px solid var(--bone-dim); }
.stat { padding: 1.2rem 1rem; border-right: 1px solid var(--bone-dim); }
.stat:last-child { border-right: 0; }
.stat__value { font-family: var(--font-display); font-size: 3.2rem; color: var(--ember); line-height: 1; }
.stat__label { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--bone-dim); margin-top: 0.4rem; }

.contact-socials__row { display: grid; grid-template-columns: 100px 1fr auto; gap: 1rem; align-items: center; padding: 0.8rem 0; border-bottom: 1px solid var(--bone-dim); }
.contact-socials__platform { font-family: var(--font-display); font-size: 1.4rem; }
.contact-socials__handle { font-family: var(--font-mono); font-size: 0.85rem; color: var(--bone-soft); }
.contact-socials__link { font-family: var(--font-mono); font-size: 0.88rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ember); border-bottom: 1px solid var(--ember); padding-bottom: 1px; }

/* Footer */
.site-footer {
  padding: 2.5rem var(--pad-r) 2rem var(--pad);
  border-top: 1px solid var(--bone-dim);
  background: var(--ink);
}
.site-footer__inner {
  max-width: 1300px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.1fr 2.4fr;
  gap: clamp(2rem, 5vw, 5rem);
}
.site-footer__brand { display: flex; flex-direction: column; gap: 1.25rem; }
.site-footer__mark {
  display: inline-flex; align-items: center; gap: 0.75rem;
  font-family: var(--font-display); color: var(--ember);
  font-size: 1.4rem; border: 0; line-height: 1;
}
.site-footer__mark img { width: 32px; height: 32px; object-fit: contain; }
.site-footer__mark:hover { color: var(--bone); }
.site-footer__tagline {
  margin: 0;
  font-family: var(--font-sans);
  color: var(--bone-soft);
  font-size: 0.95rem;
  line-height: 1.5;
  max-width: 32ch;
}
.site-footer__cols {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.site-footer__heading {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ember);
  margin: 0 0 1rem;
}
.site-footer__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.site-footer__list-link {
  font-family: var(--font-display);
  font-size: 1.25rem;
  color: var(--bone);
  border: 0;
  line-height: 1.2;
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0.4rem 0;
}
.site-footer__list-link:hover { color: var(--ember); }
.site-footer__list-link--disabled {
  color: var(--bone-dim);
  cursor: not-allowed;
}
.site-footer__list-link--disabled:hover { color: var(--bone-dim); }
.site-footer__copyright {
  margin: auto 0 0 0;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.14em;
  color: var(--bone-dim);
}
@media (max-width: 960px) {
  .site-footer__inner { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .site-footer__cols { grid-template-columns: repeat(2, 1fr); gap: 1.75rem 1rem; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  html:has(.reel-chapters) { scroll-snap-type: none; }
}

/* BTS gallery */
[data-about-bts] { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 0.4rem; margin-top: 1.5rem; }
.bts-tile { margin: 0; aspect-ratio: 4 / 3; overflow: hidden; background: var(--ink-2); position: relative; }
.bts-tile img { width: 100%; height: 100%; object-fit: cover; display: block; filter: contrast(1.05) saturate(0.55) sepia(0.18) hue-rotate(-25deg); transition: filter 0.3s ease; }
.bts-tile:hover img { filter: contrast(1.05) saturate(1) sepia(0); }

/* Contact CTA button (Reach Out Via Instagram) */
.btn-colorful {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  padding: 0 1rem;
  border-radius: 999px;
  border: 1px solid var(--ember);
  background: var(--ember-deep);
  color: var(--bone);
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  text-decoration: none;
  cursor: pointer;
  transition: background-color 0.2s ease, transform 0.2s ease;
}
.btn-colorful:hover { background: var(--ember); color: var(--bone); border: 1px solid var(--ember); }
.btn-colorful__inner {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.btn-colorful__icon {
  width: 14px;
  height: 14px;
  opacity: 0.9;
}
