/* ===================================================================
   Gabriel Wickbold — Studio Site
   Cinematic, editorial, dark/light
   =================================================================== */

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

:root {
  /* dark (default) */
  --bg: #0a0908;
  --bg-2: #121110;
  --bg-3: #1a1918;
  --fg: #f2ece3;
  --fg-dim: #9a938a;
  --fg-faint: #524c44;
  --accent: #b03c3c;       /* from Código Mãe logo */
  --accent-2: #d98b5f;     /* warm film */
  --hair: rgba(242,236,227,.10);
  --hair-strong: rgba(242,236,227,.22);
  --overlay: rgba(10,9,8,.85);

  --f-display: "Fraunces", "Times New Roman", serif;
  --f-body: "Inter", system-ui, sans-serif;
  --f-mono: "JetBrains Mono", monospace;

  --ease: cubic-bezier(.2,.8,.2,1);
  --ease-cine: cubic-bezier(.76,0,.24,1);
}

/* body locked during intro */
body.is-loading { overflow: hidden; height: 100vh; }

/* =========== INTRO LOADER =========== */
.intro {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.intro.done { pointer-events: none; }

.intro-bg {
  position: absolute; inset: 0; opacity: .18;
}
.intro-bg .ifloat {
  position: absolute;
  background-size: cover; background-position: center;
  filter: grayscale(.6) contrast(.9);
  will-change: transform;
}

.intro-logo {
  position: relative; z-index: 2;
  width: min(640px, 78vw);
  aspect-ratio: 1024 / 500;
  display: flex; align-items: center; justify-content: center;
}
.intro-logo svg {
  width: 100%; height: 100%;
  overflow: visible;
}
.intro-logo svg path {
  fill: transparent;
  stroke: #ffffff;
  stroke-width: 2.25;
  stroke-linejoin: round;
  stroke-linecap: round;
  paint-order: stroke fill;
  stroke-dasharray: var(--len, 2400);
  stroke-dashoffset: var(--len, 2400);
  filter: drop-shadow(0 0 14px rgba(255,255,255,.18));
}
.intro-logo.filled svg path { fill: #ffffff !important; }
.intro-logo svg > rect[fill="white"] { display:none; }

.intro-status {
  position: absolute; left: 36px; right: 36px; bottom: 32px; z-index: 2;
  display: flex; justify-content: space-between; gap: 24px;
  font: 400 10px/1 var(--f-mono); letter-spacing: .22em; color: var(--fg-faint); text-transform: uppercase;
  border-top: 1px solid var(--hair); padding-top: 14px;
}



[data-theme="light"] {
  --bg: #f4efe6;
  --bg-2: #ebe4d7;
  --bg-3: #ddd4c2;
  --fg: #161412;
  --fg-dim: #5b5449;
  --fg-faint: #a59c8d;
  --hair: rgba(22,20,18,.14);
  --hair-strong: rgba(22,20,18,.28);
  --overlay: rgba(244,239,230,.92);
  --accent: #8a2b2b;
}

html,body { background:var(--bg); color:var(--fg); font-family:var(--f-body); font-size:15px; line-height:1.55; -webkit-font-smoothing:antialiased; }
body { overflow-x:hidden; cursor:none; transition:background .6s var(--ease), color .6s var(--ease); }

img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { background:none; border:none; color:inherit; font:inherit; cursor:none; }

::selection { background:var(--accent); color:#f2ece3; }

/* =========== FILM GRAIN =========== */
.grain {
  position:fixed; inset:-50%;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .35 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  pointer-events:none; z-index:9000;
  opacity:.28; mix-blend-mode:overlay;
  animation: grain 1.1s steps(6) infinite;
}
[data-theme="light"] .grain { opacity:.18; mix-blend-mode:multiply; }
@keyframes grain {
  0%   { transform: translate(0,0); }
  20%  { transform: translate(-2%,1%); }
  40%  { transform: translate(1%,-2%); }
  60%  { transform: translate(-1%,2%); }
  80%  { transform: translate(2%,-1%); }
  100% { transform: translate(0,0); }
}

.vignette {
  position:fixed; inset:0; pointer-events:none; z-index:8999;
  background: radial-gradient(120% 80% at 50% 50%, transparent 55%, rgba(0,0,0,.55) 100%);
}
[data-theme="light"] .vignette { background: radial-gradient(120% 80% at 50% 50%, transparent 55%, rgba(0,0,0,.15) 100%); }

/* =========== CURSOR =========== */
.cursor { position:fixed; top:0; left:0; z-index:10000; pointer-events:none; mix-blend-mode:difference; }
.cursor-dot  { position:absolute; width:4px; height:4px; border-radius:50%; background:#fff; transform:translate(-50%,-50%); }
.cursor-ring { position:absolute; width:28px; height:28px; border-radius:50%; border:1px solid rgba(255,255,255,.55); transform:translate(-50%,-50%); transition: width .25s var(--ease), height .25s var(--ease), border-color .25s var(--ease); }
.cursor.is-hover .cursor-ring { width:60px; height:60px; border-color:#fff; }
.cursor.is-view  .cursor-ring { width:80px; height:80px; background:rgba(255,255,255,.04); }
.cursor-label { position:absolute; transform:translate(-50%,-50%); font:500 10px/1 var(--f-mono); text-transform:uppercase; letter-spacing:.14em; color:#fff; opacity:0; transition:opacity .25s; white-space:nowrap; }
.cursor.is-hover .cursor-label { opacity:1; }

/* =========== NAV =========== */
.nav {
  position:fixed; top:0; left:0; right:0; z-index:500;
  display:flex; align-items:center; justify-content:space-between;
  padding: 22px 36px;
  mix-blend-mode: normal;
}
.nav::before {
  content:""; position:absolute; inset:0;
  background: linear-gradient(to bottom, var(--bg) 0%, transparent 100%);
  opacity:.6; z-index:-1; pointer-events:none;
}
.nav-logo img { height:22px; width:auto; filter: brightness(0) invert(1); transition: filter .6s var(--ease); }
[data-theme="light"] .nav-logo img { filter: brightness(0) invert(0); }

.nav-links { display:flex; gap:32px; }
.nav-links a {
  font: 500 11px/1 var(--f-mono); text-transform:uppercase; letter-spacing:.18em;
  color:var(--fg-dim); position:relative; padding:6px 0;
  transition: color .3s var(--ease);
}
.nav-links a:hover { color: var(--fg); }
.nav-links a::after {
  content:""; position:absolute; left:0; bottom:0; width:100%; height:1px;
  background: var(--fg); transform: scaleX(0); transform-origin: right center;
  transition: transform .5s var(--ease-cine);
}
.nav-links a:hover::after { transform: scaleX(1); transform-origin: left center; }

.nav-right { display:flex; gap:20px; align-items:center; }
.lang-btn { font:500 11px/1 var(--f-mono); letter-spacing:.18em; color:var(--fg-dim); }
.lang-btn:hover { color:var(--fg); }

.theme-btn { display:flex; align-items:center; }
.theme-track {
  display:inline-block; width:40px; height:20px; border-radius:999px;
  border:1px solid var(--hair-strong); position:relative;
}
.theme-thumb {
  position:absolute; top:2px; left:2px; width:14px; height:14px; border-radius:50%;
  background: var(--fg); transition: transform .5s var(--ease-cine);
}
[data-theme="light"] .theme-thumb { transform: translateX(20px); }

/* =========== HERO 2 — layer.com inspired =========== */
.hero2 {
  position: relative;
  min-height: 100vh; width: 100%;
  display: grid; grid-template-columns: 1fr 1fr;
  padding: 140px 36px 80px; gap: 60px;
  border-bottom: 1px solid var(--hair);
}
.hero2-left {
  display: flex; flex-direction: column; justify-content: center;
  padding-right: 40px;
}
.hero2-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font: 500 11px/1 var(--f-mono); text-transform: uppercase; letter-spacing: .22em;
  color: var(--fg-dim); margin-bottom: 40px;
}
.hero2-eyebrow .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); box-shadow: 0 0 14px var(--accent);
  animation: pulse 1.8s ease-in-out infinite;
}
.hero2-title {
  font: 300 clamp(56px, 8.8vw, 144px)/.92 var(--f-display);
  letter-spacing: -0.03em;
  font-feature-settings: "ss01", "opsz" 144;
}
.hero2-title .line { display: block; overflow: hidden; }
.hero2-title em { font-style: italic; font-weight: 400; color: var(--fg); }

.hero2-lede {
  margin-top: 36px; max-width: 460px;
  font: 300 18px/1.55 var(--f-body);
  color: var(--fg-dim);
}

.hero2-meta {
  margin-top: 44px; display: grid; gap: 14px;
  border-top: 1px solid var(--hair); padding-top: 24px;
  max-width: 440px;
}
.hero2-meta > div {
  display: grid; grid-template-columns: 100px 1fr; gap: 20px;
  font: 400 11px/1.4 var(--f-mono); letter-spacing: .12em; text-transform: uppercase;
}
.hero2-meta .k { color: var(--fg-faint); }
.hero2-meta .v { color: var(--fg); }

.hero2-cta { margin-top: 44px; display: flex; gap: 14px; flex-wrap: wrap; }

.hero2-right {
  position: relative;
  display: flex; align-items: center; justify-content: center;
}
.hero2-image-wrap {
  position: relative; width: 100%; height: 82vh; max-height: 780px;
  overflow: hidden;
  box-shadow: 0 40px 80px rgba(0,0,0,.55);
}
.hero2-image {
  position: absolute; inset: 0;
  background: url('assets/works/so-m-os-hero.jpg') center/cover no-repeat;
  transition: transform 1.2s var(--ease-cine), opacity .6s var(--ease);
}
.hero2-caption {
  position: absolute; left: 20px; bottom: 20px; z-index: 2;
  display: flex; align-items: center; gap: 12px;
  font: 500 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase;
  color: #f2ece3;
  background: rgba(0,0,0,.5); backdrop-filter: blur(6px);
  padding: 10px 14px; border-radius: 2px;
}
.caption-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.hero2-index {
  position: absolute; right: 20px; top: 20px; z-index: 2;
  font: 500 10px/1 var(--f-mono); letter-spacing: .22em;
  color: #f2ece3; background: rgba(0,0,0,.5);
  padding: 10px 14px; border-radius: 2px;
}
.hero2-next {
  position: absolute; right: 20px; bottom: 20px; z-index: 2;
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(0,0,0,.5); color: #f2ece3;
  display: flex; align-items: center; justify-content: center;
  transition: background .3s var(--ease), transform .3s var(--ease);
}
.hero2-next:hover { background: var(--accent); transform: translateX(4px); }

.hero2-status {
  grid-column: 1 / -1;
  display: flex; justify-content: space-between; gap: 24px;
  font: 400 10px/1 var(--f-mono); letter-spacing: .22em; color: var(--fg-faint); text-transform: uppercase;
  border-top: 1px solid var(--hair); padding-top: 18px; margin-top: 20px;
}

/* =========== HERO =========== */
.hero {
  position:relative; height:100vh; width:100%;
  overflow:hidden;
  border-bottom: 1px solid var(--hair);
}
.hero-canvas { position:absolute; inset:0; width:100%; height:100%; z-index:1; }

.reel-marks {
  position:absolute; top:92px; left:36px; right:36px; z-index:3;
  display:flex; justify-content:space-between;
  font:400 10px/1 var(--f-mono); letter-spacing:.22em; color:var(--fg-dim);
}

.tracking-lines {
  position:absolute; inset:0; z-index:4; pointer-events:none;
  background:
    linear-gradient(to bottom, transparent 0%, transparent 49.9%, rgba(255,255,255,.03) 50%, transparent 50.1%, transparent 100%),
    repeating-linear-gradient(to bottom, transparent 0, transparent 3px, rgba(0,0,0,.04) 3px, rgba(0,0,0,.04) 4px);
}

.hero-copy {
  position:absolute; left:36px; bottom:140px; z-index:5;
  max-width: 720px;
}
.eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font:500 11px/1 var(--f-mono); text-transform:uppercase; letter-spacing:.2em;
  color:var(--fg-dim); margin-bottom: 28px;
}
.eyebrow .dot {
  width:6px; height:6px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 14px var(--accent);
  animation: pulse 1.8s ease-in-out infinite;
}
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:.35; } }

.hero-title {
  font: 300 clamp(56px, 9vw, 148px)/.95 var(--f-display);
  letter-spacing: -0.03em;
  font-feature-settings: "ss01", "opsz" 144;
}
.hero-title .line { display:block; overflow:hidden; }
.hero-title em { font-style:italic; font-weight:400; font-feature-settings:"opsz" 144; }
.hero-title .outline {
  -webkit-text-stroke: 1.5px currentColor;
  -webkit-text-fill-color: transparent;
  font-style:italic;
}

.hero-lede {
  margin-top: 32px; max-width: 520px;
  font: 300 17px/1.5 var(--f-body);
  color: var(--fg-dim);
}

.hero-cta { margin-top:42px; display:flex; gap:14px; flex-wrap:wrap; }

.btn {
  display:inline-flex; align-items:center; gap:12px;
  font:500 12px/1 var(--f-mono); text-transform:uppercase; letter-spacing:.18em;
  padding:18px 26px; border-radius:999px;
  position:relative; overflow:hidden;
  transition: transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease);
}
.btn-primary { background:var(--fg); color:var(--bg); }
.btn-primary:hover { background: var(--accent); color: #f2ece3; }
.btn-ghost { border:1px solid var(--hair-strong); color:var(--fg); }
.btn-ghost:hover { border-color: var(--fg); background: var(--fg); color: var(--bg); }

.hero-status {
  position:absolute; left:36px; right:36px; bottom:32px; z-index:5;
  display:flex; justify-content:space-between; gap:24px;
  font:400 10px/1 var(--f-mono); letter-spacing:.2em; color:var(--fg-faint); text-transform:uppercase;
  border-top: 1px solid var(--hair);
  padding-top: 14px;
}

.scroll-hint {
  position:absolute; right:36px; bottom:120px; z-index:5;
  display:flex; flex-direction:column; align-items:center; gap:12px;
  font:400 10px/1 var(--f-mono); letter-spacing:.22em; color:var(--fg-dim); text-transform:uppercase;
  writing-mode: vertical-rl; transform: rotate(180deg);
}
.scroll-hint svg { transform: rotate(180deg); color: var(--fg-dim); }

/* =========== CINEMATIC STATEMENT (film thumbs scattered) =========== */
.statement {
  position: relative;
  padding: 10vh 0;
  background: var(--bg);
  overflow: hidden;
}
.statement-stage {
  position:relative;
  margin: 0 auto;
  width: 92%; max-width: 1600px;
  aspect-ratio: 16/9;
  min-height: 520px;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  display:flex; align-items:center; justify-content:center; flex-direction:column;
}
.perf {
  position:absolute; top:0; bottom:0; width:1px;
  border-left: 1px dashed var(--hair-strong);
  opacity:.6;
}
.perf-l { left: 33.333%; }
.perf-r { left: 66.666%; }

.thumb-float {
  position:absolute;
  width: 12%; aspect-ratio: 16/10;
  overflow:hidden;
  transition: transform .8s var(--ease-cine), opacity .6s var(--ease);
  box-shadow: 0 20px 40px rgba(0,0,0,.4);
}
.thumb-float::before { font-size:8px; }
.tf-tl { top: 6%;  left: 4%;   animation: floatA 9s ease-in-out infinite; }
.tf-tr { top: 8%;  right: 4%;  width: 14%; animation: floatB 11s ease-in-out infinite; }
.tf-ml { top: 42%; left: 2%;   width: 14%; animation: floatC 8s ease-in-out infinite; }
.tf-mr { top: 40%; right: 3%;  width: 13%; animation: floatA 10s ease-in-out infinite; }
.tf-bl { bottom: 6%; left: 5%; width: 13%; animation: floatB 12s ease-in-out infinite; }
.tf-br { bottom: 10%; right: 6%; width: 12%; animation: floatC 9s ease-in-out infinite; }

@keyframes floatA { 0%,100% { transform: translate(0,0) } 50% { transform: translate(8px,-10px) } }
@keyframes floatB { 0%,100% { transform: translate(0,0) } 50% { transform: translate(-6px,8px) } }
@keyframes floatC { 0%,100% { transform: translate(0,0) } 50% { transform: translate(4px,6px) } }

.statement-title {
  position:relative; z-index:2; text-align:center;
  font: 300 clamp(38px, 5.5vw, 84px)/1.15 var(--f-display);
  font-feature-settings:"opsz" 144;
  color: var(--fg);
  letter-spacing:-.015em;
}
.statement-title em { font-style: italic; font-weight: 400; }
.statement-title .line { display:block; }
.statement-sub {
  position:relative; z-index:2;
  margin-top: 28px;
  display:flex; gap:14px; align-items:center;
  font:400 10px/1 var(--f-mono); letter-spacing:.28em; text-transform:uppercase; color: var(--fg-dim);
}
.statement-sub span:first-child,
.statement-sub span:last-child { color: var(--accent); }

@media (max-width: 900px) {
  .statement-stage { aspect-ratio: 4/5; }
  .thumb-float { width: 22% !important; }
}

/* =========== MARQUEE =========== */
.marquee-sect {
  padding: 48px 0;
  border-bottom: 1px solid var(--hair);
  overflow:hidden;
}
.marquee-track {
  display:flex; gap:48px; white-space:nowrap;
  animation: scroll 40s linear infinite;
  font: 300 clamp(48px, 7vw, 110px)/1 var(--f-display);
  font-style:italic;
}
.marquee-track span { display:inline-block; }
.marquee-track i { display:inline-block; color: var(--accent); font-style: normal; }
@keyframes scroll { to { transform: translateX(-50%); } }

/* =========== SECTION HEADS =========== */
.section-head {
  padding: 120px 36px 48px;
  display: grid; grid-template-columns: auto 1fr; column-gap: 48px; row-gap:24px;
  align-items: baseline;
  border-bottom: 1px solid var(--hair);
}
.section-num {
  font:400 11px/1 var(--f-mono); color:var(--fg-faint); letter-spacing:.2em;
  grid-row: span 2;
}
.section-title {
  font: 300 clamp(48px, 7vw, 96px)/.95 var(--f-display);
  letter-spacing:-.02em;
  font-feature-settings:"opsz" 144;
}
.section-sub {
  grid-column: 2;
  max-width: 620px; color: var(--fg-dim); font-size: 16px;
}

/* =========== WORK GRID — editorial =========== */
.work { padding: 0 36px 140px; }
.work-grid {
  padding-top: 60px;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 64px 24px;
}

.work-card {
  position:relative; cursor:none;
  display:flex; flex-direction:column; gap:18px;
}

/* Tilt origin and corner offsets create rhythm */
.work-card.lg { grid-column: span 7; }
.work-card.md { grid-column: span 5; }
.work-card.sm { grid-column: span 4; }
.work-card.wd { grid-column: span 8; }
.work-card.h-tall   .thumb { aspect-ratio: 3/4; }
.work-card.h-square .thumb { aspect-ratio: 1/1; }
.work-card.h-wide   .thumb { aspect-ratio: 16/10; }

/* Stagger every 3rd card down slightly for magazine flow on wider screens */
@media (min-width: 1100px) {
  .work-card:nth-child(3n+2) { padding-top: 32px; }
  .work-card:nth-child(4n)   { padding-top: 56px; }
}

/* THUMB === image stage with overlays */
.work-card .thumb {
  position:relative; width:100%; overflow:hidden;
  background: var(--bg-3);
  transition: transform .6s var(--ease-cine);
  isolation: isolate;
}
.work-card .thumb::before {
  /* hairline frame on hover */
  content:''; position:absolute; inset:0;
  border: 1px solid transparent;
  pointer-events:none; z-index:3;
  transition: border-color .4s var(--ease);
}
.work-card:hover .thumb::before {
  border-color: color-mix(in oklab, var(--fg) 30%, transparent 70%);
}
.work-card .thumb::after {
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg,
    rgba(0,0,0,.18) 0%,
    transparent 30%,
    transparent 55%,
    rgba(0,0,0,.65) 100%);
  opacity:.55; z-index:1;
  transition:opacity .4s var(--ease);
}
.work-card:hover .thumb::after { opacity:1; }
.work-card:hover .thumb .ph-inner {
  transform: scale(1.04);
  filter: contrast(1.06) saturate(1.05);
}
.ph-inner {
  width:100%; height:100%;
  transition: transform 1s var(--ease-cine), filter .6s var(--ease);
  filter: contrast(1.02) saturate(.96);
}

/* Number stamp · top-left corner */
.work-card .work-num {
  position:absolute; top:14px; left:14px; z-index:2;
  font: 500 11px/1 var(--f-mono); letter-spacing:.2em;
  color: rgba(255,255,255,.85);
  padding: 6px 9px;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.18);
  text-transform: uppercase;
}

/* Year stamp · bottom-right · italic display */
.work-card .work-year-stamp {
  position:absolute; bottom:16px; right:16px; z-index:2;
  font: italic 300 clamp(28px, 2.6vw, 44px)/1 var(--f-display);
  color: rgba(255,255,255,.92);
  letter-spacing: -.02em;
  text-shadow: 0 2px 14px rgba(0,0,0,.5);
  transform: translateY(8px); opacity:0;
  transition: transform .55s var(--ease-cine), opacity .55s var(--ease-cine);
}
.work-card:hover .work-year-stamp { transform: translateY(0); opacity:1; }

/* "Ver detalhes" view-cue · bottom-left, only on hover */
.work-card .work-view-cue {
  position:absolute; bottom:16px; left:16px; z-index:2;
  display:flex; align-items:center; gap:8px;
  font: 500 10.5px/1 var(--f-mono); letter-spacing:.18em;
  color: rgba(255,255,255,.92);
  text-transform: uppercase;
  padding: 8px 12px;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.2);
  transform: translateY(10px); opacity:0;
  transition: transform .55s var(--ease-cine) .05s, opacity .5s var(--ease-cine) .05s;
}
.work-card .work-view-cue em { font-style: normal; }
.work-card:hover .work-view-cue { transform: translateY(0); opacity:1; }

/* INFO ROW below thumb */
.work-card .work-info {
  display:flex; flex-direction:column; gap:8px;
  padding-right: 8px;
}
.work-card .work-info-row {
  display:flex; justify-content:space-between; align-items:baseline;
  gap: 16px;
  font: 500 10px/1 var(--f-mono); letter-spacing:.2em;
  color: var(--fg-faint); text-transform:uppercase;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--hair);
}
.work-card .work-eyebrow { color: var(--fg-dim); }
.work-card .work-edition { color: var(--fg-faint); }
.work-card .work-title {
  font: 300 clamp(24px, 2.6vw, 36px)/1.05 var(--f-display);
  letter-spacing: -.012em;
  color: var(--fg);
  margin: 4px 0 0;
}
.work-card .work-title em {
  font-style: italic;
  font-weight: 400;
}
.work-card:hover .work-title { color: var(--fg); }
.work-card .work-spec {
  font: 400 11.5px/1.5 var(--f-mono);
  letter-spacing: .08em;
  color: var(--fg-faint);
  text-transform: uppercase;
  margin-top: 2px;
}

