/* ============================================================
   Sunshine Taboada — Personal site
   Built on top of /assets/colors_and_type.css
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: var(--body-size);
  line-height: var(--body-line);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }

/* ─── LAYOUT ───────────────────────────────────────────────── */
.wrap { width: 100%; max-width: 1320px; margin: 0 auto; padding: 0 var(--space-7); }
@media (max-width: 720px) { .wrap { padding: 0 var(--space-5); } }

section { position: relative; padding: var(--space-9) 0; }
@media (max-width: 900px) { section { padding: var(--space-8) 0; } }

/* Surfaces — short aliases */
.s-ink       { background: var(--ink);        color: var(--fg-invert); }
.s-terracotta{ background: var(--terracotta); color: var(--ink); }
.s-bone      { background: var(--bone);       color: var(--ink); }
.s-paper     { background: var(--paper);      color: var(--ink); }

.s-ink h1, .s-ink h2, .s-ink h3, .s-ink h4,
.s-ink .display-1, .s-ink .display-2,
.s-ink p, .s-ink li, .s-ink .eyebrow, .s-ink .meta {
  color: var(--fg-invert);
}
.s-ink .dot { color: var(--terracotta); }
.s-ink .eyebrow { color: var(--bone-deep); }
.s-ink .fg-muted, .s-ink .meta { color: #9c8e89; }

.s-terracotta .eyebrow { color: var(--ink); opacity: .72; }
.s-bone .eyebrow { color: var(--fg-muted); }
.s-paper .eyebrow { color: var(--fg-muted); }

.dot { color: var(--terracotta); }
.s-bone .dot, .s-paper .dot, .s-terracotta .dot { color: var(--ink); }

/* ─── TYPE HELPERS ─────────────────────────────────────────── */
.display-1, .display-2, h1, h2, h3, h4 {
  font-family: var(--font-display);
  margin: 0;
}
.display-1 { font-size: var(--display-1-size); line-height: var(--display-1-line); letter-spacing: var(--display-1-track); font-weight: var(--display-1-weight); }
.display-2 { font-size: var(--display-2-size); line-height: var(--display-2-line); letter-spacing: var(--display-2-track); font-weight: var(--display-2-weight); }
h1 { font-size: var(--h1-size); line-height: var(--h1-line); letter-spacing: var(--h1-track); font-weight: var(--h1-weight); }
h2 { font-size: var(--h2-size); line-height: var(--h2-line); letter-spacing: var(--h2-track); font-weight: var(--h2-weight); }
h3 { font-size: var(--h3-size); line-height: var(--h3-line); letter-spacing: var(--h3-track); font-weight: var(--h3-weight); }
h4 { font-size: var(--h4-size); line-height: var(--h4-line); letter-spacing: var(--h4-track); font-weight: var(--h4-weight); }

p { margin: 0; }
p + p { margin-top: var(--space-4); }

.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--eyebrow-size);
  letter-spacing: var(--eyebrow-track);
  font-weight: var(--eyebrow-weight);
  text-transform: uppercase;
  color: var(--fg-muted);
  display: inline-flex; align-items: center; gap: 10px;
}
.eyebrow::before {
  content: "";
  width: 24px; height: 1px;
  background: currentColor; opacity: .6;
}
.eyebrow.plain::before { display: none; }
.meta    { font-family: var(--font-mono); font-size: var(--meta-size); line-height: var(--meta-line); color: var(--fg-muted); }
.caption { font-family: var(--font-mono); font-size: var(--caption-size); letter-spacing: var(--caption-track); text-transform: uppercase; color: var(--fg-faint); }
.num { font-family: var(--font-display); font-weight: 800; font-style: italic; letter-spacing: -0.01em; }

