/**
 * H360 — página estática Renewal DS2 (HTML/CSS/JS autossuficiente).
 * Tipografia: renewal-sitemap.css (--font-heading Ivy, --font-sans Area).
 *
 * Os antigos @import de swiper, área, ivy e renewal-sitemap foram movidos
 * para wp_enqueue_style separados em inc/enqueue.php (carregamento paralelo).
 */

:root {
  --layout-max: 1300px;
  --h360-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --h360-r-sm: 0.75rem;
  --h360-r-md: 1rem;
  --h360-r-lg: 1.25rem;
  --h360-shadow: 0 4px 16px rgb(0 0 0 / 0.06);
  --h360-shadow-hover: 0 12px 40px rgb(0 115 255 / 0.08);

  /* design_system2.html — hero overlay (mesmos stops que .ds2-hero__overlay) */
  --ds2-hero-overlay-a: rgb(238 246 255 / 0.85);
  --ds2-hero-overlay-b: rgb(255 255 255 / 0.6);
  --ds2-hero-overlay-c: rgb(0 115 255 / 0.04);
  --ds2-hero-overlay-d: rgb(240 249 255 / 0.7);
}

.h360-page {
  margin: 0;
  color: var(--renewal-text);
  background: #fff;
  font-family: var(--font-sans);
  line-height: 1.6;
  overflow-x: hidden;
}

/* Conteúdo abaixo da dobra: menos trabalho de layout/pintura fora da viewport */
.h360-intro,
.h360-cta-stripe,
.h360-palestrantes,
.h360-programacao,
.h360-lead {
  content-visibility: auto;
  contain-intrinsic-size: auto 640px;
}

.h360-footer {
  content-visibility: auto;
  contain-intrinsic-size: auto 320px;
}

.h360-page .tr-container--wide {
  max-width: var(--layout-max);
}

.h360-page .ds2-kicker {
  margin: 0 0 0.65rem;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--renewal-blue-soft);
}

.h360-page .ds2-kicker--on-dark {
  color: var(--renewal-green-accent);
}

.h360-page strong,
.h360-page b {
  font-weight: 600;
}

.h360-rail {
  box-sizing: border-box;
  max-width: var(--layout-max);
  width: min(100%, var(--layout-max));
  margin-inline: auto;
  padding-left: env(safe-area-inset-left, 0px);
  padding-right: env(safe-area-inset-right, 0px);
}

/* ─── Hero — keyframes espelhando design_system2.html (ds2-hero) ─── */
@keyframes h360-ds2-nebula-drift {
  0%,
  100% {
    transform: translate(0, 0) scale(1) rotate(0deg);
    opacity: 0.6;
  }
  25% {
    transform: translate(5%, -4%) scale(1.1) rotate(2deg);
    opacity: 0.75;
  }
  50% {
    transform: translate(-3%, 5%) scale(0.95) rotate(-1deg);
    opacity: 0.55;
  }
  75% {
    transform: translate(4%, 2%) scale(1.05) rotate(1deg);
    opacity: 0.7;
  }
}

@keyframes h360-ds2-morph-blob {
  0%,
  100% {
    border-radius: 42% 58% 70% 30% / 45% 45% 55% 55%;
  }
  25% {
    border-radius: 60% 40% 30% 70% / 50% 60% 40% 50%;
  }
  50% {
    border-radius: 30% 70% 50% 50% / 60% 30% 70% 40%;
  }
  75% {
    border-radius: 50% 50% 40% 60% / 35% 55% 45% 65%;
  }
}

/* Igual a design_system2.html @keyframes ds2-text-glow */
@keyframes h360-ds2-text-glow {
  0%,
  100% {
    text-shadow:
      0 0 40px rgb(0 115 255 / 0.2),
      0 0 80px rgb(80 160 255 / 0.1);
  }
  50% {
    text-shadow:
      0 0 60px rgb(0 115 255 / 0.3),
      0 0 100px rgb(80 160 255 / 0.15);
  }
}