/* placeholder stripe system */
.placeholder {
  position:relative; overflow:hidden;
  background: var(--bg-3);
}
.placeholder::before {
  content: attr(data-label);
  position:absolute; left:16px; top:16px; z-index:2;
  font:400 9px/1 var(--f-mono); color:var(--fg-faint);
  letter-spacing:.2em; text-transform:uppercase;
}
.placeholder .ph-inner {
  background-image: repeating-linear-gradient(135deg, transparent 0 22px, rgba(255,255,255,.035) 22px 23px);
}
[data-theme="light"] .placeholder .ph-inner {
  background-image: repeating-linear-gradient(135deg, transparent 0 22px, rgba(0,0,0,.055) 22px 23px);
}
.placeholder[data-hue="warm"]   .ph-inner { background-color:#2a1a14; }
.placeholder[data-hue="cool"]   .ph-inner { background-color:#0f1a22; }
.placeholder[data-hue="rose"]   .ph-inner { background-color:#301418; }
.placeholder[data-hue="sand"]   .ph-inner { background-color:#2c251b; }
.placeholder[data-hue="moss"]   .ph-inner { background-color:#141d16; }
.placeholder[data-hue="ink"]    .ph-inner { background-color:#0a0a12; }
.placeholder[data-hue="blood"]  .ph-inner { background-color:#2a0f10; }
.placeholder[data-hue="gold"]   .ph-inner { background-color:#2b2112; }
[data-theme="light"] .placeholder[data-hue="warm"]   .ph-inner { background-color:#d8c2ad; }
[data-theme="light"] .placeholder[data-hue="cool"]   .ph-inner { background-color:#adbac8; }
[data-theme="light"] .placeholder[data-hue="rose"]   .ph-inner { background-color:#d8b8b6; }
[data-theme="light"] .placeholder[data-hue="sand"]   .ph-inner { background-color:#cbb89a; }
[data-theme="light"] .placeholder[data-hue="moss"]   .ph-inner { background-color:#adb6a0; }
[data-theme="light"] .placeholder[data-hue="ink"]    .ph-inner { background-color:#b4b0b6; }
[data-theme="light"] .placeholder[data-hue="blood"]  .ph-inner { background-color:#c39b9a; }
[data-theme="light"] .placeholder[data-hue="gold"]   .ph-inner { background-color:#c9b88d; }

/* =========== SERIES LIST =========== */
.series { padding: 0 36px; position:relative; border-bottom:1px solid var(--hair); }
.series-list { list-style:none; }
.series-list li, .series-list .series-li-inner {
  display:grid; grid-template-columns: 80px 1fr auto auto;
  align-items: center; gap: 36px;
  padding: 36px 0;
  border-top: 1px solid var(--hair);
  cursor:none; position:relative;
  transition: padding .4s var(--ease-cine);
}
.series-list li:last-child, .series-list > *:last-child .series-li-inner { border-bottom: 1px solid var(--hair); }
.series-list li:hover, .series-list .series-li-inner:hover { padding-left: 24px; }
.series-list li:hover .s-name, .series-list .series-li-inner:hover .s-name { color: var(--accent); }
.series-list .s-num { font:400 11px/1 var(--f-mono); letter-spacing:.2em; color:var(--fg-faint); }
.series-list .s-name {
  font: 300 clamp(34px, 4vw, 56px)/1 var(--f-display); font-style:italic;
  transition: color .4s var(--ease);
}
.series-list .s-year { font:400 11px/1 var(--f-mono); color:var(--fg-dim); letter-spacing:.18em; }
.series-list .s-count { font:400 11px/1 var(--f-mono); color:var(--fg-faint); letter-spacing:.18em; }

.series-preview {
  position: fixed; top:50%; left:50%; pointer-events:none; z-index:200;
  width: 360px; aspect-ratio: 3/4;
  transform: translate(-50%,-50%) scale(.95);
  opacity: 0;
  transition: opacity .3s var(--ease), transform .3s var(--ease-cine);
}
.series-preview.is-active { opacity:1; transform: translate(-50%,-50%) scale(1); }

/* =========== CÓDIGO MÃE =========== */
.cm {
  position:relative;
  padding: 140px 36px;
  background: var(--bg-2);
  overflow:hidden;
  border-bottom: 1px solid var(--hair);
}
.cm::before {
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(80% 60% at 15% 20%, rgba(176,60,60,.08), transparent 60%),
    radial-gradient(60% 50% at 85% 80%, rgba(217,139,95,.08), transparent 60%);
  pointer-events:none;
}
.cm-inner { position:relative; max-width: 1200px; margin: 0 auto; }
.cm-eyebrow {
  display:inline-flex; align-items:center; gap:10px;
  font:500 11px/1 var(--f-mono); letter-spacing:.22em; text-transform:uppercase;
  color: var(--accent); margin-bottom: 40px;
}
.cm-eyebrow .dot { width:6px; height:6px; border-radius:50%; background: var(--accent); }

.cm-logo-wrap {
  display:flex; justify-content:center; margin: 20px 0 80px;
}
.cm-logo-wrap svg {
  width: min(560px, 80vw); height:auto;
}

/* SVG stroke animation — letters draw in */
.cm-logo-wrap path {
  fill: transparent;
  stroke: var(--accent);
  stroke-width: 1.2;
  stroke-dasharray: var(--len, 2000);
  stroke-dashoffset: var(--len, 2000);
  transition: fill 1.2s 1.4s var(--ease);
}
.cm-logo-wrap rect[fill="white"] { display:none; }
.cm-logo-wrap.animate path {
  animation: drawStroke 2.8s var(--ease-cine) forwards;
}
.cm-logo-wrap.animate path:nth-child(1) { animation-delay: .0s; }
.cm-logo-wrap.animate path:nth-child(2) { animation-delay: .15s; }
.cm-logo-wrap.animate path:nth-child(3) { animation-delay: .30s; }
.cm-logo-wrap.animate path:nth-child(4) { animation-delay: .45s; }
.cm-logo-wrap.animate path:nth-child(5) { animation-delay: .60s; }
.cm-logo-wrap.animate path:nth-child(6) { animation-delay: .75s; }
.cm-logo-wrap.animate path:nth-child(7) { animation-delay: .90s; }
.cm-logo-wrap.animate path:nth-child(8) { animation-delay: 1.05s; }
.cm-logo-wrap.animate path:nth-child(n+9) { animation-delay: 1.2s; }
.cm-logo-wrap.animate.filled path { fill: var(--accent); }

@keyframes drawStroke {
  0%   { stroke-dashoffset: var(--len, 2000); fill: transparent; }
  70%  { stroke-dashoffset: 0;                fill: transparent; }
  100% { stroke-dashoffset: 0;                fill: var(--accent); }
}

.cm-grid {
  display:grid; grid-template-columns: 1.3fr 1fr; gap: 80px;
  margin-top: 60px;
}
.cm-text p { margin-top: 20px; max-width: 56ch; color: var(--fg-dim); }
.cm-lead {
  font: 300 28px/1.35 var(--f-display); font-style:italic;
  color: var(--fg) !important;
}
.cm-lead em { font-style:normal; color: var(--accent); }
.cm-text blockquote {
  margin-top: 44px; padding-left: 24px;
  border-left: 2px solid var(--accent);
  font: 300 24px/1.4 var(--f-display); font-style:italic; color: var(--fg);
}
.cm-meta dl { display:grid; gap:18px; margin-bottom: 36px; }
.cm-meta dl > div {
  display:grid; grid-template-columns: 110px 1fr; gap:20px;
  padding-bottom: 14px; border-bottom: 1px solid var(--hair);
}
.cm-meta dt { font:400 10px/1.4 var(--f-mono); letter-spacing:.2em; text-transform:uppercase; color: var(--fg-faint); }
.cm-meta dd { color: var(--fg); font-size: 14px; }

/* =========== ABOUT =========== */
.about { padding: 0 36px 120px; border-bottom:1px solid var(--hair); }
.about-grid { display:grid; grid-template-columns: 1fr 1.4fr; gap: 60px; padding-top: 60px; }
.about-portrait { aspect-ratio: 3/4; }
.about-lead {
  font: 300 24px/1.4 var(--f-display); font-style: italic; max-width: 56ch;
}
.about-text p { margin-top: 24px; max-width: 60ch; color: var(--fg-dim); }
.about-stats {
  margin-top: 56px;
  display:grid; grid-template-columns: repeat(4, 1fr); gap: 32px;
  border-top: 1px solid var(--hair); padding-top: 32px;
}
.about-stats > div { display:flex; flex-direction:column; gap:6px; }
.about-stats strong {
  font: 300 48px/1 var(--f-display); font-feature-settings:"lnum"; letter-spacing:-.02em;
}
.about-stats span { font:400 10px/1 var(--f-mono); letter-spacing:.2em; text-transform:uppercase; color: var(--fg-faint); }

/* =========== CONTACT =========== */
.contact { padding: 120px 36px 0; text-align:center; }
.contact-inner { max-width: 1000px; margin: 0 auto; padding-bottom: 80px; }
.contact-title {
  font: 300 clamp(48px, 8vw, 120px)/.95 var(--f-display);
  font-feature-settings:"opsz" 144;
}
.contact-title span { display:block; }
.contact-title .outline {
  font-style:italic;
  -webkit-text-stroke: 1.5px currentColor;
  -webkit-text-fill-color: transparent;
}
.contact > .contact-inner > p { margin-top: 32px; color: var(--fg-dim); }
.contact-cta { margin-top: 48px; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.foot {
  display:flex; justify-content:space-between; gap:24px;
  padding: 32px 0; border-top: 1px solid var(--hair);
  font:400 10px/1 var(--f-mono); letter-spacing:.2em; text-transform:uppercase; color: var(--fg-faint);
}

/* =========== DETAIL SPLIT OVERLAY =========== */
.detail {
  position: fixed; inset:0; z-index:9500;
  display:grid; grid-template-columns: 1fr 1fr;
  background: var(--bg);
  transform: translateY(100%);
  transition: transform .8s var(--ease-cine);
  pointer-events:none;
}
.detail.is-open { transform: translateY(0); pointer-events:auto; }
.detail-close {
  position:absolute; top:24px; right:24px; z-index:3;
  width: 48px; height:48px; border-radius:50%;
  border:1px solid var(--hair-strong);
  display:flex; align-items:center; justify-content:center;
  transition: background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.detail-close:hover { background: var(--fg); color: var(--bg); border-color: var(--fg); }
.detail-left  {
  position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background: var(--bg-2);
  border-right: 1px solid var(--hair);
}
.detail-image {
  position:absolute; inset: 40px;
  background: var(--bg-3);
  overflow:hidden;
}
.detail-image .ph-inner { width:100%; height:100%; }
.detail-reel {
  position:absolute; top:20px; left:20px; z-index:2;
  display:flex; gap:10px;
  font:400 10px/1 var(--f-mono); letter-spacing:.22em; color:var(--fg-dim); text-transform:uppercase;
}
.detail-right {
  display:flex; align-items:center;
  padding: 80px 72px;
  overflow-y:auto;
}
.detail-meta { max-width: 520px; }
.detail-eyebrow { font:500 11px/1 var(--f-mono); letter-spacing:.22em; text-transform:uppercase; color: var(--accent); }
.detail-title {
  margin-top: 20px;
  font: 300 clamp(40px, 5vw, 72px)/1 var(--f-display); font-style:italic;
  letter-spacing:-.02em;
}
.detail-desc { margin-top: 24px; color: var(--fg-dim); max-width: 48ch; }
.detail-specs {
  margin-top: 36px; display:grid; gap: 14px;
  padding-top: 32px; border-top: 1px solid var(--hair);
}
.detail-specs > div { display:grid; grid-template-columns: 140px 1fr; gap:20px; align-items:baseline; }
.detail-specs dt { font:400 10px/1 var(--f-mono); letter-spacing:.2em; text-transform:uppercase; color: var(--fg-faint); }
.detail-specs dd { font-size:14px; }

.detail-price {
  margin-top: 40px; padding-top: 32px;
  border-top: 1px solid var(--hair);
  display:flex; justify-content:space-between; align-items:baseline;
}
.detail-price-label { font:400 10px/1 var(--f-mono); letter-spacing:.2em; text-transform:uppercase; color: var(--fg-faint); }
.detail-price-value { font: 300 32px/1 var(--f-display); }

.detail-actions { margin-top: 32px; display:flex; gap: 12px; flex-wrap:wrap; }
.detail-footnote { margin-top: 36px; font-size: 12px; color: var(--fg-faint); line-height:1.6; max-width: 42ch; }

/* =========== PAGE OVERLAY (clip-path transitions) =========== */
.page-overlay {
  position: fixed; inset: 0; z-index: 9800;
  background: var(--bg);
  opacity: 1;
  pointer-events: none;
}

/* =========== TWEAKS PANEL =========== */
.tweaks-panel {
  position: fixed; right: 24px; bottom: 24px; z-index: 9900;
  width: 280px; padding: 18px;
  background: var(--bg-2); border: 1px solid var(--hair-strong); border-radius: 12px;
  font: 400 12px/1.4 var(--f-mono); color: var(--fg);
  transform: translateY(20px); opacity: 0; pointer-events: none;
  transition: transform .4s var(--ease), opacity .3s var(--ease);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}
.tweaks-panel.open { transform: translateY(0); opacity: 1; pointer-events: auto; }
.tweaks-panel header { display:flex; justify-content:space-between; align-items:center; margin-bottom: 14px; padding-bottom: 10px; border-bottom: 1px solid var(--hair); }
.tweaks-panel header strong { font:500 11px/1 var(--f-mono); letter-spacing: .2em; text-transform: uppercase; }
.tweaks-panel header button { font-size: 20px; color: var(--fg-dim); cursor: pointer; }
.tweaks-panel .row { display:flex; justify-content:space-between; align-items:center; padding: 8px 0; gap: 12px; }
.tweaks-panel label { color: var(--fg-dim); font-size: 11px; }
.tweaks-panel input[type="color"] { width: 40px; height: 24px; border: 1px solid var(--hair); background: transparent; cursor: pointer; }
.tweaks-panel input[type="range"] { width: 120px; }
.tweaks-panel .tk-btn { padding: 6px 12px; border: 1px solid var(--hair-strong); border-radius: 4px; font-size: 10px; text-transform: uppercase; letter-spacing: .15em; cursor: pointer; }

/* swipe underline under nav links */
.nav-links a { overflow: hidden; }
.nav-links a .swipe-line {
  position: absolute; left: 0; bottom: 0;
  width: 100%; height: 1px; background: var(--fg);
  transform: translateX(-101%);
}
.nav-links a::after { display: none; }

/* reveal fallback */
.reveal { opacity: 1; }

/* =========== STATEMENT upgrade =========== */
.statement { padding: 12vh 0 8vh; background: #000; }
[data-theme="light"] .statement { background: var(--bg); }
.statement-title {
  position: relative; z-index: 3; text-align: center;
  font: 300 clamp(48px, 7vw, 112px)/1.08 var(--f-display);
  font-feature-settings: "opsz" 144;
  color: #fff;
  letter-spacing: -.02em;
}
[data-theme="light"] .statement-title { color: var(--fg); }
.statement-title em { font-style: italic; font-weight: 400; }
.thumb-float {
  background-size: cover !important; background-position: center !important;
}

/* =========== CONTACT COMPACT =========== */
.contact-compact {
  padding: 100px 36px 0;
  border-top: 1px solid var(--hair);
}
.cc-inner {
  display: grid; grid-template-columns: 1.1fr 1fr;
  gap: 80px; padding-bottom: 80px;
  align-items: start;
}
.cc-eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font: 500 11px/1 var(--f-mono); text-transform: uppercase; letter-spacing: .22em;
  color: var(--accent); margin-bottom: 28px;
}
.cc-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.cc-title {
  font: 300 clamp(40px, 5.5vw, 88px)/1.02 var(--f-display);
  letter-spacing: -.02em;
  font-feature-settings: "opsz" 144;
}
.cc-title em { font-style: italic; font-weight: 400; color: var(--accent); }
.cc-sub {
  margin-top: 24px; max-width: 42ch;
  color: var(--fg-dim); font-size: 15px; line-height: 1.55;
}
.cc-right { display: flex; flex-direction: column; gap: 0; }
.cc-contact-row {
  display: grid; grid-template-columns: 120px 1fr auto;
  align-items: center; gap: 24px;
  padding: 24px 0;
  border-top: 1px solid var(--hair);
  transition: padding .4s var(--ease-cine), color .3s var(--ease);
}
.cc-contact-row:last-child { border-bottom: 1px solid var(--hair); }
.cc-contact-row:hover { padding-left: 16px; color: var(--accent); }
.cc-k { font: 400 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase; color: var(--fg-faint); }
.cc-v { font: 300 22px/1.1 var(--f-display); font-style: italic; color: var(--fg); transition: color .3s var(--ease); }
.cc-contact-row:hover .cc-v { color: var(--accent); }

/* CM teaser (homepage) */
.cm .cm-lead { text-align: center; margin-top: 40px; }
.cm .cm-cta { display: inline-flex; margin-top: 32px; }
.cm-inner { text-align: center; }
/* Strokes ALWAYS accent (red) — draw effect reads as "drawing in red ink",
   not "white then fill". */
.cm .cm-logo-wrap path {
  stroke: var(--accent);
}
.cm .cm-logo-wrap.filled path { fill: var(--accent); stroke: var(--accent); }
.cm-logo-wrap svg { overflow: visible !important; }
.cm-logo-wrap svg path {
  transform-box: fill-box;
  transform-origin: center;
  will-change: transform, filter, opacity;
  transition: fill 0.8s cubic-bezier(.4,0,.2,1);
}

/* =========== SERIES PAGE =========== */
.series-page { padding: 0; }
.sp-hero {
  position: relative; height: 90vh; min-height: 640px;
  overflow: hidden; display: flex; align-items: flex-end;
  padding: 0 36px 64px;
}
.sp-hero-bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  filter: brightness(.7);
  z-index: 0;
}
.sp-hero-bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.3) 0%, rgba(0,0,0,.85) 100%);
}
.sp-hero-copy {
  position: relative; z-index: 2; max-width: 900px;
}
.sp-eyebrow {
  font: 500 11px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 28px;
  display: inline-flex; align-items: center; gap: 10px;
}
.sp-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); }
.sp-title {
  font: 300 clamp(64px, 10vw, 180px)/.92 var(--f-display);
  letter-spacing: -.03em; color: #fff;
}
.sp-title em { font-style: italic; font-weight: 400; }
.sp-meta-row {
  margin-top: 32px; display: flex; gap: 48px; flex-wrap: wrap;
  font: 400 11px/1.4 var(--f-mono); letter-spacing: .18em; text-transform: uppercase;
  color: rgba(255,255,255,.7);
}
.sp-meta-row strong { color: #fff; font-weight: 500; }

.sp-intro {
  padding: 140px 36px 80px;
  display: grid; grid-template-columns: 80px 1fr 1fr; gap: 48px;
  border-bottom: 1px solid var(--hair);
}
.sp-intro .section-num { font: 400 11px/1 var(--f-mono); color: var(--fg-faint); letter-spacing: .2em; }
.sp-intro .kicker {
  font: 300 clamp(32px, 3.5vw, 56px)/1.15 var(--f-display);
  font-style: italic; letter-spacing: -.01em;
}
.sp-intro .body { color: var(--fg-dim); font-size: 16px; line-height: 1.7; }
.sp-intro .body p + p { margin-top: 20px; }

.sp-gallery {
  padding: 80px 36px 120px;
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 32px 24px;
}
.sp-slot {
  position: relative; overflow: hidden;
  background: var(--bg-3);
  transition: transform .8s var(--ease-cine);
}
.sp-slot .bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transition: transform 1s var(--ease-cine);
}
.sp-slot:hover .bg { transform: scale(1.04); }
.sp-slot::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 70%, rgba(0,0,0,.75));
  opacity: 0; transition: opacity .4s var(--ease);
}
.sp-slot:hover::after { opacity: 1; }
.sp-slot .cap {
  position: absolute; left: 16px; bottom: 16px; z-index: 2;
  font: 500 10px/1.2 var(--f-mono); letter-spacing: .18em; text-transform: uppercase;
  color: #f2ece3; opacity: 0; transform: translateY(8px);
  transition: opacity .4s var(--ease), transform .4s var(--ease);
}
.sp-slot:hover .cap { opacity: 1; transform: translateY(0); }
.sp-slot.slot-placeholder {
  background: var(--bg-2);
  display: flex; align-items: center; justify-content: center;
}
.sp-slot.slot-placeholder::before {
  content: "IMAGEM EM BREVE";
  font: 400 10px/1 var(--f-mono); letter-spacing: .22em; color: var(--fg-faint);
}
.sp-slot.s-1 { grid-column: span 7; aspect-ratio: 16/10; }
.sp-slot.s-2 { grid-column: span 5; aspect-ratio: 3/4; }
.sp-slot.s-3 { grid-column: span 4; aspect-ratio: 4/5; }
.sp-slot.s-4 { grid-column: span 8; aspect-ratio: 16/9; }
.sp-slot.s-5 { grid-column: span 6; aspect-ratio: 1/1; }
.sp-slot.s-6 { grid-column: span 6; aspect-ratio: 4/3; }
.sp-slot.s-7 { grid-column: span 12; aspect-ratio: 21/9; }

.sp-footer {
  padding: 60px 36px 100px;
  border-top: 1px solid var(--hair);
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
}
.sp-footer-left .big {
  font: 300 clamp(32px, 4vw, 56px)/1.1 var(--f-display); font-style: italic;
  letter-spacing: -.01em;
}
.sp-footer-right { display: flex; gap: 14px; justify-content: flex-end; flex-wrap: wrap; }

.sp-nav {
  padding: 0 36px 120px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
}
.sp-nav a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 36px 32px;
  border: 1px solid var(--hair-strong);
  transition: background .4s var(--ease), border-color .4s var(--ease);
}
.sp-nav a:hover { background: var(--bg-2); border-color: var(--fg); }
.sp-nav .k { font: 400 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase; color: var(--fg-faint); }
.sp-nav .t { font: 300 28px/1 var(--f-display); font-style: italic; margin-top: 8px; }
.sp-nav .arrow { width: 48px; height: 48px; border-radius: 50%; border: 1px solid var(--hair-strong); display: flex; align-items: center; justify-content: center; color: var(--fg-dim); }
.sp-nav .prev { text-align: left; }
.sp-nav .next { text-align: right; flex-direction: row-reverse; }
.sp-nav .next .arrow { transform: none; }
.sp-nav .prev .arrow svg { transform: rotate(180deg); }

@media (max-width: 900px) {
  .hero2 { grid-template-columns: 1fr; padding: 120px 20px 60px; gap: 40px; }
  .hero2-left { padding-right: 0; }
  .hero2-image-wrap { height: 60vh; }
  .cc-inner { grid-template-columns: 1fr; gap: 40px; padding: 0 20px 60px; }
  .contact-compact { padding: 60px 20px 0; }
  .sp-hero { padding: 0 20px 40px; height: 70vh; min-height: 500px; }
  .sp-intro { grid-template-columns: 1fr; padding: 60px 20px; gap: 24px; }
  .sp-gallery { grid-template-columns: repeat(6, 1fr); padding: 40px 20px; }
  .sp-slot.s-1, .sp-slot.s-2, .sp-slot.s-3, .sp-slot.s-4,
  .sp-slot.s-5, .sp-slot.s-6, .sp-slot.s-7 { grid-column: span 6; aspect-ratio: 4/5; }
  .sp-footer { grid-template-columns: 1fr; padding: 40px 20px 60px; }
  .sp-footer-right { justify-content: flex-start; }
  .sp-nav { grid-template-columns: 1fr; padding: 0 20px 60px; }
}

/* =========== RESPONSIVE =========== */

/* detail image background-size cover */
.detail-image > div { width: 100%; height: 100%; }

@media (max-width: 900px) {
  body { cursor:auto; }
  .cursor { display:none; }
  button, a { cursor: pointer; }
  .nav { padding: 16px 20px; }
  .nav-links { display:none; }
  .hero-copy { left:20px; right:20px; bottom: 120px; }
  .reel-marks { left:20px; right:20px; top:68px; gap: 12px; flex-wrap:wrap; }
  .hero-status { left:20px; right:20px; flex-wrap:wrap; gap: 8px; }
  .scroll-hint { display:none; }
  .section-head { padding: 80px 20px 32px; grid-template-columns: 1fr; }
  .section-num { grid-row: auto; }
  .section-sub { grid-column: 1; }
  .work, .series, .about, .contact, .cm { padding-left:20px; padding-right:20px; }
  .work-grid { grid-template-columns: repeat(6, 1fr); gap: 32px 16px; }
  .work-card.lg, .work-card.md, .work-card.sm, .work-card.wd { grid-column: span 6; }
  .series-list li, .series-list .series-li-inner { grid-template-columns: 40px 1fr auto; gap:16px; }
  .series-list .s-count { display:none; }
  .cm { padding: 80px 20px; }
  .cm-grid { grid-template-columns: 1fr; gap: 40px; }
  .about-grid { grid-template-columns: 1fr; }
  .about-stats { grid-template-columns: repeat(2,1fr); }
  .detail { grid-template-columns: 1fr; grid-template-rows: 1fr 1fr; }
  .detail-right { padding: 40px 24px; }
}



/*b*/


/*b2*/


/* =========================================================
   HERO — "Intimate, Raw" composition
   Cinema composition · serif italic center · precise frames
   ========================================================= */

.hero-stage {
  position: relative;
  min-height: 100vh;
  background: #000;
  overflow: hidden;
  display: grid;
  grid-template-rows: auto 1fr auto;
  padding: 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
[data-theme="light"] .hero-stage { background: var(--bg); }

/* Perf guide lines — cinema thirds, dotted */
.hero-perfs {
  position: absolute; inset: 0;
  grid-row: 1 / -1;
  pointer-events: none;
  z-index: 1;
}
.hero-perfs .perf-line {
  position: absolute;
  top: 12%; bottom: 12%;
  width: 0;
  border-left: 1px dashed rgba(255,255,255,.14);
}
[data-theme="light"] .hero-perfs .perf-line { border-left-color: rgba(0,0,0,.14); }
.hero-perfs .perf-1 { left: 33.333%; }
.hero-perfs .perf-2 { left: 66.666%; }

/* The 6 frames — asymmetric, precise positions, small scale */
.hero-frames {
  position: absolute; inset: 0;
  z-index: 2;
  pointer-events: none;
}
.hframe {
  position: absolute;
  background-size: cover !important;
  background-position: center !important;
  box-shadow: 0 16px 32px rgba(0,0,0,.5);
  opacity: 0;
  will-change: transform, opacity;
}
/* Positions inspired by reference: top-right, mid-left, mid-right, bottom-left (4 prominent + 2 small accents) */
.hframe.hf-tl { top:  8%; left:   3%; width: 10%; aspect-ratio: 16/10; display: none; }
.hframe.hf-tr { top:  8%; right:  3%; width: 11%; aspect-ratio: 16/10; }
.hframe.hf-ml { top: 42%; left:   2.5%; width: 10%; aspect-ratio: 16/10; }
.hframe.hf-mr { top: 42%; right:  2.5%; width: 11%; aspect-ratio: 16/10; }
.hframe.hf-bl { bottom: 14%; left: 3%; width: 10%; aspect-ratio: 16/10; }
.hframe.hf-br { bottom: 18%; right: 10%; width: 7%; aspect-ratio: 16/10; display: none; }

/* Center statement — serif italic, small, confident */
.hero-center {
  grid-row: 2;
  align-self: center;
  justify-self: center;
  position: relative; z-index: 5;
  padding: 40px;
  max-width: 720px;
  text-align: center;
}
.hero-statement {
  font-family: "Fraunces", "Canela", Georgia, serif;
  font-weight: 400;
  font-style: italic;
  font-size: clamp(40px, 4.5vw, 72px);
  line-height: 1.12;
  letter-spacing: -.02em;
  color: #ffffff;
  margin: 0;
}
[data-theme="light"] .hero-statement { color: var(--fg); }
.hero-statement .line { display: block; }
.hero-statement em {
  font-style: italic;
  font-weight: 400;
  color: #ffffff;
}
[data-theme="light"] .hero-statement em { color: var(--fg); }

/* Top attribution row — 3 label/value columns */
.hero-attr {
  grid-row: 1;
  position: relative; z-index: 4;
  width: min(1360px, 94vw);
  margin: 0 auto;
  padding: 140px 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 48px;
  font-family: "Inter", sans-serif;
}
.hero-attr > div {
  display: grid; gap: 6px;
  align-content: start;
}
.hero-attr .attr-l { justify-items: start; }
.hero-attr .attr-c { justify-items: center; text-align: center; }
.hero-attr .attr-r { justify-items: end; text-align: right; }
.hero-attr .k {
  font-weight: 500; font-size: 10px; line-height: 1;
  letter-spacing: .26em; text-transform: uppercase;
  color: rgba(255,255,255,.45);
}
[data-theme="light"] .hero-attr .k { color: var(--fg-faint); }
.hero-attr .v {
  font-weight: 400; font-size: 13px; line-height: 1.35;
  letter-spacing: -.005em;
  color: rgba(255,255,255,.92);
}
[data-theme="light"] .hero-attr .v { color: var(--fg); }

/* Hero footer — minimal, two-column */
.hero-bottom {
  grid-row: 3;
  position: relative; z-index: 4;
  width: min(1360px, 94vw);
  margin: 0 auto;
  padding: 0 0 40px;
  display: grid; grid-template-columns: 1fr auto;
  gap: 48px; align-items: end;
  font-family: "Inter", sans-serif;
}
.hero-bottom .bl { display: flex; align-items: baseline; gap: 16px; }
.hero-bottom .bl .k {
  font-weight: 500; font-size: 10px; line-height: 1;
  letter-spacing: .26em; text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
[data-theme="light"] .hero-bottom .bl .k { color: var(--fg-faint); }
.hero-bottom .bl .v {
  font-weight: 400; font-size: 13px; line-height: 1.3;
  letter-spacing: -.005em;
  color: rgba(255,255,255,.82);
}
[data-theme="light"] .hero-bottom .bl .v { color: var(--fg-dim); }

.hero-bottom .br {
  display: flex; align-items: center; gap: 20px;
}
.hero-cta {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px;
  background: #ffffff;
  color: #000;
  font-family: "Inter", sans-serif;
  font-weight: 500; font-size: 11px;
  letter-spacing: .22em; text-transform: uppercase;
  border-radius: 2px;
  transition: background .4s var(--ease), transform .4s var(--ease);
}
.hero-cta:hover { background: var(--accent); color: #fff; transform: translateY(-1px); }
[data-theme="light"] .hero-cta { background: var(--fg); color: var(--bg); }
.hero-bottom .time {
  font-weight: 500; font-size: 10px; line-height: 1;
  letter-spacing: .24em; text-transform: uppercase;
  color: rgba(255,255,255,.45);
  font-variant-numeric: tabular-nums;
}
[data-theme="light"] .hero-bottom .time { color: var(--fg-faint); }

/* Mobile */
@media (max-width: 900px) {
  .hero-attr { padding: 110px 0 0; grid-template-columns: 1fr; gap: 20px; }
  .hero-attr .attr-c { justify-items: start; text-align: left; }
  .hero-attr .attr-r { justify-items: start; text-align: left; }
  .hero-bottom { grid-template-columns: 1fr; gap: 20px; }
  .hero-perfs .perf-line { top: 8%; bottom: 8%; }
  .hero-statement { font-size: clamp(26px, 6vw, 40px); }
  .hframe { display: none; }
  .hframe.hf-tl, .hframe.hf-mr, .hframe.hf-bl { display: block; opacity: .35 !important; }
}

/* ========================================================================
   v10 — full redesign overrides + new sections
   (loaded LAST so it wins the cascade)
   ======================================================================== */

/* --- Intro: 2-column status row, no counter --- */
.intro-status { justify-content: space-between; }
.intro-bg .ifloat { box-shadow: 0 30px 60px rgba(0,0,0,.5); }

/* --- Lang button: no longer has cursor swap --- */
.lang-btn { cursor: pointer; }

/* --- Hero attribution text: smaller / tighter ('fonte antiga menor') --- */
.hero-attr { padding-top: 110px; }
.hero-attr .v { font-size: 11px; line-height: 1.3; letter-spacing: -.005em; }
.hero-attr .k { font-size: 9px; letter-spacing: .28em; }
.hero-bottom .bl .v { font-size: 11px; }
.hero-bottom .bl .k { font-size: 9px; letter-spacing: .28em; }
.hero-bottom .time { font-size: 9px; letter-spacing: .26em; }

/* --- Hero center → GW logo (replaces italic statement) --- */
.hero-center { padding: 20px; }
.hero-logo {
  width: min(720px, 60vw);
  aspect-ratio: 1024 / 500;
  display: flex; align-items: center; justify-content: center;
}
.hero-logo svg { width: 100%; height: 100%; overflow: visible; }
.hero-logo svg > rect[fill="white"] { display: none; }
.hero-logo svg path {
  fill: transparent;
  stroke: var(--fg);
  stroke-width: 2;
  stroke-linejoin: round;
  stroke-linecap: round;
  paint-order: stroke fill;
  stroke-dasharray: var(--len, 2400);
  stroke-dashoffset: var(--len, 2400);
  filter: drop-shadow(0 0 18px rgba(255,255,255,.12));
}
.hero-logo.filled svg path { fill: var(--fg); }

/* --- Hero frames: 10-frame asymmetric, denser right --- */
.hero-frames .hframe {
  position: absolute;
  background-size: cover !important; background-position: center !important;
  box-shadow: 0 20px 40px rgba(0,0,0,.55);
  opacity: 0;                       /* JS reveals to .82 */
  filter: grayscale(.18) contrast(1.04);
  will-change: transform, opacity;
}
.hframe.hf-tl, .hframe.hf-tr, .hframe.hf-ml, .hframe.hf-mr,
.hframe.hf-bl, .hframe.hf-br { display: none; }   /* nuke old class names */

.hframe.hf-1  { top: 12%; left:   4%; width:  9%; aspect-ratio: 16/10; }
.hframe.hf-2  { top: 50%; left:   7%; width:  8%; aspect-ratio: 3/4;   }
.hframe.hf-3  { top: 76%; left:   3%; width: 10%; aspect-ratio: 16/10; }
.hframe.hf-4  { top: 30%; left:  38%; width:  7%; aspect-ratio: 1/1;   opacity: 0; }
.hframe.hf-5  { top:  8%; right:  4%; width: 11%; aspect-ratio: 16/10; }
.hframe.hf-6  { top: 14%; right: 22%; width:  8%; aspect-ratio: 3/4;   }
.hframe.hf-7  { top: 38%; right:  3%; width: 10%; aspect-ratio: 16/10; }
.hframe.hf-8  { top: 44%; right: 18%; width:  7%; aspect-ratio: 1/1;   }
.hframe.hf-9  { top: 70%; right:  5%; width: 11%; aspect-ratio: 16/10; }
.hframe.hf-10 { top: 78%; right: 24%; width:  8%; aspect-ratio: 3/4;   }

/* --- SLAB — compact default (series pages); homepage gets .slab-sect--tri --- */
.slab-sect {
  position: relative;
  padding: 3vw 36px 2vw;
  background: var(--bg);
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  perspective: 1000px;
  overflow: hidden;
}
.slab-viewport {
  width: 100%;
  overflow: hidden;
  padding: 0 4vw;
}
.slab {
  font-family: "Archivo Black", "Archivo", system-ui;
  font-weight: 900;
  font-size: 13.6vw;
  line-height: .82;
  letter-spacing: -.05em;
  color: var(--fg);
  text-align: center;
  white-space: nowrap;
  margin: 0;
  text-transform: none;
}

/* Tri-word slab: GABRIEL · WICK · BOLD — each word its own typeface,
   sized larger than viewport so horizontal pin scroll reveals them */
.slab.slab--tri {
  font-size: 28vw;
  line-height: 0.86;
  display: inline-flex;
  align-items: baseline;
  gap: 0.06em;
  white-space: nowrap;
  text-align: left;
  will-change: transform;
  padding-right: 2vw;
}
.slab-word { display: inline-block; }
.slab-w1 { /* GABRIEL — modern grotesque */
  font-family: "Clash Grotesk", "Inter", system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: -0.035em;
}
.slab-w2 { /* WICK — serif italic */
  font-family: "Fraunces", "Times New Roman", serif;
  font-weight: 300;
  font-style: italic;
  font-feature-settings: "opsz" 144, "ss01";
  letter-spacing: -0.045em;
  margin-left: -0.02em;
  margin-right: -0.02em;
}
.slab-w3 { /* BOLD — heaviest; the bold word IS bold */
  font-family: "Archivo Black", "Archivo", sans-serif;
  font-weight: 900;
  letter-spacing: -0.05em;
}

/* --- Reel · 2026 title in Clash Grotesk (Founders-adjacent) --- */
.reel-sect .section-title {
  font-family: "Clash Grotesk", "Inter", system-ui, sans-serif;
  font-weight: 600;
  font-style: normal;
  letter-spacing: -0.02em;
  font-feature-settings: "ss01";
}

/* --- Tri-word slab variant (homepage only) — pin container full height --- */
.slab-sect--tri {
  position: relative;
  height: 100vh;
  min-height: 480px;
  padding: 0;
  background: var(--bg);
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  overflow: hidden;
  display: flex;
  align-items: center;
}
.slab-sect--tri .slab-viewport {
  width: 100%;
  padding: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
}

/* Video players: rounded corners, consistent across Reel + CM doc */
.reel-frame, .cm-doc-frame {
  border-radius: 14px;
  box-shadow: 0 30px 80px rgba(0,0,0,.45);
}
.reel-iframe-mount, .cm-doc-iframe-mount { border-radius: 14px; }

/* Código Mãe documentary video — same visual language as Reel */
.cm-doc {
  position: relative;
  width: min(1100px, 92%);
  margin: 24px auto 40px;
  aspect-ratio: 16/9;
}
.cm-doc-frame {
  position: relative;
  width: 100%; height: 100%;
  overflow: hidden;
  background: #000;
  border: 1px solid var(--hair);
}
.cm-doc-iframe-mount, .cm-doc-iframe-mount iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
  pointer-events: none;
  border-radius: 14px;
}
.cm-doc-iframe-mount iframe {
  filter: grayscale(0.4) brightness(0.85) contrast(1.05);
  transform: scale(1.4);
  transform-origin: center;
}
.cm-doc-overlay {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,.05) 50%, rgba(0,0,0,.45) 100%);
  border-radius: 14px;
}
.cm-doc-meta {
  position: absolute; top: 20px; left: 20px;
  font: 500 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.88);
}
.cm-doc-controls {
  position: absolute; bottom: 20px; right: 20px;
  display: flex; gap: 10px;
}

/* Mobile slab logo: show at natural width, centered, no pin */
@media (max-width: 900px) {
  .slab-sect--logo {
    height: auto !important;
    min-height: 0 !important;
    padding: 12vw 20px 10vw !important;
    display: block !important;
    overflow: visible !important;
  }
  .slab-sect--logo .slab-viewport {
    overflow: visible !important;
    padding: 0 !important;
  }
  .slab-logo {
    height: auto !important;
    width: 100% !important;
    padding-left: 0 !important;
    transform: none !important;
  }
  .slab-logo svg { width: 100% !important; height: auto !important; }

  .cm-doc { width: 100%; margin: 16px 0 24px; }
  .cm-doc-iframe-mount iframe { transform: scale(1.2) !important; }
}
.slab .ch {
  display: inline-block;
  transform-origin: center bottom;
  transition: transform .35s cubic-bezier(.2,.8,.2,1);
  will-change: transform;
}

/* Interleaved Fraunces italic — ONLY on the homepage tri-word slab.
   Series page slabs stay uniform Archivo Black. */
.slab-sect--tri .slab .ch.slab-alt {
  font-family: "Fraunces", "Times New Roman", serif;
  font-style: italic;
  font-weight: 400;
  font-feature-settings: "opsz" 144, "ss01";
  letter-spacing: -0.08em;
  margin-left: -0.015em;
  margin-right: -0.01em;
}

/* Marquee — keep but smaller after slab */
.marquee-sect { padding: 24px 0; border-bottom: 1px solid var(--hair); }
.marquee-track { font-size: clamp(36px, 5vw, 72px); }

/* --- REEL section --- */
.reel-sect { padding: 0 36px 100px; }
.reel { padding-top: 40px; position: relative; }
.reel-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: #000;
  border: 1px solid var(--hair);
}
.reel-iframe-mount, .reel-iframe-mount iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0;
  pointer-events: none;
}
.reel-iframe-mount iframe {
  filter: grayscale(1) brightness(.7) contrast(1.04);
  transform: scale(1.4);    /* hide YouTube center watermark + edges */
  transform-origin: center;
}
.reel-overlay {
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,.10) 50%, rgba(0,0,0,.55) 100%);
}
.reel-meta {
  position: absolute; top: 20px; left: 20px;
  font: 500 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.85);
}
.reel-controls {
  position: absolute; bottom: 20px; right: 20px;
  display: flex; gap: 10px;
}
.rc-btn {
  width: 44px; height: 44px; border-radius: 50%;
  background: rgba(0,0,0,.55); color: #f2ece3;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid rgba(255,255,255,.18);
  pointer-events: auto;
  transition: background .3s var(--ease), transform .3s var(--ease), border-color .3s var(--ease);
  backdrop-filter: blur(8px);
}
.rc-btn:hover { background: var(--accent); border-color: var(--accent); transform: translateY(-2px); }
.rc-btn svg { width: 18px; height: 18px; }
.rc-btn.rc-expand { background: rgba(255,255,255,.12); }

/* --- REEL MODAL (cinematic expand) --- */
.reel-modal {
  position: fixed; inset: 0; z-index: 9700;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(40px) brightness(.4);
  -webkit-backdrop-filter: blur(40px) brightness(.4);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .35s var(--ease);
}
.reel-modal.is-open { opacity: 1; pointer-events: auto; }
.rm-stage {
  width: min(1280px, 92vw);
  aspect-ratio: 16/9;
  background: #000;
  position: relative;
  box-shadow: 0 60px 140px rgba(0,0,0,.7);
  will-change: transform, filter, opacity;
}
.rm-stage iframe {
  position: absolute; inset: 0; width: 100%; height: 100%; border: 0;
  filter: none !important;
  transform: none !important;
  pointer-events: auto;
}
.rm-close {
  position: absolute; top: 28px; right: 28px;
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(255,255,255,.08); color: #fff;
  border: 1px solid rgba(255,255,255,.28);
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
  transition: background .3s var(--ease);
}
.rm-close:hover { background: var(--accent); border-color: var(--accent); }

/* --- CM strip (horizontal pin) --- */
.cm-strip-sect { padding: 0 0 0; }
.cm-strip-sect .section-head { padding-left: 36px; padding-right: 36px; }
.cm-strip-wrap {
  position: relative;
  height: 100vh;
  overflow: hidden;
  background: var(--bg);
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
}
.cm-strip-track {
  position: absolute; top: 0; left: 0;
  height: 100%;
  display: flex;
  align-items: center;
  gap: 28px;
  padding: 0 36px;
  will-change: transform;
}
.cm-card {
  position: relative;
  flex-shrink: 0;
  height: 70vh;
  display: flex; flex-direction: column;
  gap: 10px;
}
.cm-card.ratio-landscape { width: calc(70vh * 1.5); }
.cm-card.ratio-portrait  { width: calc(70vh * .68); }
.cm-card.ratio-square    { width: 70vh; }
.cm-card-img {
  flex: 1;
  background-size: cover; background-position: center;
  transition: transform .6s var(--ease-cine), filter .6s var(--ease-cine);
  filter: brightness(.95);
}
.cm-card:hover .cm-card-img { transform: scale(1.04); filter: brightness(1.05); }
.cm-card-meta {
  display: flex; justify-content: space-between; align-items: baseline;
  font: 500 10px/1.2 var(--f-mono); letter-spacing: .14em; text-transform: uppercase;
  color: var(--fg-dim);
}
.cm-card-title { color: var(--fg); }
.cm-card-dim { color: var(--fg-faint); }
.cm-strip-progress {
  position: absolute; bottom: 32px; left: 36px; right: 36px;
  height: 1px; background: var(--hair);
  z-index: 2;
}
.cm-strip-progress span {
  display: block; height: 100%;
  background: var(--accent);
  transform: scaleX(0); transform-origin: left;
}

/* --- Series list: scramble preview reveal --- */
.series-preview {
  position: fixed; top: 50%; left: 50%; pointer-events: none; z-index: 200;
  width: 360px; aspect-ratio: 3/4;
  transform: translate(-50%, -50%);
  opacity: 0;
  clip-path: inset(100% 0 0 0);
  transition: opacity .25s var(--ease), clip-path .55s var(--ease-cine);
}
.series-preview.is-active { opacity: 1; clip-path: inset(0 0 0 0); }
.series-preview-img {
  width: 100%; height: 100%;
  background-size: cover; background-position: center;
  box-shadow: 0 30px 80px rgba(0,0,0,.6);
}
.series-list .s-name {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "ss01";
}

/* --- CM teaser stats --- */
.cm-stats {
  display: flex; gap: 36px; justify-content: center; flex-wrap: wrap;
  margin: 24px 0 36px;
  font: 500 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-dim);
}
.cm-stats strong {
  font: 300 22px/1 var(--f-display); font-style: italic;
  color: var(--fg);
  margin-right: 8px;
}

/* --- About portrait --- */
.about-portrait-wrap {
  display: flex; flex-direction: column; gap: 12px;
}
.about-portrait {
  aspect-ratio: 3/4;
  background-size: cover; background-position: center 28%;
  filter: grayscale(.06) contrast(1.04);
}
.about-portrait-wrap figcaption {
  font: 400 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-faint);
}

/* --- Contact: arrow LEFT, value MIDDLE, label RIGHT --- */
.cc-contact-row {
  grid-template-columns: 24px 1fr auto;
  gap: 24px;
  text-align: right;
}
.cc-arrow {
  display: inline-flex; align-items: center; justify-content: flex-start;
  color: var(--fg-faint);
  transition: transform .4s var(--ease-cine), color .3s var(--ease);
}
.cc-contact-row:hover { padding-left: 0; }
.cc-contact-row:hover .cc-arrow { color: var(--accent); transform: translateX(8px); }
.cc-contact-row .cc-v {
  text-align: left;
  font: 300 22px/1.1 var(--f-display); font-style: italic;
}
.cc-contact-row .cc-k {
  text-align: right;
  font: 400 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-faint);
}

