/* === VARIABLES === */
:root {
  --navy-950: #070D1F;
  --navy-900: #0B1430;
  --navy-800: #0F1B3D;
  --yellow: #F8C928;
  --yellow-dark: #E6B520;
  --blue: #153A97;
  --blue-light: #2C54C6;
  --purple: #3B245E;
  --red: #E1192D;
  --red-dark: #9E0F1F;
  --red-light: rgba(192,57,43,.12);
  --yellow-light: rgba(248,201,40,.12);
  --offwhite: #F4F1EA;
  --offwhite-1: #F6F2E8;
  --offwhite-2: #F4F1EA;
  --offwhite-3: #EEF3FF;
  --container: 1240px;
}

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

html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: 'Manrope', system-ui, sans-serif;
  background: var(--navy-950);
  color: var(--offwhite);
  overflow-x: hidden;
  line-height: 1.6;
}

main {
  display: flex;
  flex-direction: column;
}

::selection { background: var(--yellow); color: var(--navy-950); }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; border:none; background:none; font:inherit; -webkit-tap-highlight-color:transparent; }
*:focus-visible { outline:2px solid var(--yellow); outline-offset:3px; border-radius:2px; }

h1,h2,h3,h4 {
  font-family: 'Barlow Condensed', system-ui, sans-serif;
  letter-spacing: -.01em;
  line-height: .95;
  font-weight: 800;
}
h2,h3 { font-weight:700; }

/* === LAYOUT === */
.container { margin:0 auto; width:100%; max-width:var(--container); padding:0 1.25rem; }
@media (min-width:640px) { .container { padding:0 2rem; } }
@media (min-width:1024px) { .container { padding:0 2.5rem; } }

/* === UTILITY === */
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--yellow);
}
.eyebrow::before {
  content: '';
  display: block;
  width: 1.25rem;
  height: 2px;
  background: currentColor;
  flex-shrink: 0;
}

.section-rule {
  width:4rem;
  height:4px;
  background:var(--yellow);
  margin-top:1.1rem;
  position:relative;
  overflow:hidden;
  box-shadow:0 0 12px rgba(248,201,40,.22);
}
.section-rule::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.72), transparent);
  transform:translateX(-120%);
  animation: lineSweep 3.8s ease-in-out infinite;
  pointer-events:none;
}
.renova-blue { color:var(--blue); font-weight:800; }
.about-mini-card .renova-blue,
.media-card .renova-blue { color:#5F7CFF; }

@keyframes lineSweep {
  0%, 45% { transform:translateX(-120%); }
  75%, 100% { transform:translateX(120%); }
}

@keyframes softDrift {
  0%, 100% { transform:translate3d(0,0,0) scale(1); opacity:var(--drift-opacity, 1); }
  50% { transform:translate3d(1.2rem,-.8rem,0) scale(1.035); opacity:.82; }
}

@keyframes paperFloat {
  0%, 100% { transform:translateY(0) rotate(var(--paper-rotate, 0deg)); }
  50% { transform:translateY(-8px) rotate(calc(var(--paper-rotate, 0deg) + 2deg)); }
}

@keyframes gradientMove {
  0%, 100% { background-position:0% 50%; }
  50% { background-position:100% 50%; }
}

@keyframes heroBgIntro {
  from { opacity:0; transform:scale(1.012); }
  to { opacity:1; transform:scale(1); }
}

@keyframes heroIntro {
  from { opacity:0; transform:translate3d(0,14px,0) scale(.985); }
  to { opacity:1; transform:translate3d(0,0,0) scale(1); }
}

.bg-grid {
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 64px 64px;
}

.reveal {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .65s cubic-bezier(.22,1,.36,1), transform .65s cubic-bezier(.22,1,.36,1);
}
.reveal-left { transform:translate3d(-22px, 10px, 0); }
.reveal-right { transform:translate3d(22px, 10px, 0); }
.reveal-up { transform:translate3d(0, 22px, 0); }
.reveal-scale { transform:translate3d(0, 14px, 0) scale(.975); }
.reveal.visible { opacity:1; transform:translateY(0); }

/* === SECTION DIVIDER === */
.section-glow-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(21,58,151,.45) 30%, rgba(248,201,40,.3) 70%, transparent);
  margin: 0;
}

/* === BUTTONS === */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: .7rem 1.5rem;
  border-radius: 5px;
  transition: all .22s cubic-bezier(.22,1,.36,1);
  cursor: pointer;
  border: 2px solid transparent;
  white-space: nowrap;
  line-height: 1.2;
}
.btn svg { width:17px; height:17px; flex-shrink:0; }

.btn-yellow {
  background: var(--yellow);
  color: var(--navy-950);
  border-color: var(--yellow);
}
.btn-yellow:hover {
  background: var(--yellow-dark);
  border-color: var(--yellow-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(248,201,40,.4), 0 2px 8px rgba(248,201,40,.2);
}

.btn-red {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}
.btn-red:hover {
  background: var(--red-dark);
  border-color: var(--red-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(192,57,43,.45), 0 2px 8px rgba(192,57,43,.2);
}

.btn-outline-white {
  background: transparent;
  color: var(--offwhite);
  border-color: rgba(244,241,234,.3);
}
.btn-outline-white:hover {
  border-color: rgba(244,241,234,.75);
  background: rgba(255,255,255,.07);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,.18);
}
.hero-cta-secondary {
  border-color: rgba(244,241,234,.28);
  letter-spacing: .05em;
}

.btn-blue {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
}
.btn-blue:hover {
  background: var(--blue-light);
  border-color: var(--blue-light);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(21,58,151,.34);
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
  position: relative;
  z-index: 100;
  transition: background .3s, border-color .3s, box-shadow .3s, transform .3s;
  border-bottom: 1px solid rgba(255,255,255,.05);
  background: linear-gradient(180deg, rgba(7,13,31,.98), rgba(7,13,31,.94));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.site-header.scrolled {
  background: rgba(7,13,31,.98);
  border-color: rgba(255,255,255,.08);
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 4.25rem;
  gap: 1rem;
}

.header-brand {
  display: flex;
  align-items: center;
  gap: .7rem;
  flex-shrink: 0;
  text-decoration: none;
}

.logo-slot {
  width: 62px; height: 62px;
  border-radius: 0;
  overflow: visible;
  border: none;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.logo-slot img { width:100%; height:100%; object-fit:contain; display:block; }

.brand-text { line-height:1; }
.brand-name {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800;
  font-size: 1.05rem;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--offwhite);
  display: block;
}
.brand-name .name-city {
  color:var(--yellow);
}
.campinas-yellow { color: inherit; font-weight: inherit; }
.section-about .campinas-yellow,
.section-renovabr .campinas-yellow { color: inherit; font-weight: inherit; }
.brand-sub {
  display: block;
  font-size: .5rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.72);
  margin-top: 2px;
  opacity: .9;
}
.brand-sub .missao-brand {
  color: var(--yellow);
  font-style: normal;
  font-weight: 700;
}

.main-nav {
  display: none;
  align-items: center;
  gap: 1.1rem;
}
@media (min-width:920px) { .main-nav { display:flex; } }

.nav-link {
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(244,241,234,.68);
  transition: color .2s;
  padding: .2rem 0;
  position: relative;
}
.nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 0; right: 100%;
  height: 1px;
  background: var(--yellow);
  transition: right .2s;
}
.nav-link:hover,
.nav-link:focus-visible { color: var(--offwhite); }
.nav-link:hover::after { right: 0; }

.nav-sep { width:1px; height:1.4rem; background:rgba(255,255,255,.15); }

.nav-btn {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: .4rem 1rem;
  border-radius: 5px;
  border: none;
  cursor: pointer;
  transition: all .2s cubic-bezier(.22,1,.36,1);
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  white-space: nowrap;
  text-decoration: none;
  position: relative;
  isolation: isolate;
}
.nav-btn svg { width:13px; height:13px; flex-shrink:0; }
.nav-btn:focus-visible { outline:2px solid currentColor; outline-offset:4px; }

.nav-btn-red {
  background: var(--red);
  color: #fff;
  box-shadow: 0 0 0 1px rgba(225,25,45,.25), 0 6px 18px rgba(225,25,45,.34);
}
.nav-btn-red:hover {
  background: var(--red-dark);
  box-shadow: 0 0 0 1px rgba(225,25,45,.45), 0 8px 24px rgba(225,25,45,.5);
  transform: translateY(-2px) rotate(-1deg);
}
.nav-btn-yellow {
  background: var(--yellow);
  color: var(--navy-950);
  border:1px solid rgba(255,255,255,.15);
  box-shadow: 0 0 0 1px rgba(248,201,40,.24), 0 8px 22px rgba(248,201,40,.28);
}
.nav-btn-yellow:hover {
  background: var(--yellow-dark);
  box-shadow: 0 4px 16px rgba(248,201,40,.45);
  transform: translateY(-2px);
}

.menu-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem; height: 2.5rem;
  color: rgba(255,255,255,.85);
  transition: color .2s;
  border-radius: 6px;
  transition: color .2s, background .2s;
}
@media (min-width:920px) { .menu-toggle { display:none; } }
.menu-toggle:hover { color:var(--yellow); background:rgba(255,255,255,.06); }
.menu-toggle svg { width:22px; height:22px; }

.mobile-menu {
  display: flex;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  min-height: calc(100svh - 4.25rem);
  background: rgba(7,13,31,.98);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  z-index: 99;
  padding: 2rem 1.5rem;
  flex-direction: column;
  gap: .2rem;
  overflow-y: auto;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-12px);
  transition:
    opacity .38s cubic-bezier(.22,1,.36,1),
    transform .42s cubic-bezier(.22,1,.36,1),
    visibility 0s linear .42s;
}
.mobile-menu.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition:
    opacity .38s cubic-bezier(.22,1,.36,1),
    transform .42s cubic-bezier(.22,1,.36,1),
    visibility 0s linear 0s;
}

.mobile-nav-link {
  display: block;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800;
  font-size: 1.75rem;
  text-transform: uppercase;
  letter-spacing: .02em;
  color: var(--offwhite);
  transition: color .2s, padding-left .2s;
}
.mobile-nav-link:hover { color:var(--yellow); padding-left:.5rem; }

.mobile-nav-actions {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  margin-top: 1.75rem;
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  overflow: hidden;
  background: var(--navy-950);
  padding-top: 0;
  min-height: calc(100vh - 4.25rem);
  min-height: calc(100svh - 4.25rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Noise texture overlay for depth */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  opacity: .018;
  pointer-events: none;
  z-index: 1;
}

.hero-bg {
  position:absolute; inset:0; pointer-events:none;
  opacity:0;
  transform:scale(1.012);
  animation:heroBgIntro .58s cubic-bezier(.22,1,.36,1) .02s forwards;
}
.hero-bg::before,
.hero-bg::after {
  content:'';
  position:absolute;
  border-radius:50%;
  background:rgba(255,255,255,.86);
  box-shadow:
    0 0 24px rgba(255,255,255,.16),
    0 0 0 9px rgba(255,255,255,.03);
  pointer-events:none;
  animation: heroCircleFloat 8s ease-in-out infinite;
}
.hero-bg::before {
  width:clamp(2.2rem, 4vw, 4.2rem);
  aspect-ratio:1;
  right:8%;
  top:24%;
  opacity:.82;
}
.hero-bg::after {
  width:clamp(1.1rem, 2vw, 2rem);
  aspect-ratio:1;
  right:22%;
  top:15%;
  opacity:.7;
  animation-delay:-2.8s;
}
.hero-bg-g1 {
  position:absolute; inset:0; pointer-events:none;
  background: radial-gradient(ellipse 74% 62% at 18% 12%, rgba(21,58,151,.12) 0%, transparent 58%);
  --drift-opacity: 1;
  animation: softDrift 12s ease-in-out infinite;
}
.hero-bg-g2 {
  position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(ellipse 70% 66% at 94% 50%, rgba(248,201,40,.24) 0%, rgba(248,201,40,.14) 30%, transparent 66%),
    radial-gradient(ellipse 50% 42% at 82% 78%, rgba(248,201,40,.14) 0%, transparent 58%);
  --drift-opacity: .82;
  animation: softDrift 14s ease-in-out infinite reverse;
}
.hero-bg-g3 {
  position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(135deg, rgba(0,0,0,.28), transparent 42%, rgba(0,0,0,.28));
}
.hero-bg-grid { position:absolute; inset:0; opacity:.08; pointer-events:none; }
.hero-bg-grid::before,
.hero-bg-grid::after {
  content:'';
  position:absolute;
  border-radius:50%;
  background:rgba(255,255,255,.78);
  box-shadow:0 0 20px rgba(255,255,255,.14);
  pointer-events:none;
  animation:heroCircleFloat 9s ease-in-out infinite;
}
.hero-bg-grid::before {
  width:.72rem;
  height:.72rem;
  right:14%;
  top:39%;
}
.hero-bg-grid::after {
  width:1rem;
  height:1rem;
  right:31%;
  top:69%;
  opacity:.68;
  animation-delay:-3.1s;
}

/* Diagonal accent line */
.hero-bg-line {
  position: absolute;
  top: 0; right: 25%;
  width: 1px;
  height: 100%;
  background: linear-gradient(to bottom, transparent, rgba(248,201,40,.28) 30%, rgba(21,58,151,.18) 70%, transparent);
  transform: skewX(-16deg);
  box-shadow: 0 0 18px rgba(248,201,40,.18);
  pointer-events: none;
}
.hero-bg-line-2 {
  right: 32%;
  width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(21,58,151,.2) 40%, rgba(248,201,40,.12) 70%, transparent);
  transform: skewX(-16deg);
  box-shadow: 0 0 12px rgba(21,58,151,.14);
  opacity: .6;
}

/* Extra particles layer */
.hero-particles-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}
.hero-particles-layer::before {
  content: '';
  position: absolute;
  width: .55rem;
  height: .55rem;
  border-radius: 50%;
  background: rgba(255,255,255,.65);
  left: 18%;
  top: 58%;
  box-shadow:
    9rem -3.5rem 0 -.18rem rgba(255,255,255,.52),
    22rem 6rem 0 -.28rem rgba(255,255,255,.44),
    38rem -2rem 0 -.35rem rgba(255,255,255,.48),
    15rem 14rem 0 -.22rem rgba(255,255,255,.56),
    50rem 8rem 0 -.38rem rgba(255,255,255,.4),
    6rem -7rem 0 -.3rem rgba(248,201,40,.38),
    45rem 18rem 0 -.42rem rgba(255,255,255,.36),
    28rem -12rem 0 -.36rem rgba(255,255,255,.42),
    60rem 3rem 0 -.44rem rgba(255,255,255,.34),
    33rem 22rem 0 -.48rem rgba(255,255,255,.3);
  animation: heroCircleFloat 9.5s ease-in-out infinite;
}
.hero-particles-layer::after {
  content: '';
  position: absolute;
  width: .42rem;
  height: .42rem;
  border-radius: 50%;
  background: rgba(248,201,40,.52);
  right: 38%;
  bottom: 28%;
  box-shadow:
    -12rem 4rem 0 -.14rem rgba(255,255,255,.46),
    -5rem -9rem 0 -.2rem rgba(255,255,255,.38),
    -25rem 1rem 0 -.26rem rgba(248,201,40,.32),
    -18rem -5rem 0 -.22rem rgba(255,255,255,.44),
    -35rem 8rem 0 -.3rem rgba(255,255,255,.36),
    -8rem 12rem 0 -.24rem rgba(255,255,255,.4),
    -42rem -4rem 0 -.32rem rgba(255,255,255,.32),
    -2rem 18rem 0 -.28rem rgba(248,201,40,.28);
  animation: heroCircleFloat 7.8s ease-in-out infinite reverse;
  animation-delay: -4.2s;
}

.hero-inner {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr;
  align-items: center;
  gap: .25rem;
  padding-top: clamp(1rem, 3svh, 2rem);
  padding-bottom: clamp(1.25rem, 4svh, 2.5rem);
}
.hero-inner::before,
.hero-inner::after {
  content:'';
  position:absolute;
  border-radius:50%;
  pointer-events:none;
  z-index:-1;
  animation:heroCircleFloat 8.2s ease-in-out infinite;
}
.hero-inner::before {
  left:7%;
  top:16%;
  width:1.05rem;
  aspect-ratio:1;
  background:rgba(255,255,255,.72);
  box-shadow:
    7.4rem -2.6rem 0 -.42rem rgba(255,255,255,.58),
    16rem 5.7rem 0 -.5rem rgba(255,255,255,.46),
    3rem 16rem 0 -.56rem rgba(255,255,255,.54),
    35rem 2.4rem 0 -.54rem rgba(255,255,255,.44),
    42rem 17rem 0 -.7rem rgba(255,255,255,.52),
    24rem -8rem 0 -.58rem rgba(255,255,255,.4),
    55rem 12rem 0 -.64rem rgba(255,255,255,.36),
    11rem 22rem 0 -.6rem rgba(248,201,40,.38),
    48rem -6rem 0 -.68rem rgba(255,255,255,.32),
    28rem 20rem 0 -.72rem rgba(255,255,255,.3),
    62rem 5rem 0 -.76rem rgba(255,255,255,.28);
}
.hero-inner::after {
  right:10%;
  bottom:12%;
  width:.82rem;
  aspect-ratio:1;
  background:rgba(255,255,255,.66);
  box-shadow:
    -8rem -4rem 0 -.3rem rgba(255,255,255,.62),
    -19rem 2rem 0 -.44rem rgba(255,255,255,.48),
    -30rem -8rem 0 -.55rem rgba(255,255,255,.5),
    -3rem 7rem 0 -.48rem rgba(255,255,255,.42),
    -42rem 5rem 0 -.58rem rgba(255,255,255,.38),
    -14rem -12rem 0 -.52rem rgba(255,255,255,.44),
    -25rem 12rem 0 -.62rem rgba(248,201,40,.32),
    -50rem -3rem 0 -.66rem rgba(255,255,255,.3),
    -6rem -18rem 0 -.56rem rgba(255,255,255,.4),
    -36rem 18rem 0 -.7rem rgba(255,255,255,.28);
  animation-delay:-3.1s;
}
@media (min-width:768px) {
  .hero-inner {
    grid-template-columns: 7fr 5fr;
    gap: 2rem;
    align-items: center;
  }
}