@keyframes h360-ds2-fade-up {
  from {
    opacity: 0;
    transform: translateY(40px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ─── Hero: vídeo + capa editorial + dock inferior (vidro) + spotlight + grade ─── */
.h360-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 100vh;
  min-height: 100dvh;
  display: block;
  background-color: #020617;
}

.h360-hero__layers {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.h360-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.h360-hero__bg .h360-hero__video {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: 58% 42%;
  transform: scale(1.06);
  opacity: 1;
  filter: saturate(1.08) contrast(1.08) brightness(0.82);
  pointer-events: none;
}

.h360-hero__cinematic {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
  isolation: isolate;
  background-color: #22246a;
  background-image:
    radial-gradient(ellipse 100% 90% at 75% 25%, rgb(110 118 255 / 0.26), transparent 52%),
    radial-gradient(ellipse 80% 70% at 10% 90%, rgb(98 124 255 / 0.22), transparent 55%),
    radial-gradient(ellipse 45% 40% at 55% 55%, rgb(138 152 255 / 0.1), transparent 58%),
    linear-gradient(198deg, #2d307f 0%, #262a6f 35%, #22246a 65%, #171a48 100%);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.06),
    inset 0 -1px 0 rgb(0 0 0 / 0.5);
  opacity: 0.76;
  mix-blend-mode: normal;
}

.h360-hero__cinematic::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 38%;
  width: 170%;
  height: 170%;
  margin-left: -85%;
  margin-top: -85%;
  z-index: 0;
  pointer-events: none;
  opacity: 0.5;
  background:
    radial-gradient(circle at 35% 40%, rgb(0 115 255 / 0.2), transparent 44%),
    radial-gradient(circle at 68% 55%, rgb(120 190 255 / 0.12), transparent 42%),
    conic-gradient(
      from 190deg at 50% 50%,
      transparent 0deg,
      rgb(0 115 255 / 0.06) 52deg,
      transparent 105deg,
      rgb(74 222 128 / 0.04) 168deg,
      transparent 225deg,
      rgb(43 100 245 / 0.07) 292deg,
      transparent 360deg
    );
  animation: h360-cinematic-orbit 56s linear infinite;
}

.h360-hero__cinematic::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0.08;
  mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

@media (prefers-reduced-motion: no-preference) {
  .h360-hero__cinematic::after {
    animation: h360-cinematic-breathe 14s ease-in-out infinite;
  }
}

.h360-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  background: linear-gradient(
    118deg,
    rgb(34 36 98 / 0.9) 0%,
    rgb(52 56 132 / 0.54) 38%,
    rgb(92 116 224 / 0.28) 58%,
    rgb(29 32 84 / 0.86) 100%
  );
}

.h360-hero__nebula {
  position: absolute;
  inset: -22%;
  z-index: 3;
  pointer-events: none;
  mix-blend-mode: screen;
  background:
    radial-gradient(ellipse 48% 40% at 14% 24%, rgb(0 115 255 / 0.28), transparent 56%),
    radial-gradient(ellipse 44% 34% at 90% 16%, rgb(80 160 255 / 0.18), transparent 52%),
    radial-gradient(ellipse 38% 32% at 52% 90%, rgb(74 222 128 / 0.1), transparent 54%);
  filter: blur(48px);
  animation: h360-ds2-nebula-drift 28s ease-in-out infinite;
}

.h360-hero__blob {
  position: absolute;
  z-index: 4;
  pointer-events: none;
  mix-blend-mode: screen;
  opacity: 0.88;
  animation: h360-ds2-morph-blob 14s ease-in-out infinite;
  filter: blur(2px);
}

.h360-hero__blob--a {
  width: min(42vw, 380px);
  height: min(42vw, 380px);
  top: 4%;
  right: 2%;
  background: radial-gradient(circle at 42% 38%, rgb(0 115 255 / 0.16), rgb(80 160 255 / 0.08) 50%, transparent 72%);
  animation-delay: -3s;
}

.h360-hero__blob--b {
  width: min(32vw, 260px);
  height: min(32vw, 260px);
  bottom: 14%;
  left: 6%;
  background: radial-gradient(circle at 50% 50%, rgb(74 222 128 / 0.11), transparent 66%);
  animation-delay: -7s;
  animation-duration: 16s;
}

.h360-hero__vignette {
  position: absolute;
  inset: 0;
  z-index: 5;
  pointer-events: none;
  background: radial-gradient(
    ellipse 96% 84% at 58% 38%,
    transparent 0%,
    rgb(0 0 0 / 0.22) 52%,
    rgb(0 0 0 / 0.62) 100%
  );
}

/* Foco visual no quadrante do título (leitura) */
.h360-hero__spotlight {
  position: absolute;
  inset: 0;
  z-index: 6;
  pointer-events: none;
  background: radial-gradient(
    ellipse 85% 75% at 28% 48%,
    rgb(34 36 98 / 0.07) 0%,
    rgb(30 32 88 / 0.5) 55%,
    rgb(10 12 34 / 0.72) 100%
  );
}

.h360-hero__gridlines {
  position: absolute;
  inset: 0;
  z-index: 7;
  pointer-events: none;
  opacity: 0.055;
  background-image:
    linear-gradient(rgb(255 255 255 / 0.45) 1px, transparent 1px),
    linear-gradient(90deg, rgb(255 255 255 / 0.45) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(ellipse 90% 80% at 30% 45%, black 15%, transparent 75%);
}

.h360-hero__gridlines {
  display: none;
}

.h360-hero__foot-glow {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 8;
  height: 2px;
  border-radius: 999px;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgb(0 115 255 / 0.25) 18%,
    rgb(180 220 255 / 0.95) 48%,
    rgb(255 255 255 / 0.65) 50%,
    rgb(160 210 255 / 0.9) 52%,
    rgb(0 115 255 / 0.3) 82%,
    transparent 100%
  );
  box-shadow: 0 0 22px rgb(0 115 255 / 0.38);
}

@media (prefers-reduced-motion: no-preference) {
  .h360-hero__foot-glow {
    animation: h360-fusion-pulse 4.8s ease-in-out infinite;
  }
}

.h360-hero--reduced-motion .h360-hero__overlay {
  background: linear-gradient(118deg, rgb(15 23 42 / 0.92) 0%, rgb(15 23 42 / 0.78) 100%);
}

@media (prefers-reduced-motion: reduce) {
  .h360-hero__cinematic::before {
    animation: none;
  }

  .h360-hero__cinematic::after {
    animation: none;
  }

  .h360-hero__cinematic {
    opacity: 0.62;
  }

  .h360-hero__nebula {
    animation: none;
  }

  .h360-hero__blob {
    animation: none;
  }

  .h360-hero__foot-glow {
    animation: none;
  }
}

@media (max-width: 768px) and (prefers-reduced-motion: no-preference) {
  .h360-hero__nebula {
    filter: blur(34px);
    animation-duration: 36s;
  }

  .h360-hero__cinematic::after {
    animation: none;
    opacity: 0.07;
  }

  .h360-hero__gridlines {
    opacity: 0.03;
  }
}

@keyframes h360-hero-headline-line-in {
  from {
    opacity: 0;
    transform: translateY(1.1rem);
    filter: blur(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
  }
}

@keyframes h360-hero-line-glow-dark {
  0%,
  100% {
    text-shadow:
      0 0 28px rgb(0 115 255 / 0.38),
      0 2px 36px rgb(0 0 0 / 0.7),
      0 1px 2px rgb(255 255 255 / 0.22);
  }
  50% {
    text-shadow:
      0 0 44px rgb(80 160 255 / 0.45),
      0 2px 36px rgb(0 0 0 / 0.7),
      0 1px 2px rgb(255 255 255 / 0.28);
  }
}

@keyframes h360-hero-accent-flow {
  0%,
  100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

@keyframes h360-hero-accent-glow {
  0%,
  100% {
    filter: drop-shadow(0 0 16px rgb(0 115 255 / 0.55)) drop-shadow(0 0 36px rgb(80 160 255 / 0.28));
  }
  50% {
    filter: drop-shadow(0 0 26px rgb(0 115 255 / 0.85)) drop-shadow(0 0 52px rgb(100 180 255 / 0.4));
  }
}

@keyframes h360-hero-accent-text-pulse {
  0%,
  100% {
    text-shadow:
      0 0 40px rgb(0 115 255 / 0.55),
      0 0 85px rgb(80 160 255 / 0.28),
      0 2px 18px rgb(255 255 255 / 0.12);
  }
  50% {
    text-shadow:
      0 0 58px rgb(0 115 255 / 0.75),
      0 0 105px rgb(100 180 255 / 0.38),
      0 2px 18px rgb(255 255 255 / 0.18);
  }
}

/* Stage: coluna cheia + dock fixo no fluxo inferior */
.h360-hero__stage {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 100vh;
  min-height: 100dvh;
}

.h360-hero__inner {
  position: relative;
  z-index: 10;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: clamp(1.25rem, 3vw, 1.85rem);
  text-align: left;
  width: 100%;
  padding-block: clamp(4.2rem, 9vh, 6rem);
}

.h360-hero__kicker {
  margin: 0;
  max-width: 24rem;
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgb(148 200 255 / 0.95);
  text-shadow: 0 2px 24px rgb(0 0 0 / 0.6);
}

/* Título + H360 na mesma faixa, alinhados ao centro vertical */
.h360-hero__title-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: clamp(1.5rem, 4vw, 3.5rem);
  width: 100%;
}

.h360-hero__copy {
  display: flex;
  flex-direction: column;
  gap: clamp(1rem, 2.2vw, 1.35rem);
  min-width: 0;
}

.h360-hero__logo-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  align-self: center;
}

.h360-hero__logo {
  display: inline-block;
  padding-bottom: 0.38em;
  font-family: var(--font-sans);
  font-weight: 800;
  font-size: clamp(3.1rem, 11vw, 6.75rem);
  line-height: 1;
  letter-spacing: -0.055em;
  color: #f8fafc;
  user-select: none;
}

img.h360-hero__logo {
  display: block;
  width: 445px;
  max-width: min(42vw, 445px);
  height: auto;
  filter: drop-shadow(0 0 22px rgb(95 122 255 / 0.22)) drop-shadow(0 8px 28px rgb(0 0 0 / 0.35));
}

.h360-hero__headline {
  margin: 0;
  max-width: min(12em, 100%);
  font-family: var(--font-heading);
  font-weight: 300;
  font-size: clamp(2.35rem, 6.5vw, 4.75rem);
  line-height: 1.04;
  letter-spacing: -0.04em;
  color: #f8fafc;
  text-align: left;
  text-shadow: 0 3px 48px rgb(0 0 0 / 0.65);
}

@media (max-width: 767px) {
  .h360-rail {
    padding-left: calc(env(safe-area-inset-left, 0px) + clamp(1rem, 4vw, 1.25rem));
    padding-right: calc(env(safe-area-inset-right, 0px) + clamp(1rem, 4vw, 1.25rem));
  }

  .h360-page .tr-container,
  .h360-page .tr-container--wide {
    padding-left: calc(env(safe-area-inset-left, 0px) + clamp(1rem, 4vw, 1.25rem));
    padding-right: calc(env(safe-area-inset-right, 0px) + clamp(1rem, 4vw, 1.25rem));
  }

  .h360-hero__inner {
    align-items: center;
    text-align: center;
  }

  .h360-hero__kicker {
    margin-inline: auto;
    text-align: center;
  }

  .h360-hero__title-row {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: clamp(1.75rem, 5vw, 2.25rem);
  }

  .h360-hero__copy {
    align-items: center;
    text-align: center;
    order: 2;
  }

  .h360-hero__logo-wrap {
    order: 1;
  }

  .h360-hero__headline,
  .h360-hero__date {
    text-align: center;
  }

  .h360-hero__logo {
    font-size: clamp(3.25rem, 18vw, 5.25rem);
  }
}

.h360-hero__headline-line {
  display: block;
}

@media (prefers-reduced-motion: no-preference) {
  .h360-page .h360-hero__logo {
    animation: h360-ds2-fade-up 0.9s var(--h360-ease) both;
  }

  .h360-page .h360-hero__kicker {
    animation: h360-ds2-fade-up 0.85s var(--h360-ease) both;
  }

  .h360-page .h360-hero__headline-line:nth-child(1) {
    animation:
      h360-hero-headline-line-in 1s var(--h360-ease) both,
      h360-hero-line-glow-dark 5s ease-in-out 0.85s infinite;
  }

  .h360-page .h360-hero__headline-line:nth-child(2) {
    animation: h360-hero-headline-line-in 1s var(--h360-ease) 0.14s both;
  }

  .h360-page .h360-hero__headline-line:nth-child(3) {
    animation:
      h360-hero-headline-line-in 1s var(--h360-ease) 0.28s both,
      h360-hero-line-glow-dark 5s ease-in-out 1.1s infinite;
  }
}

.h360-hero__headline-accent {
  font-weight: 300;
  background: linear-gradient(
    100deg,
    var(--renewal-blue) 0%,
    rgb(100 180 255) 35%,
    var(--renewal-blue-mid) 65%,
    var(--renewal-blue) 100%
  );
  background-size: 220% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: var(--renewal-blue-soft);
}

@supports ((-webkit-background-clip: text) or (background-clip: text)) {
  .h360-hero__headline-accent {
    color: transparent;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .h360-hero__headline-accent {
    animation:
      h360-hero-accent-flow 10s ease-in-out infinite,
      h360-hero-accent-glow 4.5s ease-in-out infinite,
      h360-hero-accent-text-pulse 5s ease-in-out infinite;
  }
}

@media (prefers-reduced-motion: reduce) {
  .h360-hero__headline-accent {
    -webkit-text-fill-color: unset;
    color: var(--renewal-blue-soft);
    background: none;
    filter: none;
    text-shadow: 0 0 24px rgb(0 115 255 / 0.45);
  }
}

@media (prefers-reduced-motion: no-preference) {
  .h360-page .h360-hero__date {
    animation: h360-ds2-fade-up 1s var(--h360-ease) 0.5s both;
  }

  .h360-page .h360-countdown {
    animation: h360-ds2-fade-up 1s var(--h360-ease) 0.65s both;
  }
}

.h360-hero__date {
  font-family: var(--font-sans);
  font-size: clamp(1rem, 1.85vw, 1.2rem);
  font-weight: 400;
  line-height: 1.5;
  color: rgb(226 232 240 / 0.92);
  text-align: left;
  max-width: 36rem;
  margin: 0;
  text-shadow: 0 2px 24px rgb(0 0 0 / 0.55);
}

/* Contador inline: solto no background, CTA abaixo */
.h360-hero .h360-countdown {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: clamp(0.8rem, 1.8vw, 1.1rem);
  width: min(100%, 50rem);
  margin-top: clamp(0.85rem, 2vw, 1.3rem);
}

.h360-hero .h360-countdown__items {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(0.75rem, 2.5vw, 2rem);
  justify-content: flex-start;
  flex: 1 1 auto;
}

.h360-hero .h360-countdown__item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 3.75rem;
  padding: 0.35rem 0.65rem 0.5rem 0;
  border-left: 2px solid rgb(0 115 255 / 0.55);
  padding-left: 0.85rem;
}

.h360-hero .h360-countdown__num {
  font-family: var(--font-sans);
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  font-size: clamp(1.6rem, 3.8vw, 2.5rem);
  line-height: 1;
  color: #f1f5f9;
  text-shadow:
    0 0 22px rgb(0 115 255 / 0.45),
    0 2px 14px rgb(0 0 0 / 0.5);
}

.h360-hero .h360-countdown__label {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgb(203 213 225 / 0.88);
  margin-top: 0.4rem;
  text-shadow: 0 1px 10px rgb(0 0 0 / 0.45);
}

@media (max-width: 640px) {
  .h360-hero .h360-countdown {
    align-items: center;
    width: 100%;
  }

  .h360-hero .h360-countdown__items {
    justify-content: center;
    width: 100%;
  }

  .h360-hero .h360-countdown__item {
    flex: 1;
    align-items: center;
    border-left: none;
    border-top: 2px solid rgb(0 115 255 / 0.45);
    padding: 0.65rem 0.25rem 0.35rem;
    text-align: center;
  }

  .h360-hero .h360-btn--primary {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 1024px) {
  img.h360-hero__logo {
    width: 360px;
    max-width: min(50vw, 360px);
  }
}


/* ─── Botões ─── */
.h360-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.85rem 1.5rem;
  border-radius: 50px;
  font-family: var(--font-sans);
  font-size: 0.9rem;
  font-weight: 600;
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, border-color 0.2s;
}

.h360-btn:hover {
  text-decoration: none;
}

.h360-btn--primary {
  background: var(--renewal-blue);
  color: #fff;
}

.h360-btn--primary:hover {
  background: #0060d6;
  color: #fff;
}

.h360-hero .h360-btn--primary {
  box-shadow:
    0 4px 28px rgb(0 115 255 / 0.48),
    0 0 0 1px rgb(255 255 255 / 0.14) inset;
}

.h360-hero .h360-btn--primary:hover {
  box-shadow:
    0 6px 40px rgb(0 115 255 / 0.58),
    0 0 0 1px rgb(255 255 255 / 0.2) inset;
}

.h360-btn--on-dark {
  background: #fff;
  color: var(--renewal-blue);
  border-color: rgb(255 255 255 / 0.45);
}

.h360-btn--on-dark:hover {
  background: rgb(255 255 255 / 0.92);
  color: var(--renewal-blue-mid);
}

/* ─── Intro — layout editorial (referência print: 2 colunas, serif + sans, caixa #f0f7ff, oval inclinada) ─── */
.h360-intro.h360-intro--editorial {
  --h360-intro-ink: #1a1a1a;
  --h360-intro-body: #333;
  --h360-intro-accent: #3a86ff;
  --h360-intro-box-bg: #f0f7ff;
}

.h360-intro--editorial {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding-block: clamp(3.25rem, 7vw, 5.5rem);
  color: var(--h360-intro-ink);
  background: #fff;
}

.h360-intro--editorial .h360-intro__shell {
  position: relative;
  z-index: 1;
}

.h360-intro .h360-reveal {
  transition:
    opacity 0.85s var(--h360-ease) calc(var(--i, 0) * 0.1s),
    transform 0.85s var(--h360-ease) calc(var(--i, 0) * 0.1s);
}

.h360-intro__layout {
  display: grid;
  gap: clamp(2rem, 5vw, 3rem);
  align-items: center;
}

@media (min-width: 960px) {
  .h360-intro__layout {
    grid-template-columns: minmax(0, 1.12fr) minmax(0, 0.76fr);
    gap: clamp(1.75rem, 4vw, 3rem);
  }

  .h360-intro__col--media {
    margin-left: clamp(-0.25rem, -1.5vw, -1rem);
  }
}

.h360-intro__col--copy {
  min-width: 0;
}

.h360-intro__title {
  font-family: var(--font-heading);
  font-weight: 400;
  font-size: clamp(2rem, 4.2vw, 3rem);
  line-height: 1.12;
  letter-spacing: -0.02em;
  color: var(--h360-intro-ink);
  text-align: left;
  margin: 0 0 clamp(1.25rem, 2.6vw, 1.75rem);
  max-width: 17em;
}

.h360-intro__title-accent {
  color: var(--h360-intro-accent);
}

.h360-intro__title-rest {
  color: var(--h360-intro-ink);
}

.h360-intro__body {
  margin-bottom: clamp(1.35rem, 2.8vw, 1.9rem);
}

.h360-intro__body p {
  margin: 0 0 1.125rem;
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.62;
  color: var(--h360-intro-body);
  max-width: 36rem;
}

.h360-intro__body p:last-child {
  margin-bottom: 0;
}

.h360-intro__highlight {
  background: var(--h360-intro-box-bg);
  border-radius: 28px;
  padding: clamp(1.35rem, 2.6vw, 2.125rem) clamp(1.35rem, 2.8vw, 2.5rem);
  max-width: 36rem;
  border: 1px solid rgb(58 134 255 / 0.08);
  box-shadow: inset 0 1px 0 rgb(255 255 255 / 0.9);
}

.h360-intro__highlight-list {
  margin: 0;
  padding: 0 0 0 1.2rem;
  list-style-type: disc;
  font-family: var(--font-sans);
  font-size: 0.9375rem;
  line-height: 1.58;
  color: var(--h360-intro-body);
}

.h360-intro__highlight-list li {
  margin-bottom: 0.9rem;
  padding-left: 0.3rem;
}

.h360-intro__highlight-list li:last-child {
  margin-bottom: 0;
}

.h360-intro__highlight-list strong {
  color: var(--h360-intro-ink);
  font-weight: 600;
}

.h360-intro__col--media {
  display: flex;
  justify-content: center;
  align-items: center;
}

@media (min-width: 960px) {
  .h360-intro__col--media {
    justify-content: flex-end;
  }
}

.h360-intro__figure {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  max-width: 100%;
}

@media (min-width: 960px) {
  .h360-intro__figure {
    align-items: center;
  }
}

.h360-intro__caption {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
  padding: 0.72rem 1.1rem 0.78rem;
  border-radius: 999px;
  border: 1px solid rgb(58 134 255 / 0.22);
  background: linear-gradient(160deg, rgb(255 255 255 / 0.92) 0%, rgb(240 247 255 / 0.96) 100%);
  box-shadow:
    0 10px 26px rgb(58 134 255 / 0.14),
    inset 0 1px 0 rgb(255 255 255 / 0.95);
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--renewal-blue-mid);
  text-align: center;
  max-width: 20rem;
  line-height: 1.35;
}

.h360-intro__caption-name {
  font-size: 1.02rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--renewal-blue-mid);
}