/* --- WORK OVERLAY (checkout) --- */
.work-overlay {
  position: fixed; inset: 0; z-index: 9600;
  display: grid; grid-template-columns: 1.4fr 1fr;
  background: var(--bg);
  transform: translateY(100%);
  transition: transform .85s cubic-bezier(.76,0,.24,1);
  pointer-events: none;
  overflow: hidden;
}
.work-overlay.is-open { transform: translateY(0); pointer-events: auto; }
.wo-close {
  position: absolute; top: 24px; right: 24px;
  width: 48px; height: 48px; border-radius: 50%;
  border: 1px solid var(--hair-strong);
  display: flex; align-items: center; justify-content: center;
  z-index: 3;
  background: var(--bg);
  transition: background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease);
}
.wo-close:hover { background: var(--fg); color: var(--bg); border-color: var(--fg); }
.wo-grid { display: contents; }
.wo-image {
  position: relative; overflow: hidden;
  background: var(--bg-2) center/cover no-repeat;
  border-right: 1px solid var(--hair);
}
.wo-side {
  display: flex; flex-direction: column; gap: 22px;
  padding: 80px 60px;
  overflow-y: auto;
}
.wo-eyebrow {
  font: 500 10px/1 var(--f-mono);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--accent);
}
.wo-title {
  font: 300 clamp(40px, 5vw, 72px)/1 var(--f-display);
  font-style: italic;
  letter-spacing: -.02em;
  margin: 0;
}
.wo-desc { color: var(--fg-dim); max-width: 50ch; line-height: 1.6; font-size: 15px; }
.wo-specs {
  display: grid; gap: 14px;
  border-top: 1px solid var(--hair);
  padding-top: 24px;
}
.wo-specs > div { display: grid; grid-template-columns: 130px 1fr; gap: 16px; align-items: baseline; }
.wo-specs dt { font: 400 10px/1.4 var(--f-mono); letter-spacing: .2em; text-transform: uppercase; color: var(--fg-faint); }
.wo-specs dd { font-size: 14px; color: var(--fg); }
.wo-price {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 24px 0;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
}
.wo-price-k { font: 400 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase; color: var(--fg-faint); }
.wo-price-v { font: 300 24px/1 var(--f-display); font-style: italic; color: var(--accent); }
.wo-actions { display: flex; flex-direction: column; gap: 10px; }
.wo-cta { width: 100%; justify-content: center; padding: 18px 22px; }
.wo-cta svg, .wo-cta i { display: inline-block; }
.wa-icon { color: currentColor; }
.wo-foot { font-size: 11px; color: var(--fg-faint); line-height: 1.6; }
.wo-series-link {
  font: 500 11px/1 var(--f-mono);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-dim);
  margin-top: 12px;
  align-self: flex-start;
}
.wo-series-link:hover { color: var(--accent); }