.hero-content {
  order: 2;
  padding: .5rem 0 1rem;
}
.hero-content.reveal {
  opacity:1;
  transform:none;
  transition:none;
  will-change: auto;
}
@media (min-width:768px) {
  .hero-content {
    order: 1;
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  margin-bottom: 1.15rem;
  flex-wrap: nowrap;
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 0;
  backdrop-filter: none;
  opacity:0;
  animation:heroIntro .52s cubic-bezier(.22,1,.36,1) .14s forwards;
}

.badge-flag {
  width: 1.85rem;
  height: 1.25rem;
  object-fit: cover;
  border-radius: 3px;
  border: 1px solid rgba(255,255,255,.22);
  background: rgba(255,255,255,.06);
  flex-shrink: 0;
  box-shadow: 0 4px 10px rgba(0,0,0,.22);
}

.badge-sep {
  width:1.6rem;
  height:2px;
  background:linear-gradient(90deg, rgba(248,201,40,.95), rgba(255,255,255,.18));
  box-shadow:0 0 10px rgba(248,201,40,.32);
  flex-shrink:0;
}

.badge-text {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: rgba(244,241,234,.74);
  line-height: 1.35;
}
.badge-text strong { color:var(--offwhite); }
.badge-role {
  color:var(--yellow);
  font-weight:900;
  text-shadow:0 0 14px rgba(248,201,40,.3);
}
.badge-highlight {
  color: var(--yellow);
  font-style: normal;
  font-weight: 700;
  border-bottom: 2px solid rgba(248,201,40,.65);
  padding-bottom: 1px;
}

.hero-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800;
  font-size: clamp(1.85rem, 5.8vw, 5rem);
  line-height: .92;
  text-transform: uppercase;
  color: var(--offwhite);
  text-shadow: 0 2px 32px rgba(0,0,0,.4);
  white-space: nowrap;
  opacity:0;
  animation:heroIntro .58s cubic-bezier(.22,1,.36,1) .22s forwards;
}
.hero-title .yl { color:var(--yellow); display:block; text-shadow:0 0 22px rgba(248,201,40,.25); }
@media (max-width:460px) {
  .hero-title { font-size: clamp(1.55rem, 8.5vw, 1.9rem); }
}
@media (max-width:380px) {
  .hero-title { font-size: clamp(1.35rem, 8vw, 1.65rem); }
  .badge-text { letter-spacing:.12em; }
}

.hero-rule { width:5rem; height:4px; background:var(--yellow); margin-top:1rem; box-shadow:0 0 8px rgba(248,201,40,.4); }

.hero-desc {
  margin-top: 1.15rem;
  max-width: 32rem;
  font-size: .97rem;
  color: rgba(244,241,234,.72);
  line-height: 1.75;
  opacity:0;
  animation:heroIntro .54s cubic-bezier(.22,1,.36,1) .3s forwards;
}
@media (min-width:768px) { .hero-desc { font-size:1.05rem; } }
.hero-desc { color: rgba(244,241,234,.88); }
.hero-desc strong { color: var(--yellow); font-weight: 700; }

.hero-ctas {
  display:flex; flex-wrap:wrap; gap:.75rem; margin-top:1.75rem;
  opacity:0;
  animation:heroIntro .54s cubic-bezier(.22,1,.36,1) .38s forwards;
}
.hero-ctas .btn {
  box-shadow:0 10px 26px rgba(0,0,0,.24);
}
.hero-ctas .btn:hover {
  transform:translateY(-3px) scale(1.015);
}

.hero-img-col {
  order: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media (min-width:768px) {
  .hero-img-col {
    order: 2;
    justify-content: flex-end;
    align-self: center;
  }
}

.hero-img-wrap {
  position: relative;
  width: 100%;
  max-width: 360px;
  aspect-ratio: 1;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  transform: translateY(0);
  isolation:isolate;
  opacity:0;
  padding:0;
  border:0;
  border-radius: 22px;
  background:transparent;
  box-shadow:none;
  transition:translate .35s cubic-bezier(.22,1,.36,1);
  animation:heroIntro .68s cubic-bezier(.22,1,.36,1) .48s forwards;
  will-change:opacity, transform, translate;
}
@media (min-width:768px) { .hero-img-wrap { max-width:min(100%, 470px); } }

.hero-img-wrap:hover {
  translate:0 -7px;
}
.hero-img-wrap:hover::before {
  border-color:rgba(248,201,40,.46);
  box-shadow:
    0 28px 62px rgba(0,0,0,.3),
    0 0 32px rgba(248,201,40,.16),
    inset 0 1px 0 rgba(255,255,255,.13);
  animation: heroFloatHover 1.8s ease-in-out infinite;
}

.hero-img-wrap:hover .hero-img-glow { opacity:1; filter:blur(22px); }
.hero-img-wrap:hover .hero-img {
  animation:heroFloatHover 1.8s ease-in-out infinite;
  filter:drop-shadow(0 -6px 34px rgba(248,201,40,.22)) drop-shadow(0 14px 24px rgba(0,0,0,.36));
}

.hero-img-wrap::before {
  content:'';
  position:absolute;
  inset:-.55rem;
  border-radius: 22px;
  background:
    linear-gradient(145deg, rgba(15,27,61,.96), rgba(21,58,151,.7) 58%, rgba(7,13,31,.98)),
    radial-gradient(ellipse at 72% 18%, rgba(248,201,40,.16), transparent 42%);
  border:1px solid rgba(248,201,40,.22);
  box-shadow:
    0 28px 62px rgba(0,0,0,.32),
    0 0 0 1px rgba(248,201,40,.16),
    inset 0 1px 0 rgba(255,255,255,.12);
  z-index:0;
  opacity:.94;
  pointer-events:none;
  transition:border-color .35s cubic-bezier(.22,1,.36,1), box-shadow .35s cubic-bezier(.22,1,.36,1);
  animation: heroFloat 6s ease-in-out infinite;
}
.hero-img-wrap::after {
  content:'';
  position:absolute;
  top:33%;
  right:2%;
  width:clamp(1rem, 2vw, 1.8rem);
  aspect-ratio:1;
  border-radius:50%;
  background:rgba(255,255,255,.82);
  box-shadow:
    -4.8rem -3.2rem 0 -.25rem rgba(255,255,255,.72),
    -2.5rem 6.8rem 0 -.45rem rgba(255,255,255,.62),
    -8.2rem 2.2rem 0 -.55rem rgba(255,255,255,.5),
    2.6rem -5.4rem 0 -.65rem rgba(255,255,255,.56),
    3.8rem 4.7rem 0 -.78rem rgba(255,255,255,.46),
    -6.5rem 9.5rem 0 -.6rem rgba(248,201,40,.44),
    4.8rem -8.2rem 0 -.7rem rgba(255,255,255,.5),
    -10rem -1.5rem 0 -.72rem rgba(255,255,255,.38),
    1.8rem 11rem 0 -.8rem rgba(255,255,255,.42),
    0 0 24px rgba(255,255,255,.18);
  z-index:0;
  pointer-events:none;
  animation: heroCircleFloat 6.5s ease-in-out infinite reverse;
}

/* "MISSÃO" background word — centered across the entire hero */
.hero-bg-word {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 900;
  font-size: clamp(8rem, 24vw, 22rem);
  line-height: .85;
  letter-spacing: -.02em;
  color: rgba(255, 255, 255, .09);
  text-transform: uppercase;
  white-space: nowrap;
  pointer-events: none;
  user-select: none;
  z-index: 0;
}

.hero-img-glow {
  position: absolute;
  inset:-2.4rem;
  height:auto;
  background:
    radial-gradient(circle at 50% 45%, rgba(255,255,255,.32), transparent 22%),
    radial-gradient(circle at 50% 48%, rgba(21,58,151,.28), transparent 55%),
    radial-gradient(circle at 62% 38%, rgba(248,201,40,.28), transparent 48%);
  filter: blur(18px);
  z-index: 0;
  border-radius: 50%;
  opacity:.98;
  pointer-events:none;
  animation: heroGlowPulse 4s ease-in-out infinite;
  transition:opacity .35s cubic-bezier(.22,1,.36,1), filter .35s cubic-bezier(.22,1,.36,1);
}

@keyframes heroGlowPulse {
  0%, 100% { opacity: .8; transform: scaleX(1); }
  50% { opacity: 1; transform: scaleX(1.08); }
}

.hero-img {
  position: relative;
  z-index: 2;
  display: block;
  width: 100%;
  height: 128%;
  max-height: none;
  margin-top: -28%;
  object-fit: contain;
  object-position: center bottom;
  border-radius: 22px;
  filter: drop-shadow(0 -4px 28px rgba(21,58,151,.10)) drop-shadow(0 8px 20px rgba(0,0,0,.34)) drop-shadow(0 0 18px rgba(255,255,255,.06));
  transition:filter .35s cubic-bezier(.22,1,.36,1);
  animation: heroFloat 6s ease-in-out infinite;
}
@media (min-width:768px) { .hero-img { height: 132%; margin-top: -32%; object-position: center bottom; } }

@keyframes heroFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

@keyframes heroFloatHover {
  0%, 100% { transform:translateY(-7px) scale(1.025); }
  50% { transform:translateY(-12px) scale(1.035); }
}

@keyframes heroCircleFloat {
  0%, 100% { transform:translate3d(0,0,0) scale(1); }
  50% { transform:translate3d(.35rem,-.45rem,0) scale(1.025); }
}

/* ============================================================
   ABOUT / TRAJECTORY
   ============================================================ */
.section-about {
  background:
    linear-gradient(90deg, #0b1024 0%, #111936 42%, #e9e4d8 42.1%, #ede8dc 100%);
  color: var(--navy-950);
  position: relative;
  overflow:hidden;
}
.section-about::after {
  content:'';
  position:absolute;
  right:5vw;
  top:4.5rem;
  width:3.5rem;
  height:2.4rem;
  border:1px solid rgba(248,201,40,.28);
  border-radius:5px;
  background:
    linear-gradient(90deg, transparent 0 28%, rgba(248,201,40,.24) 28% 34%, transparent 34%),
    rgba(7,13,31,.06);
  transform:rotate(8deg);
  opacity:.55;
  pointer-events:none;
  animation: clapperFloat 8s ease-in-out infinite;
}
.section-about::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--blue), var(--yellow), var(--blue));
  background-size: 200% 100%;
  pointer-events:none;
  animation: shimmer 3s linear infinite;
}
@keyframes shimmer { 0% { background-position:100% 0; } 100% { background-position:-100% 0; } }

.about-grid {
  display: grid;
  gap: 3rem;
  padding: 5rem 0;
  align-items: center;
  position:relative;
}
.about-grid::before,
.about-grid::after {
  content:'';
  position:absolute;
  width:2.8rem;
  height:2.8rem;
  border:1px solid rgba(248,201,40,.26);
  border-radius:50%;
  background:rgba(255,255,255,.08);
  box-shadow:
    0 0 22px rgba(248,201,40,.08),
    5.8rem 4.6rem 0 -.95rem rgba(248,201,40,.72),
    12rem 13rem 0 -1.1rem rgba(248,201,40,.5),
    31rem 5rem 0 -1.05rem rgba(248,201,40,.48),
    22rem -1.8rem 0 -1.18rem rgba(248,201,40,.54),
    38rem 15rem 0 -1.2rem rgba(248,201,40,.4),
    2rem 21rem 0 -1.25rem rgba(248,201,40,.5),
    16rem -5rem 0 -1.28rem rgba(248,201,40,.44),
    45rem 7.5rem 0 -1.32rem rgba(248,201,40,.38),
    10rem 24rem 0 -1.36rem rgba(248,201,40,.42);
  pointer-events:none;
  animation: heroCircleFloat 7.5s ease-in-out infinite;
}
.about-grid::before {
  left:.5rem;
  top:3.2rem;
}
.about-grid::after {
  right:1rem;
  bottom:3.2rem;
  width:2rem;
  height:2rem;
  border-radius:50%;
  animation-delay:-2s;
  box-shadow:
    0 0 20px rgba(248,201,40,.1),
    -7.5rem -6rem 0 -.75rem rgba(248,201,40,.62),
    -15rem 3rem 0 -.95rem rgba(248,201,40,.44),
    -25rem -1rem 0 -1rem rgba(248,201,40,.52),
    -33rem -8rem 0 -1.15rem rgba(248,201,40,.46),
    -20rem 10rem 0 -1.22rem rgba(248,201,40,.42),
    -4rem -13rem 0 -.98rem rgba(248,201,40,.58),
    -38rem 2.5rem 0 -1.24rem rgba(248,201,40,.4),
    -11rem 14rem 0 -1.18rem rgba(248,201,40,.5),
    -29rem 12rem 0 -1.35rem rgba(248,201,40,.36);
}
@media (min-width:768px) {
  .about-grid { grid-template-columns:1fr 1fr; gap:4rem; padding:7rem 0; }
}

.about-content { order:2; }
@media (min-width:768px) { .about-content { order:2; } }
.about-content {
  background: rgba(237,232,220,.92);
  border:1px solid rgba(7,13,31,.07);
  border-radius:8px;
  padding:clamp(1.25rem, 2.5vw, 2rem);
  box-shadow:0 18px 42px rgba(7,13,31,.1);
  position:relative;
}
.about-content::before,
.about-content::after {
  content:'';
  position:absolute;
  border-radius:50%;
  pointer-events:none;
  opacity:.42;
}
.about-content::before {
  width:.62rem;
  height:.62rem;
  right:1rem;
  top:1rem;
  background:var(--yellow);
  box-shadow:
    0 0 18px rgba(248,201,40,.25),
    -4rem 2.4rem 0 -.18rem rgba(248,201,40,.36),
    -10rem 11rem 0 -.22rem rgba(248,201,40,.28),
    -1.8rem 14rem 0 -.28rem rgba(248,201,40,.34),
    -14rem 5.5rem 0 -.32rem rgba(248,201,40,.25);
  animation:heroCircleFloat 8s ease-in-out infinite;
}
.about-content::after {
  content: none;
  display: none;
}
@keyframes microSlide {
  0%, 100% { transform:translateX(0); opacity:.42; }
  50% { transform:translateX(-.35rem); opacity:.68; }
}
@media (max-width:767px) {
  .section-about {
    background:
      linear-gradient(180deg, #0b1024 0%, #111936 34%, #e9e4d8 34.1%, #ede8dc 100%);
  }
}

.about-title {
  margin-top: .75rem;
  font-size: clamp(2.25rem, 5vw, 3.25rem);
  text-transform: uppercase;
  line-height: .95;
}

.about-text {
  margin-top: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: .9rem;
  font-size: clamp(1rem, 1.4vw, 1.1rem);
  line-height: 1.68;
  color: rgba(7,13,31,.76);
  max-width: 34rem;
}
.about-text strong { color:var(--blue); }
.about-text .bl { color:var(--blue); font-weight:700; }

.btn-bio {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  margin-top: 1.25rem;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--blue);
  transition: color .2s, gap .2s;
  background: none;
  border: none;
  cursor: pointer;
  line-height: 1.45;
  padding: .28rem .1rem .34rem;
  min-height: 2.15rem;
  overflow: visible;
  white-space: normal;
}
.btn-bio:hover { color:var(--navy-950); gap:.6rem; }
.btn-bio svg { width:15px; height:15px; transition:transform .35s cubic-bezier(.22,1,.36,1); }
.btn-bio.open svg { transform:rotate(180deg); }

.bio-full {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transform: translateY(-8px);
  transition:
    max-height .62s cubic-bezier(.22,1,.36,1),
    opacity .34s ease,
    transform .46s cubic-bezier(.22,1,.36,1);
  will-change: max-height, opacity, transform;
  padding-bottom: 2px;
}
.bio-full.open { opacity: 1; transform: translateY(0); }
.bio-full.closing { opacity: 0; transform: translateY(-6px); }