/* ─── NAV ──────────────────────────────────────────────────── */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 50;
  padding: var(--space-4) var(--space-7);
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(246, 241, 238, 0.86);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-bottom: 1px solid transparent;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
  color: var(--ink);
}
.nav.is-dark {
  background: rgba(22, 20, 20, 0.78);
  color: var(--bone);
  border-bottom-color: var(--line-strong);
}
.nav.is-scrolled { border-bottom-color: var(--line); }
.nav.is-dark.is-scrolled { border-bottom-color: var(--line-strong); }
.nav-brand {
  display: inline-flex; align-items: center;
  height: 36px;
  text-decoration: none;
}
.nav-brand .mark {
  display: block;
  width: 54px;
  height: 36px;
  background-color: currentColor;
  -webkit-mask: url("logo-S-mark-black.png") no-repeat left center / contain;
          mask: url("logo-S-mark-black.png") no-repeat left center / contain;
}
.nav-links {
  display: flex; gap: var(--space-6);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 500;
}
.nav-links a { position: relative; padding: 6px 0; opacity: .72; transition: opacity .15s ease; }
.nav-links a:hover { opacity: 1; }
.nav-links a::after {
  content: ""; position: absolute; left: 0; bottom: 0;
  width: 0; height: 1px; background: currentColor;
  transition: width .2s ease;
}
.nav-links a:hover::after { width: 100%; }
.nav-cta {
  font-family: var(--font-mono); text-transform: uppercase;
  font-size: 12px; letter-spacing: 0.14em; font-weight: 500;
  padding: 10px 16px; border: 1px solid currentColor;
  transition: background .15s ease, color .15s ease;
}
.nav-cta:hover { background: var(--terracotta); border-color: var(--terracotta); color: var(--ink); }
.nav.is-dark .nav-cta:hover { background: var(--terracotta); color: var(--ink); border-color: var(--terracotta); }
@media (max-width: 900px) {
  .nav-links { display: none; }
  .nav { padding: var(--space-4) var(--space-5); }
}

/* ─── BUTTONS ─────────────────────────────────────────────── */
.btn {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 500;
  padding: 18px 28px;
  border: none;
  display: inline-flex; align-items: center; gap: 14px;
  transition: transform .12s ease, background .15s ease, color .15s ease, border-color .15s ease;
  cursor: pointer;
}
.btn:active { transform: translateY(1px); }
.btn::after {
  content: "→"; font-family: var(--font-mono); font-size: 15px;
  transition: transform .15s ease;
}
.btn:hover::after { transform: translateX(4px); }
.btn-primary { background: var(--ink); color: var(--bone); }
.btn-primary:hover { background: var(--terracotta); color: var(--ink); }
.btn-brand { background: var(--ink); color: var(--terracotta); }
.btn-brand:hover { background: var(--bone); color: var(--ink); }
.btn-ghost { background: transparent; border: 1px solid currentColor; color: inherit; }
.btn-ghost:hover { background: var(--ink); color: var(--bone); border-color: var(--ink); }
.s-ink .btn-ghost:hover { background: var(--bone); color: var(--ink); border-color: var(--bone); }
.btn-text {
  background: transparent; padding: 14px 0; color: inherit;
  border: 0; gap: 12px;
}
.btn-text::after {
  content: ""; width: 24px; height: 1px; background: currentColor;
  transition: width .18s ease;
}
.btn-text:hover::after { width: 56px; transform: none; }