/* --- Hero CTA: keep but smaller and darker on dark theme --- */
.hero-bottom .br { display: flex; align-items: center; gap: 18px; }

/* --- Cursor: scale on press --- */
.cursor.is-down .cursor-ring { width: 18px; height: 18px; transition: width .15s var(--ease), height .15s var(--ease); }
.cursor.is-down .cursor-dot  { transform: translate(-50%, -50%) scale(2); transition: transform .15s var(--ease); }

/* --- Remove series page placeholder (handled by content swap) --- */
.sp-slot.slot-placeholder { display: none !important; }

/* --- Reduced motion --- */
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none; }
  .grain { animation: none; }
  .slab .ch { transition: none; }
  .cm-card-img { transition: none; }
}

/* --- Mobile tweaks for new sections --- */
@media (max-width: 900px) {
  .hero-frames .hframe { display: none; }
  .hframe.hf-1, .hframe.hf-5, .hframe.hf-9 { display: block; opacity: .35 !important; }
  .hero-logo { width: 80vw; }

  .slab { font-size: 22vw; }   /* still impactful, less overflow */

  .reel-sect { padding: 0 20px 60px; }

  .cm-strip-wrap { height: auto; padding: 60px 20px; }
  .cm-strip-track {
    position: static; flex-wrap: nowrap; height: auto;
    overflow-x: auto; scroll-snap-type: x mandatory;
    padding: 0; gap: 16px;
  }
  .cm-card { height: 60vh; scroll-snap-align: start; }
  .cm-strip-progress { display: none; }

  .work-overlay { grid-template-columns: 1fr; grid-template-rows: 50vh 1fr; }
  .wo-side { padding: 40px 24px; }

  .cc-contact-row { grid-template-columns: 24px 1fr; }
  .cc-contact-row .cc-k { display: none; }

  .rm-stage { width: 96vw; }
}

/* --- Hide custom cursor over iframe areas (it floats but iframe captures pointer) --- */
.reel-modal, .rm-stage, .reel-iframe-mount { /* cursor: auto; */ }

/* =====================================================================
   v11 — Hero grid alignment + mono typography + passe-partout images
   ===================================================================== */

/* Hero attribution: 12-col grid aligned to 36px like section-head; mono caps */
.hero-attr {
  width: auto !important;
  max-width: none !important;
  padding: 110px 36px 0 !important;
  margin: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(12, 1fr) !important;
  column-gap: 24px !important;
  row-gap: 16px !important;
  font-family: var(--f-mono) !important;
}
.hero-attr .attr-l { grid-column: 1 / span 4; justify-items: start; text-align: left; }
.hero-attr .attr-c { grid-column: 5 / span 4; justify-items: center; text-align: center; }
.hero-attr .attr-r { grid-column: 9 / span 4; justify-items: end;   text-align: right; }
.hero-attr .k {
  font: 500 9px/1 var(--f-mono) !important;
  letter-spacing: .28em !important;
  text-transform: uppercase;
  color: var(--fg-faint) !important;
}
.hero-attr .v {
  font: 500 11px/1.3 var(--f-mono) !important;
  letter-spacing: .18em !important;
  text-transform: uppercase;
  color: var(--fg) !important;
}

/* Hero bottom: same 12-col grid, same mono */
.hero-bottom {
  width: auto !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 36px 40px !important;
  display: grid !important;
  grid-template-columns: repeat(12, 1fr) !important;
  column-gap: 24px !important;
  align-items: end;
  font-family: var(--f-mono) !important;
}
.hero-bottom .bl { grid-column: 1 / span 8; display: flex; align-items: baseline; gap: 16px; }
.hero-bottom .br { grid-column: 9 / span 4; justify-self: end; display: flex; align-items: center; gap: 18px; }
.hero-bottom .bl .k {
  font: 500 9px/1 var(--f-mono) !important;
  letter-spacing: .28em !important;
  text-transform: uppercase;
  color: var(--fg-faint) !important;
}
.hero-bottom .bl .v {
  font: 500 11px/1.3 var(--f-mono) !important;
  letter-spacing: .18em !important;
  text-transform: uppercase;
  color: var(--fg) !important;
}
.hero-bottom .time {
  font: 500 9px/1 var(--f-mono) !important;
  letter-spacing: .26em !important;
  text-transform: uppercase;
  color: var(--fg-faint) !important;
}

/* Section-head: also lay on 12-col grid so headings align with hero */
.section-head {
  padding: 120px 36px 48px !important;
  display: grid !important;
  grid-template-columns: repeat(12, 1fr) !important;
  column-gap: 24px !important;
  row-gap: 16px !important;
}
.section-head .section-num  { grid-column: 1 / span 1; grid-row: 1 / span 2; }
.section-head .section-title{ grid-column: 2 / span 11; }
.section-head .section-sub  { grid-column: 2 / span 8; max-width: none; }

@media (max-width: 900px) {
  .hero-attr { grid-template-columns: 1fr !important; padding: 110px 20px 0 !important; }
  .hero-attr .attr-l, .hero-attr .attr-c, .hero-attr .attr-r {
    grid-column: 1 / -1; justify-items: start; text-align: left;
  }
  .hero-bottom { grid-template-columns: 1fr !important; padding: 0 20px 30px !important; row-gap: 18px; }
  .hero-bottom .bl, .hero-bottom .br { grid-column: 1 / -1; justify-self: start; }
  .section-head { padding: 80px 20px 32px !important; grid-template-columns: 1fr !important; }
  .section-head .section-num, .section-head .section-title, .section-head .section-sub { grid-column: 1; }
}

/* =====================================================================
   PASSE-PARTOUT — all work imagery displayed WHOLE (contain) with
   dark padded frame so the image appears complete with breathing room
   ===================================================================== */

/* Universal frame/image helper applied to every place a work appears */
.pp {
  background-color: var(--bg-2);
  background-origin: content-box !important;
  background-clip: padding-box;
  background-size: contain !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
}

/* Hero frames — tiny, whole images */
.hero-frames .hframe {
  background-color: var(--bg-2) !important;
  background-size: contain !important;
  background-origin: content-box !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  padding: 6px !important;
  filter: grayscale(.18) contrast(1.04);
}

/* Work grid cards: contain inside a padded frame */
.work-card .thumb {
  background: var(--bg-2) !important;
  padding: 0 !important;
}
.work-card .thumb .ph-inner {
  background-color: transparent !important;
  background-size: contain !important;
  background-origin: content-box !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  padding: 28px !important;
  transition: transform .8s var(--ease-cine), filter .6s var(--ease);
}
/* Reduce hover scale since image is contained (looks weird if too aggressive) */
.work-card:hover .thumb .ph-inner { transform: scale(1.015) !important; filter: brightness(1.05); }
.work-card:hover .thumb { outline: 1px solid var(--hair-strong); }

/* CM strip cards */
.cm-card {
  background: var(--bg-2);
  padding: 0;
}
.cm-card-img {
  background-color: transparent !important;
  background-size: contain !important;
  background-origin: content-box !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  padding: 22px !important;
}
.cm-card:hover .cm-card-img { transform: scale(1.012) !important; filter: brightness(1.03) !important; }

/* CM series page gallery slots */
.sp-cm { background: var(--bg-2); }
.sp-cm .bg {
  background-size: contain !important;
  background-origin: content-box !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  padding: 24px !important;
  background-color: transparent !important;
  filter: brightness(.96);
}
.sp-cm:hover .bg { transform: scale(1.012) !important; filter: brightness(1.05) !important; }

/* Per-series page slots */
.sp-gallery .sp-slot { background: var(--bg-2); }
.sp-gallery .sp-slot .bg {
  background-size: contain !important;
  background-origin: content-box !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  padding: 32px !important;
  background-color: transparent !important;
}

/* Work overlay left image gets generous passe-partout */
.wo-image {
  background-color: var(--bg-2) !important;
  background-size: contain !important;
  background-origin: content-box !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  padding: 64px !important;
}

/* Lightbox already uses contain — ensure consistent (no change needed but force) */
.cm-lb-img {
  background-color: transparent;
  background-size: contain !important;
  padding: 32px;
  background-origin: content-box !important;
  background-repeat: no-repeat;
  background-position: center;
}

/* Hero frames — mobile keep small */
@media (max-width: 900px) {
  .hero-frames .hframe { padding: 4px !important; }
  .work-card .thumb .ph-inner { padding: 16px !important; }
  .cm-card-img { padding: 14px !important; }
  .sp-cm .bg { padding: 14px !important; }
  .sp-gallery .sp-slot .bg { padding: 18px !important; }
  .wo-image { padding: 24px !important; }
}

/* =====================================================================
   CÓDIGO MÃE SERIES PAGE — full gallery + lightbox + group index
   ===================================================================== */
.sp-gallery-cm {
  padding: 60px 36px 80px;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-flow: dense;
  gap: 14px;
}
.sp-cm { position: relative; overflow: hidden; cursor: none; }
.sp-cm .bg {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  transition: transform 1s var(--ease-cine), filter .8s var(--ease);
  filter: brightness(.92);
}
.sp-cm:hover .bg { transform: scale(1.05); filter: brightness(1.05); }
.sp-cm .cap {
  position: absolute; left: 14px; bottom: 14px; z-index: 2;
  font: 500 10px/1.2 var(--f-mono); letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.92);
  text-shadow: 0 2px 8px rgba(0,0,0,.6);
  opacity: 0; transform: translateY(8px);
  transition: opacity .4s var(--ease), transform .4s var(--ease);
}
.sp-cm:hover .cap { opacity: 1; transform: translateY(0); }

/* Span sizes */
.sp-cm-feature   { grid-column: span 12; aspect-ratio: 21/9;  }
.sp-cm-wide      { grid-column: span 8;  aspect-ratio: 16/10; }
.sp-cm-landscape { grid-column: span 4;  aspect-ratio: 75/53; }
.sp-cm-portrait  { grid-column: span 3;  aspect-ratio: 3/4;   }
.sp-cm-square    { grid-column: span 3;  aspect-ratio: 1/1;   }

@media (max-width: 1100px) {
  .sp-cm-landscape { grid-column: span 6; }
  .sp-cm-portrait, .sp-cm-square { grid-column: span 4; }
}
@media (max-width: 700px) {
  .sp-gallery-cm { grid-template-columns: repeat(6, 1fr); padding: 40px 20px 60px; gap: 10px; }
  .sp-cm-feature, .sp-cm-wide { grid-column: span 6; aspect-ratio: 16/10; }
  .sp-cm-landscape { grid-column: span 6; }
  .sp-cm-portrait, .sp-cm-square { grid-column: span 3; }
}

/* CM groups index */
.sp-groups {
  padding: 60px 36px 80px;
  border-top: 1px solid var(--hair);
}
.cm-groups-title {
  font: 300 clamp(28px, 3.5vw, 44px)/1 var(--f-display);
  font-style: italic; letter-spacing: -.01em;
  margin-bottom: 32px;
}
.cm-groups-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0;
  border-top: 1px solid var(--hair);
}
.cm-group {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 24px 0;
  border-bottom: 1px solid var(--hair);
}
.cm-group-name {
  font: 300 24px/1 var(--f-display); font-style: italic;
  color: var(--fg);
}
.cm-group-count {
  font: 500 10px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-faint);
}

/* CM Lightbox */
.cm-lightbox {
  position: fixed; inset: 0; z-index: 9700;
  background: rgba(0,0,0,.92);
  backdrop-filter: blur(20px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .35s var(--ease);
}
.cm-lightbox.is-open { opacity: 1; pointer-events: auto; }
.cm-lb-stage {
  width: min(1200px, 90vw);
  height: 88vh;
  display: flex; flex-direction: column; gap: 16px;
  margin: 0;
}
.cm-lb-img {
  flex: 1;
  background-size: contain; background-position: center; background-repeat: no-repeat;
}
.cm-lb-cap {
  display: grid; grid-template-columns: 1fr 2fr 1fr;
  font: 500 11px/1 var(--f-mono); letter-spacing: .22em; text-transform: uppercase;
  color: rgba(242,236,227,.78);
  text-align: center;
}
.cm-lb-cap span:first-child { text-align: left; }
.cm-lb-cap span:last-child  { text-align: right; }
.cm-lb-close, .cm-lb-prev, .cm-lb-next {
  position: absolute; z-index: 2;
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(255,255,255,.06); color: #fff;
  border: 1px solid rgba(255,255,255,.22);
  display: flex; align-items: center; justify-content: center;
  cursor: none;
  transition: background .3s var(--ease), border-color .3s var(--ease);
}
.cm-lb-close { top: 28px; right: 28px; }
.cm-lb-prev  { top: 50%; left: 28px;  transform: translateY(-50%); }
.cm-lb-next  { top: 50%; right: 28px; transform: translateY(-50%); }
.cm-lb-close:hover, .cm-lb-prev:hover, .cm-lb-next:hover {
  background: var(--accent); border-color: var(--accent);
}
@media (max-width: 700px) {
  .cm-lb-prev { left: 12px; }
  .cm-lb-next { right: 12px; }
  .cm-lb-stage { width: 96vw; height: 80vh; }
}

/* =====================================================================
   Per-series page renderer (sp-real tiles)
   ===================================================================== */
.sp-real {
  position: relative;
  overflow: hidden;
  cursor: none;
  background: var(--bg-2);
}
.sp-real .bg {
  position: absolute; inset: 0;
  transition: transform 1s var(--ease-cine), filter .8s var(--ease);
  filter: brightness(.96);
}
.sp-real:hover .bg { transform: scale(1.012); filter: brightness(1.05); }
.sp-real .cap {
  position: absolute; left: 18px; bottom: 18px; z-index: 2;
  font: 500 10px/1.2 var(--f-mono); letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,255,255,.92);
  text-shadow: 0 2px 8px rgba(0,0,0,.6);
  opacity: 0; transform: translateY(8px);
  transition: opacity .4s var(--ease), transform .4s var(--ease);
}
.sp-real:hover .cap { opacity: 1; transform: translateY(0); }

/* Override the 80px outer padding so per-series gallery aligns with site grid */
.sp-gallery {
  padding: 80px 36px 120px;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-flow: dense;
  gap: 16px;
}
.sp-span-std  { grid-column: span 4; aspect-ratio: 4/5; }
.sp-span-wide { grid-column: span 6; aspect-ratio: 16/10; }
.sp-empty { grid-column: 1 / -1; padding: 80px 0; text-align: center; color: var(--fg-faint); font-style: italic; }
@media (max-width: 1100px) {
  .sp-span-std  { grid-column: span 6; }
  .sp-span-wide { grid-column: span 12; aspect-ratio: 16/10; }
}
@media (max-width: 700px) {
  .sp-gallery { grid-template-columns: repeat(6, 1fr); padding: 40px 20px 60px; gap: 10px; }
  .sp-span-std, .sp-span-wide { grid-column: span 3; aspect-ratio: 4/5; }
}

/* On per-series pages: a compact slab — no massive 100vh dead space */
.sp-page-slab {
  padding: 2vw 36px 1.5vw;
  border-top: 1px solid var(--hair);
}

/* =====================================================================
   v12 — Hero grid alignment (logo + Em cartaz + ticker under "Obras"),
         CTA flush-right, shimmering exhibitions ticker
   ===================================================================== */

/* Nav becomes a 12-col grid so "Obras" (first nav-link) sits on col 5 */
.nav {
  display: grid !important;
  grid-template-columns: repeat(12, 1fr);
  column-gap: 24px;
  padding: 22px 36px;
  align-items: center;
}
.nav-logo  { grid-column: 1 / span 3; display: inline-flex; align-items: center; }
.nav-links { grid-column: 5 / span 6; display: flex; gap: 32px; justify-content: flex-start; align-items: center; }
.nav-right { grid-column: 11 / span 2; display: flex; gap: 20px; align-items: center; justify-self: end; }

/* Hero center (logo) now lives on the same 12-col grid; logo left-edge at col 5 */
.hero-center {
  grid-row: 2;
  align-self: center;
  justify-self: stretch !important;
  padding: 0 36px !important;
  max-width: none !important;
  text-align: left !important;
  display: grid !important;
  grid-template-columns: repeat(12, 1fr) !important;
  column-gap: 24px !important;
  width: 100% !important;
}
.hero-logo {
  grid-column: 5 / span 8 !important;
  justify-self: start !important;
  justify-content: flex-start !important;
  align-items: center !important;
  width: 100% !important;
  max-width: 720px !important;
  margin: 0 !important;
}

/* Hero attribution row: attr-c now LEFT-aligned at col 5 (matches "Obras" and logo) */
.hero-attr .attr-c {
  justify-items: start !important;
  text-align: left !important;
}

/* Hero bottom: 3-column grid → counter (col 1-4) · ticker (col 5-8, aligned w/ Obras) · CTA (col 9-12 flush right) */
.hero-bottom {
  padding: 0 36px 40px !important;
  display: grid !important;
  grid-template-columns: repeat(12, 1fr) !important;
  column-gap: 24px !important;
  align-items: center !important;
}
.hero-bottom .bl     { grid-column: 1 / span 4 !important; justify-self: start; display: flex; align-items: baseline; gap: 16px; }
.hero-bottom .hero-ticker { grid-column: 5 / span 4; justify-self: stretch; align-self: center; }
.hero-bottom .hero-cta    { grid-column: 9 / span 4 !important; justify-self: end !important; }

/* ---------- Exhibitions ticker · looped marquee + shimmer ---------- */
.hero-ticker {
  position: relative;
  height: 14px;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0%, #000 10%, #000 90%, transparent 100%);
}
.hero-ticker-track {
  display: flex;
  gap: 22px;
  white-space: nowrap;
  animation: heroTickerScroll 42s linear infinite;
  will-change: transform;
  font: 500 10px/1 var(--f-mono);
  letter-spacing: .22em;
  text-transform: uppercase;
}
.hero-ticker-track span {
  background: linear-gradient(110deg,
    var(--fg-dim) 0%,
    var(--fg-dim) 42%,
    var(--fg)    50%,
    var(--fg-dim) 58%,
    var(--fg-dim) 100%
  );
  background-size: 220% 100%;
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
  animation: heroTickerShimmer 3.8s linear infinite;
}
.hero-ticker-track .tk-lead {
  background: linear-gradient(110deg,
    var(--accent) 0%, var(--accent) 42%,
    #f2ece3 50%,
    var(--accent) 58%, var(--accent) 100%);
  background-size: 220% 100%;
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
}
.hero-ticker-track i {
  color: var(--accent);
  font-style: normal;
  opacity: .7;
}
@keyframes heroTickerScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes heroTickerShimmer {
  from { background-position: 220% 0; }
  to   { background-position: -220% 0; }
}
@media (prefers-reduced-motion: reduce) {
  .hero-ticker-track { animation: none; }
  .hero-ticker-track span, .hero-ticker-track .tk-lead {
    animation: none; color: var(--fg); -webkit-background-clip: initial; background-clip: initial;
  }
}

