/* ═══════════════════════════════════════════════════════
   NLBB · SITE INSTITUCIONAL · STYLES
   Híbrido Track A (Bauru/Comunidade) + Track B (SportFi)
   ═══════════════════════════════════════════════════════ */

:root {
  /* Default palette: Preto + Laranja-fogo */
  --P:  #0A0A0A;   /* Primary / fundo */
  --Pdark: #060606;
  --Plt: #161616;  /* superfície elevada */
  --Plt2: #202020;
  --A:  #E85A1A;   /* Accent laranja-fogo */
  --Alt:#FF7A3E;
  --Adk:#B84000;
  --L:  #F4EFE6;   /* Creme */
  --G:  #8A8A85;   /* gray texto */
  --line: rgba(244,239,230,.08);

  --FD: 'Bebas Neue', sans-serif;        /* display */
  --FB: 'IBM Plex Sans', sans-serif;     /* corpo */
  --FM: 'IBM Plex Mono', monospace;      /* mono / dados */

  --pad: clamp(1.5rem, 5vw, 6rem);
  --maxw: 1320px;
  --nav-h: 64px;
}

/* Palette swaps (Tweaks) */
[data-palette="black-orange"] { --P:#0A0A0A; --Pdark:#000; --Plt:#161616; --Plt2:#202020; --A:#E85A1A; --Alt:#FF7A3E; --Adk:#B84000; --L:#F4EFE6; }
[data-palette="navy-orange"]  { --P:#0B1B2E; --Pdark:#060F1A; --Plt:#122842; --Plt2:#193554; --A:#E85A1A; --Alt:#FF7A3E; --Adk:#B84000; --L:#F4EFE6; }
[data-palette="navy-gold"]    { --P:#0B1B2E; --Pdark:#060F1A; --Plt:#122842; --Plt2:#193554; --A:#F4A300; --Alt:#FFC24D; --Adk:#B07800; --L:#F6F1E6; }
[data-palette="black-gold"]   { --P:#0A0A0A; --Pdark:#000; --Plt:#161616; --Plt2:#202020; --A:#F4A300; --Alt:#FFC24D; --Adk:#B07800; --L:#F4EFE6; }

/* Display font swaps (Tweaks) */
[data-typo="bebas"]  { --FD:'Bebas Neue', sans-serif; }
[data-typo="anton"]  { --FD:'Anton', sans-serif; }
[data-typo="barlow"] { --FD:'Barlow Condensed', sans-serif; }

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: var(--nav-h); }
body {
  font-family: var(--FB);
  background: var(--P);
  color: var(--L);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
::selection { background: var(--A); color: var(--P); }

.wrap { max-width: var(--maxw); margin: 0 auto; width: 100%; }

/* ═══ DISPLAY / TIPO HELPERS ═══ */
.display { font-family: var(--FD); line-height: .9; letter-spacing: .02em; font-weight: 400; }
.mono { font-family: var(--FM); }
.kicker {
  font-family: var(--FM); font-size: .68rem; letter-spacing: .26em;
  color: var(--A); text-transform: uppercase; display: inline-flex; align-items: center; gap: .6rem;
}
.kicker::before { content: ''; width: 26px; height: 2px; background: var(--A); }

/* ═══ NAV ═══ */
.nav {
  position: fixed; inset: 0 0 auto 0; height: var(--nav-h); z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--pad);
  background: color-mix(in srgb, var(--P) 80%, transparent);
  backdrop-filter: blur(14px) saturate(1.2);
  border-bottom: 1px solid var(--line);
  transition: background .3s;
}
.nav-logo { font-family: var(--FD); font-size: 1.5rem; letter-spacing: .12em; color: var(--L); display: flex; align-items: baseline; gap: .5rem; }
.nav-logo b { color: var(--A); font-weight: 400; }
.nav-logo .dot { width: 7px; height: 7px; background: var(--A); border-radius: 50%; align-self: center; }
.nav-links { display: flex; gap: .35rem; align-items: center; }
.nav-links a {
  font-family: var(--FM); font-size: .64rem; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(244,239,230,.55); padding: .55rem .75rem; transition: color .18s; white-space: nowrap;
}
.nav-links a:hover, .nav-links a.on { color: var(--L); }
.nav-cta {
  font-family: var(--FM); font-size: .64rem; letter-spacing: .16em; text-transform: uppercase;
  background: var(--A); color: var(--P); padding: .7rem 1.2rem; font-weight: 600;
  transition: background .18s, transform .12s; white-space: nowrap;
}
.nav-cta:hover { background: var(--Alt); }
.nav-cta:active { transform: translateY(1px); }
.nav-burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: .4rem; }
.nav-burger span { width: 24px; height: 2px; background: var(--L); transition: .2s; }

/* ═══ BUTTONS ═══ */
.btn {
  display: inline-flex; align-items: center; gap: .7rem;
  font-family: var(--FM); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 600;
  padding: 1rem 1.6rem; cursor: pointer; border: 1px solid transparent; transition: all .18s; white-space: nowrap;
}
.btn-primary { background: var(--A); color: var(--P); }
.btn-primary:hover { background: var(--Alt); }
.btn-ghost { background: none; color: var(--L); border-color: rgba(244,239,230,.25); }
.btn-ghost:hover { border-color: var(--A); color: var(--A); }
.btn-dark { background: var(--P); color: var(--L); }
.btn-dark:hover { background: var(--Plt2); }
.btn .arrow { transition: transform .18s; }
.btn:hover .arrow { transform: translateX(4px); }

/* ═══ SECTION SHELL ═══ */
.sec { padding: clamp(4rem, 9vw, 8rem) var(--pad); position: relative; }
.sec.light { background: var(--L); color: var(--P); }
.sec.dark  { background: var(--P); }
.sec.darker{ background: var(--Pdark); }
.sec.accent{ background: var(--A); color: var(--P); }

.sec-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 2rem; flex-wrap: wrap; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.sec-head .titles { max-width: 760px; }
.sec-title { font-family: var(--FD); font-size: clamp(2.6rem, 7vw, 6rem); line-height: .86; letter-spacing: .02em; margin-top: 1.1rem; }
.sec-num { font-family: var(--FM); font-size: .7rem; letter-spacing: .2em; opacity: .4; }
.sec-lead { font-size: clamp(1rem, 1.5vw, 1.18rem); line-height: 1.7; max-width: 560px; }
.sec.dark .sec-lead, .sec.darker .sec-lead { color: rgba(244,239,230,.6); }
.sec.light .sec-lead { color: rgba(10,10,10,.62); }

/* divider rule under titles */
.rule { height: 3px; background: var(--A); width: 100%; }

/* ═══ HERO ═══ */
.hero { position: relative; min-height: 100vh; display: flex; align-items: flex-end; overflow: hidden; padding: 0; }
.hero-media { position: absolute; inset: 0; z-index: 0; }
.hero-media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.1) brightness(.5); }
.hero-media::after {
  content: ''; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--P) 55%, transparent) 0%, transparent 28%, color-mix(in srgb, var(--P) 92%, transparent) 88%),
    color-mix(in srgb, var(--A) 16%, transparent);
  mix-blend-mode: normal;
}
.hero-grid-overlay {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background-image:
    linear-gradient(rgba(244,239,230,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244,239,230,.03) 1px, transparent 1px);
  background-size: 88px 88px;
}
.hero-ghost {
  position: absolute; right: -2vw; top: 8vh; z-index: 1; pointer-events: none; user-select: none;
  font-family: var(--FD); font-size: clamp(16rem, 38vw, 40rem); line-height: .8;
  color: rgba(244,239,230,.035); letter-spacing: .02em;
}
.hero-inner { position: relative; z-index: 2; width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad) clamp(3rem, 7vw, 6rem); }
.hero-bar { width: 90px; height: 6px; background: var(--A); margin-bottom: 1.8rem; }
.hero-super { font-family: var(--FM); font-size: clamp(.7rem,1vw,.82rem); letter-spacing: .3em; color: var(--A); text-transform: uppercase; margin-bottom: 1.4rem; }
.hero-title { font-family: var(--FD); font-size: clamp(3.6rem, 13vw, 12rem); line-height: .82; letter-spacing: .02em; color: var(--L); text-wrap: balance; }
.hero-title .accent { color: var(--A); }
.hero-sub { font-size: clamp(1.05rem, 1.8vw, 1.5rem); line-height: 1.55; color: rgba(244,239,230,.78); max-width: 620px; margin-top: 1.8rem; }
.hero-sub strong { color: var(--L); font-weight: 600; }
.hero-tag { font-family: var(--FD); font-size: clamp(1.4rem, 3vw, 2.4rem); letter-spacing: .14em; color: var(--A); margin-top: 1.4rem; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 2.4rem; }
.hero-meta { display: flex; gap: clamp(1.5rem,4vw,3.5rem); flex-wrap: wrap; border-top: 1px solid var(--line); margin-top: 3rem; padding-top: 1.6rem; }
.hero-meta-item { display: flex; flex-direction: column; gap: .25rem; }
.hero-meta-num { font-family: var(--FD); font-size: clamp(1.8rem,3.5vw,2.8rem); color: var(--L); line-height: 1; }
.hero-meta-lbl { font-family: var(--FM); font-size: .58rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(244,239,230,.45); }