/* ─── SECTION HEADER ──────────────────────────────────────── */
.section-head {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: var(--space-7);
  align-items: baseline;
  margin-bottom: var(--space-8);
}
.section-head .index {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.section-head h2 { font-size: clamp(40px, 5.5vw, 72px); line-height: 1.05; letter-spacing: -0.01em; }
@media (max-width: 720px) {
  .section-head { grid-template-columns: 1fr; gap: var(--space-4); margin-bottom: var(--space-7); }
  .section-head .index { font-size: 20px; }
}

/* ─── HERO ────────────────────────────────────────────────── */
.hero {
  min-height: 100vh;
  padding: var(--space-10) 0 var(--space-9);
  display: grid; align-content: center;
  position: relative; overflow: hidden;
}
.hero .wrap { position: relative; z-index: 2; }
.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bone-deep);
  margin-bottom: var(--space-7);
  display: flex; flex-wrap: wrap; gap: 12px 24px; align-items: center;
}
.hero-eyebrow .sep { width: 28px; height: 1px; background: var(--bone-deep); opacity: .5; }
.hero-headline {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(64px, 11vw, 184px);
  line-height: 0.92;
  letter-spacing: -0.025em;
  max-width: 16ch;
}
.hero-headline .br { display: block; }
.hero-sub {
  margin-top: var(--space-7);
  max-width: 56ch;
  font-size: 17px;
  line-height: 1.6;
  color: var(--bone);
  opacity: .82;
}
.hero-foot {
  margin-top: var(--space-9);
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: var(--space-6); flex-wrap: wrap;
}
.hero-foot .meta-block { display: grid; gap: 4px; }
.hero-foot .meta-block .caption { color: #9c8e89; }
.hero-foot .meta-block .val { font-family: var(--font-mono); font-size: 14px; color: var(--bone); }
.hero-scroll { display: inline-flex; gap: 10px; align-items: center; color: var(--bone-deep); font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; }
.hero-scroll::after { content: "↓"; font-size: 14px; animation: bob 1.8s ease-in-out infinite; }
@keyframes bob { 0%,100% { transform: translateY(0); } 50% { transform: translateY(4px); } }

.hero-bg-mark {
  position: absolute;
  right: -8%; bottom: -18%;
  width: 78vh; max-width: 1000px;
  opacity: 0.08;
  user-select: none; pointer-events: none;
  z-index: 1;
}

/* ─── THE GAP ─────────────────────────────────────────────── */
.gap-grid {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: var(--space-7);
  align-items: start;
}
.gap-grid .lead {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 48px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.005em;
  margin-bottom: var(--space-6);
}
.gap-grid p { font-size: 17px; line-height: 1.65; max-width: 60ch; color: var(--fg); }
.gap-grid p + p { margin-top: var(--space-5); }
.gap-grid .closer {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.3;
  margin-top: var(--space-6);
  color: var(--ink);
}
@media (max-width: 720px) { .gap-grid { grid-template-columns: 1fr; gap: var(--space-4); } }

/* ─── PROBLEMS ────────────────────────────────────────────── */
.problems {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-top: 1px solid var(--ink);
  border-left: 1px solid var(--ink);
}
.problem-card {
  border-right: 1px solid var(--ink);
  border-bottom: 1px solid var(--ink);
  padding: var(--space-7);
  background: var(--bone);
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: var(--space-5);
  min-height: 280px;
}
.problem-card .head {
  display: flex; justify-content: space-between; align-items: baseline;
}
.problem-card .head .num {
  font-family: var(--font-display);
  font-size: 28px; font-weight: 800;
}
.problem-card .head .tag {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--fg-muted);
}
.problem-card h3 {
  font-family: var(--font-display);
  font-size: clamp(24px, 2.4vw, 32px);
  font-weight: 800;
  line-height: 1.1;
}
.problem-card p { font-size: 15px; line-height: 1.6; color: var(--fg); }
@media (max-width: 720px) { .problems { grid-template-columns: 1fr; } .problem-card { padding: var(--space-6); min-height: 0; } }

/* ─── CHOREOGRAPHER ───────────────────────────────────────── */
.choreographer { position: relative; overflow: hidden; }
.choreographer .wrap { position: relative; z-index: 2; }
.cho-grid {
  display: grid;
  grid-template-columns: 1fr 1.35fr;
  gap: var(--space-9);
  align-items: start;
}
.cho-side .eyebrow { color: var(--ink); opacity: .7; }
.cho-side .name {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(48px, 7vw, 104px);
  line-height: 0.95;
  letter-spacing: -0.02em;
  margin-top: var(--space-5);
}
.cho-side .name .dot { color: var(--ink); }
.cho-side .credentials {
  margin-top: var(--space-7);
  display: grid;
  gap: var(--space-3);
}
.cho-side .cred-row {
  display: grid;
  grid-template-columns: 36px 1fr;
  gap: var(--space-3);
  align-items: baseline;
  padding: var(--space-3) 0;
  border-top: 1px solid rgba(22,20,20,.25);
  font-family: var(--font-mono);
  font-size: 13px;
}
.cho-side .cred-row .k { font-weight: 600; }
.cho-side .cred-row:last-child { border-bottom: 1px solid rgba(22,20,20,.25); }