/* Mobile */
@media (max-width: 900px) {
  .nav { grid-template-columns: auto 1fr auto; padding: 16px 20px; }
  .nav-logo  { grid-column: 1; }
  .nav-links { display: none !important; }
  .nav-right { grid-column: 3; justify-self: end; }

  .hero-center { padding: 0 20px !important; }
  .hero-logo   { grid-column: 1 / -1 !important; max-width: 90vw !important; }

  .hero-bottom { grid-template-columns: 1fr !important; padding: 0 20px 30px !important; row-gap: 14px !important; }
  .hero-bottom .bl, .hero-bottom .hero-ticker, .hero-bottom .hero-cta { grid-column: 1 / -1 !important; justify-self: start !important; }

  .hero-attr .attr-c, .hero-attr .attr-r {
    justify-items: start !important; text-align: left !important;
  }
}

/* =====================================================================
   v13 — Hero logo hover polish (desktop + mobile) + mobile menu
        + mobile-only reflow for every flow / tap-target pass
   ===================================================================== */

/* ============================================================
   Hero composition — bulletproof overflow scaffolding (v17)
   The hero-stage previously had overflow:hidden (line ~1066),
   which clipped the SVG filter bleed even with overflow:visible
   on the SVG itself. Every ancestor from the <path> up to the
   section is pinned to visible here so nothing clips the logo
   filters (blur bleed, opacity, transform) on any browser.
   ============================================================ */
.hero-stage   { overflow: visible !important; }
.hero-center  { overflow: visible !important; }
.hero-frames  { overflow: visible !important; }
.hero-logo    { cursor: none; touch-action: manipulation; overflow: visible !important; }
.hero-logo svg       { overflow: visible !important; }
.hero-logo svg *     { overflow: visible !important; }

/* ============================================================
   Hero LETTER FRAMES — 2 small thumbs revealed on letter hover
   Each letter in the logo is mapped to a series; as the focus
   pool moves across the letters, the pair of thumbs swaps to
   show 2 images from the active series. Sits in the hero's
   whitespace — intentionally modest so it never competes with
   the logo itself.
   ============================================================ */
.hero-letter-frames {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 3;
}
.hlf-slot {
  position: absolute;
  margin: 0;
  width: clamp(120px, 13vw, 170px);
  aspect-ratio: 4 / 5;
  background: var(--bg-2);
  padding: 10px;
  box-shadow: 0 20px 50px rgba(0,0,0,.5);
  opacity: 0;
  will-change: opacity, filter, transform;
  filter: blur(14px);
  transform: translate3d(0, 14px, 0) scale(.94);
  overflow: hidden;
}
.hlf-slot.hlf-a {
  top:  12vh;
  left: 6vw;
}
.hlf-slot.hlf-b {
  bottom: 14vh;
  right:  6vw;
}
.hlf-bg {
  position: absolute; inset: 10px;
  background-color: transparent;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
.hlf-cap {
  position: absolute; left: 12px; bottom: 12px; right: 12px;
  font: 500 8px/1 var(--f-mono);
  letter-spacing: .24em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .78);
  text-shadow: 0 1px 6px rgba(0, 0, 0, .6);
  z-index: 2;
}

/* On touch / small screens, hide the letter frames — they rely on
   a cursor-driven focus pool and compete with the mobile layout. */
@media (max-width: 900px) {
  .hero-letter-frames { display: none !important; }
}
@media (hover: none) {
  .hero-letter-frames { display: none !important; }
}

/* --- CM letter frames (mirror of hero-letter-frames) ---
   Constrained to the logo's vertical band (below the eyebrow, above the
   video) so slot positions reference just the logo area, not the full
   section. This keeps the obras next to the logo like in the hero. */
.cm-letter-frames {
  position: absolute;
  top: 140px;
  left: 0; right: 0;
  height: clamp(280px, 38vh, 420px);
  pointer-events: none;
  z-index: 3;
}
.clf-slot {
  position: absolute;
  margin: 0;
  width: clamp(130px, 13vw, 180px);
  aspect-ratio: 4 / 5;
  background: var(--bg-3);
  padding: 22px;  /* generous passe-partout — obra breathes */
  box-shadow: 0 20px 50px rgba(0,0,0,.5);
  opacity: 0;
  will-change: opacity, filter, transform;
  filter: blur(14px);
  overflow: hidden;
  transition:
    opacity .5s cubic-bezier(.2,.8,.2,1),
    filter  .55s cubic-bezier(.2,.8,.2,1),
    transform .55s cubic-bezier(.2,.8,.2,1);
}
/* Slot A lives on the LEFT side, slot B on the RIGHT, both vertically
   centered. The closed state combines the vertical centering with a
   subtle y/scale entrance; the open state keeps only the centering. */
.clf-slot.clf-a {
  top: 50%; left: 4%;
  transform: translateY(-50%) translate3d(0, 14px, 0) scale(.94);
}
.clf-slot.clf-b {
  top: 50%; right: 4%;
  transform: translateY(-50%) translate3d(0, 14px, 0) scale(.94);
  transition-delay: .08s;   /* natural stagger without JS timers */
}
.clf-slot.clf-a.is-open,
.clf-slot.clf-b.is-open {
  opacity: 1;
  filter: blur(0px);
  transform: translateY(-50%) translate3d(0, 0, 0) scale(1);
}
.clf-bg {
  position: absolute;
  inset: 22px 22px 42px 22px; /* extra bottom pad so caption has room */
  background-color: transparent;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
.clf-cap {
  position: absolute; left: 22px; bottom: 14px; right: 22px;
  font: 500 8px/1 var(--f-mono);
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--fg-dim);
  z-index: 2;
}
@media (max-width: 900px), (hover: none) {
  .cm-letter-frames { display: none !important; }
}

.cm { position: relative; }  /* ensure letter-frames anchor to the CM section */
.hero-logo svg path {
  transform-box: fill-box;
  transform-origin: center;
  transition: fill .25s var(--ease);
  will-change: transform, fill;
}

/* --- Hamburger (appears in nav-right on mobile only) --- */
.nav-burger {
  display: none;
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--hair-strong);
  background: transparent;
  padding: 0;
  flex-direction: column; align-items: center; justify-content: center;
  gap: 5px; cursor: pointer;
  transition: background .25s var(--ease), border-color .25s var(--ease);
}
.nav-burger span {
  display: block; width: 18px; height: 1.5px;
  background: var(--fg);
  transition: transform .3s var(--ease-cine), opacity .25s var(--ease);
}
.nav-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(3px) rotate(45deg); }
.nav-burger[aria-expanded="true"] span:nth-child(2) { transform: translateY(-3px) rotate(-45deg); }
.nav-burger:hover { background: var(--bg-2); border-color: var(--fg); }

/* --- Mobile menu overlay --- */
.nav-menu {
  position: fixed; inset: 0; z-index: 9800;
  background: var(--bg);
  display: flex; align-items: stretch; justify-content: stretch;
  opacity: 0; pointer-events: none;
  transition: opacity .28s var(--ease);
}
.nav-menu.is-open { opacity: 1; pointer-events: auto; }
.nav-menu-inner {
  width: 100%; max-width: 100vw;
  padding: 20px 24px 32px;
  display: grid; grid-template-rows: auto 1fr auto;
  gap: 24px;
}
.nav-menu-head {
  display: flex; align-items: center; justify-content: space-between;
}
.nav-menu-brand {
  font: 500 10px/1 var(--f-mono);
  letter-spacing: .28em; text-transform: uppercase;
  color: var(--fg-faint);
}
.nav-menu-close {
  width: 44px; height: 44px; border-radius: 50%;
  border: 1px solid var(--hair-strong); background: transparent;
  color: var(--fg);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.nav-menu-links {
  display: flex; flex-direction: column; justify-content: center;
  gap: 2px; padding: 32px 0;
}
.nav-menu-links a {
  display: block; padding: 12px 0;
  font-family: "Fraunces", "Times New Roman", serif;
  font-weight: 300;
  font-style: italic;
  font-size: clamp(40px, 9vw, 64px);
  line-height: 1;
  letter-spacing: -.02em;
  color: var(--fg);
  text-decoration: none;
  border-bottom: 1px solid var(--hair);
  transition: color .3s var(--ease);
}
.nav-menu-links a em { font-style: italic; font-weight: 400; }
.nav-menu-links a:active { color: var(--accent); }
.nav-menu-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 16px;
  border-top: 1px solid var(--hair);
}
.nav-menu-wa {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 18px;
  background: var(--fg); color: var(--bg);
  border-radius: 999px;
  font: 500 11px/1 var(--f-mono);
  letter-spacing: .2em; text-transform: uppercase;
  text-decoration: none;
}
.nav-menu-lang {
  font: 500 11px/1 var(--f-mono);
  letter-spacing: .28em; text-transform: uppercase;
  color: var(--fg-faint);
}

/* --- Slab stacked variant (mobile 2-line) --- */
.slab--stacked { line-height: .85; }
.slab--stacked .ch:nth-child(8)::before { content: "\A"; white-space: pre; }
/* GABRIELWICKBOLD break after 'GABRIEL' (char 8). For SEXUALCOLORS break after 'SEXUAL' (char 7): */
.slab[data-text="SEXUALCOLORS"].slab--stacked .ch:nth-child(7)::before { content: "\A"; white-space: pre; }
.slab[data-text="SEXUALCOLORS"].slab--stacked .ch:nth-child(8)::before { content: ""; }
/* CODIGOMAE: break after 'CODIGO' (char 6) */
.slab[data-text="CODIGOMAE"].slab--stacked .ch:nth-child(6)::before { content: "\A"; white-space: pre; }
.slab[data-text="CODIGOMAE"].slab--stacked .ch:nth-child(8)::before { content: ""; }

/* =====================================================================
   MOBILE (≤900px) — reflow every flow
   ===================================================================== */
@media (max-width: 900px) {

  /* ---- Nav: show hamburger, hide desktop links ---- */
  .nav { padding: 14px 18px !important; grid-template-columns: 1fr auto !important; }
  .nav-logo  { grid-column: 1 !important; }
  .nav-right { grid-column: 2 !important; }
  .nav-links { display: none !important; }
  .nav-burger { display: inline-flex !important; }
  .lang-btn { display: none; }      /* folded into the menu */
  .theme-btn { width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center; }
  .theme-track { width: 44px; height: 22px; }
  .theme-thumb { width: 16px; height: 16px; top: 3px; }
  [data-theme="light"] .theme-thumb { transform: translateX(22px); }

  /* ---- Hero: tighter composition, logo full-width, ticker compressed ---- */
  .hero-stage { min-height: 92vh; }
  .hero-attr  { padding: 96px 20px 0 !important; row-gap: 14px !important; }
  .hero-attr .k { font-size: 8px !important; letter-spacing: .3em !important; }
  .hero-attr .v { font-size: 10px !important; line-height: 1.35 !important; letter-spacing: .16em !important; }

  .hero-center { padding: 0 20px !important; }
  .hero-logo   { grid-column: 1 / -1 !important; max-width: min(440px, 82vw) !important; margin: 0 auto !important; justify-self: center !important; justify-content: center !important; }

  .hero-bottom { padding: 0 20px 28px !important; row-gap: 16px !important; }
  .hero-bottom .bl { display: flex; align-items: baseline; gap: 12px; }
  .hero-bottom .bl .k, .hero-bottom .bl .v { font-size: 10px !important; line-height: 1.35 !important; }
  .hero-ticker { height: 12px !important; }
  .hero-ticker-track { gap: 14px !important; animation-duration: 32s !important; font-size: 9px !important; letter-spacing: .18em !important; }
  .hero-bottom .hero-cta {
    width: 100% !important; justify-content: center !important;
    padding: 16px 20px !important; min-height: 52px;
    border-radius: 4px !important;
  }
  .hero-bottom .hero-cta span { font-size: 12px; letter-spacing: .22em; }

  /* ---- Slab mobile: disable pin, stack words vertically ---- */
  .slab-sect {
    height: auto !important; min-height: 0 !important;
    padding: 14vw 20px 10vw !important;
    display: block !important;
    overflow: visible !important;
  }
  .slab-viewport { overflow: visible !important; padding: 0 !important; }
  .slab { font-size: 17vw !important; letter-spacing: -.04em !important; }
  .slab.slab--tri {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    gap: 0 !important;
    font-size: 22vw !important;
    line-height: 0.92 !important;
    white-space: normal !important;
    text-align: left !important;
    transform: none !important;       /* disable any GSAP transform leaked from desktop */
    padding-right: 0 !important;
  }
  .slab-word { display: block; }
  .slab-w1 { letter-spacing: -0.03em; }
  .slab-w2 { letter-spacing: -0.03em; }
  .slab-w3 { letter-spacing: -0.05em; }

  /* ---- Reel ---- */
  .reel-sect { padding: 0 20px 60px !important; }
  .reel { padding-top: 28px !important; }
  .reel-iframe-mount iframe { transform: scale(1.2) !important; }
  .reel-controls { bottom: 14px !important; right: 14px !important; gap: 10px !important; }
  .rc-btn { width: 48px; height: 48px; }

  .reel-modal { padding: 16px; }
  .reel-modal { backdrop-filter: blur(20px) brightness(.5) !important; -webkit-backdrop-filter: blur(20px) brightness(.5) !important; }
  .rm-close { top: 16px; right: 16px; }

  /* ---- Featured grid: single column, reduced passe-partout ---- */
  .work-grid { grid-template-columns: 1fr !important; gap: 20px !important; }
  .work-card.lg, .work-card.md, .work-card.sm, .work-card.wd { grid-column: 1 / -1 !important; }
  .work-card .thumb .ph-inner { padding: 18px !important; }
  .work-card .meta-row { font-size: 9px; }
  .work-card .wtitle { font-size: 20px; }

  /* ---- CM strip (horizontal, native scroll-snap on touch) ---- */
  .cm-strip-wrap {
    height: auto !important;
    min-height: 0 !important;
    padding: 24px 0 16px !important;
    overflow: hidden !important;
    position: relative !important;
  }
  .cm-strip-track {
    position: relative !important;  /* was absolute on desktop; GSAP killed on mobile */
    inset: auto !important;
    transform: none !important;     /* clear any residual GSAP transform */
    height: auto !important;
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior-x: contain !important;
    scroll-snap-type: x mandatory !important;
    scroll-padding-inline-start: 20px !important;
    padding: 6px 20px 20px !important;
    gap: 14px !important;
    will-change: scroll-position !important;
  }
  /* hide native scrollbar for cleanliness */
  .cm-strip-track::-webkit-scrollbar { display: none; }
  .cm-strip-track { scrollbar-width: none; }

  .cm-card {
    height: 52vh !important;
    min-height: 320px !important;
    max-height: 520px !important;
    flex-shrink: 0 !important;
    scroll-snap-align: start !important;
  }
  .cm-card.ratio-landscape { width: 84vw !important; max-width: 520px !important; }
  .cm-card.ratio-portrait  { width: 60vw !important; max-width: 360px !important; }
  .cm-card.ratio-square    { width: 72vw !important; max-width: 440px !important; }
  .cm-card-img { padding: 14px !important; }
  .cm-card-meta { padding: 0 2px; }
  .cm-strip-progress { display: none !important; }

  /* ---- Series list: remove cursor-follower preview on touch, tighter rows ---- */
  .series-preview { display: none !important; }
  .series-list li, .series-list .series-li-inner {
    grid-template-columns: 40px 1fr auto !important;
    gap: 12px !important; padding: 22px 0 !important;
  }
  .series-list .s-count { display: none !important; }
  .series-list .s-name { font-size: clamp(26px, 7vw, 40px) !important; }
  .series-list .s-year { font-size: 10px; }

  /* ---- CM teaser + About + Contact ---- */
  .cm { padding: 60px 20px !important; }
  .cm-logo-wrap { margin: 10px 0 40px !important; }
  .cm-stats { gap: 18px !important; flex-wrap: wrap; font-size: 9px !important; }
  .cm-stats strong { font-size: 18px !important; }
  .cm .cm-cta { padding: 16px 22px !important; }

  .about { padding: 0 20px 80px !important; }
  .about-grid { grid-template-columns: 1fr !important; gap: 32px !important; }
  .about-portrait { aspect-ratio: 4/5; }
  .about-stats { grid-template-columns: repeat(2, 1fr) !important; gap: 20px !important; }
  .about-stats strong { font-size: 36px !important; }

  .contact-compact { padding: 40px 20px 0 !important; border-top-width: 1px; }
  .cc-inner { grid-template-columns: 1fr !important; gap: 28px !important; padding-bottom: 48px !important; }
  .cc-title { font-size: clamp(32px, 8vw, 48px) !important; }
  .cc-sub { font-size: 14px !important; max-width: none; }
  .cc-contact-row {
    grid-template-columns: 24px 1fr !important;
    text-align: left !important;
    padding: 18px 0 !important;
    min-height: 56px;
  }
  .cc-contact-row .cc-k { display: none !important; }
  .cc-contact-row .cc-v { font-size: 18px !important; line-height: 1.2; }
  .cc-contact-row:hover { padding-left: 0 !important; }

  /* ---- Footer ---- */
  .foot {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px !important;
    padding: 24px 0 !important;
  }

  /* ---- Work overlay / checkout: sticky-footer CTA pattern ---- */
  .work-overlay {
    grid-template-columns: 1fr !important;
    grid-template-rows: 42vh 1fr auto !important;
  }
  .wo-close { top: 14px !important; right: 14px !important; width: 44px !important; height: 44px !important; }
  .wo-image  { padding: 14px !important; border-right: none !important; border-bottom: 1px solid var(--hair); }
  .wo-side   { padding: 24px 20px 140px !important; gap: 16px !important; overflow-y: auto; }
  .wo-title  { font-size: 32px !important; }
  .wo-desc   { font-size: 14px !important; line-height: 1.55; }
  .wo-specs > div { grid-template-columns: 100px 1fr !important; gap: 12px !important; }
  .wo-specs dd { font-size: 13px !important; }
  .wo-price  { padding: 18px 0 !important; }
  .wo-price-v { font-size: 18px !important; }
  .wo-actions {
    position: fixed !important;
    left: 0; right: 0; bottom: 0;
    padding: 14px 20px calc(14px + env(safe-area-inset-bottom, 0px)) !important;
    background: linear-gradient(to top, var(--bg) 76%, rgba(10,9,8,0) 100%);
    z-index: 4;
    gap: 10px !important;
  }
  .wo-cta { padding: 16px 18px !important; min-height: 54px; font-size: 11px !important; }
  .wo-foot { font-size: 11px !important; }
  .wo-series-link { margin-top: 12px !important; }

  /* ---- Series pages (non-CM) ---- */
  .sp-hero { height: 60vh !important; min-height: 420px !important; padding: 0 20px 32px !important; }
  .sp-title { font-size: clamp(56px, 16vw, 96px) !important; }
  .sp-meta-row { gap: 14px !important; font-size: 10px !important; margin-top: 20px !important; }
  .sp-intro { padding: 48px 20px !important; grid-template-columns: 1fr !important; gap: 20px !important; }
  .sp-intro .kicker { font-size: 26px !important; }
  .sp-intro .body { font-size: 14px; }
  .sp-page-slab { padding: 20px 0 0 !important; }
  .sp-gallery { grid-template-columns: repeat(2, 1fr) !important; padding: 32px 16px 60px !important; gap: 10px !important; }
  .sp-span-std, .sp-span-wide { grid-column: span 1 !important; aspect-ratio: 4/5 !important; }
  .sp-span-wide { grid-column: span 2 !important; aspect-ratio: 16/10 !important; }
  .sp-gallery .sp-slot .bg { padding: 14px !important; }
  .sp-footer { grid-template-columns: 1fr !important; padding: 40px 20px !important; gap: 20px !important; }
  .sp-footer-right { justify-content: flex-start !important; }
  .sp-footer-right .btn { width: 100%; justify-content: center; padding: 16px 22px; min-height: 52px; }
  .sp-nav { grid-template-columns: 1fr !important; padding: 0 20px 48px !important; gap: 12px !important; }
  .sp-nav a { padding: 24px 20px !important; }
  .sp-nav .t { font-size: 22px !important; }

  /* ---- Código Mãe series page gallery ---- */
  .sp-gallery-cm { grid-template-columns: repeat(2, 1fr) !important; padding: 40px 16px 60px !important; gap: 10px !important; }
  .sp-cm-feature { grid-column: span 2 !important; aspect-ratio: 16/9 !important; }
  .sp-cm-wide    { grid-column: span 2 !important; aspect-ratio: 16/10 !important; }
  .sp-cm-landscape { grid-column: span 2 !important; aspect-ratio: 75/53 !important; }
  .sp-cm-portrait  { grid-column: span 1 !important; aspect-ratio: 3/4 !important; }
  .sp-cm-square    { grid-column: span 1 !important; aspect-ratio: 1/1 !important; }
  .sp-cm .bg { padding: 14px !important; }
  .sp-groups { padding: 40px 20px !important; }
  .cm-groups-title { font-size: 28px !important; margin-bottom: 16px !important; }
  .cm-group { padding: 16px 0 !important; }
  .cm-group-name { font-size: 20px !important; }

  /* ---- Intro loader ---- */
  .intro-status { left: 20px !important; right: 20px !important; bottom: 24px !important; gap: 12px !important; font-size: 9px !important; padding-top: 10px !important; flex-wrap: wrap !important; }
  .intro-logo { width: 82vw !important; }

  /* ---- Hero frames: only 3 visible, absolute corner positions ---- */
  .hero-frames .hframe { display: none !important; }
  .hframe.hf-1 { display: block !important; opacity: .34 !important; top: 14% !important; left: 3% !important; width: 22% !important; }
  .hframe.hf-5 { display: block !important; opacity: .34 !important; top: 8%  !important; right: 3% !important; width: 22% !important; }
  .hframe.hf-9 { display: block !important; opacity: .34 !important; bottom: 14% !important; right: 3% !important; width: 22% !important; }

  /* ---- CM lightbox (kept from earlier) ---- */
  .cm-lb-stage { width: 96vw; height: 82vh; }

  /* ---- Section head ---- */
  .section-head { padding: 72px 20px 28px !important; grid-template-columns: 1fr !important; row-gap: 12px !important; }
  .section-head .section-num, .section-head .section-title, .section-head .section-sub {
    grid-column: 1 !important;
  }
  .section-head .section-title { font-size: clamp(32px, 8vw, 48px) !important; }
  .section-head .section-sub   { font-size: 13px !important; }
}