.bio-full-inner {
  padding-top: 1.1rem;
  padding-bottom: 1rem;
  display: flex;
  flex-direction: column;
  gap: .9rem;
  font-size: 1rem;
  line-height: 1.78;
  color: rgba(7,13,31,.76);
  border-top: 1px dashed rgba(7,13,31,.12);
  margin-top: .5rem;
}
.bio-full-inner strong { color:var(--blue); }
.bio-full-inner .bl { color:var(--blue); font-weight:700; }

.about-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: .75rem;
  margin-top: 1.75rem;
  position: relative;
}
@media (min-width:480px) {
  .about-cards { grid-template-columns:repeat(3,1fr); gap:1rem; }
  .about-cards::before {
    content:'';
    position:absolute;
    left:12%;
    right:12%;
    top:2rem;
    height:1px;
    background:linear-gradient(90deg, transparent, rgba(248,201,40,.45), rgba(59,36,94,.7), rgba(248,201,40,.45), transparent);
    box-shadow:0 0 14px rgba(248,201,40,.22);
    pointer-events:none;
  }
}

.about-mini-card {
  background: linear-gradient(145deg, #070D1F, #0d1430);
  border-radius: 8px;
  padding: 1.15rem .9rem 1rem;
  border: 1px solid rgba(59,36,94,.8);
  box-shadow: 0 16px 40px rgba(7,13,31,.42), 0 6px 14px rgba(0,0,0,.2), inset 0 1px 0 rgba(255,255,255,.06);
  transition: transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s, border-color .25s;
  text-align:center;
  position:relative;
  z-index:1;
  animation:none;
  will-change:auto;
}
.about-mini-card:nth-child(2) .mc-icon { animation-delay:-1.2s; }
.about-mini-card:nth-child(3) .mc-icon { animation-delay:-2.4s; }
.about-mini-card::before {
  content:'';
  position:absolute;
  inset:0;
  border-radius:8px;
  background:linear-gradient(135deg, rgba(248,201,40,.08), transparent 36%, rgba(59,36,94,.18));
  opacity:.65;
  pointer-events:none;
  transition:opacity .25s, transform .25s;
}
.about-mini-card:hover {
  transform: translateY(-3px);
  border-color: rgba(248,201,40,.5);
  box-shadow: 0 24px 52px rgba(7,13,31,.52), 0 8px 20px rgba(0,0,0,.22), 0 0 24px rgba(248,201,40,.16), 0 0 20px rgba(59,36,94,.3);
}
.about-mini-card:hover::before { opacity:.9; transform:scale(1.02); }
.about-mini-card .mc-icon {
  width:2.55rem;
  height:2.55rem;
  display:grid;
  place-items:center;
  margin:0 auto .7rem;
  color:var(--yellow);
  background:rgba(248,201,40,.1);
  border:1px solid rgba(248,201,40,.28);
  border-radius:50%;
  box-shadow:0 0 18px rgba(59,36,94,.3), inset 0 0 0 4px rgba(7,13,31,.5);
  position:relative;
  z-index:1;
  animation:iconGlowPulse 2.8s ease-in-out infinite;
  transition:transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s;
  will-change:transform;
}
.about-mini-card:hover .mc-icon {
  transform:scale(1.06);
  box-shadow:0 0 22px rgba(248,201,40,.18), inset 0 0 0 4px rgba(7,13,31,.5);
}
.about-mini-card .mc-icon svg {
  width:20px;
  height:20px;
  stroke:currentColor;
  stroke-width:1.8;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.about-mini-card h4 {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--yellow);
  line-height: 1.2;
  margin-bottom: .3rem;
  position:relative;
  z-index:1;
}
.about-mini-card p { font-size:.76rem; color:rgba(244,241,234,.7); line-height:1.55; position:relative; z-index:1; }

@keyframes aboutCardPulse {
  0%, 100% { box-shadow:0 12px 28px rgba(7,13,31,.28), inset 0 1px 0 rgba(255,255,255,.04); }
  50% { box-shadow:0 14px 30px rgba(7,13,31,.32), 0 0 18px rgba(248,201,40,.08), inset 0 1px 0 rgba(255,255,255,.05); }
}

@keyframes iconGlowPulse {
  0%, 100% { transform:scale(1); box-shadow:0 0 14px rgba(59,36,94,.24), inset 0 0 0 4px rgba(7,13,31,.5); }
  50% { transform:scale(1.075); box-shadow:0 0 22px rgba(248,201,40,.2), inset 0 0 0 4px rgba(7,13,31,.5); }
}

.about-img-col { order:1; }
@media (min-width:768px) { .about-img-col { order:1; } }

.about-img-wrap {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  border-radius: 6px;
  box-shadow: 0 8px 40px rgba(7,13,31,.18), 0 0 0 1px rgba(7,13,31,.08);
}
.about-img-wrap img {
  width:100%; height:100%;
  object-fit: cover;
  object-position: top center;
  transition: transform .6s cubic-bezier(.22,1,.36,1);
}
.about-img-wrap:hover img { transform:scale(1.03); }
.about-img-overlay {
  position: absolute;
  bottom:0; left:0; right:0;
  height: 35%;
  background: linear-gradient(to top, rgba(7,13,31,.3), transparent);
  pointer-events:none;
}

/* ============================================================
   ALLIANCE BAND
   ============================================================ */
.alliance-band {
  position:relative;
  background:linear-gradient(135deg, #030713, #0b1024 55%, #171023);
  color:var(--offwhite);
  overflow:hidden;
  border-top:1px solid rgba(248,201,40,.22);
  border-bottom:1px solid rgba(248,201,40,.18);
}
.alliance-pattern {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 18% 50%, rgba(59,36,94,.38), transparent 48%),
    repeating-linear-gradient(135deg, rgba(248,201,40,.08) 0, rgba(248,201,40,.08) 1px, transparent 1px, transparent 18px);
  opacity:.9;
  --drift-opacity:.9;
  pointer-events:none;
  animation:softDrift 14s ease-in-out infinite;
}
.alliance-inner {
  position:relative;
  display:flex; flex-direction:column; align-items:center;
  gap:1.2rem; padding:3rem 0;
}
@media (min-width:768px) {
  .alliance-inner { justify-content:center; gap:1.5rem; padding:4rem 0; }
}
.alliance-equation {
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:clamp(.55rem, 1.6vw, 1.1rem);
  width:100%;
  text-align:center;
}
.alliance-token,
.alliance-result {
  position:relative;
  overflow:hidden;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.08em;
  border:1px solid rgba(248,201,40,.25);
  background:rgba(255,255,255,.04);
  box-shadow:0 0 24px rgba(59,36,94,.25);
  padding:.7rem clamp(.8rem, 2vw, 1.35rem);
  border-radius:6px;
  font-size:clamp(1.55rem, 4.8vw, 4rem);
  line-height:.9;
  transition:transform .35s cubic-bezier(.22,1,.36,1), border-color .35s, box-shadow .35s;
  animation:alliancePulse 4.8s ease-in-out infinite;
}
.alliance-token::after,
.alliance-result::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(110deg, transparent 0 36%, rgba(255,255,255,.16) 48%, transparent 62% 100%);
  transform:translateX(-120%);
  animation:lineSweep 4.6s ease-in-out infinite;
  pointer-events:none;
}
.alliance-token:hover,
.alliance-result:hover {
  transform:translateY(-3px);
  border-color:rgba(248,201,40,.5);
  box-shadow:0 12px 34px rgba(0,0,0,.22), 0 0 28px rgba(248,201,40,.12);
}
.alliance-token {
  color:var(--yellow);
}
.alliance-result {
  border-color:rgba(248,201,40,.5);
  background:rgba(7,13,31,.42);
}
.result-blue {
  color:var(--blue-light);
  text-shadow:0 0 20px rgba(44,84,198,.28);
}
.result-yellow {
  color:var(--yellow);
  text-shadow:0 0 20px rgba(248,201,40,.28);
  border-color:rgba(248,201,40,.5);
}
.alliance-sign {
  font-family:'Barlow Condensed',sans-serif; font-weight:900; font-size:clamp(2rem, 5vw, 4.5rem); color:var(--yellow); line-height:.8;
  text-shadow:0 0 18px rgba(248,201,40,.28);
  animation:heroCircleFloat 5.5s ease-in-out infinite;
}
.alliance-text {
  font-size:.92rem;
  color:rgba(244,241,234,.72);
  max-width:42rem;
  line-height:1.65;
  text-align:center;
}
@media (min-width:768px) { .alliance-text { text-align:center; } }
.alliance-text u { text-decoration-thickness:2px; text-underline-offset:4px; }

@keyframes alliancePulse {
  0%, 100% { box-shadow:0 0 24px rgba(59,36,94,.25); }
  50% { box-shadow:0 0 30px rgba(248,201,40,.1), 0 0 24px rgba(59,36,94,.3); }
}

/* ============================================================
   RENOVABR
   ============================================================ */
.section-renovabr {
  position:relative; overflow:hidden;
  background:
    radial-gradient(ellipse at 82% 12%, rgba(21,58,151,.16), transparent 38%),
    linear-gradient(135deg, #f4f1ea, #eef3ff 58%, #f7f4eb);
  color:var(--navy-950);
}
.section-renovabr::before,
.section-renovabr::after {
  content:'BR';
  position:absolute;
  display:grid;
  place-items:center;
  width:2.4rem;
  height:2.4rem;
  border-radius:50%;
  color:#fff;
  background:var(--blue);
  border:1px solid rgba(255,255,255,.45);
  box-shadow:0 12px 30px rgba(21,58,151,.22), 0 0 0 8px rgba(21,58,151,.08);
  font-weight:900;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.92rem;
  opacity:.72;
  pointer-events:none;
  animation: heroCircleFloat 7s ease-in-out infinite;
}
.section-renovabr::before {
  left:8%;
  top:5rem;
}
.section-renovabr::after {
  right:10%;
  top:3.2rem;
  bottom:auto;
  width:1.9rem;
  height:1.9rem;
  opacity:.58;
  animation-delay:-2.5s;
}
.renovabr-bg { position:absolute; inset:0; pointer-events:none; }
.renovabr-bg-g1 {
  position:absolute; inset:0;
  background:radial-gradient(ellipse at top left, rgba(21,58,151,.12) 0%, transparent 44%);
}
.renovabr-bg-g2 {
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent, rgba(7,13,31,.04));
}

.renovabr-grid {
  position:relative; display:grid; gap:3rem; padding:5rem 0;
}
.renovabr-grid::before {
  content:'BR';
  position:absolute;
  right:18%;
  top:18%;
  width:1.55rem;
  height:1.55rem;
  display:grid;
  place-items:center;
  border-radius:50%;
  color:var(--blue);
  border:1px solid rgba(21,58,151,.32);
  background:rgba(255,255,255,.75);
  box-shadow:0 10px 20px rgba(21,58,151,.12);
  font-weight:900;
  opacity:.76;
  pointer-events:none;
  animation:heroCircleFloat 8s ease-in-out infinite;
}
.renovabr-grid::after {
  content:'BR';
  position:absolute;
  left:6%;
  bottom:16%;
  width:2rem;
  height:2rem;
  display:grid;
  place-items:center;
  border-radius:50%;
  color:#fff;
  background:var(--blue);
  box-shadow:0 12px 22px rgba(21,58,151,.16), 0 0 0 7px rgba(21,58,151,.07);
  font-family:'Barlow Condensed',sans-serif;
  font-size:.72rem;
  font-weight:900;
  opacity:.7;
  pointer-events:none;
  animation:heroCircleFloat 8.5s ease-in-out infinite reverse;
}
.section-renovabr .eyebrow { color:var(--blue); }
.renovabr-copy {
  text-align:center;
  position:relative;
}
.renovabr-copy::before {
  content:'BR';
  position:absolute;
  right:0;
  top:-1.2rem;
  width:1.45rem;
  height:1.45rem;
  display:grid;
  place-items:center;
  border-radius:50%;
  color:var(--blue);
  border:1px solid rgba(21,58,151,.28);
  background:rgba(255,255,255,.72);
  font-family:'Barlow Condensed',sans-serif;
  font-size:.58rem;
  font-weight:900;
  box-shadow:0 8px 18px rgba(21,58,151,.12);
  pointer-events:none;
  animation:heroCircleFloat 7.5s ease-in-out infinite;
}
.renovabr-copy .eyebrow {
  justify-content:center;
}
.renovabr-copy .section-rule {
  margin:1rem auto 0;
  background:var(--blue);
  box-shadow:0 0 14px rgba(21,58,151,.24);
}
@media (min-width:768px) {
  .renovabr-grid { grid-template-columns:5fr 7fr; align-items:center; gap:4rem; padding:7rem 0; }
  .renovabr-media { order:2; }
  .renovabr-copy { order:1; }
}

.renovabr-img-wrap {
  position:relative; aspect-ratio:4/5; overflow:hidden; border-radius:6px;
  display:block;
  cursor:pointer;
  text-decoration:none;
  transform:translateY(0);
  transition:transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s, filter .35s;
  box-shadow:0 16px 34px rgba(21,58,151,.12);
}
.renovabr-img-wrap img {
  width:100%; height:100%; object-fit:cover; object-position:top center;
  transition:transform .6s cubic-bezier(.22,1,.36,1), filter .35s;
}
.renovabr-img-ring {
  position:absolute; inset:0;
  box-shadow:inset 0 0 0 1px rgba(21,58,151,.18); border-radius:6px; pointer-events:none;
  transition:box-shadow .35s;
}
.renovabr-img-glow {
  position:absolute; inset:-6px; z-index:-1;
  background:linear-gradient(135deg, rgba(21,58,151,.28), rgba(59,36,94,.22) 55%, transparent 72%);
  filter:blur(22px); border-radius:10px;
  opacity:.75;
  pointer-events:none;
  transition:opacity .35s, filter .35s;
}
.renovabr-img-wrap::after {
  content:none;
  position:absolute;
  left:1rem;
  bottom:1rem;
  padding:.42rem .7rem;
  border-radius:100px;
  background:rgba(21,58,151,.9);
  color:#fff;
  font-family:'Barlow Condensed',sans-serif;
  font-size:.72rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.1em;
  box-shadow:0 10px 24px rgba(21,58,151,.22);
  opacity:0;
  transform:translateY(8px);
  transition:opacity .28s cubic-bezier(.22,1,.36,1), transform .28s cubic-bezier(.22,1,.36,1);
  pointer-events:none;
}
.renovabr-img-wrap::after { content:none; }

.renovabr-img-wrap:hover,
.renovabr-img-wrap:focus-visible {
  transform:translateY(-6px);
  box-shadow:0 22px 44px rgba(21,58,151,.2), 0 0 28px rgba(21,58,151,.12);
}
.renovabr-img-wrap:hover img,
.renovabr-img-wrap:focus-visible img {
  transform:scale(1.035);
  filter:saturate(1.08) contrast(1.04);
}
.renovabr-img-wrap:hover .renovabr-img-ring,
.renovabr-img-wrap:focus-visible .renovabr-img-ring {
  box-shadow:inset 0 0 0 2px rgba(21,58,151,.45), inset 0 0 38px rgba(21,58,151,.12);
}
.renovabr-img-wrap:hover .renovabr-img-glow,
.renovabr-img-wrap:focus-visible .renovabr-img-glow {
  opacity:1;
  filter:blur(18px);
}
.renovabr-img-wrap:hover::after,
.renovabr-img-wrap:focus-visible::after {
  opacity:1;
  transform:translateY(0);
}

.renovabr-title {
  margin-top:.75rem; font-size:clamp(2.5rem,5vw,3.75rem);
  text-transform:uppercase; line-height:.95;
}
.renovabr-title .bl { color:var(--blue); display:block; }

.renovabr-text {
  margin-top:1.5rem; max-width:38rem;
  font-size:1rem; color:rgba(7,13,31,.76); line-height:1.75;
  margin-left:auto;
  margin-right:auto;
}
.renovabr-text strong { color:var(--blue); }

.renovabr-extra {
  margin-top:1rem; font-size:.88rem;
  color:rgba(7,13,31,.66); line-height:1.7; max-width:36rem;
  margin-left:auto;
  margin-right:auto;
}
.renovabr-extra .bl { color:var(--blue); font-weight:800; }

/* ============================================================
   INVESTMENTS / RESULTS
   ============================================================ */
.section-investments { position:relative; overflow:hidden; background:var(--navy-950); color:var(--offwhite); }
.section-investments::before {
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(248,201,40,.6), rgba(21,58,151,.45), transparent);
  box-shadow:0 0 18px rgba(248,201,40,.24);
  z-index:1;
  pointer-events:none;
}
.section-investments::after {
  content:'R$';
  position:absolute;
  right:7%;
  top:8rem;
  width:2.6rem;
  height:2.6rem;
  display:grid;
  place-items:center;
  border-radius:50%;
  color:rgba(248,201,40,.72);
  border:1px solid rgba(248,201,40,.22);
  background:rgba(248,201,40,.06);
  box-shadow:0 0 28px rgba(248,201,40,.12);
  font-family:'Barlow Condensed',sans-serif;
  font-weight:900;
  pointer-events:none;
  animation:heroCircleFloat 7s ease-in-out infinite;
  z-index:1;
}
.section-investments > .container { position:relative; z-index:2; }
.inv-bg { position:absolute; inset:0; pointer-events:none; }
.inv-bg-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.07; }
.inv-bg-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(7,13,31,.7), rgba(7,13,31,.85) 50%, var(--navy-950));
}
.inv-bg-grid { position:absolute; inset:0; opacity:.2; }