.h360-intro__caption-role {
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: color-mix(in srgb, var(--renewal-blue-mid) 86%, #64748b);
}

@media (min-width: 960px) {
  .h360-intro__caption {
    align-items: center;
    text-align: center;
  }
}

.h360-intro__oval {
  position: relative;
  width: min(94vw, 520px);
  aspect-ratio: 1 / 1.12;
  border-radius: 50%;
  transform: rotate(14deg);
  overflow: hidden;
  box-shadow:
    0 28px 52px rgb(58 134 255 / 0.14),
    0 10px 28px rgb(0 0 0 / 0.07);
}

.h360-intro__oval-inner {
  position: absolute;
  inset: -8%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.h360-intro__oval-inner img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center center;
  transform: rotate(-14deg) scale(1.12);
  transform-origin: center center;
}

@media (prefers-reduced-motion: reduce) {
  .h360-intro__oval {
    transform: none;
  }

  .h360-intro__oval-inner img {
    transform: scale(1.06);
    object-position: center center;
  }
}

/* ─── Faixa CTA azul — efeito UAU (mesma cor base: --renewal-blue) ─── */
@keyframes h360-cta-atmosphere {
  0%,
  100% {
    opacity: 0.45;
    transform: scale(1) translate(0, 0);
  }
  40% {
    opacity: 0.62;
    transform: scale(1.03) translate(1%, -1%);
  }
  70% {
    opacity: 0.52;
    transform: scale(0.99) translate(-0.5%, 0.5%);
  }
}

@keyframes h360-cta-sheen {
  0%,
  100% {
    background-position: 0% 50%, center center;
    opacity: 0.22;
  }
  50% {
    background-position: 100% 50%, center center;
    opacity: 0.38;
  }
}

.h360-cta-stripe {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background-color: var(--renewal-blue);
  color: #fff;
  padding-block: clamp(2.25rem, 5vw, 3.25rem);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.14),
    inset 0 -1px 0 rgb(0 0 0 / 0.12);
}

