/* ============================================================
   LAPA — Sistema visual (monocromático)
   ============================================================ */

:root {
  --ink: #0a0a0a;
  --paper: #f4f4f5;
  --paper-dim: #d9d9dd;
  --gray-1: #8a8a8f;
  --gray-2: #5a5a5f;
  --line: rgba(244, 244, 245, 0.14);
  --line-ink: rgba(10, 10, 10, 0.12);

  --display: "Space Grotesk", "Helvetica Neue", Arial, sans-serif;
  --mono: "Space Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  --pad: clamp(20px, 5vw, 80px);
  --maxw: 1680px;

  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

* { margin: 0; padding: 0; box-sizing: border-box; }

html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }

body {
  font-family: var(--display);
  background: var(--ink);
  color: var(--paper);
  overflow-x: hidden;
  font-feature-settings: "ss01" 1, "ss02" 1;
}

/* ---------- Temas por seção (preto / branco intercalados) ---------- */
/* Remap dos nomes existentes: em seções claras, "paper" vira tinta e "ink" vira papel.
   Assim todo o CSS de seção continua válido sem reescrever cada regra. */
.theme-light {
  --paper: #0a0a0a;
  --paper-dim: #3a3a3f;
  --ink: #f4f4f5;
  --gray-1: #6f6f74;
  --gray-2: #9a9a9f;
  --line: rgba(10, 10, 10, 0.12);
  background: #f4f4f5;
  color: #0a0a0a;
}
.theme-dark { background: #0a0a0a; color: #f4f4f5; }
section, footer { position: relative; }

/* Lenis */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-stopped { overflow: hidden; }

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

a { color: inherit; text-decoration: none; }

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

/* ---------- Cursor customizado ---------- */
@media (hover: hover) and (pointer: fine) {
  body { cursor: none; }
  a, button, [data-hover] { cursor: none; }
}
.cursor {
  position: fixed; top: 0; left: 0;
  width: 9px; height: 9px;
  border-radius: 50%;
  background: var(--paper);
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  mix-blend-mode: difference;
  will-change: transform;
}
.cursor-ring {
  position: fixed; top: 0; left: 0;
  width: 46px; height: 46px;
  border: 1px solid var(--paper);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%) scale(1);
  mix-blend-mode: difference;
  will-change: transform;
}
/* disco “ver projeto” — sólido, sem blend, texto sempre legível */
.cursor-cta {
  position: fixed; top: 0; left: 0;
  width: 96px; height: 96px;
  border-radius: 50%;
  background: #f4f4f5;
  color: #0a0a0a;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
  z-index: 9997;
  opacity: 0;
  transform: translate(-50%, -50%) scale(0);
  will-change: transform, opacity;
}
.cursor-cta span {
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  text-align: center;
}
@media (hover: none), (pointer: coarse) {
  .cursor, .cursor-ring, .cursor-cta { display: none; }
}

/* canvas de areia do preloader */
.loader-sand {
  position: absolute; inset: 0; width: 100%; height: 100%;
  z-index: 0; pointer-events: none; display: block;
}
.loader-word, .loader-count, .loader-bar { position: relative; z-index: 1; }

/* ---------- Grão / atmosfera ---------- */
.grain {
  position: fixed; inset: 0; z-index: 9990;
  pointer-events: none; opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- PRELOADER ---------- */
.loader {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--ink); color: var(--paper);
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: var(--pad);
  overflow: hidden;
}
.loader-word {
  font-weight: 700; line-height: 0.8; letter-spacing: -0.04em;
  font-size: clamp(80px, 20vw, 320px);
  display: flex;
}
.loader-word .lch { display: inline-block; transform: translateY(110%); }
.loader-count {
  font-family: var(--mono); font-size: clamp(14px, 1.4vw, 20px);
  letter-spacing: 0.08em; align-self: flex-end; padding-bottom: 0.6em;
}
.loader-bar {
  position: absolute; left: var(--pad); right: var(--pad); bottom: calc(var(--pad) - 1px);
  height: 1px; background: var(--line);
}
.loader-bar i { position: absolute; inset: 0; width: 0%; background: var(--paper); display: block; }
/* cortina que sobe revelando o site */
.curtain { position: fixed; inset: 0; z-index: 9995; background: var(--ink); transform: translateY(0); pointer-events: none; }