.cho-body p {
  font-size: 17px; line-height: 1.7; color: var(--ink);
  max-width: 60ch;
}
.cho-body p + p { margin-top: var(--space-5); }
.cho-body .pull {
  font-family: var(--font-display);
  font-size: clamp(24px, 2.6vw, 36px);
  font-weight: 700;
  line-height: 1.2;
  margin: var(--space-6) 0;
  padding: var(--space-5) 0 var(--space-5) var(--space-5);
  border-left: 4px solid var(--ink);
}
.cho-bg-mark {
  position: absolute;
  left: -10%; top: -10%;
  width: 60vh; max-width: 800px;
  opacity: 0.08; pointer-events: none;
}
@media (max-width: 900px) { .cho-grid { grid-template-columns: 1fr; gap: var(--space-7); } }

/* ─── SERVICES (WHAT I DO) ────────────────────────────────── */
.services { display: grid; gap: 0; border-top: 1px solid var(--ink); }
.service {
  display: grid;
  grid-template-columns: 88px 1fr 1.2fr;
  gap: var(--space-7);
  padding: var(--space-8) 0;
  border-bottom: 1px solid var(--ink);
}
.service .num {
  font-family: var(--font-display);
  font-size: clamp(48px, 5vw, 72px);
  font-weight: 800;
  line-height: 1;
}
.service .title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.005em;
}
.service .for {
  margin-top: var(--space-4);
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--fg-muted);
  letter-spacing: 0.04em;
  font-style: italic;
}
.service .what {
  font-family: var(--font-display);
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.35;
  font-weight: 700;
  letter-spacing: -0.005em;
  margin-bottom: var(--space-5);
}
.service .value {
  font-size: 16px; line-height: 1.65; color: var(--fg);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--line);
  margin-bottom: var(--space-6);
}
.service .how-label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: var(--space-4);
}
.service ul { list-style: none; margin: 0; padding: 0; display: grid; gap: var(--space-3); }
.service li {
  font-family: var(--font-mono);
  font-size: 14px;
  line-height: 1.55;
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 10px;
  color: var(--fg);
}
.service li::before { content: "→"; color: var(--terracotta); font-weight: 600; }
@media (max-width: 900px) {
  .service { grid-template-columns: 1fr; gap: var(--space-5); padding: var(--space-7) 0; }
  .service .num { font-size: 40px; }
}

/* ─── RULES ───────────────────────────────────────────────── */
.rules-head {
  display: grid; grid-template-columns: 160px 1fr; gap: var(--space-7);
  align-items: baseline; margin-bottom: var(--space-8);
}
.rules-head .lead {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 600;
  font-style: italic;
  line-height: 1.25;
  max-width: 26ch;
}
.rules-list { display: grid; gap: 0; border-top: 1px solid var(--line-strong); }
.rule-item {
  display: grid;
  grid-template-columns: 88px 1.1fr 1.4fr;
  gap: var(--space-7);
  padding: var(--space-7) 0;
  border-bottom: 1px solid var(--line-strong);
  align-items: baseline;
}
.rule-item .num {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 800;
  color: var(--terracotta);
}
.rule-item .title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 800;
  line-height: 1.05;
  letter-spacing: -0.005em;
}
.rule-item .title .dot { color: var(--terracotta); }
.rule-item p {
  font-family: var(--font-mono);
  font-size: 15px; line-height: 1.65;
  max-width: 50ch;
  color: var(--bone);
  opacity: .85;
}
@media (max-width: 900px) {
  .rule-item { grid-template-columns: 56px 1fr; }
  .rule-item p { grid-column: 1 / -1; }
  .rules-head { grid-template-columns: 1fr; }
}