/* Finer tuning for very narrow phones (≤600px) */
@media (max-width: 600px) {
  .work-card .thumb .ph-inner { padding: 14px !important; }
  .sp-gallery { grid-template-columns: 1fr !important; padding: 24px 16px 48px !important; }
  .sp-span-std, .sp-span-wide { grid-column: 1 / -1 !important; aspect-ratio: 4/5 !important; }
  .sp-gallery-cm { grid-template-columns: 1fr !important; }
  .sp-cm-feature, .sp-cm-wide, .sp-cm-landscape, .sp-cm-portrait, .sp-cm-square { grid-column: 1 / -1 !important; }
  .sp-cm-landscape { aspect-ratio: 75/53 !important; }
  .cm-card.ratio-landscape { width: 86vw !important; }
  .cm-card.ratio-portrait  { width: 62vw !important; }
  .cm-card.ratio-square    { width: 78vw !important; }
  .nav-menu-links a { font-size: clamp(34px, 10vw, 56px); padding: 10px 0 !important; }
}

/* Touch devices: hide custom cursor, simplify passive hover affordances */
.is-touch .cursor { display: none !important; }
.is-touch body { cursor: auto !important; }
.is-touch button, .is-touch a { cursor: pointer !important; }

/* ============================================================================
   EXPOSIÇÕES PAGE — v1
   Anais cinematográficos. White-space generoso, typographic-first,
   hairlines impecáveis, restraint nas cores. Drop-caps, oldstyle numerals,
   sticky years, accent rail scroll-driven.
   Scoping: every selector lives under [data-page="exposicoes"].
   ============================================================================ */

[data-page="exposicoes"] {
  --ex-pad-x: clamp(20px, 4vw, 56px);
  --ex-rule: rgba(242, 236, 227, .14);
  --ex-rule-strong: rgba(242, 236, 227, .26);
  --ex-num-font: "JetBrains Mono", monospace;
  --ex-display: "Fraunces", "Times New Roman", serif;
  --ex-card-pad: clamp(22px, 2.6vw, 38px);
  background: var(--bg);
}
html[data-theme="light"] body[data-page="exposicoes"] {
  --ex-rule: rgba(22, 20, 18, .16);
  --ex-rule-strong: rgba(22, 20, 18, .32);
}

[data-page="exposicoes"] .ex-page {
  padding-top: 92px;
  text-rendering: optimizeLegibility;
  -webkit-hyphens: auto; hyphens: auto;
}

[data-page="exposicoes"] em {
  font-family: var(--ex-display);
  font-style: italic;
  font-weight: 300;
  letter-spacing: -.005em;
}

/* mark this page's nav link as active */
[data-page="exposicoes"] .nav-links a.is-active { color: var(--fg); }
[data-page="exposicoes"] .nav-links a.is-active::after {
  content: ""; display: block;
  width: 14px; height: 1px; background: var(--accent);
  margin: 4px auto 0;
}

/* === Section heads (roman numeral + tag) === */
[data-page="exposicoes"] .ex-section-head {
  display: flex; align-items: center; gap: 18px;
  padding: 0 var(--ex-pad-x);
  margin: 0 0 36px;
}
[data-page="exposicoes"] .ex-roman {
  font: 300 italic 13px/1 var(--ex-display);
  letter-spacing: .3em; text-transform: uppercase;
  color: var(--accent); opacity: .9;
  min-width: 22px;
}
[data-page="exposicoes"] .ex-section-rule,
[data-page="exposicoes"] .ex-cap-rule {
  flex: 1; height: 1px; background: var(--ex-rule);
  display: block;
}
[data-page="exposicoes"] .ex-section-tag,
[data-page="exposicoes"] .ex-cap-tag {
  font: 500 11px/1 var(--ex-num-font);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-dim);
}

/* ============================================================
   §1 HERO TIPOGRÁFICO
   ============================================================ */
[data-page="exposicoes"] .ex-hero {
  padding: clamp(56px, 9vw, 140px) var(--ex-pad-x) clamp(56px, 8vw, 120px);
  border-bottom: 1px solid var(--ex-rule);
  position: relative;
}
[data-page="exposicoes"] .ex-hero-cap {
  display: flex; align-items: center; gap: 18px;
  margin-bottom: clamp(40px, 5vw, 72px);
}
[data-page="exposicoes"] .ex-hero-title {
  font: 300 clamp(44px, 7.6vw, 132px)/.96 var(--ex-display);
  letter-spacing: -.035em;
  font-feature-settings: "onum" 1, "lnum" 0, "ss01" 1;
  color: var(--fg);
  margin: 0 0 clamp(48px, 6vw, 96px);
  max-width: 18ch;
}
[data-page="exposicoes"] .ex-hero-line {
  display: block; font-style: normal; font-weight: 300;
}
[data-page="exposicoes"] .ex-hero-line em { font-weight: 400; font-style: italic; color: var(--fg); }
[data-page="exposicoes"] .ex-hero-line:nth-child(2),
[data-page="exposicoes"] .ex-hero-line:nth-child(3) { padding-left: clamp(0px, 4vw, 80px); }
[data-page="exposicoes"] .ex-hero-line:nth-child(4) { padding-left: clamp(0px, 8vw, 160px); }

[data-page="exposicoes"] .ex-hero-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--ex-rule);
  border-block: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-stat {
  background: var(--bg);
  padding: clamp(20px, 2.4vw, 32px) clamp(16px, 2vw, 24px);
  display: flex; flex-direction: column; gap: 8px;
}
[data-page="exposicoes"] .ex-stat-num {
  font: 300 clamp(48px, 6vw, 88px)/1 var(--ex-display);
  font-style: italic;
  letter-spacing: -.04em;
  font-feature-settings: "onum" 1;
  color: var(--fg);
}
[data-page="exposicoes"] .ex-stat-key {
  font: 500 10px/1.4 var(--ex-num-font);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-dim);
}

[data-page="exposicoes"] .ex-hero-foot {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: clamp(40px, 4vw, 64px);
  font: 500 11px/1.4 var(--ex-num-font);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-dim);
}
[data-page="exposicoes"] .ex-hero-foot a {
  color: var(--fg);
  border-bottom: 1px solid var(--accent);
  padding-bottom: 2px;
}

/* ============================================================
   §2 MARQUEE
   ============================================================ */
[data-page="exposicoes"] .ex-marquee {
  border-bottom: 1px solid var(--ex-rule);
  overflow: hidden;
  position: relative;
  padding-block: clamp(28px, 3.4vw, 48px);
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
  white-space: nowrap;
}
[data-page="exposicoes"] .ex-marquee-track {
  display: inline-flex; gap: 56px; align-items: center;
  white-space: nowrap;
  will-change: transform;
}
[data-page="exposicoes"] .ex-mq-item {
  font: 300 clamp(28px, 3.6vw, 56px)/1 var(--ex-display);
  font-style: italic; letter-spacing: -.02em;
  color: var(--fg);
  padding-inline: 6px;
}
[data-page="exposicoes"] .ex-mq-sep {
  color: var(--accent); opacity: .55;
  font-size: 14px; transform: translateY(-4px);
}

/* ============================================================
   §3 MANIFESTO
   ============================================================ */
[data-page="exposicoes"] .ex-manifesto {
  padding: clamp(72px, 10vw, 140px) var(--ex-pad-x) clamp(72px, 8vw, 120px);
  border-bottom: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-manifesto-body {
  max-width: 880px;
  margin-inline: auto;
  display: grid; gap: clamp(24px, 2.8vw, 40px);
}
[data-page="exposicoes"] .ex-manifesto-p {
  font: 400 clamp(17px, 1.4vw, 21px)/1.65 "Inter", system-ui, sans-serif;
  color: var(--fg);
  max-width: 38em;
}
[data-page="exposicoes"] .ex-manifesto-p:nth-of-type(2) {
  color: var(--fg-dim);
  margin-left: clamp(0px, 4vw, 64px);
}
[data-page="exposicoes"] .ex-dropcap {
  font: 300 italic clamp(64px, 7vw, 108px)/.85 var(--ex-display);
  color: var(--accent);
  float: left;
  margin: 6px 14px 0 -2px;
  letter-spacing: -.04em;
}

[data-page="exposicoes"] .ex-quote {
  margin: clamp(24px, 3vw, 48px) 0 0;
  padding: clamp(28px, 3vw, 44px) 0 clamp(28px, 3vw, 44px) clamp(24px, 3vw, 48px);
  border-left: 1px solid var(--accent);
  position: relative;
}
[data-page="exposicoes"] .ex-quote::before {
  content: "“";
  position: absolute;
  left: clamp(8px, 1vw, 16px); top: -16px;
  font: 300 italic 96px/1 var(--ex-display);
  color: var(--accent);
  opacity: .9;
}
[data-page="exposicoes"] .ex-quote-text {
  font: 300 italic clamp(22px, 2.4vw, 32px)/1.4 var(--ex-display);
  color: var(--fg);
  margin: 0 0 18px;
  max-width: 30em;
}
[data-page="exposicoes"] .ex-quote-cite {
  font: 500 11px/1.4 var(--ex-num-font);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-dim);
}

/* ============================================================
   §4 SLAB
   ============================================================ */
[data-page="exposicoes"] .ex-slab-sect {
  padding: clamp(48px, 6vw, 96px) 0;
  border-bottom: 1px solid var(--ex-rule);
  overflow: hidden;
}
[data-page="exposicoes"] .ex-slab-sect .slab {
  font: 900 clamp(80px, 18vw, 320px)/.85 "Archivo Black", "Archivo", sans-serif;
  letter-spacing: -.04em;
  text-align: center;
  color: var(--fg);
  white-space: nowrap;
  margin: 0;
  padding: 0 var(--ex-pad-x);
}
[data-page="exposicoes"] .ex-slab-sect .slab .ch {
  display: inline-block;
  transform-origin: 50% 100%;
  transition: color .3s var(--ease);
}
[data-page="exposicoes"] .ex-slab-sect .slab .ch:hover { color: var(--accent); }

/* ============================================================
   §5 CRONOLOGIA — Magazine asymmetric layout, three decades
   12-col grid, cards in xxl/xl/lg/md sizes, dense flow.
   No per-card sticky years (replaced by floating decade pill).
   ============================================================ */
[data-page="exposicoes"] .ex-timeline-sect {
  padding: clamp(72px, 10vw, 140px) 0 clamp(72px, 9vw, 120px);
  border-bottom: 1px solid var(--ex-rule);
  position: relative;
}

[data-page="exposicoes"] .ex-filters {
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 0 var(--ex-pad-x);
  margin-bottom: clamp(36px, 4vw, 64px);
}
[data-page="exposicoes"] .ex-chip {
  appearance: none; background: transparent;
  border: 1px solid var(--ex-rule-strong);
  border-radius: 999px;
  padding: 11px 18px;
  font: 500 10px/1 var(--ex-num-font);
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--fg-dim);
  cursor: pointer;
  transition: border-color .3s var(--ease), color .3s var(--ease), background-color .3s var(--ease);
}
[data-page="exposicoes"] .ex-chip:hover { color: var(--fg); border-color: var(--fg); }
[data-page="exposicoes"] .ex-chip.is-active {
  background: var(--fg); color: var(--bg);
  border-color: var(--fg);
}

[data-page="exposicoes"] .ex-timeline {
  display: flex; flex-direction: column;
  gap: clamp(72px, 9vw, 120px);
  padding: 0 var(--ex-pad-x);
}

/* === DECADE — opening header per band === */
[data-page="exposicoes"] .ex-decade { display: grid; gap: clamp(40px, 4.6vw, 64px); }
[data-page="exposicoes"] .ex-decade.is-hidden { display: none; }

[data-page="exposicoes"] .ex-decade-head {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 2.4fr minmax(120px, auto);
  align-items: end;
  gap: clamp(20px, 3vw, 56px);
  padding-bottom: clamp(24px, 3vw, 40px);
  border-bottom: 1px solid var(--ex-rule);
  position: relative;
}
[data-page="exposicoes"] .ex-decade-mark {
  display: flex; flex-direction: column; gap: 12px;
  align-items: flex-start;
}
[data-page="exposicoes"] .ex-decade-roman {
  font: 300 italic clamp(48px, 6.4vw, 96px)/.85 var(--ex-display);
  letter-spacing: -.04em;
  color: var(--accent);
  font-feature-settings: "lnum" 0, "onum" 1;
}
[data-page="exposicoes"] .ex-decade-label {
  font: 500 10px/1 var(--ex-num-font);
  letter-spacing: .32em; text-transform: uppercase;
  color: var(--fg-dim);
}
[data-page="exposicoes"] .ex-decade-years {
  margin: 0;
  font: 400 clamp(40px, 6vw, 96px)/.95 var(--ex-num-font);
  letter-spacing: -.04em;
  color: var(--fg);
  display: inline-flex; align-items: baseline; gap: clamp(10px, 1.4vw, 20px);
}
[data-page="exposicoes"] .ex-decade-years em {
  font-family: var(--ex-num-font);
  font-style: normal; font-weight: 400;
  font-feature-settings: "tnum" 1, "zero" 1;
}
[data-page="exposicoes"] .ex-decade-dash {
  color: var(--accent);
  font: 300 italic 0.9em/1 var(--ex-display);
  transform: translateY(-.04em);
  letter-spacing: 0;
}
[data-page="exposicoes"] .ex-decade-blurb {
  font: 400 clamp(14px, 1.1vw, 16px)/1.55 "Inter", system-ui, sans-serif;
  color: var(--fg-dim);
  margin: 0;
  max-width: 36em;
  grid-column: 2;
  align-self: start;
  padding-top: 8px;
}
[data-page="exposicoes"] .ex-decade-count {
  font: 500 11px/1 var(--ex-num-font);
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--fg-dim);
  text-align: right;
  align-self: end;
  white-space: nowrap;
}

/* === DECADE GRID — 12-column magazine, structured rhythm ===
   Aligned to start: cards keep their natural height instead of being
   stretched. Combined with consistent aspect-ratios per tier (md→4/5,
   lg→3/2 or 4/5, xl→3/2, xxl→21/9 or 4/5) gives an editorial cadence
   like the home hero film-frame composition. */
[data-page="exposicoes"] .ex-decade-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  column-gap: clamp(20px, 2.4vw, 36px);
  row-gap: clamp(28px, 3vw, 48px);
  grid-auto-flow: row dense;
  align-items: stretch;
}

/* Card spans — multiples of 4 for clean 12-col rows */
[data-page="exposicoes"] .ex-card--xxl { grid-column: span 12; }
[data-page="exposicoes"] .ex-card--xl  { grid-column: span 8; }
[data-page="exposicoes"] .ex-card--lg  { grid-column: span 6; }
[data-page="exposicoes"] .ex-card--md  { grid-column: span 4; }

/* === CARD === */
[data-page="exposicoes"] .ex-card {
  display: flex; flex-direction: column;
  background: var(--bg);
  border: 1px solid var(--ex-rule);
  position: relative;
  overflow: hidden;
  isolation: isolate;
  /* Cinematic depth — subtle shadow projected like a film print */
  box-shadow:
    0 1px 0 0 var(--ex-rule) inset,
    0 8px 24px -16px rgba(0, 0, 0, .3),
    0 24px 64px -32px rgba(0, 0, 0, .25);
  transition:
    border-color .45s var(--ease-cine),
    transform .55s var(--ease-cine),
    box-shadow .55s var(--ease-cine);
}
[data-page="exposicoes"] .ex-card:hover {
  border-color: var(--ex-rule-strong);
  transform: translateY(-2px);
  box-shadow:
    0 1px 0 0 var(--ex-rule-strong) inset,
    0 14px 36px -18px rgba(0, 0, 0, .42),
    0 36px 96px -40px rgba(0, 0, 0, .35);
}
[data-page="exposicoes"] .ex-card[data-current="true"] {
  border-color: var(--accent);
  background: linear-gradient(180deg, color-mix(in oklab, var(--accent) 6%, transparent), transparent 30%);
  box-shadow:
    0 0 0 1px color-mix(in oklab, var(--accent) 30%, transparent) inset,
    0 14px 40px -18px color-mix(in oklab, var(--accent) 35%, transparent),
    0 36px 96px -40px rgba(0, 0, 0, .3);
}
/* hairline accent stroke at top — present on every card,
   expands to the full card width on hover (filmstrip "cue") */
[data-page="exposicoes"] .ex-card::before {
  content: ""; position: absolute;
  top: 0; left: 0;
  width: clamp(28px, 4vw, 60px); height: 1px;
  background: var(--accent);
  transition: width .55s var(--ease-cine);
  z-index: 3;
}
[data-page="exposicoes"] .ex-card:hover::before { width: 100%; }

/* === IMAGE === */
[data-page="exposicoes"] .ex-card-imgwrap {
  appearance: none;
  background:
    radial-gradient(140% 100% at 50% 0%,
      color-mix(in oklab, var(--bg-2) 92%, var(--accent) 6%) 0%,
      var(--bg-3) 55%,
      var(--bg) 100%);
  border: 0;
  border-bottom: 1px solid var(--ex-rule);
  padding: clamp(14px, 2.2vw, 32px);
  margin: 0;
  display: block;
  width: 100%;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: padding .5s var(--ease-cine);
}
/* image wrapper aspect-ratio classes drive size */
[data-page="exposicoes"] .ex-img--landscape { aspect-ratio: 3/2; }
[data-page="exposicoes"] .ex-img--portrait  { aspect-ratio: 4/5; }
[data-page="exposicoes"] .ex-img--tall      { aspect-ratio: 3/4; }
[data-page="exposicoes"] .ex-img--wide      { aspect-ratio: 16/9; }
[data-page="exposicoes"] .ex-img--ultra     { aspect-ratio: 21/9; }
[data-page="exposicoes"] .ex-img--standard  { aspect-ratio: 4/3; }
[data-page="exposicoes"] .ex-img--square    { aspect-ratio: 1/1; }

[data-page="exposicoes"] .ex-card-imgwrap::before,
[data-page="exposicoes"] .ex-card-imgwrap::after {
  content: ""; position: absolute;
  width: 11px; height: 11px;
  pointer-events: none;
  opacity: .55;
  transition: opacity .3s var(--ease), border-color .3s var(--ease);
}
[data-page="exposicoes"] .ex-card-imgwrap::before {
  top: 10px; left: 10px;
  border-top: 1px solid var(--ex-rule-strong);
  border-left: 1px solid var(--ex-rule-strong);
}
[data-page="exposicoes"] .ex-card-imgwrap::after {
  bottom: 10px; right: 10px;
  border-bottom: 1px solid var(--ex-rule-strong);
  border-right: 1px solid var(--ex-rule-strong);
}
[data-page="exposicoes"] .ex-card-imgwrap:hover { padding: clamp(10px, 1.6vw, 22px); }
[data-page="exposicoes"] .ex-card-imgwrap:hover::before,
[data-page="exposicoes"] .ex-card-imgwrap:hover::after { border-color: var(--accent); opacity: 1; }

[data-page="exposicoes"] .ex-card-img {
  display: block; width: 100%; height: 100%;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  transition: filter .7s var(--ease-cine), transform 1.1s var(--ease-cine);
  filter: saturate(.94);
}
[data-page="exposicoes"] .ex-card-imgwrap:hover .ex-card-img {
  filter: saturate(1.06);
  transform: scale(1.015);
}

/* Expand affordance — editorial chip with breathing room
   Floats at the bottom-right of the imgwrap, animates in on hover */
[data-page="exposicoes"] .ex-card-imgexpand {
  position: absolute;
  bottom: clamp(18px, 1.8vw, 28px);
  right: clamp(18px, 1.8vw, 28px);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px 11px 18px;
  background: rgba(8, 7, 6, .68);
  backdrop-filter: blur(14px) saturate(1.2);
  -webkit-backdrop-filter: blur(14px) saturate(1.2);
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 999px;
  color: #f6f0e6;
  font: 500 9.5px/1 var(--ex-num-font);
  letter-spacing: .26em;
  text-transform: uppercase;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .35s var(--ease), transform .45s var(--ease-cine), background-color .3s var(--ease), border-color .3s var(--ease);
  pointer-events: none;
  box-shadow: 0 10px 32px -16px rgba(0,0,0,.5);
  z-index: 4;
}
[data-page="exposicoes"] .ex-card-imgexpand-label {
  display: inline-block;
  white-space: nowrap;
}
[data-page="exposicoes"] .ex-card-imgexpand i {
  width: 13px; height: 13px;
  stroke-width: 1.6;
  transition: transform .35s var(--ease-cine);
}
[data-page="exposicoes"] .ex-card-imgwrap:hover .ex-card-imgexpand,
[data-page="exposicoes"] .ex-card-imgwrap:focus-visible .ex-card-imgexpand {
  opacity: 1; transform: translateY(0);
  background: rgba(176, 60, 60, .92);
  border-color: color-mix(in oklab, var(--accent) 60%, #fff 0%);
}
[data-page="exposicoes"] .ex-card-imgwrap:hover .ex-card-imgexpand i {
  transform: translate(2px, -2px);
}

/* B&W treatment for entries marked with mono:true */
[data-page="exposicoes"] .ex-card.is-mono .ex-card-img {
  filter: grayscale(1) saturate(.96) contrast(1.04);
}
[data-page="exposicoes"] .ex-card.is-mono .ex-card-imgwrap:hover .ex-card-img {
  filter: grayscale(1) saturate(1) contrast(1.08);
}

/* High-quality image rendering for sharper raster scaling */
[data-page="exposicoes"] .ex-card-img {
  image-rendering: -webkit-optimize-contrast;
  image-rendering: high-quality;
}


/* === CONTENT === */
[data-page="exposicoes"] .ex-card-content {
  padding: clamp(18px, 2vw, 30px);
  display: flex; flex-direction: column;
  gap: clamp(10px, 1.2vw, 18px);
  flex: 1;
}

[data-page="exposicoes"] .ex-card-meta-row {
  display: flex; align-items: center; gap: clamp(10px, 1.4vw, 18px);
  flex-wrap: wrap;
}
[data-page="exposicoes"] .ex-card-num {
  font: 500 10px/1 var(--ex-num-font);
  letter-spacing: .3em; text-transform: uppercase;
  color: var(--fg-faint);
  border-right: 1px solid var(--ex-rule-strong);
  padding-right: clamp(10px, 1.4vw, 16px);
}
[data-page="exposicoes"] .ex-card-yr {
  font: 500 clamp(13px, 1.05vw, 15px)/1 var(--ex-num-font);
  letter-spacing: -.01em;
  color: var(--fg);
  display: inline-flex;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "zero" 1;
}
[data-page="exposicoes"] .ex-card-yr .ex-yr-d {
  flex: 0 0 auto;
  display: inline-block;
  min-width: .58em;
  text-align: center;
  position: relative;
  color: var(--fg);
  transition: color .35s var(--ease);
}
[data-page="exposicoes"] .ex-card-yr.is-running .ex-yr-d {
  color: var(--accent);
  opacity: .92;
}
[data-page="exposicoes"] .ex-card-yr.is-done .ex-yr-d { color: var(--fg); }
[data-page="exposicoes"] .ex-card-tag {
  font: 500 9px/1 var(--ex-num-font);
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--accent);
  padding: 5px 9px;
  border: 1px solid color-mix(in oklab, var(--accent) 28%, transparent);
  border-radius: 999px;
  background: color-mix(in oklab, var(--accent) 5%, transparent);
  margin-left: auto;
}