.h360-cta-stripe::before {
  content: "";
  position: absolute;
  inset: -20%;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 55% 90% at 12% 45%, rgb(255 255 255 / 0.18), transparent 52%),
    radial-gradient(ellipse 50% 85% at 92% 55%, rgb(0 60 200 / 0.28), transparent 48%),
    radial-gradient(ellipse 40% 70% at 50% 100%, rgb(80 170 255 / 0.12), transparent 55%);
  filter: blur(2px);
}

.h360-cta-stripe::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background-image:
    linear-gradient(
      100deg,
      transparent 0%,
      rgb(255 255 255 / 0.14) 42%,
      rgb(255 255 255 / 0.22) 50%,
      rgb(255 255 255 / 0.14) 58%,
      transparent 100%
    ),
    url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200% 100%, auto;
  background-position: 0% 50%, center center;
  background-blend-mode: normal, overlay;
  mix-blend-mode: soft-light;
  opacity: 0.85;
}

@media (prefers-reduced-motion: no-preference) {
  .h360-cta-stripe::before {
    animation: h360-cta-atmosphere 14s ease-in-out infinite;
  }

  .h360-cta-stripe::after {
    animation: h360-cta-sheen 9s ease-in-out infinite;
  }
}

@media (prefers-reduced-motion: reduce) {
  .h360-cta-stripe::before,
  .h360-cta-stripe::after {
    animation: none;
    opacity: 0.55;
  }
}

.h360-cta-stripe__inner {
  position: relative;
  z-index: 2;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}

.h360-cta-stripe h2 {
  font-family: var(--font-heading);
  font-weight: 300;
  font-size: clamp(1.2rem, 2.2vw, 1.55rem);
  line-height: 1.25;
  margin: 0;
  max-width: 40rem;
  color: #fff;
  text-shadow:
    0 1px 2px rgb(0 0 0 / 0.12),
    0 0 40px rgb(255 255 255 / 0.08);
}

.h360-cta-stripe .h360-btn--on-dark {
  flex-shrink: 0;
  box-shadow:
    0 2px 12px rgb(0 0 0 / 0.12),
    0 0 0 1px rgb(255 255 255 / 0.2) inset;
  transition:
    transform 0.28s var(--h360-ease),
    box-shadow 0.28s var(--h360-ease),
    background 0.2s,
    color 0.2s;
}

@media (prefers-reduced-motion: no-preference) {
  .h360-cta-stripe .h360-btn--on-dark:hover {
    transform: translateY(-3px);
    box-shadow:
      0 10px 28px rgb(0 0 0 / 0.18),
      0 0 0 1px rgb(255 255 255 / 0.35) inset,
      0 0 32px rgb(255 255 255 / 0.12);
  }
}

.h360-cta-stripe .h360-btn--on-dark:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 3px var(--renewal-blue),
    0 0 0 6px rgb(255 255 255 / 0.95),
    0 6px 20px rgb(0 0 0 / 0.15);
}

/* ─── Palestrantes (cinemático) ─── */
@keyframes h360-cinematic-orbit {
  to {
    transform: rotate(360deg);
  }
}

@keyframes h360-cinematic-breathe {
  0%,
  100% {
    opacity: 0.075;
  }
  50% {
    opacity: 0.11;
  }
}

@keyframes h360-fusion-pulse {
  0%,
  100% {
    opacity: 0.75;
    box-shadow:
      0 0 18px rgb(0 115 255 / 0.35),
      0 0 42px rgb(0 115 255 / 0.14);
  }
  50% {
    opacity: 1;
    box-shadow:
      0 0 26px rgb(0 115 255 / 0.5),
      0 0 64px rgb(0 115 255 / 0.2);
  }
}