/* ─── PROOF (cases) ───────────────────────────────────────── */
.cases { display: grid; gap: var(--space-7); }
.case {
  display: grid;
  grid-template-columns: 1fr 2.4fr;
  gap: var(--space-7);
  padding: var(--space-7) 0;
  border-top: 1px solid var(--ink);
  align-items: start;
}
.cases > .case:last-child { border-bottom: 1px solid var(--ink); }
.case .num-block { display: grid; gap: var(--space-4); }
.case .num-block .index {
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--fg-muted);
}
.case .num-block .title {
  font-family: var(--font-display);
  font-size: clamp(28px, 2.8vw, 40px);
  font-weight: 800; line-height: 1.05;
  letter-spacing: -0.005em;
}
.case .num-block .title .dot { color: var(--terracotta); }
.case-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.case-cell .label {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--fg-muted);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--line);
}
.case-cell .label .num { font-family: var(--font-display); color: var(--terracotta); font-style: normal; font-weight: 800; margin-right: 4px; }
.case-cell p { font-family: var(--font-mono); font-size: 14px; line-height: 1.6; color: var(--ink); }
@media (max-width: 900px) {
  .case { grid-template-columns: 1fr; }
  .case-grid { grid-template-columns: 1fr; gap: var(--space-4); }
}

/* ─── PERSON ──────────────────────────────────────────────── */
.person-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-7);
}
.person-card {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-7);
  padding: var(--space-7) 0;
  border-top: 1px solid var(--ink);
  align-items: start;
}
.person-grid > .person-card:last-child { border-bottom: 1px solid var(--ink); }
.person-card .chap {
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--fg-muted);
}
.person-card .chap .num {
  font-family: var(--font-display); font-style: normal; font-weight: 800; color: var(--ink);
  margin-right: 10px; font-size: 18px;
}
.person-card h3 {
  font-family: var(--font-display);
  font-weight: 800; font-size: clamp(28px, 3vw, 40px);
  line-height: 1.05; letter-spacing: -0.005em;
  margin-top: var(--space-3);
}
.person-card h3 .dot { color: var(--terracotta); }
.person-card .body { font-size: 16px; line-height: 1.7; max-width: 64ch; }
.person-card .body p + p { margin-top: var(--space-4); }
.person-card .body em { font-family: var(--font-display); font-style: italic; font-weight: 600; }
@media (max-width: 900px) { .person-card { grid-template-columns: 1fr; gap: var(--space-3); } }

/* ─── PROCESS ─────────────────────────────────────────────── */
.process {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  margin-top: var(--space-7);
  border-top: 1px solid var(--line-strong);
}
.process-step {
  padding: var(--space-7) var(--space-5) var(--space-7) 0;
  border-right: 1px solid var(--line-strong);
  display: grid; gap: var(--space-4); align-content: start;
}
.process-step:last-child { border-right: 0; padding-right: 0; }
.process-step .step-head {
  display: flex; gap: 14px; align-items: baseline;
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--bone-deep);
}
.process-step .step-head .n { font-family: var(--font-display); font-weight: 800; font-size: 22px; color: var(--terracotta); letter-spacing: -0.01em; }
.process-step h3 {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(28px, 2.6vw, 40px);
  line-height: 1.05;
  letter-spacing: -0.005em;
  color: var(--bone);
}
.process-step h3 .dot { color: var(--terracotta); }
.process-step p {
  font-family: var(--font-mono);
  font-size: 14px; line-height: 1.65;
  color: var(--bone); opacity: .82;
}
.process-foot {
  margin-top: var(--space-8);
  font-family: var(--font-display);
  font-size: clamp(22px, 2.2vw, 30px);
  font-style: italic; line-height: 1.3;
  max-width: 48ch;
  color: var(--bone);
}
@media (max-width: 900px) { .process { grid-template-columns: 1fr; } .process-step { border-right: 0; border-bottom: 1px solid var(--line-strong); padding: var(--space-6) 0; } }

/* ─── YOUR MOVE ───────────────────────────────────────────── */
.move {
  position: relative;
  overflow: hidden;
  padding: var(--space-10) 0;
}
.move .wrap { position: relative; z-index: 2; }
.move-headline {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: clamp(72px, 12vw, 200px);
  line-height: 0.92;
  letter-spacing: -0.025em;
  margin-bottom: var(--space-7);
}
.move-headline .dot { color: var(--ink); }
.move-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-9);
  align-items: start;
}
.move-grid p {
  font-size: 17px; line-height: 1.7; color: var(--ink);
  max-width: 52ch;
}
.move-grid p + p { margin-top: var(--space-5); }
.move-grid .closer {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(22px, 2.4vw, 32px);
  font-weight: 600;
  line-height: 1.3;
  margin-bottom: var(--space-6);
}
.move-cta { margin-top: var(--space-7); display: inline-flex; }
.move-bg-mark {
  position: absolute;
  right: -8%; top: -18%;
  width: 80vh; max-width: 900px;
  opacity: 0.18;
  pointer-events: none;
  mix-blend-mode: multiply;
}
@media (max-width: 900px) { .move-grid { grid-template-columns: 1fr; gap: var(--space-6); } }