[data-page="exposicoes"] .ex-card-title {
  font: 400 clamp(22px, 2.4vw, 38px)/1.1 var(--ex-display);
  letter-spacing: -.02em;
  margin: 0;
  color: var(--fg);
}
[data-page="exposicoes"] .ex-card-title em { font-style: italic; font-weight: 400; }
[data-page="exposicoes"] .ex-card-inst {
  font: 500 clamp(13px, 1vw, 15px)/1.4 "Archivo", system-ui, sans-serif;
  color: var(--fg-dim);
  margin: 0;
}

/* size-tuned title scales */
[data-page="exposicoes"] .ex-card--xxl .ex-card-title { font-size: clamp(40px, 4.4vw, 72px); }
[data-page="exposicoes"] .ex-card--xl  .ex-card-title { font-size: clamp(28px, 3vw, 48px); }
[data-page="exposicoes"] .ex-card--md  .ex-card-title { font-size: clamp(20px, 1.8vw, 26px); }

[data-page="exposicoes"] .ex-card--xxl .ex-card-content {
  padding: clamp(28px, 3vw, 48px);
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  align-items: start;
  gap: clamp(20px, 2vw, 40px);
}
[data-page="exposicoes"] .ex-card--xxl .ex-card-meta-row { grid-column: 1 / -1; }
[data-page="exposicoes"] .ex-card--xxl .ex-card-foot { grid-column: 1 / -1; }
[data-page="exposicoes"] .ex-card--xxl .ex-card-title,
[data-page="exposicoes"] .ex-card--xxl .ex-card-inst,
[data-page="exposicoes"] .ex-card--xxl .ex-card-body { grid-column: 1; }
[data-page="exposicoes"] .ex-card--xxl .ex-card-specs { grid-column: 2; align-self: start; }

/* meta — full grid (xxl/xl/lg) */
[data-page="exposicoes"] .ex-card-specs {
  display: grid;
  gap: 1px;
  background: var(--ex-rule);
  border-block: 1px solid var(--ex-rule);
  margin: 0;
  grid-template-columns: 1fr;
}
[data-page="exposicoes"] .ex-card-specs > div {
  background: var(--bg);
  padding: 12px 14px;
  display: grid; gap: 4px;
}
[data-page="exposicoes"] .ex-card-specs dt {
  font: 500 9px/1 var(--ex-num-font);
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--fg-faint);
}
[data-page="exposicoes"] .ex-card-specs dd {
  font: 500 12px/1.45 "Inter", system-ui, sans-serif;
  color: var(--fg);
  margin: 0;
}
/* xl (8-col) shows specs in 3 columns to feel editorial */
[data-page="exposicoes"] .ex-card--xl .ex-card-specs,
[data-page="exposicoes"] .ex-card--xxl .ex-card-specs { grid-template-columns: 1fr; }

/* mini-meta for compact (md) cards */
[data-page="exposicoes"] .ex-card-mini-meta {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  font: 500 10px/1.4 var(--ex-num-font);
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--fg-dim);
}
[data-page="exposicoes"] .ex-card-bullet { color: var(--accent); opacity: .7; }

[data-page="exposicoes"] .ex-card-body {
  font: 400 clamp(13px, 1vw, 15px)/1.6 "Inter", system-ui, sans-serif;
  color: var(--fg-dim);
  margin: 0;
}
[data-page="exposicoes"] .ex-card--xxl .ex-card-body { font-size: clamp(14px, 1.2vw, 17px); }

/* foot — press list + open button */
[data-page="exposicoes"] .ex-card-foot {
  margin-top: auto;
  display: flex; justify-content: space-between; align-items: center;
  gap: 12px; flex-wrap: wrap;
  padding-top: clamp(12px, 1.4vw, 18px);
  border-top: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-card-press {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 6px; align-items: center;
}
[data-page="exposicoes"] .ex-press-mini {
  display: inline-flex; align-items: center; gap: 6px;
  font: 500 9.5px/1 var(--ex-num-font);
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--fg-dim);
  border: 1px solid var(--ex-rule);
  padding: 7px 11px;
  border-radius: 999px;
  text-decoration: none;
  transition: color .3s var(--ease), border-color .3s var(--ease), background-color .3s var(--ease);
}
[data-page="exposicoes"] .ex-press-mini:hover {
  color: var(--fg);
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 8%, transparent);
}
[data-page="exposicoes"] .ex-press-mini i { width: 11px; height: 11px; opacity: .6; }
[data-page="exposicoes"] .ex-press-more {
  font: 500 9.5px/1 var(--ex-num-font);
  letter-spacing: .2em;
  color: var(--fg-faint);
  padding: 7px 0;
}
[data-page="exposicoes"] .ex-card-open {
  appearance: none; background: transparent;
  border: 1px solid var(--ex-rule-strong);
  width: 38px; height: 38px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--fg);
  cursor: pointer;
  transition: background-color .3s var(--ease), border-color .3s var(--ease), color .3s var(--ease), transform .35s var(--ease-cine);
  flex-shrink: 0;
}
[data-page="exposicoes"] .ex-card-open i { width: 14px; height: 14px; transition: transform .35s var(--ease-cine); }
[data-page="exposicoes"] .ex-card-open:hover {
  background: var(--accent); border-color: var(--accent); color: #fff;
}
[data-page="exposicoes"] .ex-card-open:hover i { transform: translate(2px, -2px); }

/* === FLOATING DECADE PILL — replaces sticky years === */
[data-page="exposicoes"] .ex-decade-pill {
  position: fixed;
  top: clamp(64px, 7vw, 84px);
  left: 50%;
  transform: translate(-50%, -8px);
  display: inline-flex; align-items: center; gap: 14px;
  padding: 9px 16px 9px 14px;
  background: color-mix(in oklab, var(--bg) 88%, transparent);
  backdrop-filter: blur(14px) saturate(1.2);
  -webkit-backdrop-filter: blur(14px) saturate(1.2);
  border: 1px solid var(--hair-strong);
  border-radius: 999px;
  z-index: 600;
  font: 500 10.5px/1 var(--ex-num-font);
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--fg);
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s var(--ease), transform .45s var(--ease-cine);
  white-space: nowrap;
}
[data-page="exposicoes"] .ex-decade-pill.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}
[data-page="exposicoes"] .ex-dp-roman {
  font: 300 italic 14px/1 var(--ex-display);
  letter-spacing: 0;
  color: var(--accent);
  font-feature-settings: "lnum" 0;
}
[data-page="exposicoes"] .ex-dp-divider {
  width: 1px; height: 14px;
  background: var(--hair-strong);
}
[data-page="exposicoes"] .ex-dp-progress {
  display: block;
  width: clamp(56px, 8vw, 110px);
  height: 1px;
  background: var(--hair);
  margin-left: 4px;
  overflow: hidden;
  border-radius: 1px;
}
[data-page="exposicoes"] .ex-dp-fill {
  display: block;
  width: 100%; height: 100%;
  background: var(--accent);
  transform-origin: left center;
}

/* ============================================================
   §6 PRESS WALL
   ============================================================ */
[data-page="exposicoes"] .ex-press-sect {
  padding: clamp(72px, 9vw, 120px) 0;
  border-bottom: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-press-intro {
  font: 400 clamp(15px, 1.2vw, 17px)/1.65 "Inter", system-ui, sans-serif;
  color: var(--fg-dim);
  max-width: 36em;
  padding: 0 var(--ex-pad-x);
  margin: 0 0 clamp(36px, 4vw, 56px);
}
[data-page="exposicoes"] .ex-press-wall {
  list-style: none;
  padding: 0 var(--ex-pad-x);
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1px;
  background: var(--ex-rule);
  border-block: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-press-wall { align-items: stretch; }
[data-page="exposicoes"] .ex-press-wall li { display: flex; height: 100%; }
[data-page="exposicoes"] .ex-press-pill {
  display: flex; flex-direction: column;
  justify-content: space-between;
  gap: 12px;
  background: var(--bg);
  padding: clamp(22px, 2.2vw, 30px) clamp(18px, 1.8vw, 24px);
  text-decoration: none;
  transition: background-color .35s var(--ease);
  position: relative;
  min-height: clamp(120px, 11vw, 148px);
  width: 100%;
  box-sizing: border-box;
}
[data-page="exposicoes"] .ex-press-pill::after {
  content: "↗";
  position: absolute;
  top: 18px; right: 18px;
  font: 300 16px/1 var(--ex-display);
  color: var(--fg-faint);
  transition: color .3s var(--ease), transform .3s var(--ease);
}
[data-page="exposicoes"] .ex-press-pill:hover { background: color-mix(in oklab, var(--accent) 10%, var(--bg)); }
[data-page="exposicoes"] .ex-press-pill:hover::after { color: var(--accent); transform: translate(2px, -2px); }
[data-page="exposicoes"] .ex-press-pub {
  font: 500 11px/1 var(--ex-num-font);
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--accent);
}
[data-page="exposicoes"] .ex-press-tit {
  font: 400 italic clamp(15px, 1.2vw, 18px)/1.4 var(--ex-display);
  color: var(--fg);
}

/* ============================================================
   §7 COLEÇÕES
   ============================================================ */
[data-page="exposicoes"] .ex-collections-sect {
  padding: clamp(72px, 9vw, 120px) 0;
  border-bottom: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-collections {
  list-style: none;
  padding: 0 var(--ex-pad-x);
  margin: 0 0 clamp(36px, 4vw, 56px);
  display: grid;
  gap: 0;
}
[data-page="exposicoes"] .ex-coll {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  align-items: baseline;
  gap: clamp(12px, 2vw, 32px);
  padding: clamp(28px, 3.2vw, 44px) 0;
  border-top: 1px solid var(--ex-rule);
  position: relative;
  transition: padding-left .45s var(--ease-cine);
}
[data-page="exposicoes"] .ex-coll:last-child { border-bottom: 1px solid var(--ex-rule); }
[data-page="exposicoes"] .ex-coll:hover { padding-left: clamp(8px, 2vw, 32px); }
[data-page="exposicoes"] .ex-coll:hover::before {
  content: ""; position: absolute; left: 0; top: 50%;
  width: clamp(8px, 1.6vw, 24px); height: 1px;
  background: var(--accent);
  transform: translateY(-50%);
}
[data-page="exposicoes"] .ex-coll-num {
  font: 500 10px/1 var(--ex-num-font);
  letter-spacing: .3em; text-transform: uppercase;
  color: var(--fg-faint);
}
[data-page="exposicoes"] .ex-coll-name {
  font: 400 italic clamp(28px, 3.6vw, 52px)/1.1 var(--ex-display);
  letter-spacing: -.015em;
  color: var(--fg);
  margin: 0;
}
[data-page="exposicoes"] .ex-coll-name em {
  font-style: italic; font-weight: 300;
  color: var(--fg-dim); font-size: .55em; letter-spacing: 0;
}
[data-page="exposicoes"] .ex-coll-meta {
  font: 500 11px/1 var(--ex-num-font);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-dim);
  text-align: right;
}
[data-page="exposicoes"] .ex-coll-rule { display: none; }

[data-page="exposicoes"] .ex-coll-foot {
  font: 400 clamp(13px, 1vw, 15px)/1.6 "Inter", system-ui, sans-serif;
  color: var(--fg-dim);
  padding: 0 var(--ex-pad-x);
  margin: 0;
}
[data-page="exposicoes"] .ex-coll-foot a {
  color: var(--fg);
  border-bottom: 1px solid var(--accent);
  padding-bottom: 1px;
  transition: color .3s var(--ease);
}
[data-page="exposicoes"] .ex-coll-foot a:hover { color: var(--accent); }

/* ============================================================
   §8 CIDADES
   ============================================================ */
[data-page="exposicoes"] .ex-cities-sect {
  padding: clamp(72px, 9vw, 120px) 0;
  border-bottom: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-cities {
  list-style: none;
  padding: 0 var(--ex-pad-x);
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 0;
  border-top: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-cities li {
  display: flex; justify-content: space-between; align-items: baseline;
  gap: 12px;
  padding: clamp(14px, 1.4vw, 18px);
  border-right: 1px solid var(--ex-rule);
  border-bottom: 1px solid var(--ex-rule);
  transition: background-color .3s var(--ease);
}
[data-page="exposicoes"] .ex-cities li:hover { background: color-mix(in oklab, var(--accent) 6%, var(--bg)); }
[data-page="exposicoes"] .ex-city-name {
  font: 400 italic clamp(18px, 1.6vw, 24px)/1 var(--ex-display);
  letter-spacing: -.005em;
  color: var(--fg);
}
[data-page="exposicoes"] .ex-city-coord {
  font: 500 10px/1 var(--ex-num-font);
  letter-spacing: .2em;
  color: var(--fg-faint);
}

/* ============================================================
   §9 CONTACT
   ============================================================ */
[data-page="exposicoes"] .ex-contact {
  padding: clamp(80px, 12vw, 180px) var(--ex-pad-x) clamp(72px, 10vw, 140px);
}
[data-page="exposicoes"] .ex-contact-inner {
  max-width: 1100px;
  margin-inline: auto;
  display: grid; gap: clamp(24px, 3vw, 40px);
}
[data-page="exposicoes"] .ex-contact .ex-section-head { padding: 0; margin-bottom: 0; }
[data-page="exposicoes"] .ex-contact-title {
  font: 300 clamp(36px, 5.4vw, 80px)/1.05 var(--ex-display);
  letter-spacing: -.02em;
  color: var(--fg);
  margin: 0;
  max-width: 22ch;
}
[data-page="exposicoes"] .ex-contact-body {
  font: 400 clamp(15px, 1.15vw, 17px)/1.65 "Inter", system-ui, sans-serif;
  color: var(--fg-dim);
  max-width: 38em;
  margin: 0;
}
[data-page="exposicoes"] .ex-contact-actions {
  display: flex; flex-wrap: wrap; gap: 12px;
  margin-top: 12px;
}
[data-page="exposicoes"] .ex-contact-foot {
  font: 500 10px/1.5 var(--ex-num-font);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-faint);
  margin-top: clamp(24px, 3vw, 48px);
}
[data-page="exposicoes"] .ex-tz { color: var(--accent); opacity: .8; }

[data-page="exposicoes"] .ex-foot {
  padding: 28px var(--ex-pad-x);
  border-top: 1px solid var(--ex-rule);
  display: flex; justify-content: space-between;
  font: 500 10px/1.4 var(--ex-num-font);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-faint);
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
[data-page="exposicoes"] .ex-lightbox {
  position: fixed; inset: 0; z-index: 8000;
  background: var(--overlay);
  backdrop-filter: blur(20px);
  display: flex; align-items: center; justify-content: center;
  padding: clamp(20px, 4vw, 48px);
  opacity: 0; pointer-events: none;
  transition: opacity .35s var(--ease);
}
[data-page="exposicoes"] .ex-lightbox.is-open { opacity: 1; pointer-events: auto; }
[data-page="exposicoes"] .ex-lb-close {
  appearance: none; background: transparent;
  border: 1px solid var(--hair-strong); color: var(--fg);
  width: 44px; height: 44px; border-radius: 50%;
  position: absolute; top: 24px; right: 24px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background-color .3s var(--ease), border-color .3s var(--ease);
  z-index: 2;
}
[data-page="exposicoes"] .ex-lb-close:hover { background: var(--fg); color: var(--bg); border-color: var(--fg); }
[data-page="exposicoes"] .ex-lb-grid {
  width: 100%; max-width: 1280px;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(24px, 3vw, 48px);
  background: var(--bg-2);
  border: 1px solid var(--ex-rule);
  padding: clamp(24px, 3vw, 48px);
  max-height: 88vh;
  overflow: hidden;
}
[data-page="exposicoes"] .ex-lb-images {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  overflow-y: auto;
  scrollbar-width: thin;
  max-height: calc(88vh - 96px);
}
[data-page="exposicoes"] .ex-lb-images::-webkit-scrollbar { width: 4px; }
[data-page="exposicoes"] .ex-lb-images::-webkit-scrollbar-thumb { background: var(--ex-rule-strong); border-radius: 4px; }
[data-page="exposicoes"] .ex-lb-fig { margin: 0; position: relative; }
[data-page="exposicoes"] .ex-lb-img {
  display: block; aspect-ratio: 3/2;
  background-size: cover; background-position: center;
  background-color: var(--bg-3);
}
[data-page="exposicoes"] .ex-lb-fig--text {
  display: grid; gap: 14px; padding: 56px 32px;
  background: var(--bg-3);
  border: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-lb-num-l {
  font: 500 10px/1 var(--ex-num-font);
  letter-spacing: .3em; text-transform: uppercase;
  color: var(--fg-faint);
}
[data-page="exposicoes"] .ex-lb-title-l {
  font: 300 italic clamp(40px, 4.4vw, 72px)/.95 var(--ex-display);
  letter-spacing: -.02em; color: var(--fg);
}
[data-page="exposicoes"] .ex-lb-yr-l {
  font: 300 italic clamp(40px, 6vw, 96px)/1 var(--ex-display);
  color: var(--accent);
  font-feature-settings: "onum" 1;
}

[data-page="exposicoes"] .ex-lb-side {
  display: grid; gap: clamp(14px, 1.6vw, 22px);
  align-content: start;
  overflow-y: auto;
  max-height: calc(88vh - 96px);
}
[data-page="exposicoes"] .ex-lb-num {
  font: 500 11px/1 var(--ex-num-font);
  letter-spacing: .3em; text-transform: uppercase;
  color: var(--accent);
}
[data-page="exposicoes"] .ex-lb-title {
  font: 400 italic clamp(28px, 3vw, 44px)/1.05 var(--ex-display);
  letter-spacing: -.02em;
  color: var(--fg);
  margin: 0;
}
[data-page="exposicoes"] .ex-lb-inst {
  font: 600 14px/1.4 "Archivo", sans-serif;
  color: var(--fg);
}
[data-page="exposicoes"] .ex-lb-specs {
  margin: 0;
  display: grid; gap: 1px;
  background: var(--ex-rule);
  border-block: 1px solid var(--ex-rule);
}
[data-page="exposicoes"] .ex-lb-specs > div {
  background: var(--bg-2);
  padding: 12px 14px;
  display: flex; justify-content: space-between; gap: 14px;
}
[data-page="exposicoes"] .ex-lb-specs dt {
  font: 500 9.5px/1 var(--ex-num-font);
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--fg-faint);
}
[data-page="exposicoes"] .ex-lb-specs dd {
  font: 500 12px/1.4 "Inter", system-ui, sans-serif;
  color: var(--fg); margin: 0; text-align: right;
}
[data-page="exposicoes"] .ex-lb-body {
  font: 400 14px/1.65 "Inter", system-ui, sans-serif;
  color: var(--fg-dim); margin: 0;
}
[data-page="exposicoes"] .ex-lb-press {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 6px;
  border-top: 1px solid var(--ex-rule);
  padding-top: clamp(14px, 1.6vw, 22px);
}
[data-page="exposicoes"] .ex-lb-press a {
  display: flex; align-items: center; justify-content: space-between;
  font: 500 11px/1 var(--ex-num-font);
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--fg-dim);
  text-decoration: none;
  padding: 12px 0;
  border-bottom: 1px solid var(--ex-rule);
  transition: color .3s var(--ease), padding-left .3s var(--ease);
}
[data-page="exposicoes"] .ex-lb-press a:hover { color: var(--fg); padding-left: 8px; }
[data-page="exposicoes"] .ex-lb-press a i { width: 12px; height: 12px; opacity: .7; }


/* ============================================================
   FOCUS-VISIBLE & TAP — accessible states for keyboard + touch
   ============================================================ */
[data-page="exposicoes"] :focus-visible {
  outline: 1px solid var(--accent);
  outline-offset: 3px;
  border-radius: 2px;
}
[data-page="exposicoes"] .ex-chip:focus-visible,
[data-page="exposicoes"] .ex-press-pill:focus-visible,
[data-page="exposicoes"] .ex-entry-imgwrap:focus-visible,
[data-page="exposicoes"] .ex-entry-open:focus-visible {
  outline-offset: 4px;
}
/* Touch-friendly active state — replaces missing :hover on tap */
[data-page="exposicoes"] .ex-press-pill:active,
[data-page="exposicoes"] .ex-press-mini:active,
[data-page="exposicoes"] .ex-chip:active,
[data-page="exposicoes"] .ex-entry-imgwrap:active,
[data-page="exposicoes"] .ex-coll:active {
  background: color-mix(in oklab, var(--accent) 14%, var(--bg));
}
/* Ensure clickable areas meet 44px touch target */
[data-page="exposicoes"] .ex-chip,
[data-page="exposicoes"] .ex-press-mini,
[data-page="exposicoes"] .ex-entry-open,
[data-page="exposicoes"] .ex-lb-close { min-height: 44px; }

/* ============================================================
   MOBILE — single column, sticky becomes inline,
   touch-first interactions, lightbox full-screen.
   ============================================================ */
@media (max-width: 900px) {
  [data-page="exposicoes"] .ex-page { padding-top: 72px; }

  /* §1 hero */
  [data-page="exposicoes"] .ex-hero { padding-block: clamp(36px, 8vw, 72px); }
  [data-page="exposicoes"] .ex-hero-cap { gap: 10px; margin-bottom: 28px; flex-wrap: wrap; }
  [data-page="exposicoes"] .ex-hero-title { font-size: clamp(36px, 11vw, 72px); margin-bottom: 36px; max-width: 100%; }
  [data-page="exposicoes"] .ex-hero-stats { grid-template-columns: repeat(2, 1fr); }
  [data-page="exposicoes"] .ex-hero-line:nth-child(2),
  [data-page="exposicoes"] .ex-hero-line:nth-child(3),
  [data-page="exposicoes"] .ex-hero-line:nth-child(4) { padding-left: 0; }
  [data-page="exposicoes"] .ex-hero-foot { flex-direction: column; align-items: flex-start; gap: 10px; }

  /* §2 marquee */
  [data-page="exposicoes"] .ex-mq-item { font-size: clamp(22px, 7vw, 36px); }
  [data-page="exposicoes"] .ex-marquee-track { gap: 36px; }

  /* §3 manifesto */
  [data-page="exposicoes"] .ex-manifesto { padding-block: clamp(48px, 10vw, 80px); }
  [data-page="exposicoes"] .ex-manifesto-p:nth-of-type(2) { margin-left: 0; }
  [data-page="exposicoes"] .ex-dropcap { font-size: clamp(56px, 14vw, 84px); margin: 4px 10px 0 0; }
  [data-page="exposicoes"] .ex-quote { padding-left: 18px; }
  [data-page="exposicoes"] .ex-quote::before { font-size: 64px; left: 4px; top: -10px; }

  /* §4 slab */
  [data-page="exposicoes"] .ex-slab-sect { padding-block: 36px; }
  [data-page="exposicoes"] .ex-slab-sect .slab { font-size: clamp(56px, 16vw, 96px); }

  /* §5 cronologia */
  [data-page="exposicoes"] .ex-timeline-sect { padding-block: clamp(48px, 10vw, 80px); }
  [data-page="exposicoes"] .ex-filters { gap: 6px; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 6px; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  [data-page="exposicoes"] .ex-filters::-webkit-scrollbar { display: none; }
  [data-page="exposicoes"] .ex-chip { white-space: nowrap; padding: 12px 16px; }

  /* decade headers stack on mobile */
  [data-page="exposicoes"] .ex-decade-head {
    grid-template-columns: 1fr;
    gap: 16px;
    padding-bottom: 22px;
    align-items: start;
  }
  [data-page="exposicoes"] .ex-decade-blurb { grid-column: 1; padding-top: 0; }
  [data-page="exposicoes"] .ex-decade-count { grid-column: 1; text-align: left; align-self: start; }
  [data-page="exposicoes"] .ex-decade-roman { font-size: clamp(40px, 12vw, 64px); }
  [data-page="exposicoes"] .ex-decade-years { font-size: clamp(36px, 11vw, 64px); }

  /* magazine grid → single column on mobile */
  [data-page="exposicoes"] .ex-decade-grid {
    grid-template-columns: 1fr;
    gap: clamp(16px, 4vw, 24px);
  }
  [data-page="exposicoes"] .ex-card--xxl,
  [data-page="exposicoes"] .ex-card--xl,
  [data-page="exposicoes"] .ex-card--lg,
  [data-page="exposicoes"] .ex-card--md { grid-column: 1; }

  /* xxl loses its 2-col content layout */
  [data-page="exposicoes"] .ex-card--xxl .ex-card-content {
    grid-template-columns: 1fr;
    padding: clamp(18px, 4vw, 24px);
  }
  [data-page="exposicoes"] .ex-card--xxl .ex-card-title { font-size: clamp(28px, 8vw, 40px); }
  [data-page="exposicoes"] .ex-card-imgwrap { padding: clamp(12px, 3.5vw, 22px); }
  [data-page="exposicoes"] .ex-card-imgexpand { display: none; }

  /* mobile pill — bottom of viewport instead of top */
  [data-page="exposicoes"] .ex-decade-pill {
    top: auto;
    bottom: 18px;
    transform: translate(-50%, 8px);
    padding: 8px 14px 8px 12px;
    font-size: 10px;
    letter-spacing: .22em;
  }
  [data-page="exposicoes"] .ex-decade-pill.is-visible { transform: translate(-50%, 0); }

  /* §6 press */
  [data-page="exposicoes"] .ex-press-sect { padding-block: clamp(48px, 10vw, 80px); }
  [data-page="exposicoes"] .ex-press-pill { min-height: 0; padding: 18px 18px; }
  [data-page="exposicoes"] .ex-press-pill::after { top: 14px; right: 14px; font-size: 14px; }

  /* §7 collections */
  [data-page="exposicoes"] .ex-collections-sect { padding-block: clamp(48px, 10vw, 80px); }
  [data-page="exposicoes"] .ex-coll {
    grid-template-columns: 36px 1fr;
    grid-template-rows: auto auto;
    gap: 6px clamp(8px, 2vw, 16px);
    padding: clamp(20px, 4vw, 32px) 0;
  }
  [data-page="exposicoes"] .ex-coll-num { grid-row: 1; }
  [data-page="exposicoes"] .ex-coll-name { grid-column: 2; grid-row: 1; font-size: clamp(22px, 7vw, 36px); }
  [data-page="exposicoes"] .ex-coll-meta { grid-column: 2; grid-row: 2; text-align: left; padding-top: 0; }
  [data-page="exposicoes"] .ex-coll:hover { padding-left: 12px; }

  /* §8 cities */
  [data-page="exposicoes"] .ex-cities-sect { padding-block: clamp(48px, 10vw, 80px); }

  /* §9 contact */
  [data-page="exposicoes"] .ex-contact { padding-block: clamp(56px, 12vw, 96px); }
  [data-page="exposicoes"] .ex-contact-actions { flex-direction: column; align-items: stretch; }
  [data-page="exposicoes"] .ex-contact-actions .btn { justify-content: center; width: 100%; }

  /* lightbox full-screen */
  [data-page="exposicoes"] .ex-lightbox { padding: 0; }
  [data-page="exposicoes"] .ex-lb-close { top: 16px; right: 16px; width: 40px; height: 40px; }
  [data-page="exposicoes"] .ex-lb-grid {
    grid-template-columns: 1fr;
    max-height: 100vh;
    height: 100vh;
    padding: 64px 18px 24px;
    border: 0;
    gap: 20px;
    overflow-y: auto;
  }
  [data-page="exposicoes"] .ex-lb-images,
  [data-page="exposicoes"] .ex-lb-side { max-height: none; overflow: visible; }
  [data-page="exposicoes"] .ex-lb-img { aspect-ratio: 4/5; }
}

@media (max-width: 600px) {
  [data-page="exposicoes"] .ex-press-wall { grid-template-columns: 1fr; }
  [data-page="exposicoes"] .ex-cities { grid-template-columns: 1fr; }
  [data-page="exposicoes"] .ex-cities li { border-right: 0; }
  [data-page="exposicoes"] .ex-section-head { gap: 12px; }
  [data-page="exposicoes"] .ex-section-tag, [data-page="exposicoes"] .ex-cap-tag { font-size: 9.5px; letter-spacing: .18em; }
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  [data-page="exposicoes"] .ex-marquee-track { animation: none !important; transform: none !important; }
  [data-page="exposicoes"] *,
  [data-page="exposicoes"] *::before,
  [data-page="exposicoes"] *::after {
    animation-duration: .001ms !important;
    transition-duration: .12s !important;
  }
}

/* ============================================================
   §29 — CATÁLOGO ISOLADO (catalogo.html)
   Hero compact + 3 editorial shelves + sticky filter bar + grid
   ============================================================ */

.cat-page {
  padding: clamp(24px, 4vw, 48px) clamp(20px, 5vw, 64px) 0;
  position: relative;
  z-index: 1;
}

/* nav active state for the new "Catálogo" link */
.nav-links a.is-active { color: var(--fg); }
.nav-links a.is-active::after {
  transform: scaleX(1);
  transform-origin: left center;
  background: var(--accent);
}

/* ----- HERO ----- */
.cat-hero {
  padding-block: clamp(48px, 8vw, 96px) clamp(36px, 5vw, 56px);
  border-bottom: 1px solid var(--hair);
}
.cat-hero-inner {
  max-width: 980px;
  display: grid;
  gap: 14px;
}
.cat-kicker {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--fg-dim);
}
.cat-title {
  font-family: var(--f-display);
  font-weight: 300;
  font-size: clamp(48px, 9vw, 116px);
  line-height: .92;
  letter-spacing: -.02em;
  color: var(--fg);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .25em;
}
.cat-title em {
  font-style: italic;
  font-weight: 300;
  color: var(--accent-2);
}
.cat-sub {
  font-family: var(--f-body);
  font-size: clamp(15px, 1.4vw, 18px);
  color: var(--fg-dim);
  max-width: 720px;
  line-height: 1.55;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 16px;
  align-items: baseline;
}
.cat-sub-mono {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--fg);
  border-left: 1px solid var(--hair-strong);
  padding-left: 14px;
}

