.page-connect {
  --section-offset: calc(env(safe-area-inset-top, 0px) + 5.75rem);
  --topbar-width: min(94vw, 78rem);
  --surface-border: rgba(211, 231, 255, 0.2);
  --surface-fill: linear-gradient(120deg, rgba(10, 42, 68, 0.28), rgba(10, 42, 68, 0.1));
  background:
    radial-gradient(1300px 500px at 90% -5%, #0f4265 0%, transparent 55%),
    linear-gradient(180deg, #02192c 0%, #02253e 40%, #03233a 100%);
  overflow-x: clip;
}

.page-connect.agenda-modal-open {
  overflow: hidden;
}

.page-connect #nosotros,
.page-connect #speakers,
.page-connect #partners,
.page-connect #agenda {
  scroll-margin-top: var(--section-offset);
}

.page-connect .agenda-modal {
  position: fixed;
  inset: 0;
  z-index: 60;
  display: grid;
  place-items: center;
  padding: calc(env(safe-area-inset-top, 0px) + 0.75rem) 0.75rem calc(env(safe-area-inset-bottom, 0px) + 0.75rem);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.32s ease, visibility 0.32s ease;
}

.page-connect .agenda-modal.is-open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.page-connect .agenda-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(1, 14, 24, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.page-connect .agenda-modal-panel {
  position: relative;
  z-index: 1;
  width: min(100%, 42rem);
  max-height: min(34rem, calc(100svh - 1.5rem));
  min-height: 17.5rem;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(211, 231, 255, 0.24);
  border-radius: 1.25rem;
  background: linear-gradient(135deg, rgba(6, 38, 61, 0.88), rgba(5, 31, 50, 0.8));
  box-shadow: 0 1.5rem 3rem rgba(0, 0, 0, 0.42);
  transform: translateY(1rem) scale(0.975);
  opacity: 0;
  transition: transform 0.34s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.28s ease;
}

.page-connect .agenda-modal.is-open .agenda-modal-panel {
  transform: translateY(0) scale(1);
  opacity: 1;
}

.page-connect .agenda-modal-title {
  position: absolute;
  top: 0.875rem;
  left: 0.9375rem;
  margin: 0;
  z-index: 2;
  color: rgba(255, 255, 255, 0.86);
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 0.9375rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-connect .agenda-modal-close {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  z-index: 3;
  width: 2.5rem;
  min-height: 2.75rem;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 0.75rem;
  background: rgba(7, 28, 44, 0.56);
  color: #ffffff;
  font-size: 1.45rem;
  line-height: 1;
  cursor: pointer;
}

.page-connect .agenda-modal-content {
  flex: 1;
  display: grid;
  place-items: center;
  min-height: 17.5rem;
  overflow-y: auto;
  padding: 4rem 1.25rem 1.75rem;
  text-align: center;
}

.page-connect .agenda-modal-message {
  max-width: 32rem;
  margin: 0;
  color: #ffffff;
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(1.2rem, 5vw, 1.95rem);
  font-weight: 600;
  line-height: 1.28;
}

.page-connect .topbar {
  position: fixed;
  top: calc(env(safe-area-inset-top, 0px) + 0.625rem);
  left: 50%;
  z-index: 20;
  width: var(--topbar-width);
  min-height: 3.25rem;
  padding: 0.5rem 0.75rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  transform: translateX(-50%);
  color: #d8e7f8;
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  border: 1px solid var(--surface-border);
  border-radius: 1rem;
  background: var(--surface-fill);
  backdrop-filter: blur(14px) saturate(125%);
  -webkit-backdrop-filter: blur(14px) saturate(125%);
  box-shadow: 0 0.75rem 1.875rem rgba(0, 0, 0, 0.18);
}

.page-connect .topbar-brand {
  display: flex;
  align-items: center;
  flex: 0 0 auto;
}

.page-connect .topbar-logo {
  width: auto;
  height: 1.5rem;
}

.page-connect .topbar-toggle {
  width: 2.75rem;
  min-height: 2.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.3125rem;
  border: 1px solid rgba(211, 231, 255, 0.24);
  border-radius: 0.75rem;
  background: rgba(4, 28, 45, 0.35);
  cursor: pointer;
}

.page-connect .topbar-toggle span {
  width: 1.125rem;
  height: 0.125rem;
  border-radius: 999px;
  background: #e7f2ff;
  transition: transform 0.24s ease, opacity 0.2s ease;
}

.page-connect .topbar.menu-open .topbar-toggle span:nth-child(1) {
  transform: translateY(0.4375rem) rotate(45deg);
}

.page-connect .topbar.menu-open .topbar-toggle span:nth-child(2) {
  opacity: 0;
}

.page-connect .topbar.menu-open .topbar-toggle span:nth-child(3) {
  transform: translateY(-0.4375rem) rotate(-45deg);
}

.page-connect .topbar-links {
  position: absolute;
  top: calc(100% + 0.625rem);
  left: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 0.5rem;
  border: 1px solid var(--surface-border);
  border-radius: 0.875rem;
  background: #062842;
  box-shadow: 0 0.875rem 1.75rem rgba(0, 0, 0, 0.34);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-0.5rem) scale(0.98);
  transform-origin: top center;
  max-height: calc(100svh - (5.875rem + env(safe-area-inset-top, 0px)));
  overflow-y: auto;
  transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s ease;
}

.page-connect .topbar.menu-open .topbar-links {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.page-connect .topbar-links a {
  display: flex;
  align-items: center;
  min-height: 2.75rem;
  padding: 0.625rem 0.75rem;
  border-radius: 0.625rem;
  color: inherit;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 1.2;
  text-decoration: none;
  opacity: 0.92;
  transition: color 0.2s ease, opacity 0.2s ease, background 0.2s ease;
}

.page-connect .topbar-links a:hover,
.page-connect .topbar-links a.is-active {
  color: var(--accent);
  opacity: 1;
  background: rgba(242, 179, 124, 0.12);
}

.page-connect .topbar-links a::after {
  display: none;
}

.page-connect .topbar-links .nav-cta {
  justify-content: center;
  margin-top: 0.25rem;
  padding-inline: 1rem;
  border-radius: 999px;
  background: linear-gradient(180deg, #f4bb88 0%, #dd9960 100%);
  color: #0a2338;
  font-weight: 700;
  opacity: 1;
  box-shadow: 0 0.625rem 1.25rem rgba(224, 157, 96, 0.32);
}

.page-connect .topbar-links .nav-cta:hover,
.page-connect .topbar-links .nav-cta.is-active {
  color: #0a2338;
  background: linear-gradient(180deg, #ffd2ab 0%, #e3a56f 100%);
}

.page-connect .hero {
  position: relative;
  overflow: hidden;
  min-height: clamp(28rem, 82svh, 54rem);
  padding: calc(env(safe-area-inset-top, 0px) + 5.5rem) 0 1rem;
  background: linear-gradient(180deg, #02243d 0%, #032845 100%);
}

.page-connect .hero .container {
  position: relative;
  z-index: 2;
  min-height: clamp(21rem, 66svh, 42rem);
  display: flex;
  align-items: flex-start;
}

.page-connect .hero::before,
.page-connect .hero::after {
  content: "";
  position: absolute;
  pointer-events: none;
}

.page-connect .hero::before {
  inset: 0;
  z-index: 1;
  background: linear-gradient(90deg, rgba(2, 25, 44, 0.54) 0%, rgba(2, 25, 44, 0.14) 52%, rgba(2, 25, 44, 0) 80%);
}

.page-connect .hero::after {
  inset: 0;
  z-index: 0;
  background: url("../recursos/recurso-dorado-1.png") no-repeat;
  background-position: right -35rem top 4.5rem;
  background-size: min(74rem, 245vw);
  opacity: 0.75;
}

.page-connect .brand {
  position: relative;
  z-index: 2;
  display: grid;
  gap: 0.9rem;
  width: min(100%, 34rem);
  margin-top: clamp(2.25rem, 9vw, 7.75rem);
}

.page-connect .brand-logo {
  width: clamp(16rem, 56vw, 40rem);
}

.page-connect .brand p {
  max-width: 34rem;
  margin: 0;
  color: var(--muted);
  font-size: clamp(0.98rem, 2.3vw, 1.22rem);
  line-height: 1.45;
}

@media (max-width: 23.4375rem) {
  .page-connect .hero {
    min-height: 23.5rem;
    padding: calc(env(safe-area-inset-top, 0px) + 5rem) 0 0.35rem;
  }

  .page-connect .hero .container {
    min-height: 17.5rem;
  }

  .page-connect .hero::after {
    background-position: right -39rem top 6rem;
    background-size: min(70rem, 285vw);
  }

  .page-connect .brand {
    gap: 0.7rem;
    margin-top: 3.35rem;
  }

  .page-connect .brand-logo {
    width: min(100%, 12.75rem);
  }

  .page-connect .brand p {
    max-width: 18rem;
    font-size: 0.92rem;
    line-height: 1.38;
  }
}

.page-connect .brand p strong {
  color: var(--accent);
}

.page-connect .panel-section {
  margin-top: 0;
}

.page-connect .panel {
  padding: 1.5rem 1rem;
  border: 1px solid rgba(211, 231, 255, 0.2);
  border-radius: 1.25rem;
  background: linear-gradient(120deg, rgba(7, 62, 97, 0.4), rgba(7, 48, 77, 0.22));
  box-shadow: 0 1.125rem 2.625rem rgba(0, 0, 0, 0.2);
  backdrop-filter: blur(14px) saturate(125%);
  -webkit-backdrop-filter: blur(14px) saturate(125%);
}

.page-connect .panel h3 {
  margin: 0 0 0.25rem;
  color: var(--accent);
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(1.75rem, 7vw, 2.25rem);
  font-weight: 600;
}

.page-connect .panel .subtitle {
  margin: 0 0 1.375rem;
  color: #d8e8fa;
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(1rem, 5vw, 1.5rem);
  font-weight: 600;
  line-height: 1.3;
}

.page-connect .features {
  display: grid;
  gap: 1rem;
}

.page-connect .feature {
  display: grid;
  grid-template-columns: 2.75rem minmax(0, 1fr);
  gap: 0.75rem;
  align-items: start;
}

.page-connect .feature-icon {
  width: 2.75rem;
  height: 2.75rem;
  object-fit: contain;
  filter: brightness(0) saturate(100%) invert(76%) sepia(48%) saturate(480%) hue-rotate(330deg) brightness(106%);
}

.page-connect .feature h4 {
  margin: 0 0 0.25rem;
  color: var(--accent);
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(1rem, 4.8vw, 1.5rem);
  font-weight: 600;
  line-height: 1.3;
}

.page-connect .feature p {
  color: var(--muted);
  font-size: 0.95rem;
  line-height: 1.5;
}

.page-connect .section-title {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.625rem;
  margin-bottom: 1.5rem;
  text-align: center;
}

.page-connect .section-title .title-regular,
.page-connect .section-title .light {
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(1.5rem, 8vw, 3rem);
}

.page-connect .section-title .title-regular {
  font-weight: 400;
}

.page-connect .section-title .light {
  color: #f4bb88;
  font-style: italic;
  font-weight: 600;
}

.page-connect .section-logo {
  width: auto;
  height: 1.25rem;
}

.page-connect .video-box {
  width: 100%;
  max-width: 56.25rem;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.06);
  border-radius: 1.125rem;
  background: #0f1722;
  box-shadow: 0 1.25rem 3.125rem rgba(0, 0, 0, 0.35);
}

.page-connect .video-box iframe {
  width: 100%;
  height: 100%;
  border: 0;
}

.page-connect .voices {
  margin-top: 3rem;
}

.page-connect .voices h3,
.page-connect .partners h3 {
  margin: 0 0 1.5rem;
  text-align: center;
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(1.75rem, 7vw, 3rem);
  font-weight: 700;
}

.page-connect .speakers {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.875rem;
}

.page-connect .speaker {
  position: relative;
  display: block;
  min-height: 16rem;
  aspect-ratio: 10 / 12;
  overflow: hidden;
  border-radius: 1.25rem;
  color: inherit;
  text-decoration: none;
  transition: transform 0.28s ease, box-shadow 0.28s ease;
}

.page-connect .speaker:hover {
  transform: translateY(-0.3125rem);
  box-shadow: 0 1.375rem 2.75rem rgba(242, 179, 124, 0.25), 0 0.25rem 1rem rgba(0, 0, 0, 0.4);
}

.page-connect .speaker-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.page-connect .speaker-photo--santiago {
  object-position: 56% 22%;
}

.page-connect .speaker-photo--mariano {
  object-position: center 24%;
}

.page-connect .speaker-photo--gonzalo {
  object-position: center 12%;
}

.page-connect .speaker-photo--eduardo {
  object-position: 54% 20%;
}

.page-connect .speaker-photo--yamila {
  object-position: 28% 26%;
}

.page-connect .speaker-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(22, 10, 2, 0.96) 0%, rgba(60, 32, 4, 0.72) 36%, rgba(90, 50, 8, 0.2) 60%, transparent 78%);
}

.page-connect .speaker-badge {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  z-index: 2;
  width: 4.25rem;
  height: 4.25rem;
  animation: speaker-spin 22s linear infinite;
}

.page-connect .speaker-badge svg {
  width: 100%;
  height: 100%;
}

.page-connect .speaker-badge text {
  fill: rgba(0, 0, 0, 0.9);
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 1.4px;
  text-transform: uppercase;
}

.page-connect .speaker--gonzalo .speaker-badge text {
  fill: rgba(255, 255, 255, 0.94);
}

@keyframes speaker-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.page-connect .speaker-info {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  padding: 1rem 0.9375rem 1.125rem;
}

.page-connect .speaker h4 {
  margin: 0 0 0.1875rem;
  color: #ffffff;
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.2;
}

.page-connect .speaker p {
  color: rgba(255, 255, 255, 0.75);
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 0.8125rem;
}

.page-connect .partners {
  margin-top: 2.5rem;
  padding-bottom: 3.5rem;
}

.page-connect .partners-board {
  width: min(100%, 74rem);
  margin: 0 auto;
  padding-inline: clamp(0.15rem, 1.5vw, 0.75rem);
}

.page-connect .partners-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1rem 1.2rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.page-connect .partners-row + .partners-row {
  margin-top: 1.7rem;
}

.page-connect .partners-row--compact {
  gap: 0.95rem 1.5rem;
}

.page-connect .partner-item {
  flex: 0 0 auto;
  width: min(var(--logo-width-mobile, var(--logo-width-desktop)), 42vw);
  min-width: 0;
}

.page-connect .partner-logo {
  display: block;
  width: 100%;
  height: auto;
  opacity: 1;
  transform-origin: center;
  transition: transform 0.28s ease, filter 0.28s ease, opacity 0.28s ease;
  will-change: transform, filter;
}

.page-connect .partner-item--aws { --logo-width-mobile: 6.5rem; --logo-width-desktop: 7.9rem; }
.page-connect .partner-item--cisco { --logo-width-mobile: 5.5rem; --logo-width-desktop: 6.6rem; }
.page-connect .partner-item--crowdstrike { --logo-width-mobile: 11.1rem; --logo-width-desktop: 13.8rem; }
.page-connect .partner-item--dell { --logo-width-mobile: 11.8rem; --logo-width-desktop: 14.4rem; }
.page-connect .partner-item--ibm { --logo-width-mobile: 6.9rem; --logo-width-desktop: 8.3rem; }
.page-connect .partner-item--lenovo { --logo-width-mobile: 6.2rem; --logo-width-desktop: 7.5rem; }
.page-connect .partner-item--microsoft { --logo-width-mobile: 10.4rem; --logo-width-desktop: 12.7rem; }
.page-connect .partner-item--paloalto { --logo-width-mobile: 8.6rem; --logo-width-desktop: 10.5rem; }
.page-connect .partner-item--qualys { --logo-width-mobile: 8.8rem; --logo-width-desktop: 10.7rem; }
.page-connect .partner-item--parkplace { --logo-width-mobile: 12.4rem; --logo-width-desktop: 15.3rem; }
.page-connect .partner-item--thales { --logo-width-mobile: 10.6rem; --logo-width-desktop: 12.8rem; }
.page-connect .partner-item--quest { --logo-width-mobile: 7.4rem; --logo-width-desktop: 8.9rem; }
.page-connect .partner-item--veeam { --logo-width-mobile: 6.6rem; --logo-width-desktop: 7.9rem; }
.page-connect .partner-item--vmware { --logo-width-mobile: 6.8rem; --logo-width-desktop: 8rem; }
.page-connect .partner-item--trend { --logo-width-mobile: 8.9rem; --logo-width-desktop: 10.8rem; }

@media (hover: hover) and (pointer: fine) {
  .page-connect .partner-item:hover .partner-logo {
    transform: translateY(-0.18rem) scale(1.05);
    filter: drop-shadow(0 0 0.55rem rgba(242, 179, 124, 0.58)) drop-shadow(0 0.35rem 1rem rgba(242, 179, 124, 0.34));
    opacity: 1;
  }
}

@media (hover: none) {
  .page-connect .partner-item:active .partner-logo,
  .page-connect .partner-item:focus-within .partner-logo {
    transform: scale(1.03);
    filter: drop-shadow(0 0 0.5rem rgba(242, 179, 124, 0.5)) drop-shadow(0 0.25rem 0.7rem rgba(242, 179, 124, 0.28));
  }
}

.page-connect .event-note {
  margin-top: 1.5rem;
  margin-bottom: 2.5rem;
  padding: 1.375rem 1rem;
  text-align: center;
  border: 1px solid rgba(244, 187, 136, 0.34);
  border-radius: 1.25rem;
  background: linear-gradient(135deg, rgba(8, 53, 82, 0.5), rgba(8, 45, 73, 0.24));
  box-shadow: 0 1rem 2.125rem rgba(0, 0, 0, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(14px) saturate(125%);
  -webkit-backdrop-filter: blur(14px) saturate(125%);
}

.page-connect .event-note h3 {
  margin: 0 0 0.625rem;
  color: var(--accent);
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(1.5rem, 7vw, 2.25rem);
  font-weight: 600;
  line-height: 1.15;
}

.page-connect .event-note p {
  margin: 0;
  color: #ffffff;
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(0.95rem, 3.8vw, 1.125rem);
  font-weight: 500;
  line-height: 1.45;
}

.page-connect .cta {
  position: relative;
  margin-top: 1rem;
  padding: 4.25rem 0 11.5rem;
  text-align: center;
  overflow: hidden;
  z-index: 1;
}

.page-connect .cta .container {
  position: relative;
  z-index: 1;
}

.page-connect .cta::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -18rem;
  width: min(78rem, 290vw);
  height: 31rem;
  transform: translateX(-50%);
  background: url("../recursos/recurso-dorado-2.png") center bottom / contain no-repeat;
  opacity: 0.75;
}

.page-connect .cta p {
  position: relative;
  max-width: 28ch;
  margin: 0 auto 1.25rem;
  color: #ffffff;
  font-family: "Instrument Sans", "Segoe UI", Roboto, Arial, sans-serif;
  font-size: clamp(1.15rem, 5vw, 1.5rem);
  font-weight: 600;
  line-height: 1.28;
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.55);
}

.page-connect .cta-logo {
  width: clamp(8.75rem, 36vw, 18rem);
  margin: 0 auto;
}

.page-connect .site-footer {
  border-top: 1px solid rgba(211, 231, 255, 0.14);
  background: linear-gradient(180deg, rgba(2, 21, 35, 0.45), rgba(2, 21, 35, 0.85));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.page-connect .footer-inner {
  min-height: 5.25rem;
  padding: 1rem 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  text-align: center;
}

.page-connect .footer-logo {
  width: 6.375rem;
  opacity: 0.9;
}

.page-connect .footer-copy {
  margin: 0;
  color: rgba(236, 246, 255, 0.8);
  font-size: 0.84rem;
}

.page-connect .footer-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.625rem 0.875rem;
}

.page-connect .footer-nav a {
  color: rgba(236, 246, 255, 0.9);
  font-size: 0.84rem;
  text-decoration: none;
  transition: color 0.2s ease;
}

.page-connect .footer-nav a:hover {
  color: #f4bb88;
}

@media (prefers-reduced-motion: reduce) {
  .page-connect .speaker-badge {
    animation: none;
  }
}

@media (min-width: 23.5rem) and (max-width: 26.5625rem) {
  .page-connect .hero {
    min-height: 26rem;
    padding: calc(env(safe-area-inset-top, 0px) + 5.25rem) 0 0.5rem;
  }

  .page-connect .hero .container {
    min-height: 19rem;
  }

  .page-connect .hero::after {
    background-position: right -12rem top 13rem;
    background-size: min(40rem, 140vw);
  }
}

@media (min-width: 26.625rem) and (max-width: 35.9375rem) {
  .page-connect .hero {
    min-height: 27rem;
    padding: calc(env(safe-area-inset-top, 0px) + 5.4rem) 0 0.75rem;
  }

  .page-connect .hero .container {
    min-height: 20rem;
  }

  .page-connect .hero::after {
    background-position: right -37rem top 14rem;
    background-size: min(71rem, 265vw);
  }

  .page-connect .brand {
    margin-top: 5rem;
  }
}

@media (min-width: 36rem) {
  .page-connect {
    --section-offset: calc(env(safe-area-inset-top, 0px) + 6.25rem);
  }

  .page-connect .topbar {
    padding-inline: 1rem;
  }

  .page-connect .hero {
    padding-bottom: 2rem;
  }

  .page-connect .hero .container {
    min-height: clamp(24rem, 68svh, 44rem);
  }

  .page-connect .hero::after {
    background-position: right -31rem top 4rem;
    background-size: min(72rem, 205vw);
  }

  .page-connect .brand-logo {
    width: clamp(18rem, 50vw, 24rem);
  }

  .page-connect .panel {
    padding: 1.75rem 1.5rem;
  }

  .page-connect .feature {
    grid-template-columns: 3.125rem minmax(0, 1fr);
    gap: 1rem;
  }

  .page-connect .feature-icon {
    width: 3.125rem;
    height: 3.125rem;
  }

  .page-connect .speakers {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .page-connect .speaker {
    aspect-ratio: 4 / 5;
    min-height: 0;
  }

  .page-connect .speaker-badge {
    width: 4.5rem;
    height: 4.5rem;
  }

  .page-connect .speaker-badge text {
    font-size: 0.78rem;
  }

  .page-connect .partners-board {
    width: min(100%, 59rem);
  }

  .page-connect .partners-row {
    gap: 1rem 1.35rem;
  }

  .page-connect .cta {
    padding: 4.75rem 0 12.5rem;
  }

  .page-connect .cta::before {
    bottom: -19rem;
    height: 33rem;
  }

  .page-connect .cta p {
    max-width: 32ch;
  }
}

@media (min-width: 48rem) {
  .page-connect {
    --section-offset: 7rem;
  }

  .page-connect .topbar {
    top: 1rem;
    min-height: 4rem;
    padding: 0.875rem 1.5rem;
    gap: 1rem;
    justify-content: flex-end;
  }

  .page-connect .topbar-brand {
    margin-right: auto;
    max-width: 0;
    opacity: 0;
    overflow: hidden;
    transform: translateY(-0.625rem) scale(0.92);
    transition: max-width 0.42s ease, opacity 0.36s ease, transform 0.36s ease;
  }

  .page-connect .topbar-logo {
    height: 1.875rem;
  }

  .page-connect .topbar.is-scrolled .topbar-brand {
    max-width: 13.75rem;
    opacity: 1;
    transform: translateY(0) scale(1);
  }

  .page-connect .topbar-toggle {
    display: none;
  }

  .page-connect .topbar-links {
    position: static;
    flex-direction: row;
    align-items: center;
    gap: clamp(0.75rem, 1.8vw, 1.625rem);
    margin-right: 1.5rem;
    padding: 0;
    max-height: none;
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
  }

  .page-connect .topbar-links a {
    position: relative;
    display: inline-flex;
    align-items: center;
    min-height: 0;
    padding: 0 0 0.25rem;
    border-radius: 0;
    background: transparent;
    font-size: 1.0625rem;
    line-height: 1;
  }

  .page-connect .topbar-links a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    height: 2px;
    border-radius: 999px;
    background: var(--accent);
    transition: width 0.25s ease;
  }

  .page-connect .topbar-links a:hover,
  .page-connect .topbar-links a.is-active {
    background: transparent;
  }

  .page-connect .topbar-links a:hover::after,
  .page-connect .topbar-links a.is-active::after {
    width: 100%;
  }

  .page-connect .topbar-links .nav-cta {
    min-height: 0;
    margin-top: 0;
    padding: 0.625rem 1.125rem;
  }

  .page-connect .hero {
    min-height: clamp(34rem, 82svh, 52rem);
    padding: 8rem 0 2rem;
  }

  .page-connect .hero .container {
    min-height: clamp(27rem, 66svh, 43rem);
  }

  .page-connect .hero::after {
    background-position: right -35rem top 3.5rem;
    background-size: clamp(64rem, 118vw, 86rem);
  }

  .page-connect .brand {
    gap: 1rem;
  }

  .page-connect .brand-logo {
    width: clamp(20rem, 34vw, 28rem);
  }

  .page-connect .brand p {
    max-width: 31rem;
    font-size: 1.06rem;
  }

  .page-connect .panel-section {
    margin-top: -1rem;
  }

  .page-connect .panel {
    padding: 2.25rem 2rem;
    border-radius: 1.5rem;
  }

  .page-connect .section-logo {
    height: 1.5rem;
  }

  .page-connect .voices,
  .page-connect .partners {
    margin-top: 4rem;
  }

  .page-connect .speakers {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
  }

  .page-connect .speaker-badge {
    width: 4.75rem;
    height: 4.75rem;
    top: 0.375rem;
    right: 0.125rem;
  }

  .page-connect .speaker-badge text {
    font-size: 0.84rem;
  }

  .page-connect .partners-board {
    width: 100%;
  }

  .page-connect .partners-row {
    flex-wrap: nowrap;
    gap: 0.9rem;
  }

  .page-connect .partners-row--compact {
    gap: 1.1rem;
  }

  .page-connect .partner-item {
    width: min(var(--logo-width-desktop), 12.5vw);
  }

  .page-connect .event-note {
    padding: 1.75rem 1.5rem;
  }

  .page-connect .cta {
    padding: 5.5rem 0 10.5rem;
  }

  .page-connect .cta .container {
    transform: translateY(-2rem);
  }

  .page-connect .cta::before {
    width: min(90rem, 220vw);
    height: 36rem;
    bottom: -21.5rem;
  }

  .page-connect .cta p {
    max-width: 40rem;
    font-size: 1.375rem;
  }

  .page-connect .footer-inner {
    min-height: 4.75rem;
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
  }

  .page-connect .footer-logo {
    width: 7.375rem;
  }

  .page-connect .footer-copy,
  .page-connect .footer-nav a {
    font-size: 0.92rem;
  }
}

@media (min-width: 64rem) {
  .page-connect {
    --section-offset: 7.5rem;
    --topbar-width: min(1240px, 92vw);
  }

  .page-connect .topbar {
    width: var(--topbar-width);
    min-height: 4.625rem;
    padding-inline: 1.75rem;
  }

  .page-connect .topbar-links a {
    font-size: 1.125rem;
  }

  .page-connect .hero {
    min-height: 34rem;
    padding: 8.25rem 0 0.25rem;
  }

  .page-connect .hero .container {
    min-height: 26rem;
  }

  .page-connect .hero::after {
    background-position: right -30rem top 4.5rem;
    background-size: clamp(70rem, 106vw, 92rem);
  }

  .page-connect .brand {
    width: min(100%, 36rem);
    margin-top: 6rem;
  }

  .page-connect .brand-logo {
    width: clamp(26rem, 34vw, 34rem);
  }

  .page-connect .brand p {
    max-width: 33rem;
    font-size: 1.14rem;
  }

  .page-connect .panel {
    padding: 2.75rem 3rem;
    border-radius: 1.75rem;
  }

  .page-connect .panel .subtitle,
  .page-connect .feature h4 {
    font-size: 1.3125rem;
  }

  .page-connect .feature {
    grid-template-columns: 3.75rem minmax(0, 1fr);
    gap: 1.25rem;
    align-items: center;
  }

  .page-connect .feature-icon {
    width: 3.75rem;
    height: 3.75rem;
  }

  .page-connect .voices h3,
  .page-connect .partners h3 {
    text-align: left;
    margin-bottom: 2.25rem;
  }

  .page-connect .speakers {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .page-connect .partners-board {
    width: min(100%, 74rem);
  }

  .page-connect .partners-row {
    gap: 1.7rem;
  }

  .page-connect .partners-row--compact {
    gap: 1.95rem;
  }

  .page-connect .cta {
    padding: 5.75rem 0 11rem;
  }

  .page-connect .cta .container {
    transform: translateY(-3.5rem);
  }

  .page-connect .cta::before {
    width: min(100rem, 185vw);
    height: 40rem;
    bottom: -22rem;
  }
}

@media (max-width: 30rem) {
  .page-connect .partners-board {
    width: min(100%, 24rem);
    padding-inline: 0;
  }

  .page-connect .partners-row {
    gap: 0.85rem 1rem;
  }

  .page-connect .partners-row + .partners-row {
    margin-top: 1.35rem;
  }

  .page-connect .partners-row--compact {
    gap: 0.8rem 1.15rem;
  }

  .page-connect .partner-item {
    width: min(var(--logo-width-mobile, var(--logo-width-desktop)), 44vw);
  }
}

@media (min-width: 48rem) and (max-width: 63.9375rem) {
  .page-connect .hero {
    min-height: 31rem;
    padding: 8rem 0 0.35rem;
  }

  .page-connect .hero .container {
    min-height: 24rem;
  }

  .page-connect .hero::after {
    background-position: right -34.5rem top 4.5rem;
    background-size: clamp(64rem, 125vw, 82rem);
  }
}

@media (min-width: 75rem) {
  .page-connect .topbar {
    width: var(--topbar-width);
  }

  .page-connect .hero {
    padding: 8.5rem 0 0.75rem;
  }

  .page-connect .speakers {
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 1.25rem;
  }

}

@media (min-width: 87.5rem) {
  .page-connect {
    --section-offset: 8rem;
    --topbar-width: min(1440px, 90vw);
  }

  .page-connect .topbar {
    min-height: 4.875rem;
    padding-inline: 2rem;
  }

  .page-connect .topbar-logo {
    height: 2rem;
  }

  .page-connect .topbar-links a {
    font-size: 1.18rem;
  }

  .page-connect .hero {
    min-height: 38rem;
    padding: 8.75rem 0 0.1rem;
  }

  .page-connect .hero .container {
    min-height: 29rem;
  }

  .page-connect .hero::after {
    background-position: right -29rem top 4.75rem;
    background-size: clamp(78rem, 98vw, 100rem);
  }

  .page-connect .brand {
    width: min(100%, 38rem);
    margin-top: 6.75rem;
    gap: 1.25rem;
  }

  .page-connect .brand-logo {
    width: clamp(24rem, 34vw, 38rem);
  }

  .page-connect .brand p {
    max-width: 36rem;
    font-size: 1.18rem;
  }

  .page-connect .panel {
    padding: 3rem 3.25rem;
    border-radius: 1.9rem;
  }

  .page-connect .panel h3 {
    font-size: 2.55rem;
  }

  .page-connect .panel .subtitle {
    font-size: 1.5rem;
    margin-bottom: 1.65rem;
  }

  .page-connect .features {
    gap: 1.25rem;
  }

  .page-connect .feature {
    grid-template-columns: 4rem minmax(0, 1fr);
    gap: 1.35rem;
  }

  .page-connect .feature-icon {
    width: 4rem;
    height: 4rem;
  }

  .page-connect .feature h4 {
    font-size: 1.42rem;
  }

  .page-connect .feature p {
    font-size: 1.05rem;
  }

  .page-connect .section-title {
    margin-bottom: 2rem;
    gap: 0.9rem;
  }

  .page-connect .section-title .title-regular,
  .page-connect .section-title .light {
    font-size: clamp(2.4rem, 3vw, 3.5rem);
  }

  .page-connect .section-logo {
    height: 1.7rem;
  }

  .page-connect .video-box {
    max-width: 68rem;
    border-radius: 1.5rem;
  }

  .page-connect .voices,
  .page-connect .partners {
    margin-top: 4.5rem;
  }

  .page-connect .voices h3,
  .page-connect .partners h3 {
    font-size: clamp(2.35rem, 3vw, 3.35rem);
  }

  .page-connect .speakers {
    gap: 1.35rem;
  }

  .page-connect .speaker-badge {
    width: 5.1rem;
    height: 5.1rem;
  }

  .page-connect .speaker-badge text {
    font-size: 0.9rem;
  }

  .page-connect .speaker-info {
    padding: 1.2rem 1.1rem 1.3rem;
  }

  .page-connect .speaker h4 {
    font-size: 1.12rem;
  }

  .page-connect .speaker p {
    font-size: 0.9rem;
  }

  .page-connect .event-note {
    margin-top: 2rem;
    margin-bottom: 3rem;
    padding: 2rem 1.75rem;
  }

  .page-connect .event-note h3 {
    font-size: clamp(2rem, 2.8vw, 2.8rem);
  }

  .page-connect .event-note p {
    font-size: 1.12rem;
  }

  .page-connect .cta {
    padding: 6.25rem 0 11.75rem;
  }

  .page-connect .cta .container {
    transform: translateY(-3.75rem);
  }

  .page-connect .cta::before {
    width: min(108rem, 175vw);
    height: 43rem;
    bottom: -23rem;
  }

  .page-connect .cta p {
    max-width: 46rem;
    font-size: 1.55rem;
  }

  .page-connect .cta-logo {
    width: clamp(11rem, 16vw, 18rem);
  }

  .page-connect .footer-inner {
    min-height: 5.25rem;
  }

  .page-connect .footer-logo {
    width: 8rem;
  }
}

@media (min-width: 112.5rem) {
  .page-connect {
    --topbar-width: min(1560px, 88vw);
  }

  .page-connect .hero {
    min-height: clamp(42rem, 84svh, 54rem);
    padding: 9rem 0 0.5rem;
  }

  .page-connect .hero .container {
    min-height: 34rem;
  }

  .page-connect .hero::after {
    background-position: right -34rem top 5rem;
    background-size: 100rem;
  }

  .page-connect .brand {
    margin-top: 7rem;
  }

  .page-connect .brand-logo {
    width: 40rem;
  }

  .page-connect .brand p {
    max-width: 38rem;
    font-size: 1.22rem;
  }

  .page-connect .speakers {
    gap: 1.5rem;
  }

  .page-connect .cta::before {
    width: 112rem;
    height: 45rem;
    bottom: -24rem;
  }
}

@media (min-width: 160rem) {
  .page-connect .hero::after {
    background-position: right -36rem top 4.75rem;
    background-size: 108rem;
  }

  .page-connect .brand {
    margin-top: 9.4rem;
  }

  .page-connect .brand-logo {
    width: 47rem;
  }

  .page-connect .brand p {
    max-width: 42rem;
    font-size: 1.36rem;
  }
}

@media (min-width: 240rem) {
  .page-connect .hero::after {
    background-position: right -44rem top 4.75rem;
    background-size: 210rem;
  }

  .page-connect .brand-logo {
    width: 62rem;
  }

  .page-connect .brand {
    margin-top: 14rem;
  }

  .page-connect .brand p {
    max-width: 52rem;
    font-size: 1.75rem;
  }
}

@media (max-height: 35rem) and (orientation: landscape) {
  .page-connect .hero {
    min-height: auto;
    padding: 6.25rem 0 3.5rem;
  }

  .page-connect .brand {
    margin-top: 1rem;
  }

  .page-connect .topbar-links {
    max-height: calc(100svh - 4.5rem);
  }
}