/* Hero variant: SPLIT (media right) */
.hero[data-hero="split"] { align-items: stretch; }
.hero[data-hero="split"] .hero-media { left: auto; width: 44%; }
.hero[data-hero="split"] .hero-media::after { background: linear-gradient(90deg, var(--P) 0%, transparent 40%), color-mix(in srgb, var(--A) 14%, transparent); }
.hero[data-hero="split"] .hero-inner { display: flex; align-items: flex-end; }
.hero[data-hero="split"] .hero-ghost { display: none; }
@media (max-width: 860px) { .hero[data-hero="split"] .hero-media { width: 100%; } }

/* Hero variant: TYPE (no photo, giant type) */
.hero[data-hero="type"] .hero-media { display: none; }
.hero[data-hero="type"] { background: var(--Pdark); align-items: center; }
.hero[data-hero="type"] .hero-title { font-size: clamp(4rem, 16vw, 15rem); }
.hero[data-hero="type"] .hero-ghost { opacity: 1; }

.scroll-hint { position: absolute; bottom: 1.4rem; left: 50%; transform: translateX(-50%); z-index: 3; font-family: var(--FM); font-size: .56rem; letter-spacing: .22em; color: rgba(244,239,230,.4); text-transform: uppercase; display: flex; flex-direction: column; align-items: center; gap: .5rem; }
.scroll-hint .line { width: 1px; height: 34px; background: linear-gradient(var(--A), transparent); animation: scrolldrop 1.8s infinite; }
@keyframes scrolldrop { 0%{transform:scaleY(0);transform-origin:top;} 50%{transform:scaleY(1);transform-origin:top;} 51%{transform-origin:bottom;} 100%{transform:scaleY(0);transform-origin:bottom;} }