/* ---------- Liquid glass (desfoque progressivo fixo) ---------- */
.glass {
  position: fixed; left: 0; right: 0;
  z-index: 150;            /* acima do conteúdo, abaixo da nav (200) */
  pointer-events: none;
}
.glass > div {
  position: absolute; inset: 0;
  -webkit-backface-visibility: hidden; backface-visibility: hidden;
}
.glass-top { top: 0; height: clamp(64px, 10vh, 104px); }
.glass-bottom { bottom: 0; height: clamp(72px, 12vh, 128px); transition: opacity 0.5s var(--ease); }
.glass-bottom.glass-off { opacity: 0; }

/* TOPO — blur mais forte na borda superior, suavizando para baixo */
.glass-top > div:nth-child(1) { backdrop-filter: blur(6px) saturate(1.3); -webkit-backdrop-filter: blur(6px) saturate(1.3);
  -webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 18%, transparent 42%); mask-image: linear-gradient(to bottom, #000 0%, #000 18%, transparent 42%); }
.glass-top > div:nth-child(2) { backdrop-filter: blur(3.5px); -webkit-backdrop-filter: blur(3.5px);
  -webkit-mask-image: linear-gradient(to bottom, #000 8%, #000 34%, transparent 58%); mask-image: linear-gradient(to bottom, #000 8%, #000 34%, transparent 58%); }
.glass-top > div:nth-child(3) { backdrop-filter: blur(1.8px); -webkit-backdrop-filter: blur(1.8px);
  -webkit-mask-image: linear-gradient(to bottom, #000 30%, #000 56%, transparent 78%); mask-image: linear-gradient(to bottom, #000 30%, #000 56%, transparent 78%); }
.glass-top > div:nth-child(4) { backdrop-filter: blur(0.8px); -webkit-backdrop-filter: blur(0.8px);
  -webkit-mask-image: linear-gradient(to bottom, #000 52%, #000 76%, transparent 100%); mask-image: linear-gradient(to bottom, #000 52%, #000 76%, transparent 100%); }

/* BASE — espelhado: blur mais forte na borda inferior, suavizando para cima */
.glass-bottom > div:nth-child(1) { backdrop-filter: blur(6px) saturate(1.3); -webkit-backdrop-filter: blur(6px) saturate(1.3);
  -webkit-mask-image: linear-gradient(to top, #000 0%, #000 18%, transparent 42%); mask-image: linear-gradient(to top, #000 0%, #000 18%, transparent 42%); }
.glass-bottom > div:nth-child(2) { backdrop-filter: blur(3.5px); -webkit-backdrop-filter: blur(3.5px);
  -webkit-mask-image: linear-gradient(to top, #000 8%, #000 34%, transparent 58%); mask-image: linear-gradient(to top, #000 8%, #000 34%, transparent 58%); }
.glass-bottom > div:nth-child(3) { backdrop-filter: blur(1.8px); -webkit-backdrop-filter: blur(1.8px);
  -webkit-mask-image: linear-gradient(to top, #000 30%, #000 56%, transparent 78%); mask-image: linear-gradient(to top, #000 30%, #000 56%, transparent 78%); }
.glass-bottom > div:nth-child(4) { backdrop-filter: blur(0.8px); -webkit-backdrop-filter: blur(0.8px);
  -webkit-mask-image: linear-gradient(to top, #000 52%, #000 76%, transparent 100%); mask-image: linear-gradient(to top, #000 52%, #000 76%, transparent 100%); }

/* ---------- Layout helpers ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding-inline: var(--pad); }
.eyebrow {
  font-family: var(--mono);
  font-size: clamp(10px, 0.85vw, 12px);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gray-1);
}
.section-tag {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--gray-1);
}
.section-tag::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--paper); }

/* ---------- Top nav ---------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: clamp(18px, 2vw, 30px) var(--pad);
  mix-blend-mode: difference;
}
.nav .logo { height: 24px; width: auto; filter: invert(1); }
.nav-center { display: flex; gap: clamp(18px, 3vw, 44px); align-items: center; }
.nav-right { display: flex; gap: 20px; align-items: center; }
.nav-link {
  font-family: var(--mono);
  font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  position: relative;
}
.nav-link::after {
  content: ""; position: absolute; left: 0; bottom: -4px; height: 1px; width: 100%;
  background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .4s var(--ease);
}
.nav-link:hover::after { transform: scaleX(1); }
.nav-link .dot { color: transparent; margin-right: 8px; display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: #1fd65f; box-shadow: 0 0 6px #1fd65f, 0 0 12px rgba(31,214,95,0.7); animation: blink 1.6s ease-in-out infinite; vertical-align: middle; }
@keyframes pulse { 0%,100%{opacity:1;} 50%{opacity:.3;} }
@keyframes blink { 0%,100%{ opacity:1; box-shadow: 0 0 6px #1fd65f, 0 0 12px rgba(31,214,95,0.7); } 50%{ opacity:.35; box-shadow: 0 0 2px #1fd65f, 0 0 4px rgba(31,214,95,0.3); } }
.clock { font-family: var(--mono); font-size: 12px; letter-spacing: 0.1em; color: var(--gray-1); }
/* ---------- Seletor de idioma ---------- */
.lang { display: flex; align-items: center; gap: 8px; }
.lang-sep { font-family: var(--mono); font-size: 11px; color: var(--gray-1); opacity: .5; }
.lang-btn {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  background: none; border: 0; padding: 0; line-height: 1;
  color: var(--gray-1); cursor: pointer; position: relative;
  transition: color .35s var(--ease);
}
.lang-btn:hover { color: var(--paper); }
.lang-btn.active { color: var(--paper); }
.lang-btn.active::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -5px; height: 1px; background: currentColor;
}
@media (max-width: 720px){ .nav-center{ display: none; } .clock{ display:none; } }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex; flex-direction: column; justify-content: center;
  padding-block: 120px 0;
}
/* canvas de areia (calçadão de Copacabana) */
.sand {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  z-index: 1; pointer-events: none;
  display: block;
}
/* bokeh removido — substituído por liquid glass fixo (ver .glass) */
.hero-head, .hero-word, .hero-foot { position: relative; z-index: 2; }
.hero-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 24px; flex-wrap: wrap;
}
.hero-meta { max-width: 40ch; }
.hero-meta p { font-size: clamp(15px, 1.1vw, 19px); line-height: 1.4; color: var(--paper-dim); }
.hero-pitch { font-size: clamp(21px, 2vw, 32px) !important; line-height: 1.16 !important; font-weight: 600; letter-spacing: -0.015em; color: var(--paper) !important; text-wrap: balance; }
.hero-sub { margin-top: 14px; max-width: 36ch; font-size: clamp(13px, 1vw, 16px) !important; line-height: 1.45 !important; color: var(--paper-dim); }
.hero-cta {
  margin-top: 24px; display: inline-flex; align-items: center; gap: 0.55em;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--ink); background: var(--paper); padding: 13px 22px; border-radius: 6px;
  transition: transform .55s var(--ease), background .4s var(--ease);
}
.hero-cta .arrow { transition: transform .55s var(--ease); }
.hero-cta:hover { background: #fff; }
.hero-cta:hover .arrow { transform: translate(0.18em, -0.18em); }
.hero-word {
  font-weight: 700;
  font-size: clamp(120px, 33vw, 560px);
  line-height: 0.78;
  letter-spacing: -0.04em;
  margin-top: clamp(10px, 4vw, 40px);
  display: flex;
  user-select: none;
}
.hero-word .ch {
  display: inline-block;
  will-change: transform;
  transform: translate3d(0,0,0);
  position: relative;
}
.hero-foot {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 24px; flex-wrap: wrap;
  margin-top: clamp(24px, 4vw, 52px);
  padding-bottom: clamp(24px, 4vw, 48px);
}
.hero-foot .eyebrow { max-width: 24ch; line-height: 1.7; }
.scroll-cue { display: flex; align-items: center; gap: 12px; }
.scroll-cue .bar {
  width: 1px; height: 54px; background: var(--line);
  position: relative; overflow: hidden;
}
.scroll-cue .bar::after {
  content: ""; position: absolute; inset: 0;
  background: var(--paper);
  animation: cue 2.4s var(--ease) infinite;
}
@keyframes cue { 0% { transform: translateY(-100%);} 50%{transform:translateY(0);} 100%{transform:translateY(100%);} }

/* ---------- Manifesto ---------- */
.manifesto { padding-block: clamp(120px, 18vh, 260px); }
.manifesto .section-tag { margin-bottom: clamp(36px, 6vw, 80px); }
.manifesto-lead {
  font-size: clamp(30px, 5.2vw, 92px);
  line-height: 1.04;
  letter-spacing: -0.02em;
  font-weight: 500;
  max-width: 18ch;
}
.manifesto-lead .w { display: inline-block; opacity: 0.12; will-change: opacity, transform; }
.manifesto-body {
  margin-top: clamp(28px, 3.6vw, 52px);
  font-size: clamp(17px, 1.45vw, 23px);
  line-height: 1.46;
  letter-spacing: 0;
  font-weight: 400;
  max-width: 46ch;
  color: rgba(10,10,10,0.6);
}
.manifesto-body .w { display: inline-block; opacity: 0.12; will-change: opacity, transform; }
.manifesto-sign {
  margin-top: clamp(40px, 6vw, 90px);
  font-family: var(--mono); font-size: 13px; letter-spacing: 0.1em;
  color: var(--gray-1); text-transform: uppercase;
}

/* ---------- Serviços ---------- */
.services { padding-block: clamp(40px, 6vw, 80px) clamp(80px, 12vw, 160px); }
.services .section-tag { margin-bottom: clamp(30px, 4vw, 60px); }
.svc-row {
  position: relative;
  display: grid; grid-template-columns: 60px 1fr auto; gap: 24px; align-items: center;
  padding: clamp(22px, 3vw, 40px) 0;
  border-top: 1px solid var(--line);
  cursor: pointer;
}
.svc-row:last-child { border-bottom: 1px solid var(--line); }
.svc-row .svc-n { font-family: var(--mono); font-size: 13px; color: var(--gray-1); }
.svc-row .svc-name {
  font-size: clamp(26px, 4vw, 60px); font-weight: 500; letter-spacing: -0.02em;
  transition: transform .5s var(--ease), opacity .4s; transform-origin: left;
}
.svc-row .svc-desc {
  font-size: clamp(14px, 1.1vw, 17px); color: var(--gray-1); max-width: 36ch; line-height: 1.5;
  opacity: 0; transform: translateX(-12px); transition: opacity .5s var(--ease), transform .5s var(--ease);
  text-align: right; justify-self: end;
}
.svc-row:hover .svc-name { transform: translateX(18px); }
.svc-row:hover .svc-desc { opacity: 1; transform: translateX(0); }
.svc-row .svc-arrow { font-size: 1.4em; opacity: 0; transition: opacity .4s, transform .5s var(--ease); transform: rotate(-30deg); }
.svc-row:hover .svc-arrow { opacity: 1; transform: rotate(0); }
@media (max-width: 720px){
  .svc-row { grid-template-columns: 36px 1fr; }
  .svc-row .svc-desc { display: none; }
}

/* ---------- Portfólio ---------- */
.work { padding-block: clamp(40px, 6vw, 80px) clamp(80px, 12vw, 180px); }
.work-head {
  display: flex; justify-content: space-between; align-items: baseline;
  border-top: 1px solid var(--line);
  padding-top: 22px; margin-bottom: clamp(40px, 6vw, 90px);
}
.work-head h2 {
  font-size: clamp(28px, 4vw, 64px); font-weight: 600; letter-spacing: -0.02em;
}
.work-head .count { font-family: var(--mono); font-size: 13px; color: var(--gray-1); }

.grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(28px, 4vw, 64px) clamp(20px, 3vw, 48px);
}
.project { position: relative; display: block; }
/* layout assimétrico */
.project:nth-child(1) { grid-column: 1 / 7; }
.project:nth-child(2) { grid-column: 8 / 13; margin-top: clamp(60px, 12vw, 180px); }
.project:nth-child(3) { grid-column: 2 / 7; }
.project:nth-child(4) { grid-column: 8 / 12; margin-top: clamp(40px, 8vw, 120px); }
.project:nth-child(5) { grid-column: 1 / 6; margin-top: clamp(20px, 4vw, 60px); }
.project:nth-child(6) { grid-column: 7 / 13; }
.project:nth-child(n+7) { grid-column: span 6; }

.project-media {
  position: relative; overflow: hidden;
  background: #161616;
  aspect-ratio: 3 / 4;
}
.project:nth-child(even) .project-media { aspect-ratio: 4 / 5; }
.project-media img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(1) contrast(1.02);
  transform: scale(1.02);
  will-change: transform, filter;
  transition: filter .6s var(--ease);
}
.project:hover .project-media img { filter: grayscale(0) contrast(1.03); }
.project-num {
  position: absolute; top: 16px; left: 16px;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.1em;
  mix-blend-mode: difference; color: #fff; z-index: 2;
}
.project-info {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 16px; margin-top: 18px;
  border-top: 1px solid var(--line); padding-top: 14px;
}
.project-info h3 { font-size: clamp(20px, 2vw, 30px); font-weight: 500; letter-spacing: -0.01em; }
.project-info .disc { font-family: var(--mono); font-size: 12px; color: var(--gray-1); margin-top: 4px; }
.project-info .year { font-family: var(--mono); font-size: 13px; color: var(--gray-1); }

/* ---------- Case-study overlay ---------- */
.case {
  position: fixed; inset: 0; z-index: 9000;
  background: var(--ink);
  overflow-y: auto; overflow-x: hidden;
  opacity: 0; visibility: hidden;
  transition: opacity .5s var(--ease), visibility .5s;
}
.case.on { opacity: 1; visibility: visible; }
.case-inner { min-height: 100%; }
.case-top {
  position: sticky; top: 0; z-index: 5;
  display: flex; justify-content: space-between; align-items: center;
  padding: clamp(18px, 2vw, 28px) var(--pad);
  background: linear-gradient(var(--ink), rgba(10,10,10,0.6) 70%, transparent);
  mix-blend-mode: normal;
}
.case-close {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 10px; border: 1px solid var(--line);
  padding: 10px 18px; border-radius: 100px; background: rgba(244,244,245,0.02);
}
.case-close:hover { background: var(--paper); color: var(--ink); }
.case-hero { padding: clamp(20px, 5vw, 60px) var(--pad) clamp(40px, 6vw, 80px); }
.case-meta { display: flex; gap: 28px; flex-wrap: wrap; font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--gray-1); margin-bottom: clamp(24px,3vw,40px); }
.case-title { font-size: clamp(48px, 11vw, 200px); font-weight: 700; letter-spacing: -0.04em; line-height: 0.85; }
.case-sub { display: flex; justify-content: space-between; gap: 40px; flex-wrap: wrap; margin-top: clamp(28px, 4vw, 56px); align-items: flex-start; }
.case-summary { font-size: clamp(20px, 2vw, 32px); line-height: 1.35; font-weight: 400; max-width: 24ch; letter-spacing: -0.01em; }
.case-tags { display: flex; flex-wrap: wrap; gap: 10px; align-content: flex-start; }
.case-tag { font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em; border: 1px solid var(--line); border-radius: 100px; padding: 9px 16px; color: var(--paper-dim); }
.case-gallery { display: flex; flex-direction: column; gap: clamp(16px, 2vw, 28px); padding: 0 var(--pad) clamp(60px, 8vw, 120px); }
.case-shot { width: 100%; overflow: hidden; background: #161616; }
.case-shot img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1); }
.case-shot.tall { aspect-ratio: 16/10; }
.case-duo { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(16px, 2vw, 28px); }
.case-duo .case-shot { aspect-ratio: 3/4; }
.case-foot { border-top: 1px solid var(--line); padding: clamp(40px,5vw,70px) var(--pad) clamp(60px,8vw,100px); display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap; }
.case-foot .nxt { font-size: clamp(28px, 5vw, 80px); font-weight: 600; letter-spacing: -0.02em; }
.case-foot .nxt small { display:block; font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gray-1); font-weight: 400; margin-bottom: 12px; }
@media (max-width: 720px){ .case-duo { grid-template-columns: 1fr; } }

/* ---------- Equipe ---------- */
.team { padding-block: clamp(60px, 9vw, 140px); }
.team .section-tag { margin-bottom: clamp(40px, 5vw, 80px); }
.team-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4vw, 64px); }
@media (max-width: 720px){ .team-grid { grid-template-columns: 1fr; } }
.member { position: relative; }
.member-photo { position: relative; max-width: 460px; }
.member-media { position: relative; overflow: hidden; aspect-ratio: 4/5; background: #161616; }
.member-media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.04); transform: scale(1.04); transition: transform 1.1s var(--ease), filter .6s var(--ease); will-change: transform; }
.member:hover .member-media img { transform: scale(1); filter: grayscale(0); }
.member-name { position: absolute; left: 0; bottom: 0; padding: 22px; z-index: 2; mix-blend-mode: difference; }
.member-name h3 { font-size: clamp(28px, 3.4vw, 52px); font-weight: 600; letter-spacing: -0.02em; line-height: 0.95; color: #fff; white-space: nowrap; }
.member-name .role { font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: #fff; margin-top: 10px; }
.member-bio { margin-top: clamp(20px, 2.2vw, 30px); font-size: clamp(15px, 1.2vw, 18px); line-height: 1.5; color: var(--paper-dim); max-width: 38ch; border-top: 1px solid var(--line); padding-top: 16px; }

/* ---------- Marquee clientes ---------- */
.clients { padding-block: clamp(60px, 10vw, 140px); border-block: 1px solid var(--line); overflow: hidden; }
.clients .section-tag { padding-inline: var(--pad); margin-bottom: clamp(34px, 5vw, 64px); }
.marquee { display: flex; width: max-content; will-change: transform; }
.marquee-track { display: flex; align-items: center; }
.marquee-item {
  font-size: clamp(48px, 9vw, 150px); font-weight: 600; letter-spacing: -0.03em;
  padding-inline: clamp(28px, 4vw, 70px);
  white-space: nowrap; color: var(--paper);
}
.marquee-item .star { display: inline-block; margin-left: clamp(28px, 4vw, 70px); color: var(--gray-2); font-size: 0.4em; vertical-align: middle; }

/* ---------- Footer ---------- */
.footer { padding-block: clamp(80px, 12vw, 200px) clamp(40px, 5vw, 70px); }
.footer .cta-tag { font-family: var(--mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gray-1); margin-bottom: clamp(24px,3vw,40px); display: block; }
.footer-cta {
  font-size: clamp(40px, 9vw, 180px); font-weight: 700; letter-spacing: -0.03em;
  line-height: 0.9; margin-bottom: clamp(50px, 8vw, 120px);
}
.footer-cta a { display: inline-flex; align-items: center; gap: 0.2em; }
.footer-cta .arrow { font-size: 0.5em; transform: translateY(0.06em); transition: transform .5s var(--ease); }
.footer-cta a:hover .arrow { transform: translate(0.1em, -0.1em); }
.footer-grid {
  display: grid; grid-template-columns: repeat(12, 1fr);
  gap: 32px 24px; border-top: 1px solid var(--line); padding-top: clamp(34px, 4vw, 60px);
}
.footer-col { grid-column: span 3; }
.footer-col:first-child { grid-column: 1 / 4; }
.footer-col h4 { font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gray-1); margin-bottom: 18px; }
.footer-col a, .footer-col p { font-size: clamp(16px, 1.3vw, 20px); line-height: 1.6; display: inline-block; }
.footer-col a { position: relative; }
.footer-col a::after { content:""; position:absolute; left:0; bottom:-2px; height:1px; width:100%; background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .4s var(--ease); }
.footer-col a:hover::after { transform: scaleX(1); }
.mag-btn {
  display: inline-flex; align-items: center; gap: 12px;
  border: 1px solid var(--line); border-radius: 100px;
  padding: 16px 26px; font-size: 15px;
  will-change: transform;
}
.mag-btn .mag-inner { display: inline-flex; align-items: center; gap: 12px; will-change: transform; }
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px; flex-wrap: wrap;
  margin-top: clamp(60px, 10vw, 130px);
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em;
  color: var(--gray-1); text-transform: uppercase;
}

/* ---------- Reveal util ---------- */
.rise { opacity: 0; transform: translateY(40px); }

@media (max-width: 860px) {
  .grid { gap: 48px 16px; }
  .project:nth-child(n) { grid-column: 1 / 13 !important; margin-top: 0 !important; }
  .footer-col, .footer-col:first-child { grid-column: span 6; }
  .hero-word { font-size: clamp(96px, 40vw, 320px); }
}
@media (max-width: 540px) {
  .footer-col, .footer-col:first-child { grid-column: 1 / 13; }
  .case-meta { gap: 16px; }
}

@media (prefers-reduced-motion: reduce) {
  .rise, .manifesto-body .w, .manifesto-lead .w, .hero-word .ch { opacity: 1 !important; transform: none !important; }
  .scroll-cue .bar::after { animation: none; }
  .loader { display: none; }
  .curtain { display: none; }
}