/* ─── TESTIMONIALS (placeholder) ──────────────────────────── */
.testimonials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-8);
}
.testimonial {
  border: 1px dashed rgba(22,20,20,.35);
  padding: var(--space-6);
  background: rgba(22,20,20,.04);
  display: grid; gap: var(--space-5);
  min-height: 220px;
}
.testimonial .quote {
  font-family: var(--font-display);
  font-size: 22px;
  line-height: 1.3;
  font-style: italic;
  color: rgba(22,20,20,.55);
}
.testimonial .att {
  font-family: var(--font-mono); font-size: 12px;
  color: rgba(22,20,20,.5);
  letter-spacing: 0.04em;
}
.testimonial .placeholder-tag {
  font-family: var(--font-mono);
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(22,20,20,.4);
}
@media (max-width: 900px) { .testimonials { grid-template-columns: 1fr; } }

/* ─── FOOTER ──────────────────────────────────────────────── */
.footer {
  padding: var(--space-8) 0 var(--space-7);
  background: var(--ink);
  color: var(--bone);
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--space-7);
  padding-bottom: var(--space-8);
  border-bottom: 1px solid var(--line-strong);
}
.footer .logo {
  font-family: var(--font-display);
  font-size: 56px; font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1;
}
.footer .logo .dot { color: var(--terracotta); }
.footer .col-label {
  font-family: var(--font-mono);
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--bone-deep); opacity: .7;
  margin-bottom: var(--space-4);
}
.footer .col a, .footer .col p {
  display: block;
  font-family: var(--font-mono); font-size: 14px;
  color: var(--bone); margin-bottom: 8px;
  transition: color .15s ease;
}
.footer .col a:hover { color: var(--terracotta); }
.footer-meta {
  margin-top: var(--space-6);
  display: flex; justify-content: space-between; gap: var(--space-5); flex-wrap: wrap;
  font-family: var(--font-mono); font-size: 12px;
  color: var(--bone-deep); opacity: .8;
  letter-spacing: 0.04em;
}
@media (max-width: 900px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer .logo { font-size: 40px; }
}
@media (max-width: 600px) { .footer-grid { grid-template-columns: 1fr; } }

/* ─── PRESS-IN ANIMATION ──────────────────────────────────── */
@media (prefers-reduced-motion: no-preference) {
  .reveal { opacity: 0; transform: translateY(12px); transition: opacity .6s ease, transform .6s cubic-bezier(.2,.0,.2,1); }
  .reveal.in { opacity: 1; transform: none; }
}


/* ============================================================
   V3 — Editorial revisions
   ============================================================ */

/* ─── NAV BRAND ─── "S." text mark with terracotta dot */
.nav-brand .nav-S {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 32px;
  line-height: 1;
  letter-spacing: -0.02em;
  display: inline-flex;
  align-items: baseline;
  color: currentColor;
}
.nav-brand .nav-S .dot { color: var(--terracotta); }
.nav.is-dark .nav-brand .nav-S { color: var(--bone); }
.nav.is-dark .nav-brand .nav-S .dot { color: var(--terracotta); }