/* ═══ MANIFESTO ═══ */
.manifesto { background: var(--L); color: var(--P); }
.manifesto-body { max-width: 920px; }
.manifesto-lead {
  font-family: var(--FD); font-size: clamp(2rem, 5vw, 4rem); line-height: 1.02; letter-spacing: .02em;
  border-left: 5px solid var(--A); padding-left: clamp(1.2rem,2.5vw,2.2rem); margin-bottom: 2.5rem; text-wrap: balance;
}
.manifesto-p { font-size: clamp(1.05rem, 1.6vw, 1.3rem); line-height: 1.85; color: rgba(10,10,10,.72); margin-bottom: 1.3rem; max-width: 760px; }
.manifesto-p strong { color: var(--A); font-weight: 600; }
.manifesto-cine { display: none; }
.manifesto-cine.show { display: block; }
.manifesto-cine .line { font-family: var(--FB); font-size: clamp(1.1rem,1.8vw,1.45rem); line-height: 1.7; color: rgba(10,10,10,.7); margin-bottom: .4rem; }
.manifesto-cine .line.em { font-family: var(--FD); font-size: clamp(1.8rem,3.5vw,2.6rem); color: var(--P); letter-spacing: .02em; margin: 1.4rem 0 .6rem; line-height: 1; }
.manifesto-cine .line.acc { color: var(--A); font-weight: 600; }
.manifesto-cine .spacer { height: 1.4rem; }
.manifesto-sign { font-family: var(--FD); font-size: clamp(2.4rem,6vw,5rem); letter-spacing: .06em; margin-top: 2.5rem; color: var(--P); }
.manifesto-sign .accent { color: var(--A); }
.manifesto-toggle { display: inline-flex; gap: .5rem; margin-top: 2rem; }
.mtog-btn { font-family: var(--FM); font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; padding: .55rem .9rem; border: 1px solid rgba(10,10,10,.2); background: none; color: rgba(10,10,10,.55); cursor: pointer; transition: all .15s; }
.mtog-btn.on { background: var(--P); color: var(--L); border-color: var(--P); }

/* ═══ MANTRAS STRIP ═══ */
.mantras { background: var(--A); color: var(--P); overflow: hidden; padding: clamp(1.4rem,2.5vw,2rem) 0; }
.mantras-track { display: flex; gap: 3.5rem; white-space: nowrap; animation: marquee 38s linear infinite; width: max-content; }
.mantras:hover .mantras-track { animation-play-state: paused; }
.mantra-item { font-family: var(--FD); font-size: clamp(1.4rem, 3vw, 2.4rem); letter-spacing: .04em; display: inline-flex; align-items: center; gap: 3.5rem; }
.mantra-item::after { content: '●'; font-size: .5em; opacity: .5; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ═══ LIGA / GOVERNANÇA ═══ */
.proof-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px,1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.proof-cell { background: var(--P); padding: clamp(1.6rem,2.5vw,2.2rem); display: flex; flex-direction: column; gap: .6rem; transition: background .2s; }
.proof-cell:hover { background: var(--Plt); }
.proof-num { font-family: var(--FM); font-size: .58rem; letter-spacing: .18em; color: var(--A); }
.proof-h { font-family: var(--FD); font-size: clamp(1.4rem,2.5vw,1.9rem); letter-spacing: .03em; line-height: 1; }
.proof-d { font-size: .88rem; line-height: 1.6; color: rgba(244,239,230,.55); }

.rtb { margin-top: clamp(2.5rem,5vw,4rem); display: grid; grid-template-columns: 1fr 1.3fr; gap: clamp(1.5rem,4vw,3.5rem); align-items: start; }
.rtb-quote { font-family: var(--FD); font-size: clamp(1.8rem,3.5vw,2.8rem); line-height: 1.04; letter-spacing: .02em; }
.rtb-quote .accent { color: var(--A); }
.rtb-text { font-size: .98rem; line-height: 1.85; color: rgba(244,239,230,.6); }
.rtb-text p { margin-bottom: 1rem; }
.rtb-text strong { color: var(--L); font-weight: 600; }
@media (max-width: 800px){ .rtb { grid-template-columns: 1fr; } }

/* stats band */
.stats { display: grid; grid-template-columns: repeat(auto-fit,minmax(160px,1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: clamp(2.5rem,5vw,4rem); }
.stat { background: var(--Pdark); padding: clamp(1.6rem,3vw,2.4rem); text-align: left; }
.stat-num { font-family: var(--FD); font-size: clamp(2.6rem,5vw,4.2rem); color: var(--A); line-height: .9; }
.stat-lbl { font-family: var(--FM); font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(244,239,230,.5); margin-top: .6rem; line-height: 1.5; }

/* ═══ PRODUTOS ═══ */
.products { display: grid; grid-template-columns: repeat(2,1fr); gap: clamp(1rem,2vw,1.4rem); }
@media (max-width: 760px){ .products { grid-template-columns: 1fr; } }
.product {
  position: relative; overflow: hidden; min-height: 360px; display: flex; flex-direction: column; justify-content: flex-end;
  padding: clamp(1.6rem,3vw,2.4rem); border: 1px solid var(--line); background: var(--Plt); isolation: isolate;
}
.product-media { position: absolute; inset: 0; z-index: -1; }
.product-media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) brightness(.42) contrast(1.05); transition: transform .6s, filter .4s; }
.product:hover .product-media img { transform: scale(1.06); filter: grayscale(.4) brightness(.5) contrast(1.05); }
.product-media::after { content:''; position:absolute; inset:0; background: linear-gradient(180deg, transparent 30%, color-mix(in srgb, var(--P) 88%, transparent) 100%); }
.product-tag { position: absolute; top: clamp(1.4rem,3vw,2rem); left: clamp(1.6rem,3vw,2.4rem); font-family: var(--FM); font-size: .6rem; letter-spacing: .18em; text-transform: uppercase; color: var(--A); }
.product-num { position: absolute; top: clamp(1.4rem,3vw,2rem); right: clamp(1.6rem,3vw,2.4rem); font-family: var(--FM); font-size: .6rem; letter-spacing: .12em; color: rgba(244,239,230,.4); }
.product-name { font-family: var(--FD); font-size: clamp(2.4rem,5vw,3.4rem); line-height: .92; letter-spacing: .03em; }
.product-desc { font-size: .92rem; line-height: 1.6; color: rgba(244,239,230,.68); margin-top: .7rem; max-width: 420px; }
.product-link { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--FM); font-size: .64rem; letter-spacing: .14em; text-transform: uppercase; color: var(--A); margin-top: 1.1rem; }
.product:hover .product-link .arrow { transform: translateX(4px); }
.product-link .arrow { transition: transform .18s; }