.h360-palestrantes,
.h360-lead {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background-color: #070b12;
  background-image:
    radial-gradient(ellipse 125% 88% at 8% 12%, rgb(0 115 255 / 0.3), transparent 54%),
    radial-gradient(ellipse 105% 82% at 96% 88%, rgb(43 100 245 / 0.2), transparent 56%),
    radial-gradient(ellipse 50% 38% at 68% 46%, rgb(74 222 128 / 0.09), transparent 58%),
    linear-gradient(172deg, #0f172a 0%, #111827 24%, #0c1422 50%, #111827 74%, #070b12 100%);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.07),
    inset 0 -1px 0 rgb(0 0 0 / 0.45);
}

.h360-palestrantes {
  padding-block: clamp(2.75rem, 7vw, 4.75rem);
}

.h360-palestrantes {
  background-color: #1a1b4a;
  background-image:
    radial-gradient(ellipse 125% 88% at 8% 12%, rgb(90 96 255 / 0.32), transparent 54%),
    radial-gradient(ellipse 105% 82% at 96% 88%, rgb(76 109 255 / 0.24), transparent 56%),
    radial-gradient(ellipse 50% 38% at 68% 46%, rgb(74 222 128 / 0.09), transparent 58%),
    linear-gradient(172deg, #252768 0%, #1f215a 24%, #1a1b4a 50%, #181946 74%, #121336 100%);
}

.h360-lead {
  padding-block: clamp(3rem, 8vw, 5.25rem);
}

.h360-lead {
  background-color: #1a1b4a;
  background-image:
    radial-gradient(ellipse 125% 88% at 8% 12%, rgb(90 96 255 / 0.32), transparent 54%),
    radial-gradient(ellipse 105% 82% at 96% 88%, rgb(76 109 255 / 0.24), transparent 56%),
    radial-gradient(ellipse 50% 38% at 68% 46%, rgb(74 222 128 / 0.09), transparent 58%),
    linear-gradient(172deg, #252768 0%, #1f215a 24%, #1a1b4a 50%, #181946 74%, #121336 100%);
}

.h360-palestrantes::before,
.h360-lead::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 42%;
  width: 160%;
  height: 160%;
  margin-left: -80%;
  margin-top: -80%;
  z-index: 0;
  pointer-events: none;
  opacity: 0.55;
  background:
    radial-gradient(circle at 30% 35%, rgb(0 115 255 / 0.22), transparent 42%),
    radial-gradient(circle at 72% 58%, rgb(120 190 255 / 0.14), transparent 40%),
    conic-gradient(
      from 200deg at 50% 50%,
      transparent 0deg,
      rgb(0 115 255 / 0.07) 55deg,
      transparent 110deg,
      rgb(74 222 128 / 0.05) 165deg,
      transparent 220deg,
      rgb(43 100 245 / 0.08) 285deg,
      transparent 360deg
    );
  animation: h360-cinematic-orbit 56s linear infinite;
}

.h360-lead::before {
  background:
    radial-gradient(circle at 30% 35%, rgb(90 96 255 / 0.24), transparent 42%),
    radial-gradient(circle at 72% 58%, rgb(145 156 255 / 0.16), transparent 40%),
    conic-gradient(
      from 200deg at 50% 50%,
      transparent 0deg,
      rgb(90 96 255 / 0.08) 55deg,
      transparent 110deg,
      rgb(74 222 128 / 0.05) 165deg,
      transparent 220deg,
      rgb(76 109 255 / 0.1) 285deg,
      transparent 360deg
    );
}

.h360-palestrantes::before {
  background:
    radial-gradient(circle at 30% 35%, rgb(90 96 255 / 0.24), transparent 42%),
    radial-gradient(circle at 72% 58%, rgb(145 156 255 / 0.16), transparent 40%),
    conic-gradient(
      from 200deg at 50% 50%,
      transparent 0deg,
      rgb(90 96 255 / 0.08) 55deg,
      transparent 110deg,
      rgb(74 222 128 / 0.05) 165deg,
      transparent 220deg,
      rgb(76 109 255 / 0.1) 285deg,
      transparent 360deg
    );
}

.h360-palestrantes::after,
.h360-lead::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.075;
  mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

@media (prefers-reduced-motion: no-preference) {
  .h360-palestrantes::after,
  .h360-lead::after {
    animation: h360-cinematic-breathe 14s ease-in-out infinite;
  }
}

@media (prefers-reduced-motion: reduce) {
  .h360-palestrantes::before,
  .h360-lead::before {
    animation: none;
  }
  .h360-palestrantes::after,
  .h360-lead::after {
    animation: none;
  }
}

.h360-palestrantes__inner,
.h360-lead__inner {
  position: relative;
  z-index: 2;
}

.h360-palestrantes__fusion,
.h360-lead__fusion,
.h360-hero__fusion {
  position: relative;
  z-index: 2;
  margin: 0 auto clamp(0.25rem, 1.5vw, 0.75rem);
  margin-bottom: clamp(1.25rem, 3.5vw, 2.25rem);
  width: min(56rem, calc(100% - clamp(2.5rem, 8vw, 5.5rem)));
  height: 2px;
  border-radius: 999px;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgb(0 115 255 / 0.25) 18%,
    rgb(180 220 255 / 0.95) 48%,
    rgb(255 255 255 / 0.65) 50%,
    rgb(160 210 255 / 0.9) 52%,
    rgb(0 115 255 / 0.3) 82%,
    transparent 100%
  );
  box-shadow: 0 0 18px rgb(0 115 255 / 0.35);
}

.h360-lead__fusion {
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgb(90 96 255 / 0.28) 18%,
    rgb(186 192 255 / 0.95) 48%,
    rgb(255 255 255 / 0.65) 50%,
    rgb(170 178 255 / 0.9) 52%,
    rgb(90 96 255 / 0.34) 82%,
    transparent 100%
  );
  box-shadow: 0 0 18px rgb(90 96 255 / 0.38);
}

.h360-palestrantes__fusion {
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgb(90 96 255 / 0.28) 18%,
    rgb(186 192 255 / 0.95) 48%,
    rgb(255 255 255 / 0.65) 50%,
    rgb(170 178 255 / 0.9) 52%,
    rgb(90 96 255 / 0.34) 82%,
    transparent 100%
  );
  box-shadow: 0 0 18px rgb(90 96 255 / 0.38);
}

@media (prefers-reduced-motion: no-preference) {
  .h360-palestrantes__fusion,
  .h360-lead__fusion,
  .h360-hero__fusion {
    animation: h360-fusion-pulse 4.8s ease-in-out infinite;
  }
}

.h360-palestrantes .ds2-kicker--on-dark,
.h360-lead .ds2-kicker--on-dark {
  color: var(--renewal-green-accent);
  margin-bottom: 0.35rem;
}

.h360-palestrantes .tr-advisors__head,
.h360-lead .tr-advisors__head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: flex-start;
  margin-bottom: clamp(2rem, 4vw, 3rem);
}

.h360-lead .tr-advisors__head {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
}

@media (max-width: 767px) {
  .h360-palestrantes .tr-advisors__head,
  .h360-lead .tr-advisors__head {
    grid-template-columns: 1fr;
  }
}

.h360-palestrantes .tr-advisors__title,
.h360-lead .tr-advisors__title {
  margin: 0;
  font-weight: 300;
  line-height: 1.12;
  color: #fff;
}

.h360-palestrantes .tr-advisors__kicker,
.h360-lead .tr-advisors__kicker {
  display: block;
  margin-bottom: 0.35rem;
  font-family: var(--font-sans) !important;
  font-weight: 400;
  font-size: clamp(1.15rem, 2.2vw, 1.5rem);
  letter-spacing: -0.02em;
  color: rgb(255 255 255 / 0.92);
}

.h360-palestrantes .tr-advisors__display,
.h360-lead .tr-advisors__display {
  display: block;
  font-family: var(--font-heading) !important;
  font-weight: 300;
  font-size: clamp(2.15rem, 4.5vw, 3.35rem);
  letter-spacing: -0.02em;
  color: #fff;
}

.h360-palestrantes .tr-advisors__intro p,
.h360-lead .tr-advisors__intro p {
  margin: 0 0 1rem;
  max-width: 34rem;
  font-size: clamp(0.875rem, 1.25vw, 0.9375rem);
  line-height: 1.65;
  color: rgb(255 255 255 / 0.72);
}

.h360-lead .tr-advisors__intro {
  margin-top: 0;
}

.h360-palestrantes .tr-advisors__link,
.h360-lead .tr-advisors__link {
  display: inline-block;
  font-size: 0.875rem;
  font-weight: 500;
  color: #fff;
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.h360-palestrantes .tr-advisors__link:hover,
.h360-lead .tr-advisors__link:hover {
  color: rgb(255 255 255 / 0.88);
}

.h360-speaker-swiper-wrap {
  position: relative;
  margin-bottom: clamp(1.25rem, 3vw, 1.85rem);
}

.h360-speaker-swiper .swiper-slide {
  height: auto;
}

.h360-speaker-card {
  text-align: center;
}

.h360-speaker-card img {
  display: block;
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center top;
  border-radius: var(--h360-r-lg);
  border: 1px solid rgb(0 115 255 / 0.12);
  box-shadow: var(--h360-shadow);
}

.h360-speaker-card p {
  margin: 0.65rem 0 0;
  font-family: var(--font-sans);
  font-size: clamp(0.8rem, 1.05vw, 0.9rem);
  line-height: 1.35;
  color: rgb(255 255 255 / 0.88);
}

.h360-speaker-card__handle {
  display: block;
  margin-top: 0.2rem;
  font-size: 0.85em;
  opacity: 0.85;
}

.h360-speaker-footer {
  display: flex;
  flex-direction: column;
  gap: 1.15rem;
  margin-top: 0.5rem;
}

@media (min-width: 640px) {
  .h360-speaker-footer {
    flex-direction: row;
    align-items: center;
  }
  .h360-speaker-footer__rule {
    flex: 1;
    height: 1px;
    background: rgb(255 255 255 / 0.16);
  }
}

@media (max-width: 639px) {
  .h360-speaker-footer__rule {
    width: 100%;
    height: 1px;
    background: rgb(255 255 255 / 0.16);
  }
}

.h360-speaker-nav {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
}

.h360-speaker-nav button {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgb(255 255 255 / 0.26);
  background: transparent;
  color: rgb(255 255 255 / 0.82);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}

.h360-speaker-nav button:last-child {
  background: rgb(255 255 255 / 0.09);
  border-color: rgb(255 255 255 / 0.34);
}

.h360-speaker-nav button:hover {
  color: #fff;
  border-color: rgb(255 255 255 / 0.4);
}

.h360-speaker-progress {
  display: none;
}

.h360-speaker-progress__bar {
  display: none;
}

/* ─── Programação (gradiente claro DS2) ─── */
@keyframes h360-prog-nebula {
  0%,
  100% {
    transform: translate(0, 0) scale(1) rotate(0deg);
    opacity: 0.65;
  }
  50% {
    transform: translate(-2%, 3%) scale(1.05) rotate(-1deg);
    opacity: 0.78;
  }
}

.h360-programacao {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding-block: clamp(3.25rem, 9vw, 5.75rem);
  background: linear-gradient(180deg, #e3f0ff 0%, #f5f9ff 18%, #fff 48%, #fafdff 72%, #eef6ff 100%);
}

.h360-programacao::before {
  content: "";
  position: absolute;
  inset: -18%;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 52% 42% at 10% 22%, rgb(0 115 255 / 0.1), transparent 56%),
    radial-gradient(ellipse 48% 36% at 88% 14%, rgb(80 160 255 / 0.08), transparent 52%),
    radial-gradient(ellipse 42% 34% at 50% 88%, rgb(74 222 128 / 0.055), transparent 54%);
  filter: blur(56px);
  animation: h360-prog-nebula 26s ease-in-out infinite;
}

.h360-programacao::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: 0.038;
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

@media (prefers-reduced-motion: reduce) {
  .h360-programacao::before {
    animation: none;
  }
}

.h360-programacao__inner {
  position: relative;
  z-index: 2;
}

.h360-programacao .ds2-kicker {
  text-align: center;
  margin: 0 auto 0.35rem;
  color: var(--renewal-blue-mid);
  letter-spacing: 0.14em;
}

.h360-programacao h2.h360-programacao__title {
  font-family: var(--font-heading);
  font-weight: 300;
  font-size: clamp(1.85rem, 3.8vw, 2.75rem);
  text-align: center;
  margin: 0 0 clamp(2rem, 4vw, 2.75rem);
}

.h360-programacao__grid {
  display: grid;
  gap: clamp(1.25rem, 3vw, 2rem);
}

@media (min-width: 900px) {
  .h360-programacao__grid {
    grid-template-columns: 1fr 1fr;
    align-items: stretch;
  }
}

.h360-programacao__panel {
  position: relative;
  overflow: hidden;
  border-radius: var(--h360-r-lg);
  padding: clamp(1.35rem, 2.8vw, 1.85rem);
  background: linear-gradient(155deg, rgb(255 255 255 / 0.97) 0%, rgb(248 250 252 / 0.99) 100%);
  border: 1px solid rgb(0 115 255 / 0.12);
  box-shadow: 0 4px 28px rgb(0 115 255 / 0.07), inset 0 1px 0 rgb(255 255 255 / 0.95);
  backdrop-filter: blur(12px);
  height: 100%;
}

.h360-programacao__panel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgb(0 115 255 / 0.22), transparent);
  pointer-events: none;
}