/* ─── S WATERMARK — recurring structural element ───────────── */
.s-watermark {
  position: absolute;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  opacity: .07;
  width: 60vh;
  max-width: 720px;
  top: 50%;
  left: -8%;
  transform: translateY(-50%) rotate(-6deg);
}
.s-watermark img { display: block; width: 100%; }
.s-watermark-right { left: auto; right: -10%; transform: translateY(-50%) rotate(8deg); }
.s-watermark-tl { top: -8%; left: -6%; transform: rotate(-8deg); }
.s-watermark-br { top: auto; bottom: -10%; right: -8%; left: auto; transform: rotate(10deg); }
.s-bone .s-watermark { opacity: .065; }
.s-paper .s-watermark { opacity: .055; }
.s-ink .s-watermark { opacity: .05; filter: invert(1); }
.s-terracotta .s-watermark { opacity: .12; }
section { position: relative; overflow: hidden; }
section .wrap { position: relative; z-index: 2; }

/* ─── FOUR PATTERNS — editorial offset layout ─────────────── */
.problems-section { padding-bottom: var(--space-9); }
.patterns {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: pattern;
  display: grid;
  gap: 0;
  border-top: 1px solid var(--ink);
}
.pattern {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--space-7);
  padding: var(--space-7) 0;
  border-bottom: 1px solid var(--ink);
  align-items: center;
  position: relative;
}
.pattern .p-aside {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  padding-top: 0;
}
.pattern .p-num {
  font-family: var(--font-display);
  font-weight: 900;
  font-style: italic;
  font-size: clamp(56px, 7vw, 96px);
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: var(--ink);
}
.pattern .p-num .dot { color: var(--terracotta); }
.pattern .p-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.pattern .p-body { max-width: none; min-width: 0; }
.pattern .p-head {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 35px;
  line-height: 1.15;
  letter-spacing: -0.01em;
  margin-bottom: var(--space-4);
}
.pattern .p-head em {
  font-style: italic;
  font-weight: 700;
  color: var(--terracotta);
}
.pattern .p-head .dot { color: var(--terracotta); }
.pattern .p-body p {
  font-family: var(--font-mono);
  font-size: 15px;
  line-height: 1.65;
  color: var(--fg);
  max-width: none;
  white-space: nowrap;
  margin: 0;
}
/* Subtle hover */
.pattern { transition: background 0.35s ease; }
.pattern:hover { background: rgba(22,20,20,0.025); }

@media (max-width: 900px) {
  .pattern {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
  .pattern .p-num { font-size: 56px; }
  .pattern .p-head { font-size: 26px; }
}

.patterns-foot {
  margin-top: var(--space-8);
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 600;
  line-height: 1.25;
  max-width: 22ch;
  color: var(--ink);
}
.patterns-foot em { color: var(--terracotta); font-style: italic; }
.patterns-foot .dot { color: var(--terracotta); }

/* ─── CHOREOGRAPHER PORTRAIT ──────────────────────────────── */
.cho-portrait {
  position: relative;
  margin: 0 0 var(--space-7);
  width: 100%;
}
.cho-portrait-frame {
  position: relative;
  background: transparent;
  border: none;
  padding: 0;
}
.cho-portrait-frame img {
  display: block;
  width: 100%;
  height: auto;
}

/* ─── FOOTER SOCIALS ──────────────────────────────────────── */
.footer-socials {
  display: inline-flex;
  gap: 14px;
  margin-top: var(--space-4);
}
.footer-social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 1px solid var(--line-strong);
  color: var(--bone);
  border-radius: 0;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
}
.footer-social:hover {
  background: var(--terracotta);
  color: var(--ink);
  border-color: var(--terracotta);
  transform: translateY(-2px);
}
.footer-social svg { display: block; }
.footer .col .footer-socials a { margin-bottom: 0; }

/* ─── HERO EYEBROW: remove leading dash visual (text already cleaned) */
/* (no-op — text edit was sufficient) */

/* ─── SECTION DIVIDER GLYPH: small S between sections ────── */
/* Optional small ornament; reserve class but no auto-use */
.s-divider {
  display: flex; justify-content: center; padding: var(--space-6) 0;
  background: var(--paper);
}
.s-divider .s-glyph {
  width: 28px; height: 28px;
  background-color: var(--terracotta);
  -webkit-mask: url("logo-S-mark-black.png") no-repeat center / contain;
          mask: url("logo-S-mark-black.png") no-repeat center / contain;
}

/* ─── PARALLAX TARGET for watermarks ──────────────────────── */
.s-watermark { transition: transform 0.05s linear; }