/* ═══ NOTÍCIAS / JOGOS ═══ */
.games { display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(2rem,4vw,3.5rem); align-items: start; }
@media (max-width: 900px){ .games { grid-template-columns: 1fr; } }
.fixtures { display: flex; flex-direction: column; }
.fixture { display: grid; grid-template-columns: auto 1fr auto; gap: 1.2rem; align-items: center; padding: 1.3rem 0; border-bottom: 1px solid rgba(10,10,10,.12); }
.sec.dark .fixture, .sec.darker .fixture { border-bottom-color: var(--line); }
.fixture-date { font-family: var(--FM); font-size: .62rem; letter-spacing: .1em; text-align: center; line-height: 1.4; }
.fixture-date .d { font-family: var(--FD); font-size: 1.7rem; display: block; line-height: .9; color: var(--A); }
.fixture-match { display: flex; flex-direction: column; gap: .2rem; }
.fixture-teams { font-family: var(--FD); font-size: clamp(1.2rem,2.2vw,1.6rem); letter-spacing: .03em; }
.fixture-meta { font-family: var(--FM); font-size: .58rem; letter-spacing: .1em; opacity: .55; text-transform: uppercase; }
.fixture-cta { font-family: var(--FM); font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; padding: .5rem .8rem; border: 1px solid currentColor; opacity: .7; transition: .18s; }
.fixture-cta:hover { opacity: 1; background: var(--A); color: var(--P); border-color: var(--A); }

.news { display: flex; flex-direction: column; gap: 1rem; }
.news-card { display: flex; gap: 1.1rem; align-items: stretch; background: var(--Plt); border: 1px solid var(--line); overflow: hidden; transition: border-color .2s; }
.news-card:hover { border-color: var(--A); }
.news-thumb { width: 118px; flex-shrink: 0; overflow: hidden; }
.news-thumb img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(.7) brightness(.8); }
.news-body { padding: 1rem 1.1rem 1.1rem 0; display: flex; flex-direction: column; gap: .35rem; }
.news-cat { font-family: var(--FM); font-size: .54rem; letter-spacing: .16em; text-transform: uppercase; color: var(--A); }
.news-title { font-family: var(--FD); font-size: clamp(1.1rem,1.8vw,1.4rem); letter-spacing: .02em; line-height: 1; color: var(--L); }
.news-date { font-family: var(--FM); font-size: .56rem; letter-spacing: .08em; color: rgba(244,239,230,.4); margin-top: auto; }

/* ═══ INSCRIÇÃO CTA ═══ */
.enroll { position: relative; overflow: hidden; text-align: center; }
.enroll-media { position: absolute; inset: 0; z-index: 0; }
.enroll-media img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) brightness(.32) contrast(1.1); }
.enroll-media::after { content:''; position:absolute; inset:0; background: color-mix(in srgb, var(--A) 22%, transparent); }
.enroll-inner { position: relative; z-index: 2; max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; align-items: center; gap: 1.4rem; }
.enroll-h { font-family: var(--FD); font-size: clamp(3rem,9vw,7rem); line-height: .85; letter-spacing: .02em; }
.enroll-h .accent { color: var(--A); }
.enroll-p { font-size: clamp(1.05rem,1.6vw,1.25rem); line-height: 1.6; color: rgba(244,239,230,.8); max-width: 560px; }

/* ═══ PATROCINADORES ═══ */
.sponsor-tiers { display: grid; gap: 1px; background: rgba(10,10,10,.1); border: 1px solid rgba(10,10,10,.1); margin-bottom: clamp(2.5rem,5vw,3.5rem); }
.tier { display: grid; grid-template-columns: 220px 1fr 1fr; gap: 1px; background: rgba(10,10,10,.1); }
@media (max-width: 800px){ .tier { grid-template-columns: 1fr; } }
.tier-head { background: var(--P); color: var(--L); padding: 1.6rem; }
.tier-name { font-family: var(--FD); font-size: clamp(1.6rem,3vw,2.2rem); letter-spacing: .03em; line-height: 1; }
.tier-tag { font-family: var(--FM); font-size: .58rem; letter-spacing: .18em; text-transform: uppercase; color: var(--A); margin-bottom: .5rem; }
.tier-col { background: var(--L); padding: 1.6rem; }
.tier-col h5 { font-family: var(--FM); font-size: .56rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(10,10,10,.5); margin-bottom: .7rem; }
.tier-col ul { list-style: none; font-size: .86rem; line-height: 1.85; color: rgba(10,10,10,.72); }
.tier-col li { padding-left: 1.1rem; position: relative; }
.tier-col li::before { content:''; position:absolute; left:0; top:.62em; width:5px; height:5px; background: var(--A); }

.partners { display: flex; flex-wrap: wrap; gap: 1px; background: rgba(10,10,10,.1); border: 1px solid rgba(10,10,10,.1); }
.partner { flex: 1 1 160px; background: var(--L); padding: 1.8rem 1.4rem; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .4rem; min-height: 110px; }
.partner-name { font-family: var(--FD); font-size: 1.5rem; letter-spacing: .04em; color: var(--P); text-align: center; line-height: .95; }
.partner-role { font-family: var(--FM); font-size: .52rem; letter-spacing: .14em; text-transform: uppercase; color: var(--A); }
.partner.anchor { background: var(--P); }
.partner.anchor .partner-name { color: var(--L); }