.h360-programacao__panel h3 {
  font-family: var(--font-heading);
  font-weight: 300;
  font-size: clamp(1.15rem, 2vw, 1.42rem);
  color: var(--renewal-blue-mid);
  margin: 0 0 1rem;
}

.h360-schedule {
  list-style: none;
  margin: 0;
  padding: 0;
}

.h360-schedule li {
  padding: 0.65rem 0;
  border-bottom: 1px solid rgb(0 115 255 / 0.06);
  font-size: clamp(0.875rem, 1.05vw, 0.9375rem);
  line-height: 1.55;
}

.h360-schedule li:last-child {
  border-bottom: 0;
}

.h360-schedule strong {
  color: var(--renewal-blue-mid);
  font-weight: 600;
}

/* ─── Lead / formulário (mesmo shell cinematográfico que .h360-palestrantes) ─── */
.h360-lead__grid {
  display: grid;
  gap: clamp(2rem, 4vw, 3rem);
  align-items: stretch;
}

@media (min-width: 900px) {
  .h360-lead__grid {
    grid-template-columns: 1.1fr 0.9fr;
  }
}

.h360-lead__panel {
  position: relative;
  overflow: hidden;
  border-radius: var(--h360-r-lg);
  height: 100%;
}

.h360-lead__panel::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  pointer-events: none;
  z-index: 1;
}

.h360-lead__panel--form {
  padding: clamp(1.25rem, 2.5vw, 1.65rem);
  background: linear-gradient(155deg, rgb(255 255 255 / 0.96) 0%, rgb(248 250 252 / 0.98) 100%);
  border: 1px solid rgb(0 115 255 / 0.14);
  box-shadow: 0 4px 32px rgb(0 0 0 / 0.22);
  backdrop-filter: blur(12px);
}

.h360-lead__panel--form::before {
  background: linear-gradient(90deg, transparent, rgb(0 115 255 / 0.22), transparent);
}

/* ─── Formulário lead — premium DS2 (design_system2: ds2-form-simple + ds2-panel) ─── */
@keyframes h360-form-shimmer {
  0%,
  100% {
    background-position: 0% 50%;
    opacity: 0.28;
  }
  50% {
    background-position: 100% 50%;
    opacity: 0.42;
  }
}

.h360-lead .h360-form.h360-lead__panel--form {
  position: relative;
  isolation: isolate;
  margin: 0;
  padding: clamp(1.35rem, 3vw, 1.95rem);
  background:
    linear-gradient(145deg, rgb(255 255 255 / 0.97) 0%, rgb(248 250 252 / 0.99) 100%),
    linear-gradient(165deg, rgb(239 246 255 / 0.55) 0%, transparent 52%);
  border: 1px solid rgb(0 115 255 / 0.12);
  box-shadow:
    0 1px 0 rgb(255 255 255 / 0.85) inset,
    0 20px 44px -28px rgb(0 115 255 / 0.2),
    0 6px 20px rgb(15 23 42 / 0.06);
  transition:
    border-color 0.3s var(--h360-ease),
    box-shadow 0.3s var(--h360-ease),
    transform 0.35s var(--h360-ease);
}

.h360-lead .h360-form.h360-lead__panel--form::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(
    105deg,
    transparent 0%,
    rgb(255 255 255 / 0.4) 45%,
    rgb(0 115 255 / 0.06) 50%,
    rgb(255 255 255 / 0.35) 55%,
    transparent 100%
  );
  background-size: 220% 100%;
  mix-blend-mode: soft-light;
}

.h360-lead .h360-form.h360-lead__panel--form > * {
  position: relative;
  z-index: 1;
}

@media (prefers-reduced-motion: no-preference) {
  .h360-lead .h360-form.h360-lead__panel--form::after {
    animation: h360-form-shimmer 7s ease-in-out infinite;
  }

  .h360-lead .h360-form.h360-lead__panel--form:hover {
    border-color: #bfdbfe;
    box-shadow:
      0 1px 0 rgb(255 255 255 / 0.92) inset,
      0 24px 52px -22px rgb(0 115 255 / 0.24),
      0 12px 32px rgb(15 23 42 / 0.08);
    transform: translateY(-3px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .h360-lead .h360-form.h360-lead__panel--form::after {
    display: none;
  }
}

.h360-lead__panel--aside {
  padding: clamp(1.35rem, 2.6vw, 1.85rem);
  background: linear-gradient(165deg, rgb(255 255 255 / 0.09) 0%, rgb(255 255 255 / 0.035) 100%);
  border: 1px solid rgb(255 255 255 / 0.14);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.07),
    0 8px 36px rgb(0 0 0 / 0.2);
  backdrop-filter: blur(12px);
}

.h360-lead__panel--aside::before {
  background: linear-gradient(90deg, transparent, rgb(255 255 255 / 0.2), transparent);
}

.h360-form .h360-field > label,
.h360-form .h360-field--half > div > label {
  display: block;
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--renewal-text-muted);
  margin: 0 0 0.45rem;
}

.h360-form .h360-field {
  margin-bottom: 0.15rem;
}

.h360-form .h360-field--half {
  display: grid;
  gap: 1rem;
}

@media (min-width: 600px) {
  .h360-form .h360-field--half {
    grid-template-columns: 1fr 1fr;
  }
}

.h360-form input[type="text"],
.h360-form input[type="email"],
.h360-form input[type="tel"],
.h360-form select {
  width: 100%;
  box-sizing: border-box;
  padding: 0.88rem 1.25rem;
  border-radius: 50px;
  border: 1px solid rgb(203 213 225 / 0.9);
  font-family: var(--font-sans);
  font-size: 1rem;
  background: rgb(255 255 255 / 0.88);
  color: var(--renewal-text);
  box-shadow: 0 1px 2px rgb(15 23 42 / 0.04) inset;
  margin-bottom: 1.05rem;
  transition:
    border-color 0.28s var(--h360-ease),
    box-shadow 0.28s var(--h360-ease),
    background 0.28s var(--h360-ease);
}