.inv-hero { position:relative; text-align:center; padding:5rem 0 0; }
.inv-hero::before,
.inv-hero::after {
  content:'R$';
  position:absolute;
  display:grid;
  place-items:center;
  width:2.25rem;
  height:2.25rem;
  border-radius:50%;
  color:rgba(248,201,40,.58);
  border:1px solid rgba(248,201,40,.2);
  background:rgba(7,13,31,.48);
  box-shadow:0 12px 28px rgba(0,0,0,.18), 0 0 18px rgba(248,201,40,.1);
  font-family:'Barlow Condensed',sans-serif;
  font-size:.82rem;
  font-weight:900;
  pointer-events:none;
  animation:heroCircleFloat 8s ease-in-out infinite;
}
.inv-hero::before {
  left:8%;
  top:42%;
}
.inv-hero::after {
  content:'R$';
  right:10%;
  top:58%;
  width:1.45rem;
  height:1.45rem;
  background:radial-gradient(circle at 34% 30%, rgba(255,255,255,.5), transparent 20%), rgba(248,201,40,.18);
  animation-delay:-2.4s;
}
@media (min-width:768px) { .inv-hero { padding:7rem 0 0; } }

.inv-title {
  margin-top:.75rem; font-size:clamp(2.25rem,5.5vw,4rem);
  text-transform:uppercase; line-height:.95;
}
.inv-title .yl { color:var(--yellow); }

.inv-total {
  display:flex; align-items:baseline; justify-content:center;
  gap:.5rem; margin-top:2rem; flex-wrap:wrap;
  filter: drop-shadow(0 0 18px rgba(248,201,40,.14));
}
.inv-currency {
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  color:var(--yellow); font-size:clamp(1.6rem,3.5vw,2.75rem); line-height:1;
}
.inv-number {
  font-family:'Barlow Condensed',sans-serif; font-weight:800;
  color:var(--yellow); font-size:clamp(3.4rem,9vw,7.9rem); line-height:1;
  font-variant-numeric:tabular-nums; letter-spacing:-.02em;
  text-shadow:0 0 22px rgba(248,201,40,.48), 0 0 58px rgba(248,201,40,.2);
}

.inv-desc {
  margin-top:1rem; max-width:none; margin-left:auto; margin-right:auto;
  font-size:clamp(.72rem, 2.4vw, .95rem); color:rgba(244,241,234,.65); line-height:1.7;
  white-space:nowrap;
}
.inv-desc strong {
  color:var(--yellow);
  font-weight:800;
  padding:.08rem .35rem;
  background:rgba(248,201,40,.09);
  border-bottom:1px solid rgba(248,201,40,.45);
}
@media (max-width:380px) {
  .inv-desc { font-size:.62rem; letter-spacing:-.01em; }
}

.inv-list {
  position:relative; display:grid; gap:.75rem;
  padding:3.5rem 0 5rem; max-width:56rem; margin:0 auto;
}
@media (min-width:768px) { .inv-list { grid-template-columns:1fr 1fr; gap:1rem; } }

.inv-card {
  border-radius:8px;
  border:1px solid rgba(248,201,40,.22);
  background:linear-gradient(145deg, rgba(255,255,255,.065), rgba(255,255,255,.025));
  box-shadow: 0 0 0 0 rgba(248,201,40,0), inset 0 1px 0 rgba(248,201,40,.12);
  overflow:hidden;
  transition:border-color .25s, box-shadow .25s, transform .25s;
  backdrop-filter: blur(8px);
}
.inv-card:hover { border-color:rgba(248,201,40,.55); box-shadow:0 10px 32px rgba(0,0,0,.28), 0 0 18px rgba(248,201,40,.12); transform:translateY(-3px); }
.inv-card.open { border-color:rgba(248,201,40,.7); box-shadow:0 4px 28px rgba(248,201,40,.14), 0 0 24px rgba(248,201,40,.08); }

.inv-card-btn {
  display:flex; align-items:center; gap:.75rem; padding:.75rem 1rem;
  width:100%; text-align:left; cursor:pointer; background:none; border:none; color:var(--offwhite);
}

.inv-img { width:4.5rem; height:3.5rem; object-fit:cover; border-radius:4px; flex-shrink:0; }
@media (min-width:768px) { .inv-img { width:5.5rem; height:4.5rem; } }

.inv-info { flex:1; min-width:0; }
.inv-label { font-size:.62rem; font-weight:700; text-transform:uppercase; letter-spacing:.18em; color:rgba(244,241,234,.38); }
.inv-name { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:1.15rem; text-transform:uppercase; line-height:1.1; color:var(--offwhite); }
.inv-value { font-family:'Barlow Condensed',sans-serif; font-weight:700; font-size:1.05rem; color:var(--yellow); margin-top:.15rem; }

.inv-chevron {
  flex-shrink:0; width:20px; height:20px;
  color:rgba(244,241,234,.4); transition:transform .35s cubic-bezier(.22,1,.36,1), color .2s;
}
.inv-card.open .inv-chevron { transform:rotate(180deg); color:var(--yellow); }

.inv-body { overflow:hidden; max-height:0; transition:max-height .4s cubic-bezier(.4,0,.2,1); }
.inv-body.open { max-height:400px; }

.inv-body-inner {
  padding:0 1rem 1rem; border-top:1px solid rgba(255,255,255,.08);
  padding-top:.75rem; font-size:.88rem; color:rgba(244,241,234,.65); line-height:1.72;
}

/* ============================================================
   CONTRA
   ============================================================ */
.section-contra {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse 70% 50% at 90% 20%, rgba(180,20,20,.10) 0%, transparent 55%),
    radial-gradient(ellipse 55% 40% at 10% 80%, rgba(200,30,30,.05) 0%, transparent 50%),
    linear-gradient(180deg, #060b1a, #09101f 60%, #050914);
  color: var(--offwhite);
  padding-bottom: 5rem;
}
.section-contra::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(200,30,30,.7), rgba(220,50,50,.4), transparent);
  box-shadow: 0 0 18px rgba(200,30,30,.2);
  pointer-events:none;
}
.section-contra .container { position: relative; z-index: 2; }

/* Background X elements */
.contra-bg { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.contra-x {
  position: absolute;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 900;
  color: rgba(200,30,30,.07);
  line-height: 1;
  user-select: none;
  animation: contraXFloat 10s ease-in-out infinite;
}
.contra-x-1 { font-size: clamp(5rem, 12vw, 9rem); top: 6%; left: 3%; animation-delay: 0s; }
.contra-x-2 { font-size: clamp(3rem, 7vw, 6rem); top: 18%; right: 5%; animation-delay: -3s; color: rgba(200,30,30,.05); }
.contra-x-3 { font-size: clamp(6rem, 14vw, 11rem); bottom: 8%; left: 8%; animation-delay: -5.5s; }
.contra-x-4 { font-size: clamp(2.5rem, 5vw, 4.5rem); bottom: 22%; right: 12%; animation-delay: -1.8s; color: rgba(200,30,30,.04); }
.contra-x-5 { font-size: clamp(4rem, 9vw, 7rem); top: 44%; left: 44%; animation-delay: -4.2s; color: rgba(200,30,30,.05); }
.contra-x-6 { font-size: clamp(2rem, 4vw, 3.5rem); top: 72%; right: 28%; animation-delay: -7s; }
.contra-bg-glow {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(60px);
}
.contra-bg-glow-1 {
  width: clamp(18rem, 40vw, 32rem);
  height: clamp(14rem, 30vw, 24rem);
  background: radial-gradient(circle, rgba(200,30,30,.09), transparent 70%);
  top: 5%;
  right: -5%;
}
.contra-bg-glow-2 {
  width: clamp(14rem, 32vw, 26rem);
  height: clamp(10rem, 22vw, 18rem);
  background: radial-gradient(circle, rgba(200,30,30,.06), transparent 70%);
  bottom: 10%;
  left: -2%;
}
@keyframes contraXFloat {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  33%  { transform: translateY(-14px) rotate(3deg); }
  66%  { transform: translateY(8px) rotate(-2deg); }
}

/* Header */
.contra-head { text-align: center; padding: 5rem 0 0; }
@media (min-width: 768px) { .contra-head { padding-top: 7rem; } }

.contra-title {
  margin-top: .75rem;
  font-size: clamp(2.4rem, 6vw, 4.5rem);
  text-transform: uppercase;
  line-height: 1;
}
.contra-red-text { color: rgba(220,50,50,.95); }

.eyebrow-red { color: rgba(220,50,50,.9); border-color: rgba(220,50,50,.3); }
.section-rule-red {
  background: linear-gradient(90deg, transparent, rgba(220,50,50,.8), rgba(200,30,30,.5), transparent);
  box-shadow: 0 0 10px rgba(220,50,50,.18);
}

/* Layout — image left, cards right */
.contra-layout {
  display: grid;
  gap: 2.5rem;
  padding: 3.5rem 0 2rem;
  align-items: start;
}
@media (min-width: 900px) {
  .contra-layout {
    grid-template-columns: auto 1fr;
    gap: 3.5rem;
    align-items: center;
  }
}

/* Cards */
.contra-cards { display: grid; gap: .9rem; }
@media (min-width: 640px) { .contra-cards { grid-template-columns: 1fr 1fr; } }

.contra-card {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  padding: 1.1rem 1.1rem 1.1rem 1rem;
  border-radius: 8px;
  border: 1px solid rgba(200,30,30,.22);
  border-left: 3px solid rgba(200,30,30,.7);
  background: linear-gradient(135deg, rgba(200,30,30,.06), rgba(255,255,255,.025));
  backdrop-filter: blur(6px);
  transition: border-color .25s, box-shadow .25s, transform .25s;
}
.contra-card:hover {
  border-color: rgba(200,30,30,.5);
  border-left-color: rgba(220,50,50,.9);
  box-shadow: 0 8px 28px rgba(0,0,0,.24), 0 0 16px rgba(200,30,30,.1);
  transform: translateY(-3px);
}

.contra-card-x {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(200,30,30,.15);
  border: 1px solid rgba(200,30,30,.35);
  color: rgba(220,60,60,.9);
  font-size: .9rem;
  font-weight: 900;
  font-family: 'Barlow Condensed', sans-serif;
  line-height: 1;
  transition: background .25s, border-color .25s;
}
.contra-card:hover .contra-card-x {
  background: rgba(200,30,30,.28);
  border-color: rgba(220,60,60,.6);
}

.contra-badge {
  display: inline-block;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(220,60,60,.8);
  background: rgba(200,30,30,.1);
  border: 1px solid rgba(200,30,30,.22);
  border-radius: 3px;
  padding: .15rem .5rem;
  margin-bottom: .45rem;
}

.contra-card-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1.05rem;
  font-weight: 700;
  text-transform: uppercase;
  line-height: 1.15;
  color: var(--offwhite);
  margin: 0 0 .35rem;
}
.contra-mark {
  background: transparent;
  color: var(--red);
  font-weight: 800;
  padding: 0;
  border-radius: 0;
  text-shadow: none;
}

.contra-card-desc {
  font-size: .8rem;
  color: rgba(244,241,234,.55);
  line-height: 1.65;
  margin: 0;
}

/* Image column — left on desktop */
.contra-img-col {
  display: flex;
  justify-content: center;
}
@media (min-width: 900px) {
  .contra-img-col { justify-content: flex-start; }
}

.contra-img-wrap {
  position: relative;
  width: clamp(18rem, 40vw, 30rem);
  flex-shrink: 0;
}

.contra-img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 5.6;
  border-radius: 16px;
  object-fit: cover;
  object-position: center top;
  filter: drop-shadow(0 12px 32px rgba(0,0,0,.45));
}

.contra-img-glow {
  position: absolute;
  inset: -1.5rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,30,30,.18), transparent 60%);
  filter: blur(28px);
  z-index: -1;
  pointer-events:none;
}

/* Image badges */
.contra-img-badge {
  position: absolute;
  display: flex;
  align-items: center;
  gap: .55rem;
  padding: .5rem .8rem;
  border-radius: 8px;
  background: rgba(7,13,31,.88);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(8px);
  box-shadow: 0 8px 24px rgba(0,0,0,.38);
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(244,241,234,.82);
  white-space: nowrap;
  line-height: 1.3;
}
.contra-img-badge svg { width: 1.1rem; height: 1.1rem; color: rgba(244,241,234,.7); flex-shrink: 0; }

.contra-img-badge-top {
  top: -1rem;
  right: -1rem;
}
.contra-img-badge-bot {
  bottom: 1rem;
  left: -1.2rem;
}

.cib-icon {
  width: 1.4rem;
  height: 1.4rem;
  color: rgba(244,241,234,.85);
  flex-shrink: 0;
}
.cib-label {
  font-size: .62rem;
  color: rgba(244,241,234,.6);
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
}

/* ============================================================
   PROJECTS
   ============================================================ */
.section-projects {
  background:
    radial-gradient(ellipse at 12% 4%, rgba(248,201,40,.12), transparent 35%),
    radial-gradient(ellipse at 82% 18%, rgba(59,36,94,.32), transparent 38%),
    linear-gradient(180deg, #050914, #0b1024 68%, #080b17);
  color: var(--offwhite);
  position: relative;
  overflow: hidden;
}
.section-projects::before,
.section-media::before {
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(248,201,40,.6), rgba(21,58,151,.45), transparent);
  box-shadow:0 0 18px rgba(248,201,40,.24);
  pointer-events:none;
}
.section-projects::after {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  opacity:.06;
  background-image:
    linear-gradient(rgba(7,13,31,.5) 1px, transparent 1px),
    linear-gradient(90deg, rgba(7,13,31,.5) 1px, transparent 1px);
  background-size:48px 48px;
}
.section-projects .container { position:relative; z-index:1; }

.projects-head { text-align:center; padding:5rem 0 0; }
@media (min-width:768px) { .projects-head { padding-top:7rem; } }

.projects-title {
  margin-top:.75rem; font-size:clamp(3rem,7vw,4.5rem); text-transform:uppercase;
}

.projects-grid {
  display:grid; gap:1.55rem; padding:3.5rem 0 5rem;
  perspective: 1500px;
}
@media (min-width:640px) { .projects-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px) { .projects-grid { grid-template-columns:repeat(3,1fr); } }

.proj-card {
  position:relative;
  background: transparent;
  border-radius: 13px;
  overflow: visible;
  border: 0;
  box-shadow: none;
  transform: translateY(0) rotate(var(--card-tilt, 0deg));
  transition: transform .35s cubic-bezier(.22,1,.36,1);
  height: 28rem;
  min-height:0;
  cursor:pointer;
}
.proj-card.reveal,
.proj-card.reveal.visible {
  will-change: transform;
}
.proj-card::before {
  content:none;
  position:absolute;
  inset:.45rem;
  border:1px solid rgba(244,241,234,.12);
  border-radius:10px;
  pointer-events:none;
  z-index:3;
}
.proj-card::after {
  content:'◆';
  position:absolute;
  right:.8rem;
  bottom:.6rem;
  font-family:'Barlow Condensed',sans-serif;
  color:rgba(248,201,40,.7);
  font-size:1.15rem;
  line-height:1;
  transform:rotate(180deg);
  z-index:3;
}
.proj-card::before,
.proj-card::after {
  backface-visibility:hidden;
}
.proj-card::after { content:none; }
.proj-card-inner {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  transform-style:preserve-3d;
  transition:transform .85s cubic-bezier(.22,1,.36,1);
  will-change:transform;
}
.proj-card.open .proj-card-inner { transform:rotateY(180deg); }
.proj-card-front,
.proj-body {
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  overflow:hidden;
  border-radius:13px;
  border:2px solid rgba(248,201,40,.22);
  box-shadow:0 18px 38px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.05);
  backface-visibility:hidden;
}
.proj-body { pointer-events:none; }
.proj-card.open .proj-body { pointer-events:auto; }
.proj-card.open .proj-card-front { pointer-events:none; }
.proj-card-front {
  display:flex;
  flex-direction:column;
  background:linear-gradient(145deg, #0a1024, #111735 62%, #090d1d);
}
.proj-card-front::before {
  content:'';
  position:absolute;
  inset:.45rem;
  border:1px solid rgba(244,241,234,.12);
  border-radius:10px;
  pointer-events:none;
  z-index:3;
}
.proj-card-front::after {
  content:'♦';
  position:absolute;
  right:.8rem;
  bottom:.6rem;
  font-family:'Barlow Condensed',sans-serif;
  color:rgba(248,201,40,.7);
  font-size:1.15rem;
  line-height:1;
  z-index:3;
}
.proj-card:nth-child(3n+1) { --card-tilt:-1.2deg; }
.proj-card:nth-child(3n+2) { --card-tilt:.8deg; }
.proj-card:nth-child(3n) { --card-tilt:-.4deg; }
.proj-card:hover {
  transform: translateY(-8px) rotate(0deg);
}
.proj-card:focus-visible {
  outline:2px solid var(--yellow);
  outline-offset:4px;
}
.proj-card.open {
  outline: 2px solid var(--yellow);
  outline-offset: 0;
  transform: translateY(0) rotate(var(--card-tilt, 0deg));
  height:28rem;
  min-height:0;
  box-shadow: 0 18px 34px rgba(0,0,0,.38), 0 0 18px rgba(248,201,40,.16);
}
.proj-card.open:hover {
  transform: translateY(0) rotate(var(--card-tilt, 0deg));
}
.proj-card.open .proj-card-inner::before {
  content:'';
  position:absolute;
  inset:-2px;
  border-radius:15px;
  background:linear-gradient(120deg, rgba(248,201,40,.08), rgba(248,201,40,.42), rgba(21,58,151,.18), rgba(248,201,40,.08));
  opacity:.72;
  pointer-events:none;
  animation:projActiveGlow 3.8s ease-in-out infinite;
}
@keyframes projActiveGlow {
  0%, 100% { opacity:.48; }
  50% { opacity:.78; }
}

.proj-accent {
  position:absolute; top:0; left:0;
  height:3px; width:3rem;
  background:var(--yellow);
  transition:width .35s cubic-bezier(.22,1,.36,1);
  box-shadow:0 1px 6px rgba(248,201,40,.4);
}
.proj-card:hover .proj-accent,
.proj-card.open .proj-accent { width:100%; }

.proj-num {
  position:absolute; top:.8rem; left:.85rem;
  font-family:'Barlow Condensed',sans-serif; font-weight:900;
  font-size:1.45rem; line-height:.9;
  -webkit-text-stroke:0;
  color:var(--yellow); opacity:.95;
  user-select:none; pointer-events:none;
  z-index:4;
}
.proj-num::after {
  content:'◆';
  display:block;
  font-size:.8rem;
  margin-top:.18rem;
}

.proj-visual {
  position:relative;
  height:9.2rem;
  overflow:hidden;
  background:
    linear-gradient(135deg, rgba(7,13,31,.96), rgba(59,36,94,.72)),
    repeating-linear-gradient(135deg, rgba(248,201,40,.12) 0 2px, transparent 2px 12px);
}
.proj-visual::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(7,13,31,.12), rgba(7,13,31,.65));
  pointer-events:none;
}
.proj-visual::before {
  content:'';
  position:absolute;
  left:4rem;
  bottom:.8rem;
  width:4.4rem;
  height:3px;
  background:var(--yellow);
  z-index:2;
  box-shadow:0 0 12px rgba(248,201,40,.65);
  pointer-events:none;
}
.proj-visual img {
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  opacity:.68;
  filter:saturate(1.05) contrast(1.05);
  transition:transform .65s cubic-bezier(.22,1,.36,1), opacity .35s;
}
.proj-card:hover .proj-visual img { transform:scale(1.06); opacity:.82; }
.proj-visual.empty img { display:none; }