/* ----- SHELVES ----- */
.cat-shelves {
  padding-block: clamp(36px, 5vw, 64px);
  display: grid;
  gap: clamp(40px, 5vw, 64px);
  border-bottom: 1px solid var(--hair);
}
.cat-shelf {
  display: grid;
  gap: 20px;
}
.cat-shelf-head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 6px 16px;
}
.cat-shelf-kicker {
  grid-column: 1;
  grid-row: 1;
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--fg-faint);
}
.cat-shelf-title {
  grid-column: 1;
  grid-row: 2;
  font-family: var(--f-display);
  font-weight: 300;
  font-size: clamp(26px, 3.6vw, 40px);
  line-height: 1.05;
  color: var(--fg);
}
.cat-shelf-title em { color: var(--accent-2); font-style: italic; }
.cat-shelf-meta {
  grid-column: 2;
  grid-row: 1 / span 2;
  align-self: end;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--fg-dim);
}
.cat-shelf-track {
  display: flex;
  gap: 18px;
  overflow-x: auto;
  scroll-snap-type: x proximity;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 6px;
}
.cat-shelf-track::-webkit-scrollbar { display: none; }
.cat-shelf-tile {
  flex: 0 0 auto;
  width: clamp(220px, 22vw, 300px);
  scroll-snap-align: start;
  display: grid;
  gap: 10px;
  cursor: pointer;
  position: relative;
}
.cat-shelf-img {
  aspect-ratio: 4 / 5;
  background-size: cover;
  background-position: center;
  background-color: var(--bg-2);
  border: 1px solid var(--hair);
  filter: saturate(.95) contrast(1.02);
  transition: transform .5s var(--ease), filter .5s var(--ease), border-color .3s var(--ease);
}
.cat-shelf-tile:hover .cat-shelf-img {
  transform: translateY(-3px) scale(1.01);
  filter: saturate(1.08) contrast(1.05);
  border-color: var(--hair-strong);
}
.cat-shelf-tile figcaption {
  display: grid;
  gap: 4px;
  padding: 0 2px;
}
.cat-shelf-eyebrow {
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--fg-faint);
}
.cat-shelf-name {
  font-family: var(--f-display);
  font-style: italic;
  font-weight: 300;
  font-size: 17px;
  line-height: 1.15;
  color: var(--fg);
}
.cat-shelf-price {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: .08em;
  color: var(--accent-2);
}

/* ----- FILTER BAR ----- */
.cat-filters {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in oklab, var(--bg) 86%, transparent);
  backdrop-filter: blur(14px) saturate(1.1);
  -webkit-backdrop-filter: blur(14px) saturate(1.1);
  border-block: 1px solid var(--hair);
  padding: 14px clamp(0px, 2vw, 12px);
  margin-inline: calc(-1 * clamp(20px, 5vw, 64px));
  padding-inline: clamp(20px, 5vw, 64px);
  display: grid;
  gap: 14px;
  grid-template-columns: 1fr;
}
.cat-filter-group {
  display: grid;
  grid-template-columns: 96px 1fr;
  align-items: center;
  gap: 14px;
}
.cat-filter-group.cat-filter-tail {
  grid-template-columns: 1fr;
  display: flex;
  flex-wrap: wrap;
  gap: 14px 24px;
  align-items: center;
  padding-top: 6px;
  border-top: 1px dashed var(--hair);
}
.cat-filter-label {
  font-family: var(--f-mono);
  font-size: 10.5px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--fg-faint);
}
.cat-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.cat-chip {
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: .08em;
  color: var(--fg-dim);
  background: transparent;
  border: 1px solid var(--hair);
  border-radius: 999px;
  padding: 7px 14px;
  cursor: pointer;
  transition: color .25s var(--ease), border-color .25s var(--ease), background-color .25s var(--ease), transform .25s var(--ease);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}
.cat-chip:hover {
  color: var(--fg);
  border-color: var(--hair-strong);
  transform: translateY(-1px);
}
.cat-chip.is-active {
  color: var(--bg);
  background: var(--fg);
  border-color: var(--fg);
}
.cat-chip-count {
  font-size: 10px;
  opacity: .55;
  letter-spacing: .12em;
}
.cat-chip.is-active .cat-chip-count { opacity: .7; }

/* toggle */
.cat-toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: .12em;
  color: var(--fg-dim);
}
.cat-toggle input { display: none; }
.cat-toggle-track {
  width: 36px;
  height: 18px;
  border-radius: 999px;
  background: var(--bg-3);
  border: 1px solid var(--hair-strong);
  position: relative;
  transition: background-color .3s var(--ease);
}
.cat-toggle-thumb {
  position: absolute;
  top: 2px; left: 2px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--fg-dim);
  transition: transform .3s var(--ease), background-color .3s var(--ease);
}
.cat-toggle input:checked + .cat-toggle-track {
  background: color-mix(in oklab, var(--accent) 60%, var(--bg-3));
}
.cat-toggle input:checked + .cat-toggle-track .cat-toggle-thumb {
  transform: translateX(18px);
  background: var(--fg);
}
.cat-toggle:hover .cat-toggle-label { color: var(--fg); }

/* sort */
.cat-sort {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: .12em;
  color: var(--fg-dim);
}
.cat-sort-trigger {
  font: inherit;
  letter-spacing: inherit;
  color: var(--fg);
  background: transparent;
  border: 1px solid var(--hair-strong);
  border-radius: 999px;
  padding: 7px 14px 7px 16px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-transform: uppercase;
  transition: border-color .25s var(--ease, ease), background .25s var(--ease, ease);
}
.cat-sort-trigger:hover { border-color: var(--fg); }
.cat-sort[data-state="open"] .cat-sort-trigger {
  border-color: var(--fg);
  background: color-mix(in oklab, var(--bg) 88%, var(--fg) 12%);
}
.cat-sort-current { white-space: nowrap; }
.cat-sort-chev {
  transition: transform .3s var(--ease-cine, cubic-bezier(.76,0,.24,1));
  opacity: .65;
}
.cat-sort[data-state="open"] .cat-sort-chev {
  transform: rotate(180deg);
  opacity: 1;
}
.cat-sort-panel {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 220px;
  margin: 0;
  padding: 6px;
  list-style: none;
  background: color-mix(in oklab, var(--bg) 92%, var(--fg) 4%);
  border: 1px solid var(--hair-strong);
  border-radius: 8px;
  box-shadow: 0 18px 40px -16px rgba(0, 0, 0, .55);
  backdrop-filter: blur(12px);
  z-index: 30;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition:
    opacity .22s var(--ease-cine, cubic-bezier(.76,0,.24,1)),
    transform .25s var(--ease-cine, cubic-bezier(.76,0,.24,1));
}
.cat-sort[data-state="open"] .cat-sort-panel {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.cat-sort-panel li {
  font: inherit;
  letter-spacing: inherit;
  text-transform: uppercase;
  color: var(--fg-dim);
  padding: 9px 14px;
  border-radius: 6px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  transition: background .18s ease, color .18s ease;
}
.cat-sort-panel li:hover { color: var(--fg); background: color-mix(in oklab, var(--bg) 80%, var(--fg) 20%); }
.cat-sort-panel li.is-active {
  color: var(--fg);
  background: color-mix(in oklab, var(--bg) 70%, var(--fg) 30%);
}
.cat-sort-panel li.is-active::after {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--fg);
}
@media (prefers-reduced-motion: reduce) {
  .cat-sort-panel, .cat-sort-chev, .cat-sort-trigger { transition: none !important; }
}

.cat-count {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--fg-faint);
  margin-left: auto;
}

/* ----- GRID ----- */
.cat-grid-wrap { padding-block: clamp(28px, 4vw, 48px) clamp(48px, 6vw, 80px); }
.cat-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: clamp(12px, 1.4vw, 22px);
}
.cat-tile {
  position: relative;
  display: grid;
  gap: 8px;
  cursor: pointer;
  grid-column: span 4;
}
.cat-tile-portrait  { grid-column: span 3; }
.cat-tile-square    { grid-column: span 4; }
.cat-tile-landscape { grid-column: span 4; }
.cat-tile:nth-child(13n+1) { grid-column: span 6; } /* feature row every 13 tiles */
.cat-tile-img {
  aspect-ratio: 4 / 5;
  background-size: cover;
  background-position: center;
  background-color: var(--bg-2);
  border: 1px solid var(--hair);
  filter: saturate(.95) contrast(1.02);
  transition: transform .5s var(--ease), filter .5s var(--ease), border-color .3s var(--ease);
}
.cat-tile-landscape .cat-tile-img { aspect-ratio: 3 / 2; }
.cat-tile-portrait  .cat-tile-img { aspect-ratio: 4 / 5; }
.cat-tile-square    .cat-tile-img { aspect-ratio: 1 / 1; }
.cat-tile:nth-child(13n+1) .cat-tile-img { aspect-ratio: 16 / 10; }
.cat-tile:hover .cat-tile-img {
  transform: translateY(-3px);
  filter: saturate(1.08) contrast(1.05);
  border-color: var(--hair-strong);
}
.cat-tile-cap {
  display: grid;
  gap: 4px;
  padding: 2px 2px 0;
}
.cat-tile-eyebrow {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--fg-faint);
}
.cat-tile-title {
  font-family: var(--f-display);
  font-style: italic;
  font-weight: 300;
  font-size: 16px;
  line-height: 1.15;
  color: var(--fg);
}
.cat-tile-meta {
  display: flex;
  gap: 12px;
  align-items: baseline;
  flex-wrap: wrap;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .08em;
}
.cat-tile-price { color: var(--accent-2); }
.cat-tile-ed { color: var(--fg-faint); }

/* badges */
.cat-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  font-family: var(--f-mono);
  font-size: 9.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: 5px 9px;
  border-radius: 2px;
  pointer-events: none;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.cat-badge-rare {
  background: rgba(217,139,95,.18);
  color: var(--accent-2);
  border: 1px solid color-mix(in oklab, var(--accent-2) 50%, transparent);
}
.cat-badge-sold {
  background: rgba(176,60,60,.22);
  color: #f7c2c2;
  border: 1px solid color-mix(in oklab, var(--accent) 50%, transparent);
}

/* shelf badges share style; place via wrapper if needed in future */

/* empty state */
.cat-empty {
  padding: clamp(40px, 6vw, 80px) 0;
  display: grid;
  gap: 16px;
  justify-items: start;
  font-family: var(--f-display);
  font-size: 22px;
  font-style: italic;
  font-weight: 300;
  color: var(--fg-dim);
}
.cat-clear {
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  background: transparent;
  border: 1px solid var(--hair-strong);
  color: var(--fg);
  padding: 10px 20px;
  cursor: pointer;
  border-radius: 999px;
  transition: background-color .25s var(--ease), color .25s var(--ease);
}
.cat-clear:hover { background: var(--fg); color: var(--bg); }

/* "em breve" state for placeholder categories (esculturas, prints, etc.) */
.cat-empty-soon {
  padding: clamp(72px, 10vw, 140px) clamp(24px, 5vw, 64px);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 24px;
  border: 1px dashed var(--hair-strong);
  margin: clamp(32px, 5vw, 56px) 0;
  background: color-mix(in oklab, var(--bg) 95%, var(--accent-2) 5%);
}
.cat-soon-eyebrow {
  font-family: var(--f-mono);
  font-size: 11.5px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.cat-soon-eyebrow .dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
  animation: catSoonPulse 1.6s ease-in-out infinite;
}
@keyframes catSoonPulse {
  0%, 100% { opacity: .5; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.3); }
}
.cat-soon-lead {
  font-family: var(--f-display);
  font-style: italic;
  font-weight: 300;
  font-size: clamp(20px, 2.4vw, 28px);
  line-height: 1.4;
  color: var(--fg);
  max-width: 540px;
  margin: 0;
}

/* footer */
.cat-foot {
  padding-block: 28px 36px;
  border-top: 1px solid var(--hair);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px 24px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg-faint);
}

/* ----- mobile ----- */
@media (max-width: 900px) {
  .cat-filter-group { grid-template-columns: 1fr; gap: 8px; }
  .cat-filter-group .cat-chips {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: none;
  }
  .cat-filter-group .cat-chips::-webkit-scrollbar { display: none; }
  .cat-filters { padding: 12px clamp(20px, 5vw, 64px); }
  .cat-filter-group.cat-filter-tail {
    flex-direction: column;
    align-items: stretch;
    gap: 12px;
  }
  .cat-count { margin-left: 0; }
  .cat-grid {
    grid-template-columns: repeat(6, 1fr);
    gap: 12px;
  }
  .cat-tile, .cat-tile-portrait, .cat-tile-square, .cat-tile-landscape { grid-column: span 3; }
  .cat-tile:nth-child(13n+1) { grid-column: span 6; }
}
@media (max-width: 540px) {
  .cat-grid { grid-template-columns: 1fr 1fr; }
  .cat-tile, .cat-tile-portrait, .cat-tile-square, .cat-tile-landscape { grid-column: span 1; }
  .cat-tile:nth-child(13n+1) { grid-column: span 2; }
  .cat-shelf-tile { width: 220px; }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
  .cat-tile-img, .cat-shelf-img, .cat-toggle-track, .cat-toggle-thumb, .cat-chip {
    transition: none !important;
  }
  .cat-tile:hover .cat-tile-img,
  .cat-shelf-tile:hover .cat-shelf-img { transform: none; }
}

/* ========= Catálogo · seletor de cor dominante ========= */
.cat-swatches {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.cat-swatch {
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: 1px solid var(--hair);
  padding: 7px 14px 7px 10px;
  border-radius: 999px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--fg-dim);
  transition:
    border-color .25s var(--ease, ease),
    color .25s var(--ease, ease),
    background .25s var(--ease, ease),
    transform .2s var(--ease, ease);
}
.cat-swatch:hover {
  border-color: var(--fg-dim);
  color: var(--fg);
  transform: translateY(-1px);
}
.cat-swatch.is-active {
  border-color: var(--fg);
  color: var(--fg);
  background: color-mix(in oklab, var(--bg) 85%, var(--fg) 15%);
}
.cat-swatch--all {
  padding: 7px 16px;
}
.cat-swatch-dot {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: var(--swatch, var(--fg-faint));
  box-shadow:
    0 0 0 1px color-mix(in oklab, var(--fg) 35%, transparent 65%) inset,
    0 1px 2px rgba(0,0,0,.4);
  flex-shrink: 0;
  transition: transform .25s var(--ease, ease);
}
.cat-swatch:hover .cat-swatch-dot { transform: scale(1.12); }
.cat-swatch.is-active .cat-swatch-dot {
  box-shadow:
    0 0 0 2px var(--bg) inset,
    0 0 0 3px var(--fg) inset,
    0 1px 2px rgba(0,0,0,.4);
}
.cat-swatch-label { white-space: nowrap; }
.cat-swatch-count {
  font-size: 10px;
  font-weight: 500;
  color: var(--fg-faint);
  font-variant-numeric: tabular-nums;
}
.cat-swatch.is-active .cat-swatch-count { color: var(--fg-dim); }
@media (prefers-reduced-motion: reduce) {
  .cat-swatch, .cat-swatch-dot { transition: none !important; }
}