.h360-form input::placeholder {
  color: #94a3b8;
}

.h360-form select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1.1rem center;
  background-color: rgb(255 255 255 / 0.88);
  padding-right: 2.75rem;
}

.h360-form input:hover {
  border-color: rgb(0 115 255 / 0.25);
  background: #fff;
}

.h360-form select:hover {
  border-color: rgb(0 115 255 / 0.25);
  background-color: #fff;
}

.h360-form input:focus-visible {
  outline: none;
  border-color: rgb(0 115 255 / 0.5);
  background: #fff;
  box-shadow:
    0 0 0 3px rgb(0 115 255 / 0.14),
    0 1px 2px rgb(15 23 42 / 0.06) inset;
}

.h360-form select:focus-visible {
  outline: none;
  border-color: rgb(0 115 255 / 0.5);
  background-color: #fff;
  box-shadow:
    0 0 0 3px rgb(0 115 255 / 0.14),
    0 1px 2px rgb(15 23 42 / 0.06) inset;
}

.h360-form .h360-check {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  margin: 0.35rem 0 1rem;
  font-size: 0.875rem;
  line-height: 1.45;
}

.h360-form .h360-check label {
  font-size: 0.875rem;
  font-weight: 400;
  letter-spacing: normal;
  text-transform: none;
  color: var(--renewal-text-muted);
  margin: 0;
  cursor: pointer;
}

.h360-form .h360-check input {
  margin-top: 0.2rem;
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 0.25rem;
  border: 1px solid rgb(203 213 225 / 0.95);
  accent-color: var(--renewal-blue);
  cursor: pointer;
  flex-shrink: 0;
}

.h360-form .h360-legal {
  font-family: var(--font-sans);
  font-size: 0.8125rem;
  line-height: 1.55;
  margin: 0 0 1.1rem;
  padding: 0.8rem 1rem 0.8rem 1.05rem;
  border-radius: var(--h360-r-sm);
  background: linear-gradient(90deg, rgb(241 245 249 / 0.95), rgb(248 250 252 / 0.9));
  border: 1px solid rgb(226 232 240 / 0.9);
  border-left: 3px solid var(--renewal-blue-soft);
  color: var(--renewal-text-muted);
}

.h360-form .h360-legal a {
  color: var(--renewal-blue-mid);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.h360-form .h360-legal a:hover {
  color: var(--renewal-blue);
}

.h360-lead .h360-form .h360-check {
  color: var(--renewal-text-muted);
}

.h360-form .h360-btn--submit {
  width: 100%;
  margin-top: 0.2rem;
  padding: 0.95rem 1.25rem;
  background: var(--renewal-blue);
  border: none;
  border-radius: 50px;
  color: #fff;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  cursor: pointer;
  box-shadow: 0 6px 22px rgb(0 115 255 / 0.32);
  transition:
    background 0.22s var(--h360-ease),
    color 0.22s var(--h360-ease),
    box-shadow 0.22s var(--h360-ease),
    transform 0.22s var(--h360-ease);
}

.h360-form .h360-btn--submit:hover {
  background: #0060d6;
  color: #fff;
  box-shadow: 0 10px 30px rgb(0 115 255 / 0.4);
}

.h360-form .h360-btn--submit:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 3px rgb(255 255 255 / 0.95),
    0 0 0 6px rgb(0 115 255 / 0.35),
    0 10px 30px rgb(0 115 255 / 0.35);
}

.h360-form__status {
  min-height: 1.35rem;
  margin: 0.65rem 0 0;
  font-family: var(--font-sans);
  font-size: 0.8rem;
  line-height: 1.4;
  color: color-mix(in srgb, var(--renewal-blue-mid) 88%, #475569);
}

@media (prefers-reduced-motion: no-preference) {
  .h360-form .h360-btn--submit:hover {
    transform: translateY(-2px);
  }
}

.h360-lead__aside-eyebrow {
  margin: 0 0 0.85rem;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--renewal-green-accent);
}

.h360-lead__meta {
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgb(255 255 255 / 0.82);
}

.h360-lead__meta strong {
  color: rgb(255 255 255 / 0.95);
}

/* ─── Rodapé — efeito UAU (mesma cor base: --renewal-blue-mid) ─── */
.h360-footer {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  background-color: var(--renewal-blue-mid);
  padding-block: clamp(2.5rem, 6vw, 3.5rem);
  text-align: center;
  color: #fff;
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.12),
    inset 0 -1px 0 rgb(0 0 0 / 0.15);
}

.h360-footer::before {
  content: "";
  position: absolute;
  inset: -25%;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 50% 95% at 15% 40%, rgb(255 255 255 / 0.14), transparent 54%),
    radial-gradient(ellipse 48% 90% at 88% 60%, rgb(0 50 160 / 0.32), transparent 50%),
    radial-gradient(ellipse 35% 75% at 50% 0%, rgb(80 140 255 / 0.1), transparent 58%);
  filter: blur(3px);
}

.h360-footer::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background-image:
    linear-gradient(
      95deg,
      transparent 0%,
      rgb(255 255 255 / 0.1) 44%,
      rgb(255 255 255 / 0.16) 50%,
      rgb(255 255 255 / 0.1) 56%,
      transparent 100%
    ),
    url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200% 100%, auto;
  background-position: 0% 50%, center center;
  background-blend-mode: normal, overlay;
  mix-blend-mode: soft-light;
  opacity: 0.8;
}

@media (prefers-reduced-motion: no-preference) {
  .h360-footer::before {
    animation: h360-cta-atmosphere 16s ease-in-out infinite;
  }

  .h360-footer::after {
    animation: h360-cta-sheen 10s ease-in-out infinite;
  }
}

@media (prefers-reduced-motion: reduce) {
  .h360-footer::before {
    animation: none;
    opacity: 0.48;
  }

  .h360-footer::after {
    animation: none;
    opacity: 0.52;
  }
}

.h360-footer .h360-rail {
  position: relative;
  z-index: 2;
}

.h360-footer img {
  max-width: min(400px, 85vw);
  height: auto;
  margin-bottom: 1.5rem;
  filter: drop-shadow(0 4px 20px rgb(0 0 0 / 0.15));
}

.h360-social {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.h360-social a {
  width: 44px;
  height: 44px;
  border-radius: var(--h360-r-md);
  background: #fff;
  color: var(--renewal-blue-mid);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow:
    0 2px 10px rgb(0 0 0 / 0.1),
    0 0 0 1px rgb(255 255 255 / 0.25) inset;
  transition:
    background 0.22s var(--h360-ease),
    color 0.22s var(--h360-ease),
    transform 0.25s var(--h360-ease),
    box-shadow 0.25s var(--h360-ease);
}

.h360-social a:hover {
  background: var(--renewal-blue);
  color: #fff;
}

@media (prefers-reduced-motion: no-preference) {
  .h360-social a:hover {
    transform: translateY(-3px);
    box-shadow:
      0 10px 24px rgb(0 0 0 / 0.18),
      0 0 0 1px rgb(255 255 255 / 0.2) inset;
  }
}

.h360-social a:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 3px var(--renewal-blue-mid),
    0 0 0 6px rgb(255 255 255 / 0.95),
    0 4px 16px rgb(0 0 0 / 0.12);
}

.h360-social svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.h360-footer__copy {
  font-size: 0.875rem;
  font-style: italic;
  opacity: 0.92;
  margin: 0;
  text-shadow: 0 1px 2px rgb(0 0 0 / 0.12);
}

/* ─── Reveal ─── */
.h360-reveal {
  opacity: 1;
  transform: none;
  transition: none;
}

/**
 * H360 WOW / premium layer
 * Consolidado aqui para manter um unico CSS local em DEPLOY/h360.
 */
@keyframes h360-wow-mesh-shift {
  0%,
  100% {
    transform: translate(0, 0) scale(1);
    opacity: 0.42;
  }
  33% {
    transform: translate(2%, -3%) scale(1.03);
    opacity: 0.52;
  }
  66% {
    transform: translate(-2%, 2%) scale(0.98);
    opacity: 0.38;
  }
}

@keyframes h360-wow-aurora {
  0%,
  100% {
    transform: rotate(0deg) scale(1);
  }
  50% {
    transform: rotate(180deg) scale(1.08);
  }
}