.proj-btn {
  display:flex; flex-direction:column; align-items:flex-start;
  text-align:left; width:100%;
  padding:1.25rem 1.5rem 1rem;
  background:none; border:none; cursor:pointer; color:var(--offwhite);
  flex:1;
  min-height:0;
}
.proj-btn::after {
  content:attr(data-summary);
  display:block;
  order: 4;
  margin-top:.85rem;
  max-width:16rem;
  font-size:.78rem;
  line-height:1.55;
  color:rgba(244,241,234,.62);
}
.proj-icon { order: 0; }
.proj-cat { order: 1; }
.proj-title { order: 2; }
.proj-toggle {
  order: 5;
  margin-top: 1.1rem;
  padding: 0;
  background: none;
  border: none;
  color: rgba(244,241,234,.58);
  transition: color .2s, gap .2s;
}
.proj-card:hover .proj-toggle,
.proj-card:focus-visible .proj-toggle {
  color: var(--yellow);
  gap: .55rem;
}

.proj-icon {
  display:flex; align-items:center; justify-content:center;
  width:2.6rem; height:2.6rem;
  border-radius:50%;
  background:rgba(248,201,40,.1); color:var(--yellow);
  border:1px solid rgba(248,201,40,.22);
  flex-shrink:0;
  transition:transform .25s, box-shadow .25s;
  box-shadow:0 2px 8px rgba(0,0,0,.15);
}
.proj-icon svg { width:18px; height:18px; }
.proj-card:hover .proj-icon { transform:scale(1.1); box-shadow:0 4px 14px rgba(0,0,0,.25); }

.proj-cat {
  font-size:.58rem; font-weight:700; text-transform:uppercase; letter-spacing:.16em;
  color:var(--yellow); display:block; margin-top:.6rem;
  padding:.2rem .5rem;
  background:rgba(248,201,40,.09);
  border-radius:3px;
  display:inline-block;
}

.proj-title {
  margin-top:1rem;
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:1.45rem; text-transform:uppercase; line-height:1.05;
  padding-right:.6rem; color:var(--offwhite);
  transition:color .2s;
}
.proj-card:hover .proj-title { color:var(--yellow); }

.proj-toggle {
  margin-top:1.1rem;
  display:inline-flex; align-items:center; gap:.35rem;
  font-size:.65rem; font-weight:600; text-transform:uppercase; letter-spacing:.14em;
  color:rgba(244,241,234,.58);
}
.proj-toggle svg { width:13px; height:13px; transition:transform .35s cubic-bezier(.22,1,.36,1); }
.proj-card.open .proj-toggle svg { transform:rotate(180deg); }

.proj-body {
  inset:0;
  overflow:hidden;
  max-height:none;
  opacity:1;
  visibility:visible;
  transform:rotateY(180deg);
  transition:none;
  z-index:4;
  display:flex;
  align-items:stretch;
  justify-content:center;
  backface-visibility:hidden;
  border-radius:13px;
  border:1px solid rgba(248,201,40,.32);
  background:
    radial-gradient(ellipse at 18% 12%, rgba(248,201,40,.16), transparent 34%),
    radial-gradient(ellipse at 85% 88%, rgba(59,36,94,.26), transparent 38%),
    linear-gradient(145deg, #10245c, #0b173a 64%, #081126);
  background-size:auto, auto;
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.06),
    inset 0 0 0 .55rem rgba(7,13,31,.18),
    0 18px 36px rgba(0,0,0,.18);
}
.proj-body::before {
  content:attr(data-num);
  position:absolute;
  right:.55rem;
  top:1rem;
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(5rem, 10vw, 7.6rem);
  line-height:.8;
  font-weight:900;
  color:rgba(248,201,40,.08);
  transform:none;
  letter-spacing:.03em;
  opacity:1;
  pointer-events:none;
  z-index:0;
}
.proj-body::after {
  content:'';
  position:absolute;
  inset:.55rem;
  height:auto;
  border:1px solid rgba(248,201,40,.2);
  border-radius:7px;
  background:linear-gradient(145deg, rgba(248,201,40,.045), transparent 42%, rgba(255,255,255,.025));
  box-shadow:inset 0 0 28px rgba(7,13,31,.18);
  pointer-events:none;
}
.proj-body.open { max-height:none; }
.proj-card.open .proj-body {
  opacity:1;
  visibility:visible;
  transition:none;
}

.proj-body-inner {
  position:relative;
  z-index:1;
  width:100%;
  min-height:100%;
  padding:1.55rem 1.45rem 1.6rem;
  border-top:0;
  font-size:.9rem; color:rgba(244,241,234,.88); line-height:1.66;
  text-align:left;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  overflow:auto;
}
.proj-back-head {
  display:flex;
  align-items:center;
  gap:.65rem;
  margin-bottom:1rem;
  flex-shrink:0;
}
.proj-back-num {
  display:block;
  font-family:'Barlow Condensed',sans-serif;
  font-size:clamp(3.2rem, 9vw, 5rem);
  line-height:.82;
  font-weight:900;
  color:var(--yellow);
  letter-spacing:.02em;
  margin:0;
  text-shadow:0 0 18px rgba(248,201,40,.18);
}
.proj-back-suit {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:2rem;
  height:2rem;
  margin-bottom:0;
  border-radius:50%;
  border:1px solid rgba(248,201,40,.28);
  color:var(--yellow);
  background:rgba(248,201,40,.08);
  font-size:1.3rem;
  line-height:1;
  text-shadow:0 0 14px rgba(248,201,40,.24);
}
.proj-back-icon {
  display:none;
  place-items:center;
  width:2.85rem;
  height:2.85rem;
  border-radius:50%;
  color:var(--yellow);
  background:rgba(248,201,40,.11);
  border:1px solid rgba(248,201,40,.28);
  box-shadow:0 0 20px rgba(248,201,40,.12), inset 0 0 0 4px rgba(7,13,31,.28);
  margin-bottom:.7rem;
}
.proj-back-icon svg { width:19px; height:19px; }
.proj-back-cat {
  display:none;
  max-width:100%;
  padding:.24rem .55rem;
  border-radius:3px;
  background:rgba(248,201,40,.1);
  color:var(--yellow);
  font-size:.58rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.14em;
  line-height:1.35;
}
.proj-back-title {
  display:none;
  margin-top:.85rem;
  font-family:'Barlow Condensed',sans-serif;
  font-weight:800;
  font-size:clamp(1.35rem, 4.5vw, 1.85rem);
  line-height:1.02;
  text-transform:uppercase;
  color:var(--offwhite);
}
.proj-back-text,
.proj-body-inner p {
  display:block;
  margin-top:0;
  color:rgba(255,255,255,.94);
  font-size:.93rem;
  font-weight:500;
  line-height:1.76;
  letter-spacing:.005em;
  max-width:100%;
  text-wrap:pretty;
}
.proj-card-front::after,
.proj-num::after,
.proj-back-suit {
  content:none;
  display:none;
}
.proj-back-head { margin-bottom:1.15rem; }
.proj-back-text mark {
  color: var(--yellow);
  background: rgba(248,201,40,.15);
  border-radius: 3px;
  padding: 0 .18em;
  font-weight: 800;
  box-shadow:0 0 14px rgba(248,201,40,.2);
}

/* ============================================================
   MEDIA
   ============================================================ */
.section-media {
  background:var(--offwhite-1);
  color:var(--navy-950);
  position:relative;
  overflow:hidden;
}
.section-media::after {
  content:'';
  position:absolute;
  inset:auto 0 0 0;
  height:42%;
  background:linear-gradient(0deg, rgba(21,58,151,.07), transparent);
  pointer-events:none;
}

.media-inner { padding:5rem 0; position:relative; z-index:1; }
@media (min-width:768px) { .media-inner { padding:7rem 0; } }
.media-inner::before,
.media-inner::after {
  content:'';
  position:absolute;
  width:5.2rem;
  height:6.3rem;
  background:
    linear-gradient(#fff 0 0) padding-box,
    linear-gradient(135deg, rgba(7,13,31,.18), rgba(248,201,40,.18)) border-box;
  border:1px solid transparent;
  box-shadow:0 12px 28px rgba(7,13,31,.1);
  opacity:.52;
  pointer-events:none;
  animation: paperFloat 8s ease-in-out infinite;
}
.media-inner::before {
  top:5.4rem;
  left:1.5rem;
  --paper-rotate:-10deg;
  transform:rotate(var(--paper-rotate));
}
.media-inner::after {
  right:1.6rem;
  bottom:5rem;
  --paper-rotate:8deg;
  transform:rotate(var(--paper-rotate));
  animation-delay:-2.5s;
}
.section-media .media-inner::before,
.section-media .media-inner::after {
  background-image:
    linear-gradient(180deg, rgba(7,13,31,.12) 0 .45rem, transparent .45rem .9rem, rgba(7,13,31,.08) .9rem 1.05rem, transparent 1.05rem 1.45rem, rgba(7,13,31,.08) 1.45rem 1.6rem, transparent 1.6rem),
    linear-gradient(#fff, #f6f2e8);
}
.media-inner > .reveal:first-child { text-align:center; }
.media-inner > .reveal:first-child .eyebrow { justify-content:center; color:var(--blue); }
.media-inner > .reveal:first-child .section-rule { margin:1rem auto 0; }
.media-inner > .reveal:last-child {
  position:relative;
}
.media-inner > .reveal:last-child::before,
.media-inner > .reveal:last-child::after {
  content:'';
  position:absolute;
  width:3.8rem;
  height:4.8rem;
  background-image:
    linear-gradient(180deg, rgba(7,13,31,.14) 0 .32rem, transparent .32rem .68rem, rgba(7,13,31,.08) .68rem .82rem, transparent .82rem 1.18rem, rgba(7,13,31,.08) 1.18rem 1.3rem, transparent 1.3rem),
    linear-gradient(#fff, #f7f3e8);
  border:1px solid rgba(7,13,31,.1);
  box-shadow:0 12px 24px rgba(7,13,31,.1);
  opacity:.6;
  pointer-events:none;
  animation: paperFloat 8s ease-in-out infinite;
  z-index:-1;
}
.media-inner > .reveal:last-child::before {
  left:8%;
  bottom:-1.2rem;
  --paper-rotate:-7deg;
  transform:rotate(var(--paper-rotate));
}
.media-inner > .reveal:last-child::after {
  right:10%;
  top:-.8rem;
  --paper-rotate:9deg;
  transform:rotate(var(--paper-rotate));
  animation-delay:-2s;
}

.media-grid {
  position:relative;
}
.media-grid::before,
.media-grid::after {
  content:'';
  position:absolute;
  width:4.3rem;
  height:5.4rem;
  background-image:
    linear-gradient(180deg, rgba(7,13,31,.14) 0 .36rem, transparent .36rem .78rem, rgba(7,13,31,.09) .78rem .92rem, transparent .92rem 1.25rem, rgba(7,13,31,.08) 1.25rem 1.38rem, transparent 1.38rem),
    linear-gradient(#fff, #f7f3e8);
  border:1px solid rgba(7,13,31,.1);
  box-shadow:0 12px 24px rgba(7,13,31,.1);
  opacity:.64;
  pointer-events:none;
  z-index:-1;
  animation: paperFloat 9s ease-in-out infinite;
}
.media-grid::before {
  left:-3rem;
  top:1rem;
  --paper-rotate:12deg;
  transform:rotate(var(--paper-rotate));
}
.media-grid::after {
  right:-2.2rem;
  top:35%;
  --paper-rotate:-12deg;
  transform:rotate(var(--paper-rotate));
  animation-delay:-3s;
}

.media-title {
  margin-top:.75rem;
  font-size:clamp(2.25rem,5vw,3.5rem);
  text-transform:uppercase; line-height:.95;
}
.media-title .bl { color:var(--blue); }

.media-empty {
  border:1px solid rgba(7,13,31,.14);
  background:linear-gradient(145deg, rgba(255,255,255,.92), rgba(238,243,255,.86));
  border-radius:8px; padding:2.4rem; text-align:center;
  margin-top:2rem;
  box-shadow:0 14px 32px rgba(7,13,31,.08);
}
.media-empty h3 { font-size:1.5rem; text-transform:uppercase; color:var(--navy-950); }
.media-empty p {
  margin-top:.5rem; font-size:.88rem; color:rgba(7,13,31,.5);
  max-width:28rem; margin-left:auto; margin-right:auto;
}

.media-grid { display:grid; gap:1.25rem; margin:2.25rem auto 0; max-width:62rem; }
@media (min-width:640px) { .media-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px) { .media-grid { grid-template-columns:repeat(3,1fr); } }

.media-card {
  display:flex; flex-direction:column;
  background:linear-gradient(145deg, #0b1024, #121a38); border-radius:8px; padding:1.4rem;
  box-shadow:0 16px 34px rgba(7,13,31,.18);
  border:1px solid rgba(248,201,40,.14);
  color:var(--offwhite);
  transition: transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s, border-color .35s;
  position:relative;
  overflow: hidden;
  animation: mediaCardIdle 6s ease-in-out infinite;
}
.media-card:nth-child(3n+1) { animation-delay: -1.4s; }
.media-card:nth-child(3n+2) { animation-delay: -3.2s; }
.media-card:nth-child(3n)   { animation-delay: -4.8s; }
@keyframes mediaCardIdle {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-4px); }
}
.media-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 0 30%, rgba(248,201,40,.22) 48%, transparent 66% 100%);
  transform: translateX(-120%);
  pointer-events: none;
  animation: mediaShine 7s ease-in-out infinite;
  opacity: .85;
}
.media-card:nth-child(3n+1)::after { animation-delay: -2s; }
.media-card:nth-child(3n+2)::after { animation-delay: -4s; }
@keyframes mediaShine {
  0%   { transform: translateX(-120%); }
  55%  { transform: translateX(120%); }
  100% { transform: translateX(120%); }
}
.media-card::before {
  content:'';
  position:absolute;
  right:1rem;
  top:1rem;
  width:1.3rem;
  height:1rem;
  border:1px solid rgba(248,201,40,.28);
  border-radius:2px;
  background:linear-gradient(180deg, rgba(248,201,40,.18) 0 35%, transparent 35%);
  opacity:.7;
  pointer-events:none;
}
.media-card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 24px 48px rgba(7,13,31,.36), 0 0 28px rgba(248,201,40,.22);
  border-color: rgba(248,201,40,.55);
  animation-play-state: paused;
}
.media-card:hover .media-card-title { color: var(--yellow); }
.media-card-title { transition: color .25s; }