/* ═══ ORIGEM ═══ */
.origin { display: grid; grid-template-columns: 1fr 1fr; gap: 0; align-items: stretch; }
@media (max-width: 860px){ .origin { grid-template-columns: 1fr; } }
.origin-media { position: relative; overflow: hidden; min-height: 420px; }
.origin-media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(1) contrast(1.1) brightness(.6); }
.origin-media::after { content:''; position:absolute; inset:0; background: linear-gradient(0deg, color-mix(in srgb,var(--P) 70%,transparent), transparent), color-mix(in srgb, var(--A) 14%, transparent); }
.origin-cap { position: absolute; bottom: 1.4rem; left: 1.6rem; z-index: 2; font-family: var(--FM); font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(244,239,230,.7); }
.origin-text { background: var(--Plt); padding: clamp(2rem,5vw,4rem); display: flex; flex-direction: column; justify-content: center; }
.origin-q { font-family: var(--FD); font-size: clamp(1.8rem,4vw,3rem); line-height: 1.04; letter-spacing: .02em; margin-bottom: 1.6rem; text-wrap: balance; }
.origin-q .accent { color: var(--A); }
.origin-p { font-size: .98rem; line-height: 1.85; color: rgba(244,239,230,.62); margin-bottom: 1rem; max-width: 520px; }
.origin-p strong { color: var(--L); font-weight: 600; }

/* ═══ CONTATO / FOOTER ═══ */
.contact { background: var(--Pdark); }
.contact-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: start; }
@media (max-width: 800px){ .contact-grid { grid-template-columns: 1fr; } }
.contact-h { font-family: var(--FD); font-size: clamp(2.6rem,6vw,5rem); line-height: .88; letter-spacing: .02em; }
.contact-h .accent { color: var(--A); }
.contact-p { font-size: 1.05rem; line-height: 1.7; color: rgba(244,239,230,.6); margin-top: 1.2rem; max-width: 460px; }
.contact-channels { display: flex; flex-direction: column; gap: .9rem; }
.channel { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.1rem 1.3rem; border: 1px solid var(--line); background: var(--Plt); transition: all .18s; }
.channel:hover { border-color: var(--A); background: var(--Plt2); }
.channel-name { font-family: var(--FM); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--L); }
.channel-val { font-family: var(--FM); font-size: .64rem; letter-spacing: .06em; color: rgba(244,239,230,.5); }

.footer { background: #000; padding: clamp(3rem,6vw,5rem) var(--pad) 2rem; }
.footer-top { display: flex; justify-content: space-between; align-items: flex-start; gap: 2rem; flex-wrap: wrap; padding-bottom: 2.5rem; border-bottom: 1px solid var(--line); }
.footer-logo { font-family: var(--FD); font-size: clamp(3rem,8vw,6rem); letter-spacing: .08em; line-height: .8; }
.footer-logo .accent { color: var(--A); }
.footer-tag { font-family: var(--FD); font-size: 1.3rem; letter-spacing: .12em; color: var(--A); margin-top: .6rem; }
.footer-cols { display: flex; gap: clamp(2rem,5vw,4rem); flex-wrap: wrap; }
.footer-col h6 { font-family: var(--FM); font-size: .58rem; letter-spacing: .18em; text-transform: uppercase; color: rgba(244,239,230,.4); margin-bottom: 1rem; }
.footer-col a { display: block; font-size: .85rem; color: rgba(244,239,230,.6); padding: .25rem 0; transition: color .15s; }
.footer-col a:hover { color: var(--A); }
.footer-bot { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding-top: 1.8rem; font-family: var(--FM); font-size: .56rem; letter-spacing: .12em; color: rgba(244,239,230,.3); text-transform: uppercase; }

/* ═══ TWEAKS PANEL ═══ */
#tweaks { position: fixed; bottom: 1rem; right: 1rem; z-index: 9999; width: 282px; max-height: calc(100vh - 2rem); overflow-y: auto;
  background: rgba(8,8,8,.97); backdrop-filter: blur(16px); border: 1px solid rgba(244,239,230,.14); padding: 1.3rem; display: none; }
#tweaks.open { display: block; }
.tw-title { font-family: var(--FM); font-size: .58rem; letter-spacing: .24em; text-transform: uppercase; color: var(--A); margin-bottom: 1.3rem; display: flex; justify-content: space-between; }
.tw-group { margin-bottom: 1.3rem; }
.tw-label { font-family: var(--FM); font-size: .54rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(244,239,230,.4); margin-bottom: .6rem; }
.tw-opts { display: flex; gap: .3rem; flex-wrap: wrap; }
.tw-btn { font-family: var(--FM); font-size: .58rem; letter-spacing: .06em; padding: .4rem .65rem; border: 1px solid rgba(244,239,230,.16); background: none; color: rgba(244,239,230,.45); cursor: pointer; transition: all .15s; text-transform: uppercase; }
.tw-btn:hover { border-color: var(--A); color: var(--A); }
.tw-btn.on { background: var(--A); border-color: var(--A); color: var(--P); }
.tw-swatches { display: flex; gap: .35rem; flex-wrap: wrap; }
.tw-sw { width: 40px; height: 40px; border: 2px solid transparent; cursor: pointer; padding: 0; display: flex; }
.tw-sw span { flex: 1; }
.tw-sw.on { border-color: var(--L); }
.tw-close { width: 100%; margin-top: .6rem; font-family: var(--FM); font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; padding: .5rem; border: 1px solid rgba(244,239,230,.14); background: none; color: rgba(244,239,230,.4); cursor: pointer; }
.tw-close:hover { color: var(--L); border-color: rgba(244,239,230,.35); }

/* reveal on scroll */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }

/* ═══ RESPONSIVE NAV ═══ */
@media (max-width: 980px) {
  .nav-links { position: fixed; inset: var(--nav-h) 0 auto 0; flex-direction: column; align-items: stretch; gap: 0;
    background: var(--Pdark); border-bottom: 1px solid var(--line); padding: .5rem var(--pad) 1.2rem; transform: translateY(-130%); transition: transform .3s; }
  .nav-links.open { transform: none; }
  .nav-links a { padding: .9rem 0; border-bottom: 1px solid var(--line); font-size: .8rem; }
  .nav-burger { display: flex; }
  .nav-desktop-cta { display: none; }
}