@keyframes h360-wow-cta-sheen {
  0%,
  100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

@keyframes h360-wow-logo-sheen {
  0%,
  100% {
    filter: drop-shadow(0 0 22px rgb(0 115 255 / 0.45)) drop-shadow(0 0 48px rgb(80 160 255 / 0.15))
      drop-shadow(0 4px 28px rgb(0 0 0 / 0.55));
  }
  50% {
    filter: drop-shadow(0 0 32px rgb(0 115 255 / 0.65)) drop-shadow(0 0 64px rgb(100 190 255 / 0.28))
      drop-shadow(0 4px 28px rgb(0 0 0 / 0.55));
  }
}

.h360-page--wow .h360-hero__layers::after {
  content: "";
  position: absolute;
  inset: -5%;
  z-index: 7;
  pointer-events: none;
  opacity: 0.55;
  mix-blend-mode: screen;
  background:
    radial-gradient(ellipse 70% 55% at 15% 25%, rgb(0 115 255 / 0.35), transparent 55%),
    radial-gradient(ellipse 55% 45% at 85% 75%, rgb(130 200 255 / 0.22), transparent 52%),
    radial-gradient(ellipse 40% 35% at 50% 50%, rgb(74 222 128 / 0.08), transparent 60%),
    conic-gradient(
      from 140deg at 50% 40%,
      rgb(0 115 255 / 0.12) 0deg,
      transparent 80deg,
      rgb(43 100 245 / 0.1) 160deg,
      transparent 240deg,
      rgb(0 115 255 / 0.08) 320deg,
      rgb(0 115 255 / 0.12) 360deg
    );
}

.h360-page--wow .h360-hero__layers::before {
  content: "";
  position: absolute;
  inset: -30%;
  z-index: 6;
  pointer-events: none;
  opacity: 0.18;
  mix-blend-mode: soft-light;
  background: radial-gradient(circle at 50% 50%, rgb(255 255 255 / 0.15), transparent 45%);
  animation: h360-wow-aurora 48s linear infinite;
}

@media (prefers-reduced-motion: reduce) {
  .h360-page--wow .h360-hero__layers::after {
    animation: none;
    opacity: 0.38;
  }

  .h360-page--wow .h360-hero__layers::before {
    animation: none;
    opacity: 0.1;
  }
}

@media (prefers-reduced-motion: no-preference) {
  .h360-page--wow .h360-hero__layers::after {
    animation: h360-wow-mesh-shift 22s ease-in-out infinite;
  }
}

.h360-page--wow .h360-hero__vignette {
  background: radial-gradient(
    ellipse 95% 85% at 48% 40%,
    transparent 0%,
    rgb(0 0 0 / 0.18) 58%,
    rgb(0 0 0 / 0.52) 100%
  );
}

@media (prefers-reduced-motion: no-preference) {
  .h360-page--wow .h360-hero__logo {
    animation: h360-wow-logo-sheen 6s ease-in-out infinite;
  }
}

.h360-page--wow .h360-hero__headline {
  max-width: min(22em, 96vw);
  text-shadow:
    0 2px 48px rgb(0 0 0 / 0.65),
    0 0 80px rgb(0 115 255 / 0.06);
}

.h360-page--wow .h360-hero .h360-countdown__num {
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}

.h360-page--wow .h360-hero .h360-btn--primary {
  padding-inline: 1.65rem;
  background-image: linear-gradient(
    105deg,
    rgb(0 115 255) 0%,
    rgb(0 90 210) 38%,
    rgb(60 160 255) 50%,
    rgb(0 90 210) 62%,
    rgb(0 115 255) 100%
  );
  background-size: 200% 100%;
  background-position: 0% 50%;
  box-shadow:
    0 6px 32px rgb(0 115 255 / 0.55),
    0 0 0 1px rgb(255 255 255 / 0.18) inset,
    0 0 40px rgb(80 170 255 / 0.25);
  transition:
    transform 0.35s var(--h360-ease, cubic-bezier(0.22, 1, 0.36, 1)),
    box-shadow 0.35s var(--h360-ease, cubic-bezier(0.22, 1, 0.36, 1));
}

@media (prefers-reduced-motion: no-preference) {
  .h360-page--wow .h360-hero .h360-btn--primary {
    animation: h360-wow-cta-sheen 4.5s ease-in-out infinite;
  }
}

@media (prefers-reduced-motion: reduce) {
  .h360-page--wow .h360-hero .h360-btn--primary {
    background-image: none;
    background-color: var(--renewal-blue);
  }
}

.h360-page--wow .h360-hero .h360-btn--primary:hover {
  transform: translateY(-2px);
  box-shadow:
    0 10px 44px rgb(0 115 255 / 0.65),
    0 0 0 1px rgb(255 255 255 / 0.24) inset,
    0 0 56px rgb(100 190 255 / 0.35);
}

@media (max-width: 768px) {
  .h360-page--wow .h360-hero__layers::before {
    opacity: 0.08;
  }
}

@media (max-width: 768px) {
  .h360-lead__panel--form,
  .h360-lead__panel--aside,
  .h360-programacao__panel {
    backdrop-filter: none;
  }

  .h360-page--wow .h360-hero__layers::after,
  .h360-page--wow .h360-hero__logo,
  .h360-page--wow .h360-hero .h360-btn--primary {
    animation: none !important;
  }
}

.h360-page--wow .h360-lead__map {
  margin-top: 1rem;
  border-radius: 1rem;
  overflow: hidden;
  border: 1px solid rgb(255 255 255 / 0.2);
  background: rgb(15 23 42 / 0.2);
  box-shadow:
    inset 0 1px 0 rgb(255 255 255 / 0.12),
    0 10px 26px rgb(0 0 0 / 0.24);
}

.h360-page--wow .h360-lead__map-frame {
  display: block;
  width: 100%;
  height: clamp(15rem, 26vw, 18rem);
  border: 0;
}

/* Swiper pagination override */
.h360-speaker-swiper-wrap .swiper-pagination-progressbar {
  position: relative !important;
  margin-top: 1rem;
  height: 4px !important;
  background: rgb(255 255 255 / 0.15) !important;
}

.h360-speaker-swiper-wrap .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  background: rgb(255 255 255 / 0.55) !important;
}

/* ───────────────────────────────────────────────────────────────────────────
 * PERF — desativa animações infinitas decorativas e backdrop-filter pesado.
 * Ganho: ~30 animações infinitas em paralelo deixam de gastar GPU/CPU em idle.
 * As fade-ups iniciais do herói (transient) seguem ativas.
 * ─────────────────────────────────────────────────────────────────────────── */
.h360-hero__cinematic::before,
.h360-hero__cinematic::after,
.h360-hero__nebula,
.h360-hero__blob,
.h360-hero__blob--a,
.h360-hero__blob--b,
.h360-hero__foot-glow,
.h360-cta-stripe::before,
.h360-cta-stripe::after,
.h360-palestrantes::before,
.h360-lead::before,
.h360-palestrantes::after,
.h360-lead::after,
.h360-palestrantes__fusion,
.h360-lead__fusion,
.h360-hero__fusion,
.h360-programacao::before,
.h360-lead .h360-form.h360-lead__panel--form::after,
.h360-footer::before,
.h360-footer::after,
.h360-page--wow .h360-hero__layers::before,
.h360-page--wow .h360-hero__layers::after,
.h360-page--wow .h360-hero__logo,
.h360-page--wow .h360-hero .h360-btn--primary {
  animation: none !important;
}

/* Remove decorativos animados extras: nebula/blobs do hero não são essenciais */
.h360-hero__nebula,
.h360-hero__blob,
.h360-programacao::before {
  display: none !important;
}

/* backdrop-filter (blur) é caro em Safari/mobile. Substituímos por opacidade
 * sólida equivalente para preservar a leitura sem custo de composição. */
.h360-form,
.h360-lead__panel,
.h360-form-embed {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* ───────────────────────────────────────────────────────────────────────────
 * PERF — desliga TODOS os efeitos de entrada/reveal.
 * Os elementos passam a ser pintados imediatamente em estado final, eliminando
 * o "delay percebido" de carregamento (opacity:0 + animation delay) e o custo
 * de IntersectionObserver para revelar blocos.
 * ─────────────────────────────────────────────────────────────────────────── */
.h360-page .h360-hero__logo,
.h360-page .h360-hero__kicker,
.h360-page .h360-hero__headline-line,
.h360-page .h360-hero__headline-line:nth-child(1),
.h360-page .h360-hero__headline-line:nth-child(2),
.h360-page .h360-hero__headline-line:nth-child(3),
.h360-page .h360-hero__date,
.h360-page .h360-countdown,
.h360-hero__headline-accent {
  animation: none !important;
  opacity: 1 !important;
  transform: none !important;
}