.media-card-outlet { font-size:.62rem; font-weight:700; text-transform:uppercase; letter-spacing:.16em; color:rgba(248,201,40,.72); }
.media-card-title {
  margin-top:.4rem;
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:1.1rem; text-transform:uppercase; line-height:1.2;
  color:var(--offwhite); flex:1;
}
.media-card-desc { margin-top:.65rem; font-size:.85rem; line-height:1.65; color:rgba(244,241,234,.68); }
.media-card-cta {
  margin-top:.9rem;
  display:inline-flex; align-items:center; gap:.35rem;
  font-size:.82rem; font-weight:600;
  color:var(--yellow); transition:color .2s, gap .2s;
}
.media-card:hover .media-card-cta { color:var(--yellow); gap:.55rem; }
.media-card-cta svg { width:13px; height:13px; }
.media-channel-label {
  position:absolute;
  right:.9rem;
  bottom:.75rem;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  max-width:7rem;
  padding:.12rem .4rem;
  border-radius:3px;
  border:1px solid rgba(244,241,234,.12);
  background:rgba(244,241,234,.06);
  color:rgba(244,241,234,.48);
  font-family:'Barlow Condensed',sans-serif;
  font-size:.56rem;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  box-shadow:none;
}
.media-card:hover .media-channel-label {
  color:rgba(244,241,234,.68);
  border-color:rgba(244,241,234,.2);
}

/* ============================================================
   YOUTUBE
   ============================================================ */
.section-yt { position:relative; overflow:hidden; background:var(--navy-900); color:var(--offwhite); }
.section-yt::before {
  content:'';
  position:absolute;
  top:3.5rem;
  left:5vw;
  width:5.8rem;
  height:3.6rem;
  border:1px solid rgba(248,201,40,.28);
  border-radius:6px;
  background:
    repeating-linear-gradient(135deg, rgba(248,201,40,.22) 0 .45rem, transparent .45rem .9rem),
    rgba(255,255,255,.035);
  transform:rotate(-8deg);
  opacity:.78;
  box-shadow:0 0 24px rgba(248,201,40,.12);
  animation: clapperFloat 7s ease-in-out infinite;
  pointer-events:none;
}
.section-yt::after {
  content:'';
  position:absolute;
  right:6vw;
  bottom:4rem;
  width:8rem;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(248,201,40,.55), transparent);
  box-shadow:0 -14px 0 rgba(248,201,40,.12), 0 14px 0 rgba(248,201,40,.12);
  opacity:.72;
  pointer-events:none;
}
.yt-bg { position:absolute; inset:0; pointer-events:none; }
.yt-bg-g { position:absolute; inset:0; background:radial-gradient(ellipse at bottom, rgba(21,58,151,.26) 0%, transparent 55%); }

.yt-inner { position:relative; padding:5rem 0 6rem; }
.yt-inner::before,
.yt-inner::after {
  content:'';
  position:absolute;
  border:1px solid rgba(248,201,40,.24);
  border-radius:5px;
  background:
    repeating-linear-gradient(135deg, rgba(248,201,40,.2) 0 .35rem, transparent .35rem .7rem),
    rgba(255,255,255,.035);
  box-shadow:0 0 20px rgba(248,201,40,.1);
  pointer-events:none;
  opacity:.68;
  animation: clapperFloat 8s ease-in-out infinite;
}
.yt-inner::before {
  width:4.8rem;
  height:3rem;
  right:2rem;
  top:4.2rem;
  transform:rotate(10deg);
}
.yt-inner::after {
  width:3.8rem;
  height:2.4rem;
  left:2rem;
  bottom:2.8rem;
  transform:rotate(7deg);
  animation-delay:-2.2s;
}

@keyframes clapperFloat {
  0%, 100% { translate:0 0; }
  50% { translate:0 -7px; }
}

.yt-header { text-align:center; max-width:44rem; margin:0 auto; }
.yt-title { margin-top:.75rem; font-size:clamp(2.25rem,5vw,3.25rem); text-transform:uppercase; line-height:.95; }
.yt-title .yl { color:var(--yellow); }

.yt-grid { display:grid; gap:1.25rem; margin-top:3rem; }
.yt-grid {
  position:relative;
}
.yt-grid::before,
.yt-grid::after {
  content:'';
  position:absolute;
  width:4.2rem;
  height:2.7rem;
  border:1px solid rgba(248,201,40,.24);
  border-radius:5px;
  background:
    repeating-linear-gradient(135deg, rgba(248,201,40,.2) 0 .32rem, transparent .32rem .64rem),
    rgba(255,255,255,.035);
  box-shadow:0 0 20px rgba(248,201,40,.1);
  pointer-events:none;
  opacity:.64;
  animation: clapperFloat 8s ease-in-out infinite;
  z-index:-1;
}
.yt-grid::before {
  left:-2rem;
  top:1rem;
  transform:rotate(-9deg);
}
.yt-grid::after {
  right:-1.8rem;
  bottom:1.4rem;
  transform:rotate(11deg);
  animation-delay:-3s;
}
@media (min-width:640px) { .yt-grid { grid-template-columns:repeat(2,1fr); } }
@media (min-width:1024px) { .yt-grid { grid-template-columns:repeat(3,1fr); } }

.yt-card {
  display:block; overflow:hidden; border-radius:6px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  transition:border-color .2s, transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s;
}
.yt-card:hover {
  border-color:var(--yellow);
  transform:translateY(-3px);
  box-shadow:0 8px 28px rgba(0,0,0,.3);
}

.yt-thumb { position:relative; aspect-ratio:16/9; overflow:hidden; background:var(--navy-950); }
.yt-thumb img {
  width:100%; height:100%; object-fit:cover;
  opacity:.65; transition:opacity .4s, transform .5s cubic-bezier(.22,1,.36,1);
}
.yt-card:hover .yt-thumb img { opacity:1; transform:scale(1.04); }

.yt-play { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; pointer-events:none; }
.yt-play span {
  display:inline-flex; align-items:center; justify-content:center;
  width:3.2rem; height:3.2rem; border-radius:50%;
  background:var(--yellow); color:var(--navy-950);
  box-shadow:0 4px 20px rgba(0,0,0,.35);
  transition:transform .3s cubic-bezier(.22,1,.36,1);
}
.yt-play span svg { width:18px; height:18px; }
.yt-card:hover .yt-play span { transform:scale(1.12); }

.yt-info { padding:1rem; }
.yt-info-title {
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:1.05rem; text-transform:uppercase; line-height:1.2; color:var(--offwhite);
}

.yt-cta { display:flex; justify-content:center; margin-top:2.5rem; }

/* ============================================================
   SOCIAL
   ============================================================ */
.section-social {
  order: 30;
  background:var(--navy-950);
  color: var(--offwhite);
  border-top: 1px solid rgba(255,255,255,.05);
  position: relative;
  overflow:hidden;
}
.section-social::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, rgba(248,201,40,.3) 50%, transparent);
  pointer-events:none;
}
.section-social::after {
  content:none;
}

.social-inner { padding:4rem 0 5rem; text-align:center; }

.social-title { margin-top:.75rem; font-size:clamp(2rem,4vw,2.75rem); text-transform:uppercase; line-height:.95; }

.social-desc { margin-top:.9rem; font-size:.93rem; color:rgba(244,241,234,.55); max-width:26rem; margin-left:auto; margin-right:auto; }

.social-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:.9rem;
  margin-top:2.5rem; max-width:42rem; margin-left:auto; margin-right:auto;
}
@media (min-width:640px) { .social-grid { grid-template-columns:repeat(4,1fr); } }

.social-card {
  display:flex; flex-direction:column; align-items:center; gap:.6rem;
  padding:1.5rem 1rem; border-radius:10px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);
  color:var(--offwhite); transition:all .25s cubic-bezier(.22,1,.36,1);
  text-align:center; text-decoration:none;
}
.social-card:hover {
  border-color:rgba(248,201,40,.6);
  background:rgba(248,201,40,.06);
  transform:translateY(-4px);
  box-shadow:0 10px 28px rgba(0,0,0,.3);
}
.social-icon {
  width:2.5rem; height:2.5rem;
  display:flex; align-items:center; justify-content:center;
  border-radius:50%;
  background:rgba(255,255,255,.08);
  transition:background .2s;
}
.social-card:hover .social-icon { background:rgba(248,201,40,.18); }
.social-icon svg { width:19px; height:19px; }

.social-label {
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:.82rem; text-transform:uppercase; letter-spacing:.07em;
  color:rgba(244,241,234,.8);
}

/* ============================================================
   ENGAGE / FORM
   ============================================================ */