/* ═══════════════════════════════════════════════════════
   SUBPÁGINAS — componentes (mesma IDV do index)
   ═══════════════════════════════════════════════════════ */

/* nav active state for cross-page links */
.nav-links a.current { color: var(--A); }

/* ── PAGE HERO (compacto, foto tratada) ── */
.phero { position: relative; min-height: 64vh; display: flex; align-items: flex-end; overflow: hidden; padding: 0; border-bottom: 1px solid var(--line); }
.phero-media { position: absolute; inset: 0; z-index: 0; }
.phero-media img { width: 100%; height: 100%; object-fit: cover; object-position: center 32%; filter: grayscale(1) contrast(1.08) brightness(.58); }
.phero-media::after { content:''; position: absolute; inset: 0;
  background: linear-gradient(180deg, color-mix(in srgb,var(--P) 35%,transparent) 0%, transparent 42%, color-mix(in srgb,var(--P) 88%,transparent) 94%), color-mix(in srgb, var(--A) 13%, transparent); }
.phero-grid { position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background-image: linear-gradient(rgba(244,239,230,.03) 1px, transparent 1px), linear-gradient(90deg, rgba(244,239,230,.03) 1px, transparent 1px); background-size: 88px 88px; }
.phero-ghost { position: absolute; right: -1vw; top: 4vh; z-index: 1; pointer-events: none; user-select: none; font-family: var(--FD); font-size: clamp(9rem,26vw,26rem); line-height: .8; color: rgba(244,239,230,.04); }
.phero-inner { position: relative; z-index: 2; width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 7rem var(--pad) clamp(2.5rem,5vw,4rem); }
.phero-bar { width: 80px; height: 6px; background: var(--A); margin-bottom: 1.4rem; }
.phero-super { font-family: var(--FM); font-size: clamp(.66rem,1vw,.78rem); letter-spacing: .28em; color: var(--A); text-transform: uppercase; margin-bottom: 1rem; }
.phero-title { font-family: var(--FD); font-size: clamp(3rem,9vw,7.5rem); line-height: .84; letter-spacing: .02em; color: var(--L); text-wrap: balance; }
.phero-title .accent { color: var(--A); }
.phero-sub { font-size: clamp(1rem,1.5vw,1.3rem); line-height: 1.55; color: rgba(244,239,230,.78); max-width: 620px; margin-top: 1.4rem; }
.phero-sub strong { color: var(--L); font-weight: 600; }
.phero-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 2rem; }
.phero-meta { display: flex; gap: clamp(1.2rem,3vw,2.8rem); flex-wrap: wrap; border-top: 1px solid var(--line); margin-top: 2.4rem; padding-top: 1.4rem; }
.phero-meta-item { display: flex; flex-direction: column; gap: .2rem; }
.phero-meta-num { font-family: var(--FD); font-size: clamp(1.5rem,3vw,2.4rem); color: var(--L); line-height: 1; }
.phero-meta-lbl { font-family: var(--FM); font-size: .56rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(244,239,230,.45); }