.section-engage {
  order: 20;
  background:
    linear-gradient(180deg, var(--offwhite-3), #f8f6f0),
    radial-gradient(ellipse at top, rgba(248,201,40,.18), transparent 46%);
  color:var(--navy-950);
  position:relative;
  overflow:hidden;
}
.section-engage.mode-red {
  background:
    radial-gradient(ellipse at top, rgba(225,25,45,.16), transparent 44%),
    linear-gradient(180deg, #f7f1f1, #f8f6f0);
  background-size:160% 160%;
  animation: gradientMove 10s ease-in-out infinite;
}
.section-engage.mode-yellow,
.section-engage.mode-voluntario {
  background:
    radial-gradient(ellipse at top, rgba(248,201,40,.2), transparent 46%),
    linear-gradient(180deg, #f7f2dc, #f8f6f0);
  background-size:160% 160%;
  animation: gradientMove 10s ease-in-out infinite;
}
.section-engage.mode-sugestao {
  background:
    radial-gradient(ellipse at top, rgba(21,58,151,.18), transparent 46%),
    linear-gradient(180deg, #eef3ff, #f8f6f0);
  background-size:160% 160%;
  animation: gradientMove 10s ease-in-out infinite;
}
.section-engage::before {
  content:'';
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(225,25,45,.35), rgba(248,201,40,.5), transparent);
  background-size:200% 100%;
  pointer-events:none;
  animation: gradientMove 5.5s ease-in-out infinite;
}
.section-engage::after,
.engage-inner::before,
.engage-inner::after {
  content:'';
  position:absolute;
  width:5.8rem;
  height:5.8rem;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23153A97' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 35h9l24 12V17L23 29h-9v6z'/%3E%3Cpath d='M23 35l4 15h8l-5-17'/%3E%3Cpath d='M49 25c4 3 4 11 0 14'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-size:contain;
  pointer-events:none;
  opacity:.07;
  filter:drop-shadow(0 10px 18px rgba(21,58,151,.12));
  animation:heroCircleFloat 8s ease-in-out infinite;
}
.section-engage::after {
  right:8%;
  top:7rem;
  z-index:0;
  rotate:-12deg;
}

.engage-megaphones {
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:hidden;
}
.engage-megaphones span {
  position:absolute;
  width:clamp(3.2rem, 7vw, 6.8rem);
  height:clamp(3.2rem, 7vw, 6.8rem);
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg' fill='none' stroke='%23153A97' stroke-width='4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M14 35h9l24 12V17L23 29h-9v6z'/%3E%3Cpath d='M23 35l4 15h8l-5-17'/%3E%3Cpath d='M49 25c4 3 4 11 0 14'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-size:contain;
  opacity:.14;
  filter:drop-shadow(0 12px 18px rgba(21,58,151,.15));
  animation:heroCircleFloat 8.5s ease-in-out infinite;
}
.engage-megaphones span:nth-child(1) { left:5%; top:7%; rotate:-18deg; opacity:.15; }
.engage-megaphones span:nth-child(2) { right:7%; top:10%; rotate:16deg; opacity:.16; animation-delay:-1.2s; }
.engage-megaphones span:nth-child(3) { left:13%; top:39%; width:4.4rem; height:4.4rem; rotate:10deg; opacity:.12; animation-delay:-2.2s; }
.engage-megaphones span:nth-child(4) { right:12%; top:45%; width:5rem; height:5rem; rotate:-10deg; opacity:.13; animation-delay:-3.1s; }
.engage-megaphones span:nth-child(5) { left:3%; bottom:10%; width:6rem; height:6rem; rotate:15deg; opacity:.13; animation-delay:-4.2s; }
.engage-megaphones span:nth-child(6) { right:4%; bottom:13%; width:5.4rem; height:5.4rem; rotate:-20deg; opacity:.15; animation-delay:-5s; }
.engage-megaphones span:nth-child(7) { left:48%; top:18%; width:3.6rem; height:3.6rem; rotate:24deg; opacity:.1; animation-delay:-1.8s; }
.engage-megaphones span:nth-child(8) { left:51%; bottom:5%; width:4.7rem; height:4.7rem; rotate:-14deg; opacity:.11; animation-delay:-3.8s; }

.engage-inner { padding:5rem 0 6rem; position:relative; z-index:1; }
.engage-inner::before {
  left:7%;
  bottom:8rem;
  width:4.6rem;
  height:4.6rem;
  z-index:0;
  rotate:11deg;
  opacity:.06;
  animation-delay:-2.4s;
}
.engage-inner::after {
  right:18%;
  bottom:3.4rem;
  width:3.6rem;
  height:3.6rem;
  z-index:0;
  rotate:18deg;
  opacity:.055;
  animation-delay:-4s;
}
.engage-head,
.form-card { position:relative; z-index:1; }
@media (min-width:768px) { .engage-inner { padding:6rem 0 7rem; } }

.engage-head { text-align:center; max-width:36rem; margin:0 auto; }

.engage-title {
  margin-top:.75rem; font-size:clamp(2.25rem,5vw,3.25rem);
  text-transform:uppercase; line-height:.95;
}
.engage-title .bl { color:var(--blue); }
.section-engage.mode-red .engage-title .bl { color:var(--red); }
.section-engage.mode-yellow .engage-title .bl,
.section-engage.mode-voluntario .engage-title .bl { color:var(--yellow); text-shadow:0 0 14px rgba(248,201,40,.2); }
.section-engage.mode-sugestao .engage-title .bl { color:var(--blue); }

.engage-desc { margin-top:.9rem; font-size:.93rem; color:rgba(7,13,31,.6); line-height:1.7; }

.engage-badge {
  display:inline-flex; align-items:center; gap:.4rem; margin-top:1.1rem;
  background:var(--navy-950); color:var(--yellow);
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:.8rem; text-transform:uppercase; letter-spacing:.1em;
  padding:.4rem .85rem; border-radius:100px;
  border:1px solid rgba(248,201,40,.22);
  box-shadow: 0 10px 28px rgba(7,13,31,.22), 0 3px 8px rgba(0,0,0,.14);
}
.engage-badge::before { content:'›'; font-size:1rem; }
.section-engage.mode-red .engage-badge { color:#fff; background:var(--red); border-color:rgba(225,25,45,.45); }
.section-engage.mode-red .engage-badge::before { content:'×'; }
.section-engage.mode-yellow .engage-badge,
.section-engage.mode-voluntario .engage-badge { color:var(--navy-950); background:var(--yellow); }
.section-engage.mode-sugestao .engage-badge { color:#fff; background:var(--blue); border-color:rgba(21,58,151,.45); }

.form-card {
  max-width:40rem; margin:2.5rem auto 0;
  background:rgba(255,255,255,.94); border-radius:10px;
  box-shadow:0 8px 40px rgba(7,13,31,.12), 0 2px 8px rgba(7,13,31,.06);
  overflow:hidden;
  transition:box-shadow .3s, outline .3s, transform .3s;
  outline:2px solid transparent;
  position:relative;
}
.form-card::before {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(120deg, transparent 0 30%, rgba(255,255,255,.35) 48%, transparent 66% 100%);
  transform:translateX(-120%);
  animation: formGlint 6.5s ease-in-out infinite;
  opacity:.55;
}
.form-card::after {
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg, rgba(248,201,40,.18), rgba(248,201,40,.08), transparent 68%);
  transform:translateX(-105%);
  opacity:0;
  z-index:2;
}
.form-card.mode-red::after {
  background:linear-gradient(90deg, rgba(225,25,45,.24), rgba(225,25,45,.1), transparent 68%);
}
.form-card.mode-yellow::after,
.form-card.mode-voluntario::after {
  background:linear-gradient(90deg, rgba(248,201,40,.24), rgba(248,201,40,.1), transparent 68%);
}
.form-card.mode-sugestao::after {
  background:linear-gradient(90deg, rgba(21,58,151,.22), rgba(21,58,151,.09), transparent 68%);
}
.form-card.support-swipe::after {
  animation:supportSwipe .74s cubic-bezier(.16,1,.3,1);
}
.form-card.mode-red {
  outline-color:var(--red);
  box-shadow:0 14px 46px rgba(225,25,45,.18), 0 0 0 2px var(--red);
}
.form-card.mode-yellow {
  outline-color:var(--yellow);
  box-shadow:0 8px 40px rgba(248,201,40,.18), 0 0 0 2px var(--yellow);
}
.form-card.mode-voluntario {
  outline-color:var(--yellow);
  box-shadow:0 12px 42px rgba(248,201,40,.18), 0 0 0 2px var(--yellow), 0 0 28px rgba(248,201,40,.12);
}
.form-card.mode-sugestao {
  outline-color:var(--blue);
  box-shadow:0 12px 42px rgba(21,58,151,.18), 0 0 0 2px var(--blue), 0 0 28px rgba(21,58,151,.12);
}
.form-card:hover { transform:translateY(-2px); }

.form-tabs { display:grid; grid-template-columns:1fr 1fr; }

.form-tab-btn {
  display:flex; align-items:center; justify-content:center; gap:.5rem;
  padding:1rem;
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:.95rem; text-transform:uppercase; letter-spacing:.06em;
  transition:all .2s; cursor:pointer; border:none;
  background:var(--offwhite-1); color:rgba(7,13,31,.45);
}
.form-tab-btn svg { width:15px; height:15px; flex-shrink:0; }
.form-tab-btn:not(.active-red):not(.active-dark):hover { background:var(--offwhite-2); color:var(--navy-950); }
.form-tab-btn.active-red { background:var(--red); color:#fff; }
.form-tab-btn.active-dark { background:var(--yellow); color:var(--navy-950); }
.section-engage.mode-sugestao #tab-apoio.active-dark,
.form-card.mode-sugestao ~ #tab-apoio.active-dark {
  background:var(--blue);
  color:#fff;
}
.section-engage.mode-sugestao #tab-apoio.active-dark svg {
  filter:drop-shadow(0 0 8px rgba(255,255,255,.16));
}

.form-card.mode-red .form-body { background:linear-gradient(180deg, rgba(225,25,45,.06), #fff); }
.form-card.mode-yellow .form-body,
.form-card.mode-voluntario .form-body { background:linear-gradient(180deg, rgba(248,201,40,.13), #fff); }
.form-card.mode-sugestao .form-body { background:linear-gradient(180deg, rgba(21,58,151,.08), #fff); }
.form-card.mode-red .form-body,
.form-card.mode-yellow .form-body,
.form-card.mode-voluntario .form-body,
.form-card.mode-sugestao .form-body {
  background-size:180% 180%;
  animation: gradientMove 8s ease-in-out infinite;
}

@keyframes formGlint {
  0%, 52% { transform:translateX(-120%); }
  72%, 100% { transform:translateX(120%); }
}

@keyframes supportSwipe {
  0% { transform:translateX(-105%); opacity:0; }
  22% { opacity:.85; }
  100% { transform:translateX(105%); opacity:0; }
}

.form-subtabs { display:grid; grid-template-columns:1fr 1fr; border-bottom:1px solid rgba(7,13,31,.08); }
.form-subtab-btn {
  display:flex; align-items:center; justify-content:center; gap:.35rem; padding:.7rem;
  font-family:'Barlow Condensed',sans-serif; font-weight:700;
  font-size:.78rem; text-transform:uppercase; letter-spacing:.06em;
  cursor:pointer; border:none; background:var(--offwhite-2); color:rgba(7,13,31,.45);
  transition:all .2s;
}
.form-subtab-btn svg { width:13px; height:13px; flex-shrink:0; }
.form-subtab-btn.active { background:var(--yellow); color:var(--navy-950); font-weight:800; }
.form-card.mode-sugestao .form-subtab-btn.active { background:var(--blue); color:#fff; }
.form-subtab-btn:not(.active):hover { background:var(--offwhite-1); color:var(--navy-950); }

.form-body { padding:1.5rem 1.5rem 2rem; }
@media (min-width:640px) { .form-body { padding:2rem 2rem 2.5rem; } }

.form-pane { display:none; }
.form-pane.active {
  display:block;
  animation: paneIn .28s cubic-bezier(.22,1,.36,1);
}
@keyframes paneIn {
  from { opacity:0; transform:translateY(8px); }
  to { opacity:1; transform:translateY(0); }
}

.form-row { display:grid; gap:1rem; margin-bottom:1rem; }
@media (min-width:520px) { .form-row.two { grid-template-columns:1fr 1fr; } }

.form-group { display:flex; flex-direction:column; gap:.3rem; }

.form-label { font-size:.62rem; font-weight:700; text-transform:uppercase; letter-spacing:.14em; color:rgba(7,13,31,.5); }

.form-input,
.form-select,
.form-textarea {
  width:100%; border:1.5px solid rgba(7,13,31,.14); border-radius:6px;
  background:rgba(255,255,255,.92); color:var(--navy-950);
  font-family:'Manrope',sans-serif; font-size:.88rem;
  transition:border-color .2s, box-shadow .2s, transform .2s;
}
.form-input, .form-select { height:2.5rem; padding:0 .75rem; }
.form-textarea { min-height:6.5rem; padding:.65rem .75rem; resize:vertical; line-height:1.6; }
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline:none; border-color:var(--yellow); box-shadow:0 0 0 3px rgba(248,201,40,.2);
  transform:translateY(-1px);
}
.form-card.mode-red .form-input:focus,
.form-card.mode-red .form-select:focus,
.form-card.mode-red .form-textarea:focus {
  border-color:var(--red); box-shadow:0 0 0 3px rgba(192,57,43,.15);
}
.form-card.mode-yellow .form-input:focus,
.form-card.mode-yellow .form-select:focus,
.form-card.mode-yellow .form-textarea:focus {
  border-color:var(--yellow); box-shadow:0 0 0 3px rgba(248,201,40,.24), 0 8px 18px rgba(248,201,40,.08);
}
.form-card.mode-voluntario .form-input:focus,
.form-card.mode-voluntario .form-select:focus,
.form-card.mode-voluntario .form-textarea:focus {
  border-color:var(--yellow); box-shadow:0 0 0 3px rgba(248,201,40,.24), 0 8px 18px rgba(248,201,40,.08);
}
.form-card.mode-sugestao .form-input:focus,
.form-card.mode-sugestao .form-select:focus,
.form-card.mode-sugestao .form-textarea:focus {
  border-color:var(--blue); box-shadow:0 0 0 3px rgba(21,58,151,.18), 0 8px 18px rgba(21,58,151,.08);
}
.form-card.mode-sugestao #pane-sugestao .btn-yellow {
  background:var(--blue);
  color:#fff !important;
  border-color:var(--blue);
  box-shadow:0 10px 24px rgba(21,58,151,.22);
}
.form-input.err, .form-select.err, .form-textarea.err { border-color:var(--red); }

.form-err {
  font-size:.7rem; color:var(--red);
  display:flex; align-items:center; gap:.25rem; margin-top:.15rem;
}
.form-err svg { width:11px; height:11px; flex-shrink:0; }

.form-consent { margin:1rem 0 1.25rem; }
.form-consent label {
  display:flex; align-items:flex-start; gap:.5rem;
  font-size:.76rem; color:rgba(7,13,31,.62); line-height:1.55; cursor:pointer;
}
.form-consent input[type="checkbox"] {
  width:1rem; height:1rem; margin-top:.1rem;
  flex-shrink:0; accent-color:var(--yellow); cursor:pointer;
}
.form-card.mode-red .form-consent input[type="checkbox"] { accent-color:var(--red); }
.form-consent a { color:var(--blue); text-decoration:underline; }

.form-notice { margin-top:.75rem; font-size:.68rem; color:rgba(7,13,31,.38); line-height:1.6; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  position:relative;
  background:var(--navy-950);
  color:rgba(244,241,234,.65);
  border-top:0;
  overflow:hidden;
}
.site-footer::before {
  content:'';
  position:absolute;
  top:0;
  left:50%;
  width:min(72rem, calc(100% - 2rem));
  height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg, transparent, rgba(248,201,40,.7), rgba(21,58,151,.65), rgba(248,201,40,.7), transparent);
  box-shadow:0 0 18px rgba(248,201,40,.16);
  pointer-events:none;
}
.site-footer::after {
  content:none;
}

.footer-main {
  padding:2.5rem 0 3rem;
  display:flex; flex-direction:column; align-items:center; gap:1.5rem;
}
@media (min-width:768px) {
  .footer-main { flex-direction:row; justify-content:space-between; align-items:center; }
}

.footer-brand { display:flex; align-items:center; gap:.6rem; text-decoration:none; }
.footer-logo {
  width:34px; height:34px; border-radius:6px;
  border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.04);
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
.footer-logo img { width:100%; height:100%; object-fit:contain; }

.footer-name {
  font-family:'Barlow Condensed',sans-serif; font-weight:800;
  font-size:1rem; text-transform:uppercase; letter-spacing:.06em; color:var(--offwhite);
}

.footer-copy { font-size:.7rem; color:rgba(244,241,234,.38); line-height:1.6; text-align:center; }
@media (min-width:768px) { .footer-copy { text-align:left; } }

.footer-socials { display:flex; align-items:center; gap:.5rem; list-style:none; }
.footer-socials a {
  display:inline-flex; align-items:center; justify-content:center;
  width:2.1rem; height:2.1rem; border-radius:50%;
  border:1px solid rgba(255,255,255,.13); color:rgba(244,241,234,.6);
  transition:border-color .2s, color .2s, transform .2s; text-decoration:none;
}
.footer-socials a:hover { border-color:var(--yellow); color:var(--yellow); transform:translateY(-1px); }
.footer-socials a svg { width:14px; height:14px; }

.footer-bottom {
  padding:1.1rem 0; border-top:1px solid rgba(255,255,255,.05);
  text-align:center; font-size:.66rem; color:rgba(244,241,234,.28);
}
.footer-bottom strong { color:rgba(244,241,234,.48); }

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (max-width:640px) {
  .hero-bg::before,
  .hero-bg::after,
  .hero-img-wrap::before,
  .hero-img-wrap::after,
  .about-grid::before,
  .about-grid::after,
  .section-renovabr::before,
  .section-renovabr::after,
  .renovabr-grid::before,
  .section-investments::after,
  .inv-hero::before,
  .inv-hero::after {
    animation-duration:10s;
  }
  .proj-card { transition-duration:.55s; }
  .form-card::before { animation-duration:8s; }
}

/* ============================================================
   LEGAL MODAL
   ============================================================ */
.legal-modal {
  position: fixed;
  inset: 0;
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity .28s cubic-bezier(.22,1,.36,1);
}
.legal-modal.open {
  opacity: 1;
  pointer-events: auto;
}
.legal-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5,9,20,.78);
  backdrop-filter: blur(6px);
  cursor: pointer;
  pointer-events: none;
}
.legal-modal.open .legal-modal-backdrop {
  pointer-events: auto;
}
.legal-modal-box {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 680px;
  max-height: 88vh;
  background: linear-gradient(160deg, #0d1630, #0a1228);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 14px;
  box-shadow: 0 32px 80px rgba(0,0,0,.64), 0 0 0 1px rgba(255,255,255,.04);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: translateY(12px) scale(.97);
  transition: transform .3s cubic-bezier(.22,1,.36,1);
}
.legal-modal.open .legal-modal-box {
  transform: translateY(0) scale(1);
}
.legal-modal-close {
  position: absolute;
  top: .75rem;
  right: .75rem;
  z-index: 2;
  width: 2.2rem;
  height: 2.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(244,241,234,.7);
  cursor: pointer;
  transition: background .2s, color .2s;
}
.legal-modal-close:hover {
  background: rgba(255,255,255,.14);
  color: var(--offwhite);
}
.legal-modal-close svg { width: 1rem; height: 1rem; }

/* Tabs */
.legal-tabs {
  display: flex;
  border-bottom: 1px solid rgba(255,255,255,.08);
  flex-shrink: 0;
  padding: 0 1.5rem;
  gap: .25rem;
}
.legal-tab {
  position: relative;
  padding: 1rem 1.25rem .85rem;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: .82rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(244,241,234,.45);
  background: none;
  border: none;
  cursor: pointer;
  transition: color .2s;
}
.legal-tab::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0; right: 0;
  height: 2px;
  background: var(--yellow);
  border-radius: 2px 2px 0 0;
  transform: scaleX(0);
  transition: transform .22s cubic-bezier(.22,1,.36,1);
}
.legal-tab.active { color: var(--offwhite); }
.legal-tab.active::after { transform: scaleX(1); }
.legal-tab:hover:not(.active) { color: rgba(244,241,234,.72); }

/* Panes */
.legal-body {
  flex: 1 1 auto;
  position: relative;
  min-height: 0;
  display: flex;
}
.legal-pane {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .22s ease, transform .22s cubic-bezier(.22,1,.36,1);
  pointer-events: none;
  display: none;
}
.legal-pane.active {
  display: block;
  opacity: 1;
  transform: translateY(0);
}
.legal-modal.open .legal-pane.active {
  pointer-events: auto;
}
.legal-pane::-webkit-scrollbar { width: 8px; }
.legal-pane::-webkit-scrollbar-thumb {
  background: rgba(248,201,40,.35);
  border-radius: 4px;
}
.legal-pane::-webkit-scrollbar-track { background: rgba(255,255,255,.04); }
.legal-pane-inner {
  padding: 2rem 2rem 2.5rem;
}
.legal-doc-title {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: clamp(1.6rem, 4vw, 2.2rem);
  font-weight: 800;
  text-transform: uppercase;
  color: var(--offwhite);
  line-height: 1;
  margin: 0;
}
.legal-rule {
  height: 2px;
  border-radius: 2px;
  margin: .8rem 0 1.5rem;
  background: linear-gradient(90deg, var(--yellow), rgba(248,201,40,.3), transparent);
  width: 8rem;
}
.legal-content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.legal-content h3 {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(244,241,234,.9);
  margin: .5rem 0 0;
}
.legal-content p {
  font-size: .88rem;
  color: rgba(244,241,234,.55);
  line-height: 1.76;
  margin: 0;
}

/* Back button */
.legal-back-btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  margin-top: 2rem;
  padding: .55rem 1.1rem;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700;
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(244,241,234,.7);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 6px;
  cursor: pointer;
  transition: background .2s, color .2s, border-color .2s, transform .2s;
}
.legal-back-btn svg { width: 14px; height: 14px; }
.legal-back-btn:hover {
  background: rgba(255,255,255,.11);
  color: var(--offwhite);
  border-color: rgba(255,255,255,.22);
  transform: translateX(-3px);
}

/* Consent link style */
.form-consent a.legal-link {
  color: var(--blue-light);
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color .18s;
}
.form-consent a.legal-link:hover { color: var(--offwhite); }

@media (prefers-reduced-motion:reduce) {
  *,*::before,*::after {
    animation-duration:.01ms !important;
    animation-delay:0ms !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .reveal { opacity:1 !important; transform:none !important; }
  .hero-img-glow { animation:none !important; }
  .section-about::before { animation:none !important; }
}

/* ============================================================
   MOBILE OVERRIDES — focused on UX, density, fluidity
   ============================================================ */

/* Hide bg-word "MISSÃO" line break */
.badge-line-1, .badge-line-2 { display: inline; }
.badge-text strong.missao-yellow,
.missao-yellow { color: var(--yellow) !important; font-weight: 800; }

/* Mobile menu fluid stagger */
.mobile-menu .mobile-nav-link,
.mobile-menu .mobile-nav-actions > * {
  opacity: 0;
  transform: translateY(-14px);
  transition: opacity .42s cubic-bezier(.22,1,.36,1), transform .42s cubic-bezier(.22,1,.36,1);
}
.mobile-menu.open .mobile-nav-link,
.mobile-menu.open .mobile-nav-actions > * {
  opacity: 1;
  transform: translateY(0);
  transition-delay: calc(70ms + var(--menu-i, 0) * 55ms);
}

/* Contra "exibir mais" */
.contra-more-toggle,
.proj-more-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  margin: .5rem auto 0;
  padding: 0 0 .15rem;
  background: none;
  border: none;
  color: rgba(244,241,234,.7);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: color .2s, transform .2s, border-color .2s;
  border-bottom: 1px dashed rgba(244,241,234,.28);
}
.proj-more-toggle { color: rgba(244,241,234,.78); }
.contra-more-toggle:hover, .contra-more-toggle:active,
.proj-more-toggle:hover, .proj-more-toggle:active {
  color: var(--yellow);
  border-bottom-color: rgba(248,201,40,.55);
}
.contra-more-toggle:active, .proj-more-toggle:active { transform: scale(.96); }
.contra-more-toggle svg,
.proj-more-toggle svg {
  width: 14px; height: 14px;
  transition: transform .42s cubic-bezier(.22,1,.36,1);
}
.contra-layout.contra-expanded .contra-more-toggle svg,
.section-projects.proj-expanded .proj-more-toggle svg { transform: rotate(180deg); }
.contra-more-toggle .contra-more-label[data-more-label],
.proj-more-toggle .proj-more-label[data-more-label] {}

@media (max-width: 767px) {

  /* ===== HERO ===== */
  .hero-bg-word { display: none; }

  /* Center everything */
  .hero-inner {
    text-align: center;
    justify-items: center;
    place-items: center;
  }
  .hero-content {
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 1.1rem 0 .85rem;
    margin-left: auto;
    margin-right: auto;
    max-width: 24rem;
    width: 100%;
  }
  .hero-title { margin-left: auto; margin-right: auto; }
  .hero-img-col { margin-left: auto; margin-right: auto; justify-content: center !important; }
  .hero-badge { display: none !important; }
  .hero-desc {
    display: block;
    font-size: .85rem;
    line-height: 1.6;
    margin-top: 1rem;
    max-width: 22rem;
    padding: 0 .25rem;
    color: rgba(244,241,234,.82);
  }
  .hero-rule { margin-left: auto; margin-right: auto; }
  .hero-ctas { justify-content: center; margin-top: 1.25rem; }
  .hero-title { white-space: normal; }

  /* Image respects border-radius and the wrap shape */
  .hero-img-col { width: 100%; }
  .hero-img-wrap {
    overflow: visible;
    max-width: 280px;
    margin: 0 auto;
  }
  .hero-img {
    width: 100%;
    height: 100%;
    margin-top: 0;
    object-fit: cover;
    object-position: center top;
    border-radius: 22px;
    animation: heroFloat 6s ease-in-out infinite;
  }
  /* Bigger, more visible contour that moves with the image */
  .hero-img-wrap::before {
    inset: -1.05rem;
    border-radius: 26px;
    border: 1.5px solid rgba(248,201,40,.55);
    box-shadow:
      0 22px 48px rgba(0,0,0,.36),
      0 0 0 1px rgba(248,201,40,.32),
      inset 0 1px 0 rgba(255,255,255,.16),
      0 0 32px rgba(248,201,40,.18);
    opacity: 1;
    animation: heroFloat 6s ease-in-out infinite;
  }

  /* ===== SOBRE — remove image, soften section transition ===== */
  .section-about {
    padding: 0;
    background:
      linear-gradient(180deg, var(--navy-950) 0%, rgba(255,255,255,.97) 14%, #fff 28%, #fff 100%);
  }
  .about-img-col { display: none !important; }
  .section-about .about-grid {
    grid-template-columns: 1fr !important;
    max-width: 30rem !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 1.4rem !important;
    padding-right: 1.4rem !important;
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .about-content { text-align: left; }
  /* breathing room on body — let bg show on sides */
  .section-about + * { position: relative; }

  /* ===== ALLIANCE BAND — slightly bigger ===== */
  .alliance-band { padding: 0; }
  .alliance-inner {
    padding: 2.4rem 0 2.2rem !important;
    gap: 1rem !important;
  }
  .alliance-equation { font-size: 1.05rem; gap: .55rem; }
  .alliance-token, .alliance-result { font-size: 1.35rem; }
  .alliance-sign { font-size: 1.15rem; }
  .alliance-logos img,
  .alliance-logos svg { max-height: 1.7rem; }

  /* ===== RENOVABR — compact + closer to next section ===== */
  .section-renovabr {
    padding-bottom: 0;
  }
  .renovabr-grid {
    padding: 2.4rem 0 2rem;
    gap: 1.2rem;
  }
  .renovabr-media { max-width: 200px; margin: 0 auto; }
  .renovabr-img-wrap {
    aspect-ratio: 4 / 4.6;
    border-radius: 10px;
    box-shadow: 0 14px 28px rgba(21,58,151,.18), 0 0 0 3px rgba(21,58,151,.12);
    transition: transform .35s cubic-bezier(.22,1,.36,1), box-shadow .35s;
  }
  .renovabr-img-wrap:active { transform: translateY(-3px) scale(.99); }
  .renovabr-img-ring { box-shadow: inset 0 0 0 2px rgba(21,58,151,.32); border-radius: 10px; }
  .renovabr-img-wrap img { border-radius: 7px; }
  .renovabr-copy { text-align: center; padding: 0 .4rem; }
  .renovabr-title { font-size: clamp(1.7rem, 6.8vw, 2.2rem); }
  .renovabr-text { font-size: .9rem; }
  .renovabr-extra { font-size: .85rem; }
  /* BR floaters — corrected: white bg, blue letters, proportional */
  .renovabr-grid::before,
  .renovabr-grid::after,
  .renovabr-copy::before {
    width: 1.35rem !important;
    height: 1.35rem !important;
    font-size: .5rem !important;
    background: #fff !important;
    color: var(--blue) !important;
    border: 1px solid rgba(21,58,151,.35) !important;
    box-shadow: 0 6px 14px rgba(21,58,151,.16) !important;
  }
  .renovabr-grid::before { right: 4%; top: 1%; opacity: .8; }
  .renovabr-grid::after { left: 3%; bottom: 2%; opacity: .75; }
  .renovabr-copy::before { right: 0; top: -2.2rem; opacity: .85; }

  /* ===== FUI CONTRA — animated open & close ===== */
  .section-contra { padding-top: 0; padding-bottom: 0; }
  .contra-layout { padding: 1.6rem 0 1rem !important; gap: 1.2rem !important; }
  .contra-more-toggle { margin-top: .3rem !important; }
  .contra-cards {
    display: flex !important;
    flex-direction: column;
    gap: 0 !important;
    grid-template-columns: 1fr;
  }
  .contra-card + .contra-card { margin-top: .65rem; }
  .contra-card { padding: .85rem; transition: background .25s; }
  .contra-card:active { background: rgba(225,25,45,.06); }
  .contra-card-title { font-size: .92rem; }
  .contra-card-desc { font-size: .8rem; line-height: 1.5; }
  .contra-card:nth-child(n+3) {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    border-width: 0 !important;
    margin-top: 0 !important;
    transform: translateY(-6px);
    transition:
      max-height .5s cubic-bezier(.22,1,.36,1),
      opacity .35s ease,
      transform .35s cubic-bezier(.22,1,.36,1),
      padding .4s cubic-bezier(.22,1,.36,1),
      margin .35s,
      border-width .2s;
    pointer-events: none;
  }
  .contra-layout.contra-expanded .contra-card:nth-child(n+3) {
    max-height: 22rem;
    opacity: 1;
    padding: .85rem !important;
    border-width: 1px !important;
    margin-top: .65rem !important;
    transform: translateY(0);
    pointer-events: auto;
  }
  .contra-layout.contra-expanded .contra-card:nth-child(3) { transition-delay: 0s; }
  .contra-layout.contra-expanded .contra-card:nth-child(4) { transition-delay: .05s; }
  .contra-layout.contra-expanded .contra-card:nth-child(5) { transition-delay: .1s; }
  .contra-layout.contra-expanded .contra-card:nth-child(6) { transition-delay: .15s; }
  .contra-more-toggle { display: inline-flex; }
  .contra-img-wrap { width: clamp(13rem, 60vw, 17rem); margin: 0 auto; }
  .contra-img { aspect-ratio: 4 / 4.6; }

  /* ===== PROJECTS — "Fui contra" style cards on mobile ===== */
  .section-projects { padding: 0 0 2rem; }
  .projects-grid {
    display: flex !important;
    flex-direction: column;
    grid-template-columns: 1fr !important;
    gap: 0 !important;
    padding: 1.8rem 0 1.2rem;
    max-width: 24rem;
    margin-left: auto;
    margin-right: auto;
    perspective: none;
  }
  .proj-card + .proj-card { margin-top: .75rem; }
  /* Disable 3D flip on mobile — show a flat compact card */
  .proj-card {
    height: auto !important;
    min-height: 0 !important;
    transform: none !important;
    transition: transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s, border-color .25s;
    background: linear-gradient(135deg, rgba(248,201,40,.06), rgba(255,255,255,.025));
    border-radius: 10px;
    border: 1px solid rgba(248,201,40,.22);
    border-left: 3px solid rgba(248,201,40,.7);
    overflow: hidden;
    box-shadow: 0 8px 22px rgba(0,0,0,.28);
  }
  .proj-card.open { height: auto !important; }
  .proj-card:active {
    transform: translateY(-2px) scale(.99) !important;
    border-color: rgba(248,201,40,.5);
    box-shadow: 0 12px 28px rgba(0,0,0,.34), 0 0 16px rgba(248,201,40,.14);
  }
  .proj-card-inner {
    position: static !important;
    transform: none !important;
    transform-style: flat !important;
    display: flex;
    align-items: stretch;
    gap: 0;
  }
  .proj-card.open .proj-card-inner { transform: none !important; }
  .proj-card-front,
  .proj-body {
    position: relative !important;
    inset: auto !important;
    width: auto !important;
    height: auto !important;
    transform: none !important;
    backface-visibility: visible !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    overflow: visible !important;
  }
  .proj-card-front {
    display: grid !important;
    grid-template-columns: 5rem 1fr;
    gap: .85rem;
    align-items: center;
    padding: .65rem .9rem .65rem .65rem;
    width: 100% !important;
  }
  .proj-card-front::before, .proj-card-front::after { display: none !important; }
  .proj-card::before, .proj-card::after { display: none !important; }
  /* the back (proj-body) is collapsed on mobile */
  .proj-body { display: none !important; }
  /* hide accent line, number badge, flip toggle */
  .proj-accent { display: none !important; }
  .proj-num { display: none !important; }
  .proj-toggle { display: none !important; }
  .proj-card-front .proj-icon { display: none !important; }
  /* image thumbnail on the left */
  .proj-visual {
    grid-row: 1 / span 1;
    height: 4.6rem !important;
    width: 5rem;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid rgba(248,201,40,.28);
    background: linear-gradient(135deg, rgba(7,13,31,.96), rgba(59,36,94,.72)) !important;
  }
  .proj-visual::before, .proj-visual::after { display: none !important; }
  .proj-visual img {
    width: 100% !important;
    height: 100% !important;
    opacity: .92 !important;
    object-fit: cover !important;
  }
  /* the button becomes the text column */
  .proj-btn {
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    padding: 0 !important;
    gap: 0 !important;
    text-align: left;
    width: 100%;
    min-width: 0;
    background: transparent !important;
    border: 0 !important;
    cursor: default;
  }
  .proj-cat {
    order: 1;
    font-size: .54rem;
    letter-spacing: .14em;
    color: var(--yellow);
    background: rgba(248,201,40,.1);
    border-radius: 3px;
    padding: .14rem .42rem;
    margin: 0 !important;
    display: inline-block;
    text-transform: uppercase;
    font-weight: 700;
  }
  .proj-title {
    order: 2;
    font-family: 'Barlow Condensed', sans-serif;
    font-size: 1rem !important;
    font-weight: 700;
    text-transform: uppercase;
    line-height: 1.12 !important;
    color: var(--offwhite) !important;
    margin: .35rem 0 0 !important;
    padding: 0 !important;
  }
  .proj-btn::after {
    order: 3;
    content: attr(data-summary);
    font-size: .74rem !important;
    line-height: 1.45 !important;
    color: rgba(244,241,234,.62);
    margin: .35rem 0 0 !important;
    max-width: none !important;
    display: block;
  }

  /* show only 2 cards; rest collapse with smooth animation */
  .proj-card:nth-child(n+3) {
    max-height: 0;
    opacity: 0;
    overflow: hidden;
    margin: 0 !important;
    padding: 0 !important;
    border-width: 0 !important;
    transform: translateY(-6px);
    transition:
      max-height .55s cubic-bezier(.22,1,.36,1),
      opacity .4s ease,
      transform .4s cubic-bezier(.22,1,.36,1),
      margin .35s, padding .35s, border-width .2s;
    pointer-events: none;
  }
  .section-projects.proj-expanded .proj-card:nth-child(n+3) {
    max-height: 10rem;
    opacity: 1;
    border-width: 1px !important;
    border-left-width: 3px !important;
    margin-top: .75rem !important;
    transform: translateY(0);
    pointer-events: auto;
  }
  .section-projects.proj-expanded .proj-card:nth-child(3) { transition-delay: 0s; }
  .section-projects.proj-expanded .proj-card:nth-child(4) { transition-delay: .05s; }
  .section-projects.proj-expanded .proj-card:nth-child(5) { transition-delay: .1s; }
  .section-projects.proj-expanded .proj-card:nth-child(6) { transition-delay: .15s; }
  .proj-more-toggle {
    display: flex !important;
    margin: -.15rem auto 0 !important;
    align-self: center;
  }
  .section-projects > .container { text-align: center; }
  .projects-grid { padding-bottom: .35rem !important; }

  /* ===== MEDIA — lateral breathing room ===== */
  .media-inner { padding: 2.6rem 0 !important; }
  .container.media-inner,
  .section-media .container {
    padding-left: 1.4rem !important;
    padding-right: 1.4rem !important;
    max-width: 22rem !important;
  }
  .media-grid {
    grid-template-columns: 1fr !important;
    gap: .7rem;
    margin-top: 1.4rem;
  }
  .media-card {
    padding: .85rem 1rem;
    border-radius: 10px;
    transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s, border-color .3s;
  }
  .media-card:active { transform: translateY(-3px) scale(.99); border-color: rgba(248,201,40,.5); }
  .media-card-outlet { font-size: .56rem; }
  .media-card-title { font-size: .88rem; margin-top: .25rem; }
  .media-card-desc { font-size: .74rem; margin-top: .35rem; line-height: 1.45; }
  .media-card-cta { margin-top: .55rem; font-size: .72rem; }
  .media-channel-label { right: .65rem; bottom: .55rem; font-size: .5rem; }
  .media-grid::before, .media-grid::after { display: none; }

  /* ===== YOUTUBE — only 2 videos with lateral breathing ===== */
  .section-yt .yt-inner {
    padding: 2.6rem 1rem 3rem !important;
    max-width: 25rem !important;
  }
  .yt-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: .7rem;
    margin-top: 1.6rem;
  }
  .yt-card:nth-child(n+3) { display: none !important; }
  .yt-card { font-size: .78rem; transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s; }
  .yt-card:active { transform: translateY(-3px) scale(.99); box-shadow: 0 12px 26px rgba(0,0,0,.34); }
  .yt-thumb { aspect-ratio: 16 / 11; }
  .yt-play span { width: 2.6rem; height: 2.6rem; }
  .yt-play span svg { width: 15px; height: 15px; }
  .yt-info { padding: .65rem .75rem; }
  .yt-info-title { font-size: .82rem; line-height: 1.2; }
  .yt-cta { margin-top: 1.4rem; }
  .yt-grid::before, .yt-grid::after { display: none; }

  /* ===== FORM — compact but not squeezed ===== */
  .engage-inner { padding: 2.2rem 0 2.6rem !important; }
  .section-engage .container.engage-inner {
    padding-left: .85rem !important;
    padding-right: .85rem !important;
  }
  .form-card { margin: 1rem auto 0; max-width: 26rem; }
  .form-card form { padding: .85rem .9rem 1rem !important; }
  .form-card form > * { margin-top: .45rem !important; }
  .form-card label, .form-card legend { font-size: .7rem; }
  .form-card input, .form-card textarea, .form-card select {
    padding: .5rem .65rem !important;
    font-size: .85rem !important;
    border-radius: 6px !important;
  }
  .form-card textarea { min-height: 3.6rem !important; }
  .form-tab-btn { padding: .6rem !important; font-size: .78rem !important; }
  .form-subtabs { padding: .4rem !important; }
  .form-subtab-btn { padding: .45rem !important; font-size: .68rem !important; }
  .engage-title { font-size: clamp(1.6rem, 7vw, 2.1rem) !important; }
  .engage-desc { font-size: .82rem; margin-top: .5rem; }
  .engage-badge { font-size: .64rem; padding: .26rem .58rem; margin-top: .65rem; }
  .form-consent { font-size: .68rem !important; }
  .form-submit, .form-card button[type="submit"] {
    padding: .62rem 1rem !important;
    font-size: .82rem !important;
    margin-top: .55rem !important;
    transition: transform .15s, background .2s !important;
  }
  .form-submit:active, .form-card button[type="submit"]:active { transform: scale(.97); }
  .form-card input:focus, .form-card textarea:focus, .form-card select:focus {
    transform: translateY(-1px);
    transition: transform .18s, border-color .2s, box-shadow .2s;
  }

  /* ===== SOCIAL — 2x2 grid ===== */
  .social-inner { padding: 2.6rem 0 3rem; }
  .social-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: .7rem;
    margin-top: 1.6rem;
    max-width: 20rem;
  }
  .social-card {
    padding: 1rem .6rem;
    gap: .45rem;
    border-radius: 10px;
    transition: transform .25s cubic-bezier(.22,1,.36,1), background .25s, border-color .25s, box-shadow .25s;
  }
  .social-card:active {
    transform: translateY(-3px) scale(.97);
    background: rgba(248,201,40,.12);
    border-color: rgba(248,201,40,.55);
    box-shadow: 0 10px 22px rgba(0,0,0,.32);
  }
  .social-icon {
    width: 2rem; height: 2rem;
    transition: transform .25s cubic-bezier(.22,1,.36,1), background .25s;
  }
  .social-card:active .social-icon { transform: scale(1.12) rotate(-4deg); }
  .social-icon svg { width: 15px; height: 15px; }
  .social-label { font-size: .7rem; letter-spacing: .06em; }
  .social-title { font-size: clamp(1.6rem, 7vw, 2.1rem); }
  .social-desc { font-size: .82rem; margin-top: .55rem; }

  /* ===== Microinteractions on hero CTAs ===== */
  .hero-ctas .btn { transition: transform .2s cubic-bezier(.22,1,.36,1), box-shadow .2s, background .2s; }
  .hero-ctas .btn:active { transform: translateY(-2px) scale(.97); }

  /* General touch feedback on buttons */
  .btn, .nav-btn, .form-tab-btn, .form-subtab-btn, .menu-toggle {
    -webkit-tap-highlight-color: transparent;
  }
  .form-tab-btn:active, .form-subtab-btn:active { transform: scale(.97); transition: transform .15s; }
}