/* ── TROFÉUS ── */
.trophies { display: grid; grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); gap: clamp(1rem,2vw,1.4rem); }
.trophy { border: 1px solid var(--line); background: var(--Plt); padding: clamp(1.6rem,3vw,2.2rem); display: flex; flex-direction: column; transition: border-color .2s, background .2s; }
.trophy:hover { border-color: var(--A); background: var(--Plt2); }
.trophy-top { display: flex; align-items: baseline; justify-content: space-between; }
.trophy-num { font-family: var(--FD); font-size: clamp(3rem,5vw,4rem); color: var(--A); line-height: .8; }
.trophy-status { font-family: var(--FM); font-size: .56rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(244,239,230,.45); }
.trophy-name { font-family: var(--FD); font-size: clamp(1.5rem,2.4vw,2rem); letter-spacing: .03em; line-height: .98; margin-top: 1.1rem; }
.trophy-when { font-family: var(--FM); font-size: .64rem; letter-spacing: .12em; text-transform: uppercase; color: var(--A); margin-top: .6rem; }
.trophy-desc { font-size: .9rem; line-height: 1.65; color: rgba(244,239,230,.6); margin-top: .9rem; }
.sec.light .trophy { background: #fff; border-color: rgba(10,10,10,.12); }
.sec.light .trophy:hover { border-color: var(--A); }
.sec.light .trophy-name { color: var(--P); }
.sec.light .trophy-desc { color: rgba(10,10,10,.62); }
.sec.light .trophy-status { color: rgba(10,10,10,.45); }

/* ── FORMATO / STEPS (numbered) ── */
.steps { display: grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.step { background: var(--P); padding: clamp(1.6rem,3vw,2.2rem); }
.step-n { font-family: var(--FD); font-size: clamp(2.6rem,5vw,3.6rem); color: var(--A); line-height: .8; }
.step-h { font-family: var(--FD); font-size: clamp(1.4rem,2.2vw,1.8rem); letter-spacing: .03em; margin-top: .8rem; }
.step-d { font-size: .9rem; line-height: 1.6; color: rgba(244,239,230,.6); margin-top: .5rem; }
.sec.light .step { background: #fff; }
.sec.light .step-d { color: rgba(10,10,10,.62); }
.steps.on-cream .step { background: var(--L); }

/* ── TABELA DE CLASSIFICAÇÃO ── */
.classif { overflow-x: auto; border: 1px solid var(--line); }
.classif table { width: 100%; border-collapse: collapse; min-width: 560px; }
.classif thead tr { background: var(--Pdark); }
.classif th { font-family: var(--FM); font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(244,239,230,.55); padding: .9rem .8rem; text-align: center; }
.classif th:nth-child(2) { text-align: left; }
.classif td { padding: .85rem .8rem; border-top: 1px solid var(--line); text-align: center; font-family: var(--FM); font-variant-numeric: tabular-nums; font-size: .9rem; color: rgba(244,239,230,.8); }
.classif td.pos { color: var(--A); font-weight: 600; }
.classif td.team { text-align: left; font-family: var(--FD); font-size: 1.3rem; letter-spacing: .03em; color: var(--L); }
.classif td.team .city { font-family: var(--FM); font-size: .62rem; letter-spacing: .06em; color: rgba(244,239,230,.4); margin-left: .5rem; }
.classif td.pts { font-family: var(--FD); font-size: 1.4rem; color: var(--A); }
.classif tbody tr:hover { background: var(--Plt); }
.classif .colorbar { display: inline-flex; width: 8px; height: 22px; overflow: hidden; vertical-align: middle; margin-right: .6rem; }
.classif .colorbar span { flex: 1; }

/* ── CARDS DE TIME ── */
.teams { display: grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.team-card { background: var(--P); padding: clamp(1.6rem,3vw,2rem); transition: background .2s; }
.team-card:hover { background: var(--Plt); }
.team-colors { display: flex; height: 8px; width: 96px; overflow: hidden; }
.team-colors span { flex: 1; }
.team-name { font-family: var(--FD); font-size: clamp(1.6rem,2.5vw,2.1rem); letter-spacing: .03em; line-height: .95; margin-top: 1rem; }
.team-city { font-family: var(--FM); font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--A); margin-top: .4rem; }
.team-dl { margin-top: 1.3rem; border-top: 1px solid var(--line); padding-top: 1rem; display: grid; gap: .5rem; }
.team-dl .row { display: flex; justify-content: space-between; align-items: baseline; gap: 1rem; }
.team-dl dt { font-family: var(--FM); font-size: .58rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(244,239,230,.4); }
.team-dl dd { font-size: .85rem; color: rgba(244,239,230,.78); text-align: right; }

/* ── FORMULÁRIO ── */
.form-wrap { display: grid; grid-template-columns: 1.4fr 1fr; gap: clamp(2rem,4vw,3.5rem); align-items: start; }
@media (max-width: 900px){ .form-wrap { grid-template-columns: 1fr; } }
.form-card { border: 1px solid rgba(10,10,10,.14); background: #fff; padding: clamp(1.6rem,3vw,2.4rem); }
.form-card h3 { font-family: var(--FD); font-size: clamp(1.8rem,3vw,2.4rem); letter-spacing: .03em; color: var(--P); }
.form-intro { font-size: .92rem; line-height: 1.6; color: rgba(10,10,10,.62); margin: .6rem 0 1.6rem; }
.field { display: flex; flex-direction: column; gap: .4rem; margin-bottom: 1.1rem; }
.field label { font-family: var(--FM); font-size: .6rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(10,10,10,.6); }
.field input, .field select, .field textarea { width: 100%; background: var(--L); color: var(--P); border: 1px solid rgba(10,10,10,.25); padding: .8rem .9rem; font-family: var(--FB); font-size: 1rem; border-radius: 0; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--A); }
.field-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
@media (max-width: 560px){ .field-2 { grid-template-columns: 1fr; } }
.form-actions { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; margin-top: .4rem; }
.form-alt { font-family: var(--FM); font-size: .64rem; letter-spacing: .06em; text-transform: uppercase; color: rgba(10,10,10,.5); }
.form-alt a { color: var(--Adk); text-decoration: underline; }
.form-ok { display: none; border-left: 3px solid #1e7f3d; background: rgba(30,127,61,.08); padding: .9rem 1rem; font-size: .9rem; color: var(--P); margin-top: 1rem; }
.form-ok.show { display: block; }
.form-ok a { color: var(--Adk); text-decoration: underline; }
.aside-block { margin-bottom: 2rem; }
.aside-block h4 { font-family: var(--FD); font-size: 1.5rem; letter-spacing: .03em; }
.sec.light .aside-block h4 { color: var(--P); }
.doc-list { list-style: none; margin-top: .8rem; display: grid; gap: .5rem; }
.doc-list li { position: relative; padding-left: 1.2rem; font-size: .9rem; line-height: 1.5; }
.sec.light .doc-list li { color: rgba(10,10,10,.72); }
.doc-list li::before { content:''; position: absolute; left: 0; top: .55em; width: 6px; height: 6px; background: var(--A); }
.taxa-box { border: 1px solid rgba(10,10,10,.18); padding: 1.3rem; }
.taxa-box .lbl { font-family: var(--FM); font-size: .6rem; letter-spacing: .14em; text-transform: uppercase; color: var(--Adk); }
.taxa-box .val { font-family: var(--FD); font-size: clamp(1.6rem,3vw,2.2rem); color: var(--P); margin-top: .3rem; letter-spacing: .02em; }
.taxa-box .obs { font-size: .85rem; line-height: 1.55; color: rgba(10,10,10,.6); margin-top: .5rem; }
.prazo-dl { margin-top: .8rem; border-top: 1px solid rgba(10,10,10,.15); }
.prazo-dl .row { display: flex; justify-content: space-between; gap: 1rem; padding: .7rem 0; border-bottom: 1px solid rgba(10,10,10,.15); }
.prazo-dl dt { font-size: .85rem; color: rgba(10,10,10,.72); }
.prazo-dl dd { font-family: var(--FM); font-size: .64rem; letter-spacing: .06em; text-transform: uppercase; color: var(--P); }

/* categorias chips */
.cats { display: grid; grid-template-columns: repeat(auto-fit,minmax(230px,1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.cat { background: var(--P); padding: 1.4rem; border-top: 2px solid transparent; }
.cat.dest { border-top-color: var(--A); }
.cat-head { display: flex; align-items: center; justify-content: space-between; gap: .5rem; }
.cat-name { font-family: var(--FD); font-size: 1.6rem; letter-spacing: .03em; }
.cat-flag { font-family: var(--FM); font-size: .54rem; letter-spacing: .14em; text-transform: uppercase; color: var(--A); }
.cat-desc { font-size: .85rem; line-height: 1.55; color: rgba(244,239,230,.6); margin-top: .5rem; }

/* ── COTAS ── */
.cotas { display: grid; grid-template-columns: repeat(auto-fit,minmax(280px,1fr)); gap: clamp(1rem,2vw,1.4rem); }
.cota { border: 1px solid rgba(10,10,10,.14); background: #fff; padding: clamp(1.6rem,3vw,2.2rem); display: flex; flex-direction: column; }
.cota.dest { border: 2px solid var(--A); }
.cota-top { display: flex; align-items: baseline; justify-content: space-between; }
.cota-name { font-family: var(--FD); font-size: clamp(2rem,3.5vw,2.8rem); letter-spacing: .03em; color: var(--P); }
.cota-flag { font-family: var(--FM); font-size: .56rem; letter-spacing: .14em; text-transform: uppercase; color: var(--A); }
.cota-price { font-family: var(--FM); font-size: .95rem; font-weight: 600; color: var(--Adk); margin-top: .4rem; }
.cota-aud { font-size: .85rem; line-height: 1.5; color: rgba(10,10,10,.6); margin-top: .5rem; }
.cota-list { list-style: none; margin-top: 1.1rem; border-top: 1px solid rgba(10,10,10,.15); padding-top: 1rem; display: grid; gap: .5rem; }
.cota-list li { position: relative; padding-left: 1.2rem; font-size: .85rem; line-height: 1.45; color: rgba(10,10,10,.72); }
.cota-list li::before { content:''; position: absolute; left: 0; top: .5em; width: 6px; height: 6px; background: var(--A); }

/* ── FAQ ── */
.faq-group { margin-bottom: clamp(2.5rem,5vw,3.5rem); }
.faq-group-head { display: flex; align-items: center; gap: 1rem; margin-bottom: .5rem; }
.faq-group-head h3 { font-family: var(--FD); font-size: clamp(1.6rem,3vw,2.2rem); letter-spacing: .03em; white-space: nowrap; }
.faq-group-head .ln { flex: 1; height: 2px; background: var(--A); opacity: .5; }
.faq-item { border-top: 1px solid rgba(10,10,10,.14); }
.faq-q { width: 100%; text-align: left; background: none; border: 0; cursor: pointer; padding: 1.2rem 0; display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; font-family: var(--FD); font-size: clamp(1.15rem,1.8vw,1.5rem); letter-spacing: .02em; color: var(--P); }
.faq-q .pm { font-family: var(--FM); font-size: 1.3rem; color: var(--A); flex-shrink: 0; transition: transform .2s; }
.faq-item.open .faq-q .pm { transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq-a-inner { padding-bottom: 1.3rem; font-size: 1rem; line-height: 1.7; color: rgba(10,10,10,.7); max-width: 70ch; }
.faq-item.open .faq-a { max-height: 320px; }

/* ── CTA strip ── */
.ctastrip { display: flex; align-items: center; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.ctastrip-h { font-family: var(--FD); font-size: clamp(2rem,4vw,3.2rem); letter-spacing: .03em; line-height: .95; }
.ctastrip-p { font-size: .95rem; line-height: 1.6; margin-top: .5rem; }
.sec.accent .ctastrip-p { color: rgba(10,10,10,.72); }

/* convidados (subpage) */
.guests { display: grid; grid-template-columns: repeat(auto-fit,minmax(220px,1fr)); gap: 1px; background: rgba(10,10,10,.18); border: 1px solid rgba(10,10,10,.18); margin-top: 2rem; }
.guest { background: var(--A); padding: 1.4rem; }
.guest-n { font-family: var(--FD); font-size: 2.4rem; color: rgba(10,10,10,.45); line-height: .8; }
.guest-t { font-size: .92rem; font-weight: 600; color: var(--P); margin-top: .6rem; line-height: 1.4; }

/* ── HUB (landing nav cards) ── */
.hub { display: grid; grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); }
.hub-card { background: var(--P); padding: clamp(1.6rem,3vw,2.4rem); display: flex; flex-direction: column; gap: .5rem; min-height: 200px; position: relative; transition: background .2s; }
.hub-card:hover { background: var(--Plt); }
.hub-num { font-family: var(--FM); font-size: .58rem; letter-spacing: .16em; text-transform: uppercase; color: var(--A); }
.hub-title { font-family: var(--FD); font-size: clamp(2rem,3.5vw,2.8rem); letter-spacing: .03em; line-height: .92; margin-top: auto; }
.hub-desc { font-size: .88rem; line-height: 1.55; color: rgba(244,239,230,.55); }
.hub-go { font-family: var(--FM); font-size: .62rem; letter-spacing: .14em; text-transform: uppercase; color: var(--A); display: inline-flex; align-items: center; gap: .5rem; margin-top: .4rem; }
.hub-go .arrow { transition: transform .18s; }
.hub-card:hover .hub-go .arrow { transform: translateX(4px); }

/* ── MANIFESTO TEASER ── */
.mteaser { background: var(--L); color: var(--P); }
.mteaser-quote { font-family: var(--FD); font-size: clamp(2.4rem,6vw,5rem); line-height: .95; letter-spacing: .02em; border-left: 5px solid var(--A); padding-left: clamp(1.2rem,2.5vw,2.2rem); max-width: 18ch; }
.mteaser-quote .accent { color: var(--A); }
.mteaser-p { font-size: clamp(1rem,1.5vw,1.2rem); line-height: 1.7; color: rgba(10,10,10,.65); max-width: 52ch; margin-top: 1.6rem; }
