/* ============================================== */
/* Navbar Styles - ConneCT                        */
/* ============================================== */

#mainNavbar {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 100%
  );
  padding: 1rem 0;
  transition: var(--transition-fast);
  box-shadow: 0 2px 15px rgba(15, 92, 140, 0.15);
}

#mainNavbar.navbar-scrolled {
  background: linear-gradient(
    135deg,
    rgba(4, 41, 64, 0.98) 0%,
    rgba(15, 92, 140, 0.98) 100%
  );
  padding: 0.75rem 0;
  box-shadow: 0 4px 25px rgba(15, 92, 140, 0.25);
}

/* Logo */
#mainNavbar .navbar-logo {
  height: 50px;
  width: auto;
  transition: var(--transition-fast);
  filter: brightness(1);
}

#mainNavbar .navbar-logo:hover {
  filter: brightness(1.15);
  transform: scale(1.05);
}

#mainNavbar .navbar-brand {
  padding-right: 1rem;
}

#mainNavbar.navbar-scrolled .navbar-logo {
  height: 42px;
}

/* Navigation Links */
#mainNavbar .nav-link {
  color: var(--branco-gelo);
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 1rem;
  padding: 0.5rem 1rem;
  position: relative;
  transition: var(--transition-fast);
  text-transform: capitalize;
}

#mainNavbar .nav-link::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--azul-claro), var(--azul-suave));
  transition: var(--transition-fast);
  transform: translateX(-50%);
  border-radius: 2px;
}

#mainNavbar .nav-link:hover,
#mainNavbar .nav-link.active {
  color: var(--azul-suave);
}

#mainNavbar .nav-link:hover::after,
#mainNavbar .nav-link.active::after {
  width: 70%;
}

/* Dropdown Menu */
#mainNavbar .dropdown-menu {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo),
    var(--azul-principal)
  );
  border: 2px solid var(--azul-claro);
  border-radius: 12px;
  padding: 0.5rem 0;
  margin-top: 0.5rem;
  box-shadow: 0 8px 24px rgba(15, 92, 140, 0.3);
  animation: dropdownSlide 0.3s ease-out;
}

@keyframes dropdownSlide {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#mainNavbar .dropdown-item {
  color: var(--branco-gelo);
  font-family: var(--font-primary);
  font-weight: 500;
  font-size: 0.9rem;
  padding: 0.75rem 1.5rem;
  transition: var(--transition-fast);
  position: relative;
  overflow: hidden;
}

#mainNavbar .dropdown-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 4px;
  height: 100%;
  background: linear-gradient(180deg, var(--azul-claro), var(--azul-suave));
  transform: scaleY(0);
  transition: var(--transition-fast);
}

#mainNavbar .dropdown-item:hover {
  background: rgba(84, 172, 191, 0.2);
  color: var(--azul-suave);
  padding-left: 2rem;
}

#mainNavbar .dropdown-item:hover::before {
  transform: scaleY(1);
}

#mainNavbar .dropdown-item:active,
#mainNavbar .dropdown-item.active {
  background: rgba(84, 172, 191, 0.3);
  color: var(--branco-gelo);
}

/* Auth Buttons Container */
#mainNavbar .navbar-auth-buttons {
  gap: 0.5rem;
}

/* Botão Entrar */
#mainNavbar .btn-navbar-cta {
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  border: 2px solid transparent;
  color: var(--branco-gelo);
  font-weight: 600;
  font-size: 0.9rem;
  padding: 0.5rem 1.5rem;
  border-radius: 50px;
  transition: all var(--transition-fast);
  text-transform: none;
  position: relative;
  overflow: hidden;
}

#mainNavbar .btn-navbar-cta::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  transform: translate(-50%, -50%);
  transition:
    width 0.5s,
    height 0.5s;
}

#mainNavbar .btn-navbar-cta:hover::before {
  width: 300px;
  height: 300px;
}

#mainNavbar .btn-navbar-cta:hover {
  background: linear-gradient(135deg, var(--azul-suave), var(--azul-claro));
  border-color: var(--branco-gelo);
  color: var(--azul-petroleo);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(84, 172, 191, 0.5);
}

/* Botão Cadastrar */
#mainNavbar .btn-outline-primary {
  background: transparent;
  border: 2px solid var(--azul-suave);
  color: var(--azul-suave);
  font-weight: 600;
  font-size: 0.9rem;
  padding: 0.5rem 1.5rem;
  border-radius: 50px;
  transition: all var(--transition-fast);
  text-transform: none;
  position: relative;
  overflow: hidden;
}

#mainNavbar .btn-outline-primary::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(187, 232, 242, 0.3),
    transparent
  );
  transition: left 0.5s;
}

#mainNavbar .btn-outline-primary:hover::before {
  left: 100%;
}

#mainNavbar .btn-outline-primary:hover {
  background: var(--azul-suave);
  border-color: var(--azul-suave);
  color: var(--azul-petroleo);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(187, 232, 242, 0.5);
}

/* Ícones Sociais */
.navbar-social-icons {
  gap: 0.5rem;
}

.navbar-social-icons .social-icon-link {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(187, 232, 242, 0.15);
  border: 2px solid var(--azul-suave);
  border-radius: 50%;
  color: var(--azul-suave);
  font-size: 1.1rem;
  transition: var(--transition-fast);
  text-decoration: none;
}

.navbar-social-icons .social-icon-link:hover {
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  border-color: var(--branco-gelo);
  color: var(--branco-gelo);
  transform: translateY(-3px) scale(1.1);
  box-shadow: 0 6px 20px rgba(84, 172, 191, 0.4);
}

/* Animação especial para Instagram */
.navbar-social-icons .social-icon-link:hover i.bi-instagram {
  animation: rotate-scale 0.6s ease-in-out;
}

@keyframes rotate-scale {
  0% {
    transform: rotate(0deg) scale(1);
  }

  50% {
    transform: rotate(180deg) scale(1.2);
  }

  100% {
    transform: rotate(360deg) scale(1);
  }
}

/* Navbar Spacer */
.navbar-spacer {
  height: 82px;
}

/* laptop Styles */
@media (max-width: 1366px) {
  #mainNavbar .navbar-logo {
    height: 40px;
  }

  #mainNavbar .nav-link {
    font-size: 0.8rem;
    padding: 0.5rem 0.65rem;
  }

  #mainNavbar .btn-navbar-cta,
  #mainNavbar .btn-outline-primary {
    font-size: 0.8rem;
    padding: 0.4rem 1.2rem;
  }

  #mainNavbar .navbar-auth-buttons {
    margin-left: 0.5rem;
  }

  #mainNavbar .dropdown-item {
    font-size: 0.8rem;
    padding: 0.65rem 1.25rem;
  }
}

@media (max-width: 1280px) {
  #mainNavbar .navbar-logo {
    height: 38px;
  }

  #mainNavbar .nav-link {
    font-size: 0.75rem;
    padding: 0.5rem 0.55rem;
  }

  #mainNavbar .btn-navbar-cta,
  #mainNavbar .btn-outline-primary {
    font-size: 0.75rem;
    padding: 0.35rem 1rem;
  }

  #mainNavbar .dropdown-item {
    font-size: 0.75rem;
    padding: 0.6rem 1.1rem;
  }
}

@media (max-width: 1024px) {
  #mainNavbar .navbar-logo {
    height: 36px;
  }

  #mainNavbar .nav-link {
    font-size: 0.7rem;
    padding: 0.5rem 0.5rem;
  }

  #mainNavbar .btn-navbar-cta,
  #mainNavbar .btn-outline-primary {
    font-size: 0.7rem;
    padding: 0.35rem 0.9rem;
  }

  #mainNavbar .dropdown-item {
    font-size: 0.7rem;
    padding: 0.55rem 1rem;
  }

  .navbar-social-icons .social-icon-link {
    width: 30px;
    height: 30px;
    font-size: 1rem;
  }
}

/* Mobile Styles */
@media (max-width: 991.98px) {
  #mainNavbar .navbar-collapse {
    background: linear-gradient(
      135deg,
      var(--azul-petroleo) 0%,
      var(--azul-principal) 100%
    );
    padding: 1rem;
    margin-top: 0.5rem;
    border-radius: 12px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
  }

  #mainNavbar .nav-link {
    padding: 0.85rem 0.5rem;
    border-bottom: 1px solid rgba(187, 232, 242, 0.15);
  }

  #mainNavbar .nav-link::after {
    display: none;
  }

  #mainNavbar .nav-item:last-child .nav-link {
    border-bottom: none;
  }

  /* Dropdown no mobile */
  #mainNavbar .dropdown-menu {
    background: linear-gradient(
      135deg,
      rgba(4, 41, 64, 0.95),
      rgba(15, 92, 140, 0.95)
    );
    border: 1px solid rgba(187, 232, 242, 0.3);
    margin-top: 0.25rem;
  }

  #mainNavbar .dropdown-item {
    font-size: 0.9rem;
    padding: 0.75rem 1rem;
  }

  /* Botões no mobile */
  #mainNavbar .navbar-auth-buttons {
    flex-direction: column;
    width: 100%;
    margin: 1rem 0 0 0;
    padding-top: 1rem;
    border-top: 1px solid rgba(187, 232, 242, 0.2);
  }

  #mainNavbar .btn-navbar-cta,
  #mainNavbar .btn-outline-primary {
    width: 100%;
    text-align: center;
    font-size: 0.95rem;
    padding: 0.75rem 1.5rem;
  }

  #mainNavbar .btn-navbar-cta {
    margin-bottom: 0.5rem;
  }

  /* Ícones sociais no mobile */
  .navbar-social-icons {
    justify-content: center;
    padding: 1rem 0;
    margin-top: 1rem;
    border-top: 1px solid rgba(187, 232, 242, 0.2);
    gap: 1rem;
  }

  .navbar-social-icons .social-icon-link {
    width: 45px;
    height: 45px;
    font-size: 1.2rem;
  }

  .navbar-spacer {
    height: 70px;
  }
}

/* Toggler customizado */
#mainNavbar .navbar-toggler {
  border-color: rgba(187, 232, 242, 0.5);
  padding: 0.4rem 0.6rem;
}

#mainNavbar .navbar-toggler:focus {
  box-shadow: 0 0 0 0.2rem rgba(84, 172, 191, 0.3);
}

#mainNavbar .navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28187, 232, 242, 1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* ================================================
SEÇÃO HERO - #hero
================================================ */

#hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  background: url("/assets/img/img/bkg-home.png") no-repeat center center;
  background-size: cover;
  overflow: hidden;
}

/* Background decorativo */
#hero .hero__bg-shape {
  position: absolute;
  top: -150px;
  right: -150px;
  width: 700px;
  height: 700px;
  background: radial-gradient(
    circle,
    var(--azul-suave) 0%,
    var(--azul-claro) 50%,
    transparent 70%
  );
  opacity: 0.2;
  border-radius: 50%;
  z-index: -1;
  animation: float 25s ease-in-out infinite;
  filter: blur(40px);
}

#hero .hero__bg-shape::before {
  content: "";
  position: absolute;
  bottom: -200px;
  left: -200px;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    var(--azul-principal) 0%,
    transparent 70%
  );
  opacity: 0.15;
  border-radius: 50%;
  animation: float 20s ease-in-out infinite reverse;
  filter: blur(50px);
}

@keyframes float {
  0%,
  100% {
    transform: translate(0, 0) rotate(0deg) scale(1);
  }

  25% {
    transform: translate(30px, -30px) rotate(5deg) scale(1.05);
  }

  50% {
    transform: translate(-20px, 20px) rotate(-5deg) scale(0.95);
  }

  75% {
    transform: translate(25px, 25px) rotate(3deg) scale(1.02);
  }
}

/* Container de conteúdo */
#hero .hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
}

/* Headline - H1 */
#hero .hero__headline {
  font-family: var(--font-primary);
  font-size: 4rem;
  font-weight: 700;
  color: var(--azul-preto);
  line-height: 1.2;
  margin-bottom: 2rem;
  letter-spacing: -0.02em;
}

#hero .hero__headline-destaque {
  color: var(--azul-principal);
  position: relative;
  display: inline-block;
}

#hero .hero__headline-destaque::after {
  content: "";
  position: absolute;
  bottom: 8px;
  left: 0;
  width: 100%;
  height: 12px;
  background: var(--azul-suave);
  opacity: 0.5;
  z-index: -1;
  transform: skewX(-5deg);
}

/* Subheadline - H2 */
#hero .hero__subheadline {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 400;
  color: var(--azul-petroleo);
  line-height: 1.7;
  margin-bottom: 3rem;
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

/* CTAs */
#hero .hero__ctas {
  display: flex;
  flex-wrap: wrap;
  gap: 2.5rem;
  margin-bottom: 4rem;
  justify-content: center;
}

#hero .hero__cta-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  align-items: center;
}

#hero .hero__cta-microcopy {
  font-family: var(--font-primary);
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--azul-petroleo);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

#hero .hero__cta-btn {
  padding: 1rem 2.5rem;
  font-size: 1.0625rem;
  font-weight: 600;
  border-radius: 50px;
  transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.2);
  position: relative;
  overflow: hidden;
  min-width: 200px;
}

#hero .hero__cta-btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  transform: translate(-50%, -50%);
  transition:
    width 0.6s ease,
    height 0.6s ease;
}

#hero .hero__cta-btn:hover {
  transform: translateY(-4px) scale(1.03);
  box-shadow: 0 10px 30px rgba(15, 92, 140, 0.45);
}

#hero .hero__cta-btn:hover::before {
  width: 400px;
  height: 400px;
}

#hero .hero__cta-btn:active {
  transform: translateY(-1px) scale(0.98);
  box-shadow: 0 5px 20px rgba(15, 92, 140, 0.35);
}

#hero .hero__cta-btn i {
  font-size: 1.125rem;
  transition: transform 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

#hero .hero__cta-btn:hover i {
  transform: scale(1.15) rotate(-8deg);
}

/* Botão outline específico */
#hero .btn-outline-primary.hero__cta-btn {
  background: transparent;
  border: 2px solid var(--azul-principal);
  color: var(--azul-principal);
}

#hero .btn-outline-primary.hero__cta-btn::before {
  background: var(--azul-principal);
  opacity: 0.1;
}

#hero .btn-outline-primary.hero__cta-btn:hover {
  background: var(--azul-principal);
  color: white;
  border-color: var(--azul-principal);
  box-shadow: 0 10px 30px rgba(15, 92, 140, 0.45);
}

/* Steps Cards */
#hero .hero__steps {
  max-width: 1200px;
  margin: 0 auto;
}

#hero .hero__steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}

#hero .hero__step-card {
  background: white;
  border-radius: 16px;
  padding: 2rem 1.5rem;
  text-align: center;
  box-shadow: 0 4px 20px rgba(15, 92, 140, 0.1);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  border: 2px solid transparent;
  position: relative;
  overflow: hidden;
}

#hero .hero__step-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(
    90deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s ease;
}

#hero .hero__step-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 35px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-suave);
}

#hero .hero__step-card:hover::before {
  transform: scaleX(1);
}

#hero .hero__step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  color: white;
  font-size: 1.75rem;
  font-weight: 700;
  border-radius: 50%;
  margin: 0 auto 1.25rem;
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.3);
  transition: all 0.4s cubic-bezier(0.68, -0.55, 0.265, 1.55);
}

#hero .hero__step-card:hover .hero__step-number {
  transform: scale(1.15) rotate(360deg);
  box-shadow: 0 6px 20px rgba(15, 92, 140, 0.5);
}

#hero .hero__step-text {
  font-family: var(--font-primary);
  font-size: 0.9375rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

/* Título dos step cards */
#hero .hero__step-title {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--azul-preto);
  margin: 0 0 0.6rem;
  line-height: 1.3;
}

/* Logos institucionais */
#hero .hero__logos {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  margin-top: 2.5rem;
}

#hero .hero__logos-label {
  font-family: var(--font-primary);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  opacity: 0.65;
}

#hero .hero__logos-list {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.5rem;
  flex-wrap: wrap;
}

#hero .hero__logo-img {
  height: 48px;
  width: auto;
  object-fit: contain;
  opacity: 0.75;
  filter: grayscale(20%);
  transition:
    opacity 0.3s ease,
    filter 0.3s ease;
}

#hero .hero__logo-img:hover {
  opacity: 1;
  filter: grayscale(0%);
}

/* ================================================ */
/* Carousel Hint - Hero Section                     */
/* ================================================ */

#hero .carousel-hint {
  position: absolute;
  bottom: -45px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0, 123, 255, 0.9);
  color: white;
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 500;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  z-index: 10;
  animation: fadeInOut 4s ease-in-out;
}

#hero .carousel-hint i {
  margin-right: 8px;
}

#desafio-ao-projeto .carousel-hint {
  position: absolute;
  bottom: -45px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0, 123, 255, 0.9);
  color: white;
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 0.85rem;
  font-weight: 500;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  z-index: 10;
  animation: fadeInOut 4s ease-in-out;
}

#desafio-ao-projeto .carousel-hint i {
  margin-right: 8px;
}

@keyframes fadeInOut {
  0% {
    opacity: 0;
    transform: translateX(-100%) translateY(0);
  }
  10% {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
  90% {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
  100% {
    opacity: 0;
    transform: translateX(-50%) translateY(0);
  }
}

/* ================================================
       RESPONSIVIDADE
       ================================================ */

/* Tablets - 992px */
@media (max-width: 991.98px) {
  #hero {
    min-height: auto;
  }

  #hero .hero__headline {
    font-size: 3.25rem;
    margin-bottom: 1.75rem;
  }

  #hero .hero__subheadline {
    font-size: 1.125rem;
    margin-bottom: 2.5rem;
  }

  #hero .hero__ctas {
    gap: 2rem;
    margin-bottom: 3.5rem;
  }

  #hero .hero__steps-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.25rem;
  }

  #hero .hero__step-card {
    padding: 1.75rem 1.25rem;
  }
}

/* Mobile - 768px */
@media (max-width: 767.98px) {
  #hero .hero__headline {
    font-size: 2.5rem;
    margin-bottom: 1.5rem;
  }

  #hero .hero__subheadline {
    font-size: 1.0625rem;
    margin-bottom: 2.5rem;
  }

  #hero .hero__ctas {
    flex-direction: column;
    gap: 2rem;
    margin-bottom: 3rem;
  }

  #hero .hero__cta-btn {
    width: 100%;
    padding: 1.125rem;
  }

  #hero .hero__steps-grid {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }

  #hero .hero__step-card {
    padding: 1.5rem 1.25rem;
  }

  #hero .hero__step-number {
    width: 48px;
    height: 48px;
    font-size: 1.5rem;
    margin-bottom: 1rem;
  }

  #hero .hero__step-text {
    font-size: 0.9375rem;
  }

  #hero .hero__bg-shape {
    width: 500px;
    height: 500px;
  }
}

/* Mobile pequeno - 576px */
@media (max-width: 575.98px) {
  #hero .hero__headline {
    font-size: 2rem;
  }

  #hero .hero__headline-destaque::after {
    height: 8px;
    bottom: 5px;
  }

  #hero .hero__subheadline {
    font-size: 0.9375rem;
    margin-bottom: 2rem;
  }

  #hero .hero__ctas {
    gap: 1.5rem;
    margin-bottom: 2.5rem;
  }

  #hero .hero__cta-microcopy {
    font-size: 0.8125rem;
  }

  #hero .hero__cta-btn {
    padding: 1rem;
  }

  #hero .hero__steps-grid {
    gap: 1rem;
  }

  #hero .hero__step-card {
    padding: 1.5rem 1rem;
  }

  #hero .hero__step-number {
    width: 44px;
    height: 44px;
    font-size: 1.375rem;
    margin-bottom: 0.875rem;
  }

  #hero .hero__step-text {
    font-size: 0.875rem;
  }

  #hero .hero__bg-shape {
    width: 400px;
    height: 400px;
  }
}

/* Animações AOS - Ajustes específicos */
#hero [data-aos="fade-up"] {
  transform: translateY(40px);
  opacity: 0;
}

#hero [data-aos].aos-animate {
  transform: translate(0);
  opacity: 1;
}

/* Tablet (md) - Padronizar altura dos cards no carousel */
@media (min-width: 768px) and (max-width: 991.98px) {
  #hero .hero__step-card {
    min-height: 220px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}

/* ============================================== */
/* SEÇÃO: Desafios - ConneCT                      */
/* ============================================== */

#desafios {
  background: linear-gradient(
    135deg,
    rgba(187, 232, 242, 0.2) 0%,
    var(--branco-gelo) 100%
  );
  position: relative;
  overflow: hidden;
}

/* Efeito decorativo de fundo */
#desafios::before {
  content: "";
  position: absolute;
  top: -50px;
  right: -50px;
  width: 300px;
  height: 300px;
  background: radial-gradient(
    circle,
    rgba(0, 131, 113, 0.08) 0%,
    transparent 70%
  );
  border-radius: 50%;
  z-index: 0;
}

#desafios::after {
  content: "";
  position: absolute;
  bottom: -50px;
  left: -50px;
  width: 300px;
  height: 300px;
  background: radial-gradient(
    circle,
    rgba(102, 51, 153, 0.08) 0%,
    transparent 70%
  );
  border-radius: 50%;
  z-index: 0;
}

#desafios .container-fluid {
  position: relative;
  z-index: 1;
  padding-left: 40px;
  padding-right: 40px;
}

@media (max-width: 767.98px) {
  #desafios .container-fluid {
    padding-left: 15px;
    padding-right: 15px;
  }
}

/* Título Principal */
#desafios .desafios__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--dark);
  font-family: var(--font-heading);
  line-height: 1.3;
}

#desafios .desafios__highlight {
  background: linear-gradient(
    90deg,
    var(--primary) 0%,
    var(--secondary) 50%,
    var(--primary) 100%
  );
  background-size: 200% auto;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: text-shine 3s ease-in-out infinite;
  position: relative;
  display: inline-block;
}

@keyframes text-shine {
  0% {
    background-position: 0% center;
  }

  50% {
    background-position: 100% center;
  }

  100% {
    background-position: 0% center;
  }
}

#desafios .desafios__highlight::after {
  content: "";
  position: absolute;
  bottom: 5px;
  left: 0;
  width: 100%;
  height: 12px;
  background: linear-gradient(
    90deg,
    rgba(0, 131, 113, 0.2),
    rgba(102, 51, 153, 0.2)
  );
  z-index: -1;
  border-radius: 4px;
}

/* Subtítulo */
#desafios .desafios__subtitle {
  font-size: 1.1rem;
  color: var(--text-secondary);
  max-width: 700px;
  margin: 0 auto;
  line-height: 1.6;
}

/* Swiper Wrapper */
#desafios .desafios__swiper-wrapper {
  position: relative;
  width: 100%;
}

#desafios .swiper-wrapper {
  display: flex;
  align-items: stretch;
}

#desafios .swiper-slide {
  height: auto;
  display: flex;
  width: 380px !important;
  flex-shrink: 0;
}

/* Desktop Grande - mais cards visíveis */
@media (min-width: 1600px) {
  #desafios .swiper-slide {
    width: 400px !important;
  }
}

/* Tablet */
@media (min-width: 768px) and (max-width: 1023.98px) {
  #desafios .swiper-slide {
    width: 350px !important;
  }
}

/* Mobile */
@media (max-width: 767.98px) {
  #desafios .swiper-slide {
    width: 320px !important;
  }
}

#desafios .swiper {
  padding: 40px 0;
  margin: 0 auto;
  width: 100%;
}

@media (min-width: 1400px) {
  #desafios .swiper {
    padding: 40px 60px;
  }
}

@media (max-width: 1280px) {
  #desafios .swiper {
    padding: 40px 20px;
  }
}

@media (max-width: 767.98px) {
  #desafios .swiper {
    padding: 20px 0;
  }
}

/* Banner de Desafio */
#desafios .desafios__banner {
  display: flex;
  flex-direction: column;
  position: relative;
  width: 100%;
  height: 100%;
  border-radius: 20px;
  overflow: hidden;
  text-decoration: none;
  transition: var(--transition-medium);
  box-shadow: 0 5px 25px rgba(0, 0, 0, 0.08);
  background: white;
}

#desafios .desafios__banner:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.25);
}

/* Área de Imagem do Banner */
#desafios .desafios__banner::before {
  content: "";
  display: block;
  width: 100%;
  height: 250px;
  background-image: inherit;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: var(--transition-slow);
}

#desafios .desafios__banner:hover::before {
  transform: scale(1.08);
}

/* Overlay Gradient do Banner */
#desafios .desafios__banner-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 250px;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.3) 100%);
  opacity: 0;
  transition: var(--transition-medium);
  z-index: 1;
}

#desafios .desafios__banner:hover .desafios__banner-overlay {
  opacity: 1;
}

/* Conteúdo do Banner */
#desafios .desafios__banner-content {
  position: relative;
  z-index: 2;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  padding: 25px;
  background: white;
}

/* Título do Banner */
#desafios .desafios__banner-title {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 15px;
  font-family: var(--font-primary);
  line-height: 1.4;
  min-height: 60px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Prazo de Entrega do Banner */
#desafios .desafios__banner-prazo {
  display: flex;
  align-items: center;
  font-size: 0.95rem;
  color: var(--primary);
  font-weight: 600;
  margin-bottom: 15px;
  padding: 8px 12px;
  background: rgba(15, 92, 140, 0.08);
  border-radius: 8px;
  width: fit-content;
}

#desafios .desafios__banner-prazo i {
  font-size: 1rem;
}

/* Descrição do Banner */
#desafios .desafios__banner-description {
  font-size: 0.95rem;
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 20px;
  flex-grow: 1;
  min-height: 80px;
}

/* Botão do Banner */
#desafios .desafios__banner-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 28px;
  background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
  color: white;
  text-decoration: none;
  border-radius: 50px;
  font-weight: 600;
  font-size: 0.95rem;
  transition: var(--transition-medium);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.3);
  position: relative;
  overflow: hidden;
  width: 100%;
  text-align: center;
}

#desafios .desafios__banner-btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.2),
    transparent
  );
  transition: left 0.5s ease;
}

#desafios .desafios__banner:hover .desafios__banner-btn {
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(15, 92, 140, 0.4);
  color: white;
}

#desafios .desafios__banner:hover .desafios__banner-btn::before {
  left: 100%;
}

#desafios .desafios__banner-btn i {
  transition: var(--transition-fast);
}

#desafios .desafios__banner:hover .desafios__banner-btn i {
  transform: translateX(5px);
}

/* Botão Ver Todos */
#desafios .desafios__btn-all {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 15px 40px;
  background: transparent;
  color: var(--primary);
  text-decoration: none;
  border: 2px solid var(--primary);
  border-radius: 50px;
  font-weight: 600;
  font-size: 1rem;
  transition: var(--transition-medium);
  position: relative;
  overflow: hidden;
}

#desafios .desafios__btn-all::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
  transition: left 0.4s ease;
  z-index: -1;
}

#desafios .desafios__btn-all:hover {
  color: white;
  border-color: var(--primary);
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(0, 131, 113, 0.3);
}

#desafios .desafios__btn-all:hover::before {
  left: 0;
}

#desafios .desafios__btn-all i {
  transition: var(--transition-fast);
}

#desafios .desafios__btn-all:hover i {
  transform: translateX(5px);
}

/* Estado Vazio */
#desafios .desafios__empty {
  padding: 60px 20px;
  text-align: center;
  background: white;
  border-radius: 20px;
  box-shadow: 0 5px 25px rgba(0, 0, 0, 0.08);
}

#desafios .desafios__empty i {
  font-size: 3rem;
  color: var(--primary);
  opacity: 0.5;
}

#desafios .desafios__empty p {
  font-size: 1.1rem;
  color: var(--text-secondary);
  margin: 0;
}

/* Customização Swiper - Navegação */
#desafios .desafios__swiper-next,
#desafios .desafios__swiper-prev {
  width: 50px;
  height: 50px;
  background: white;
  border-radius: 50%;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  color: var(--primary);
  transition: var(--transition-medium);
}

/* Telas grandes - botões mais visíveis */
@media (min-width: 1400px) {
  #desafios .desafios__swiper-next,
  #desafios .desafios__swiper-prev {
    width: 55px;
    height: 55px;
  }

  #desafios .desafios__swiper-next::after,
  #desafios .desafios__swiper-prev::after {
    font-size: 22px;
  }
}

#desafios .desafios__swiper-next::after,
#desafios .desafios__swiper-prev::after {
  font-size: 20px;
  font-weight: bold;
}

#desafios .desafios__swiper-next:hover,
#desafios .desafios__swiper-prev:hover {
  background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
  color: white;
  transform: scale(1.1);
}

/* Customização Swiper - Paginação */
#desafios .desafios__swiper-pagination {
  margin-top: 30px;
  position: relative;
}

#desafios .desafios__swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background: var(--dark);
  opacity: 0.3;
  transition: var(--transition-medium);
}

#desafios .desafios__swiper-pagination .swiper-pagination-bullet-active {
  background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);
  opacity: 1;
  width: 35px;
  border-radius: 6px;
}

/* Responsividade */
@media (max-width: 991.98px) {
  #desafios .desafios__title {
    font-size: 2rem;
  }

  #desafios .desafios__banner::before {
    height: 220px;
  }

  #desafios .desafios__banner-overlay {
    height: 220px;
  }
}

@media (max-width: 767.98px) {
  #desafios .desafios__title {
    font-size: 1.8rem;
  }

  #desafios .desafios__subtitle {
    font-size: 1rem;
  }

  #desafios .desafios__banner::before {
    height: 200px;
  }

  #desafios .desafios__banner-overlay {
    height: 200px;
  }

  #desafios .desafios__banner-title {
    font-size: 1.2rem;
    min-height: auto;
  }

  #desafios .desafios__swiper-next,
  #desafios .desafios__swiper-prev {
    width: 40px;
    height: 40px;
  }

  #desafios .desafios__swiper-next::after,
  #desafios .desafios__swiper-prev::after {
    font-size: 16px;
  }
}

@media (max-width: 575.98px) {
  #desafios .desafios__title {
    font-size: 1.6rem;
  }

  #desafios .desafios__btn-all {
    padding: 12px 30px;
    font-size: 0.95rem;
  }
}

/* ============================================== */
/* SEÇÃO: O que é o ConneCT - ConneCT             */
/* ============================================== */

#o-que-e-connect {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 50%,
    var(--azul-petroleo) 100%
  );
  position: relative;
  overflow: hidden;
}

/* Efeito decorativo de fundo */
#o-que-e-connect::before {
  content: "";
  position: absolute;
  top: -100px;
  left: -100px;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(84, 172, 191, 0.08) 0%,
    transparent 70%
  );
  border-radius: 50%;
  z-index: 0;
}

#o-que-e-connect::after {
  content: "";
  position: absolute;
  bottom: -100px;
  right: -100px;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(187, 232, 242, 0.06) 0%,
    transparent 70%
  );
  border-radius: 50%;
  z-index: 0;
}

#o-que-e-connect .container {
  position: relative;
  z-index: 1;
}

/* Título Principal */
#o-que-e-connect .o-que-e-connect__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: white;
  font-family: var(--font-heading);
  line-height: 1.3;
}

#o-que-e-connect .o-que-e-connect__highlight {
  color: white;
  position: relative;
  display: inline-block;
}

#o-que-e-connect .o-que-e-connect__highlight::after {
  content: "";
  position: absolute;
  bottom: 5px;
  left: 0;
  width: 100%;
  height: 12px;
  background: rgba(255, 255, 255, 0.3);
  z-index: -1;
  border-radius: 4px;
}

/* Texto Corrido */
#o-que-e-connect .o-que-e-connect__text {
  text-align: center;
  max-width: 100%;
}

#o-que-e-connect .o-que-e-connect__text p {
  font-size: 1.1rem;
  line-height: 1.8;
  color: white;
  margin-bottom: 1.2rem;
}

#o-que-e-connect .o-que-e-connect__text p:last-child {
  margin-bottom: 0;
}

/* CTA Secundário */
#o-que-e-connect .o-que-e-connect__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 35px;
  background: transparent;
  color: white;
  text-decoration: none;
  border: 2px solid white;
  border-radius: 50px;
  font-weight: 600;
  font-size: 1rem;
  transition: var(--transition-medium);
  position: relative;
  overflow: hidden;
}

#o-que-e-connect .o-que-e-connect__cta::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    135deg,
    var(--azul-claro) 0%,
    var(--azul-suave) 100%
  );
  transition: left 0.4s ease;
  z-index: -1;
}

#o-que-e-connect .o-que-e-connect__cta:hover {
  color: var(--azul-petroleo);
  border-color: white;
  transform: translateY(-2px);
  box-shadow: 0 6px 25px rgba(255, 255, 255, 0.3);
}

#o-que-e-connect .o-que-e-connect__cta:hover::before {
  left: 0;
}

#o-que-e-connect .o-que-e-connect__cta i {
  transition: var(--transition-fast);
}

#o-que-e-connect .o-que-e-connect__cta:hover i {
  transform: translateX(5px);
}

/* Responsividade */
@media (max-width: 991.98px) {
  #o-que-e-connect .o-que-e-connect__title {
    font-size: 2rem;
  }

  #o-que-e-connect .o-que-e-connect__text p {
    font-size: 1.05rem;
  }
}

@media (max-width: 767.98px) {
  #o-que-e-connect .o-que-e-connect__title {
    font-size: 1.8rem;
  }

  #o-que-e-connect .o-que-e-connect__text p {
    font-size: 1rem;
  }

  #o-que-e-connect .o-que-e-connect__cta {
    padding: 12px 28px;
    font-size: 0.95rem;
  }
}

@media (max-width: 575.98px) {
  #o-que-e-connect .o-que-e-connect__title {
    font-size: 1.6rem;
  }

  #o-que-e-connect .o-que-e-connect__text p {
    font-size: 0.95rem;
  }

  #o-que-e-connect .o-que-e-connect__cta {
    padding: 10px 24px;
    font-size: 0.9rem;
  }
}

/* ============================================== */
/* SEÇÃO: Do desafio ao projeto - ConneCT         */
/* ============================================== */

#desafio-ao-projeto {
  background: var(--branco-gelo);
  position: relative;
  overflow: hidden;
}

/* Efeito decorativo de fundo */
#desafio-ao-projeto::before {
  content: "";
  position: absolute;
  top: -100px;
  left: -100px;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(15, 92, 140, 0.05) 0%,
    transparent 70%
  );
  border-radius: 50%;
  z-index: 0;
}

#desafio-ao-projeto::after {
  content: "";
  position: absolute;
  bottom: -100px;
  right: -100px;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(84, 172, 191, 0.05) 0%,
    transparent 70%
  );
  border-radius: 50%;
  z-index: 0;
}

#desafio-ao-projeto .container {
  position: relative;
  z-index: 1;
}

/* Título Principal */
#desafio-ao-projeto .desafio-ao-projeto__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--dark);
  font-family: var(--font-heading);
  line-height: 1.3;
}

#desafio-ao-projeto .desafio-ao-projeto__highlight {
  background: linear-gradient(
    90deg,
    var(--primary) 0%,
    var(--secondary) 50%,
    var(--primary) 100%
  );
  background-size: 200% auto;
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: text-shine 3s ease-in-out infinite;
  position: relative;
  display: inline-block;
}

@keyframes text-shine {
  0% {
    background-position: 0% center;
  }

  50% {
    background-position: 100% center;
  }

  100% {
    background-position: 0% center;
  }
}

#desafio-ao-projeto .desafio-ao-projeto__highlight::after {
  content: "";
  position: absolute;
  bottom: 5px;
  left: 0;
  width: 100%;
  height: 12px;
  background: linear-gradient(
    90deg,
    rgba(15, 92, 140, 0.2),
    rgba(84, 172, 191, 0.2)
  );
  z-index: -1;
  border-radius: 4px;
}

/* Subtítulo */
#desafio-ao-projeto .desafio-ao-projeto__subtitle {
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  max-width: 800px;
  margin: 0 auto;
  line-height: 1.7;
}

/* Timeline Container - Layout Horizontal Desktop */
#desafio-ao-projeto .desafio-ao-projeto__timeline {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2rem;
  max-width: 1400px;
  margin: 0 auto;
  position: relative;
}

/* Step Individual */
#desafio-ao-projeto .desafio-ao-projeto__step {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Card da Etapa */
#desafio-ao-projeto .desafio-ao-projeto__step-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  transition: var(--transition-medium);
  background: white;
  border-radius: 1rem;
  padding: 2rem 1.5rem;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  height: 350px;
  justify-content: flex-start;
}

#desafio-ao-projeto .desafio-ao-projeto__step-card:hover {
  transform: translateY(-10px);
}

/* Header do Step - Ícone e Número lado a lado */
#desafio-ao-projeto .desafio-ao-projeto__step-header {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1rem;
}

/* Círculo com Ícone */
#desafio-ao-projeto .desafio-ao-projeto__step-circle {
  width: 80px;
  height: 80px;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.3);
  transition: var(--transition-medium);
  position: relative;
  z-index: 2;
}

#desafio-ao-projeto
  .desafio-ao-projeto__step-card:hover
  .desafio-ao-projeto__step-circle {
  transform: scale(1.1);
  box-shadow: 0 12px 35px rgba(15, 92, 140, 0.45);
}

/* Ícone dentro do Círculo */
#desafio-ao-projeto .desafio-ao-projeto__step-icon {
  display: flex;
  align-items: center;
  justify-content: center;
}

#desafio-ao-projeto .desafio-ao-projeto__step-icon i {
  font-size: 1.5rem;
  color: white;
  transition: var(--transition-medium);
}

#desafio-ao-projeto
  .desafio-ao-projeto__step-card:hover
  .desafio-ao-projeto__step-icon
  i {
  transform: scale(1.15);
}

/* Número da Etapa */
#desafio-ao-projeto .desafio-ao-projeto__step-number {
  font-size: 1.25rem;
  font-weight: 300;
  color: rgba(15, 92, 140, 0.4);
  font-family: var(--font-heading);
  margin-left: 1rem;
  transition: var(--transition-medium);
}

#desafio-ao-projeto
  .desafio-ao-projeto__step-card:hover
  .desafio-ao-projeto__step-number {
  color: var(--azul-principal);
}

/* Linha Conectora Horizontal - Desktop */
#desafio-ao-projeto .desafio-ao-projeto__step-connector {
  position: absolute;
  top: 175px;
  left: 50%;
  width: 100%;
  height: 3px;
  background: linear-gradient(
    to right,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  z-index: -1;
}

/* Remove conector da última etapa */
#desafio-ao-projeto
  .desafio-ao-projeto__step:last-child
  .desafio-ao-projeto__step-connector {
  display: none;
}

/* Título da Etapa */
#desafio-ao-projeto .desafio-ao-projeto__step-title {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--azul-preto);
  font-family: var(--font-primary);
  margin-bottom: 0.75rem;
  line-height: 1.3;
}

/* Texto da Etapa */
#desafio-ao-projeto .desafio-ao-projeto__step-text {
  font-size: 0.9rem;
  color: var(--azul-petroleo);
  line-height: 1.7;
  margin: 0;
}

/* CTA da Seção */
#desafio-ao-projeto .desafio-ao-projeto__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 16px 40px;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  color: white;
  text-decoration: none;
  border-radius: 50px;
  font-weight: 600;
  font-size: 1.0625rem;
  transition: var(--transition-medium);
  box-shadow: 0 4px 20px rgba(15, 92, 140, 0.3);
  position: relative;
  overflow: hidden;
}

#desafio-ao-projeto .desafio-ao-projeto__cta::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  transform: translate(-50%, -50%);
  transition:
    width 0.6s ease,
    height 0.6s ease;
}

#desafio-ao-projeto .desafio-ao-projeto__cta:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 35px rgba(15, 92, 140, 0.45);
}

#desafio-ao-projeto .desafio-ao-projeto__cta:hover::before {
  width: 400px;
  height: 400px;
}

#desafio-ao-projeto .desafio-ao-projeto__cta i {
  transition: var(--transition-fast);
}

#desafio-ao-projeto .desafio-ao-projeto__cta:hover i {
  transform: translateX(5px);
}

/* Responsividade */
@media (max-width: 1024px) {
  #desafio-ao-projeto .desafio-ao-projeto__step-card {
    height: 450px;
  }
}

/* Responsividade */
@media (max-width: 991.98px) {
  #desafio-ao-projeto .desafio-ao-projeto__title {
    font-size: 2rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__subtitle {
    font-size: 1.05rem;
  }

  /* Layout vertical no tablet */
  #desafio-ao-projeto .desafio-ao-projeto__timeline {
    flex-direction: column;
    gap: 2rem;
  }

  /* Remove linha conectora no tablet */
  #desafio-ao-projeto .desafio-ao-projeto__step-connector {
    display: none;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-card {
    height: auto;
    min-height: 300px;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-circle {
    width: 70px;
    height: 70px;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-icon i {
    font-size: 1.75rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-number {
    font-size: 1.125rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-title {
    font-size: 1.3rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-text {
    font-size: 0.95rem;
  }
}

@media (max-width: 767.98px) {
  #desafio-ao-projeto .desafio-ao-projeto__title {
    font-size: 1.8rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__subtitle {
    font-size: 1rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__timeline {
    gap: 1.5rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-card {
    height: auto;
    min-height: 280px;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-circle {
    width: 60px;
    height: 60px;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-icon i {
    font-size: 1.5rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-number {
    font-size: 1rem;
    margin-left: 0.75rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-title {
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-text {
    font-size: 0.9375rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__cta {
    padding: 14px 32px;
    font-size: 1rem;
  }
}

@media (max-width: 575.98px) {
  #desafio-ao-projeto .desafio-ao-projeto__title {
    font-size: 1.6rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__subtitle {
    font-size: 0.95rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__timeline {
    gap: 1rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-card {
    height: 280px;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-circle {
    width: 55px;
    height: 55px;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-icon i {
    font-size: 1.25rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-number {
    font-size: 0.9375rem;
    margin-left: 0.5rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-title {
    font-size: 1.1rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-text {
    font-size: 0.875rem;
    padding: 0 1rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__cta {
    padding: 12px 28px;
    font-size: 0.9375rem;
    width: 100%;
  }

  /* Empilhar ícone e número no mobile */
  #desafio-ao-projeto .desafio-ao-projeto__step-header {
    flex-direction: column;
    gap: 0.5rem;
  }

  #desafio-ao-projeto .desafio-ao-projeto__step-number {
    margin-left: 0;
  }
}

/* Tablet (md) - Padronizar altura dos cards no carousel */
@media (min-width: 768px) and (max-width: 991.98px) {
  #desafio-ao-projeto .desafio-ao-projeto__step-card {
    min-height: 270px;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}

/* ============================================== */
/* SEÇÃO: Benefícios para todos - ConneCT         */
/* ============================================== */

#beneficios-para-todos {
  background: linear-gradient(
    135deg,
    var(--azul-suave) 0%,
    var(--branco-gelo) 100%
  );
  position: relative;
  overflow: hidden;
}

#beneficios-para-todos .container-fluid {
  position: relative;
  z-index: 2;
  padding-left: 3rem;
  padding-right: 3rem;
}

@media (max-width: 767.98px) {
  #beneficios-para-todos .container-fluid {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

/* ============================================== */
/* SEÇÃO: Estatísticas - ConneCT                  */
/* ============================================== */

#estatisticas {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
  padding: 80px 0;
  position: relative;
  overflow: hidden;
}

/* Título Principal */
#estatisticas .estatisticas__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 1rem;
}

#estatisticas .estatisticas__highlight {
  color: #0056b3;
  position: relative;
  display: inline-block;
}

#estatisticas .estatisticas__highlight::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, #0056b3, #007bff);
  border-radius: 2px;
}

/* Subtítulo */
#estatisticas .estatisticas__subtitle {
  font-size: 1.125rem;
  color: #6c757d;
  font-weight: 400;
}

/* Swiper Container */
#estatisticas .estatisticas__swiper-wrapper {
  position: relative;
  padding: 0 50px;
}

#estatisticas .estatisticas__swiper {
  padding: 20px 10px 60px;
}

/* Card de Estatística */
#estatisticas .estatisticas__card {
  background: #ffffff;
  border-radius: 20px;
  padding: 40px 30px;
  text-align: center;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  transition: all 0.3s ease;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

#estatisticas .estatisticas__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(0, 86, 179, 0.2);
}

/* Ícone */
#estatisticas .estatisticas__icon-wrapper {
  width: 80px;
  height: 80px;
  background: linear-gradient(135deg, #0056b3, #007bff);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  transition: all 0.3s ease;
}

#estatisticas .estatisticas__card:hover .estatisticas__icon-wrapper {
  transform: scale(1.1) rotate(5deg);
}

#estatisticas .estatisticas__icon {
  font-size: 2rem;
  color: #ffffff;
}

/* Número */
#estatisticas .estatisticas__number {
  font-size: 3rem;
  font-weight: 700;
  color: #0056b3;
  margin-bottom: 10px;
  line-height: 1;
}

/* Label */
#estatisticas .estatisticas__label {
  font-size: 1.125rem;
  font-weight: 600;
  color: #1a1a1a;
  margin: 0;
}

/* Navegação Swiper */
#estatisticas .estatisticas__swiper-next,
#estatisticas .estatisticas__swiper-prev {
  width: 45px;
  height: 45px;
  background: #0056b3;
  border-radius: 50%;
  color: #ffffff;
  transition: all 0.3s ease;
}

#estatisticas .estatisticas__swiper-next::after,
#estatisticas .estatisticas__swiper-prev::after {
  font-size: 18px;
  font-weight: bold;
}

#estatisticas .estatisticas__swiper-next:hover,
#estatisticas .estatisticas__swiper-prev:hover {
  background: #003d82;
  transform: scale(1.1);
}

/* Paginação Swiper */
#estatisticas .estatisticas__swiper-pagination {
  bottom: 20px !important;
}

#estatisticas .estatisticas__swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background: #0056b3;
  opacity: 0.3;
  transition: all 0.3s ease;
}

#estatisticas
  .estatisticas__swiper-pagination
  .swiper-pagination-bullet-active {
  opacity: 1;
  transform: scale(1.3);
  background: #0056b3;
}

/* Responsividade */
@media (max-width: 991.98px) {
  #estatisticas .estatisticas__title {
    font-size: 2rem;
  }

  #estatisticas .estatisticas__swiper-wrapper {
    padding: 0 40px;
  }
}

@media (max-width: 767.98px) {
  #estatisticas {
    padding: 60px 0;
  }

  #estatisticas .estatisticas__title {
    font-size: 1.75rem;
  }

  #estatisticas .estatisticas__subtitle {
    font-size: 1rem;
  }

  #estatisticas .estatisticas__swiper-wrapper {
    padding: 0 30px;
  }

  #estatisticas .estatisticas__card {
    padding: 30px 20px;
  }

  #estatisticas .estatisticas__number {
    font-size: 2.5rem;
  }

  #estatisticas .estatisticas__label {
    font-size: 1rem;
  }

  #estatisticas .estatisticas__icon-wrapper {
    width: 60px;
    height: 60px;
  }

  #estatisticas .estatisticas__icon {
    font-size: 1.5rem;
  }
}

/* ============================================== */
/* SEÇÃO: Benefícios para todos - ConneCT         */
/* ============================================== */

/* Título Principal */
#beneficios-para-todos .beneficios__title {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-preto);
}

#beneficios-para-todos .beneficios__highlight {
  position: relative;
  display: inline-block;
  background: linear-gradient(
    90deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 50%,
    var(--azul-principal) 100%
  );
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: text-shine 3s ease-in-out infinite;
}

#beneficios-para-todos .beneficios__highlight::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 8px;
  width: 100%;
  height: 10px;
  background: linear-gradient(90deg, var(--azul-principal), var(--azul-claro));
  border-radius: 4px;
  opacity: 0.3;
}

/* Subtítulo */
#beneficios-para-todos .beneficios__subtitle {
  font-size: 1.1rem;
  color: var(--azul-preto);
  line-height: 1.6;
  max-width: 900px;
  margin: 0 auto;
}

/* Tabs Navigation */
#beneficios-para-todos .beneficios__tabs {
  border-bottom: 3px solid rgba(15, 92, 140, 0.1);
  display: flex;
  justify-content: center;
  gap: 0;
}

#beneficios-para-todos .beneficios__tabs .nav-item {
  flex: 1;
  max-width: 300px;
}

#beneficios-para-todos .beneficios__tabs .nav-link {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--azul-principal);
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  padding: 1rem 2rem;
  transition: var(--transition-medium);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  text-align: center;
  width: 100%;
}

#beneficios-para-todos .beneficios__tabs .nav-link i {
  font-size: 1.5rem;
  transition: var(--transition-medium);
}

#beneficios-para-todos .beneficios__tabs .nav-link:hover {
  color: var(--azul-claro);
  background: rgba(84, 172, 191, 0.05);
}

#beneficios-para-todos .beneficios__tabs .nav-link:hover i {
  transform: scale(1.15);
}

#beneficios-para-todos .beneficios__tabs .nav-link.active {
  color: var(--azul-principal);
  background: rgba(84, 172, 191, 0.1);
  border-bottom-color: var(--azul-principal);
}

#beneficios-para-todos .beneficios__tabs .nav-link.active i {
  transform: scale(1.1);
}

/* Tab Content */
#beneficios-para-todos .beneficios__tab-content {
  padding: 2rem 0;
}

/* Cards de Benefícios */
#beneficios-para-todos .beneficios__card {
  background: var(--branco-gelo);
  border-radius: 12px;
  padding: 2rem;
  height: 100%;
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  border: 2px solid rgba(15, 92, 140, 0.1);
  transition: var(--transition-medium);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

#beneficios-para-todos .beneficios__card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(15, 92, 140, 0.15);
  border-color: var(--azul-claro);
}

/* Ícone Circular */
#beneficios-para-todos .beneficios__icon-circle {
  width: 70px;
  height: 70px;
  min-width: 70px;
  border-radius: 50%;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-medium);
}

#beneficios-para-todos .beneficios__card:hover .beneficios__icon-circle {
  transform: scale(1.1);
}

#beneficios-para-todos .beneficios__icon-circle i {
  font-size: 2rem;
  color: var(--branco-gelo);
}

/* Título do Card */
#beneficios-para-todos .beneficios__card-title {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--azul-preto);
  margin: 0;
  line-height: 1.5;
}

/* CTA Button */
#beneficios-para-todos .beneficios__cta {
  font-size: 1.1rem;
  font-weight: 600;
  padding: 1rem 2.5rem;
  border-radius: 50px;
  text-transform: none;
  transition: var(--transition-medium);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.2);
}

#beneficios-para-todos .beneficios__cta::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  transform: translate(-50%, -50%);
  transition:
    width 0.6s ease,
    height 0.6s ease;
}

#beneficios-para-todos .beneficios__cta:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.3);
}

#beneficios-para-todos .beneficios__cta:hover::before {
  width: 400px;
  height: 400px;
}

#beneficios-para-todos .beneficios__cta i {
  transition: var(--transition-medium);
}

#beneficios-para-todos .beneficios__cta:hover i {
  transform: translateX(5px);
}

/* ================================================ */
/* Responsividade - Tablets                         */
/* ================================================ */

@media (max-width: 991.98px) {
  #beneficios-para-todos .beneficios__title {
    font-size: 2rem;
  }

  #beneficios-para-todos .beneficios__subtitle {
    font-size: 1rem;
  }

  #beneficios-para-todos .beneficios__tabs .nav-link {
    font-size: 1rem;
    padding: 0.875rem 1.5rem;
  }

  #beneficios-para-todos .beneficios__tabs .nav-link i {
    font-size: 1.25rem;
  }

  #beneficios-para-todos .beneficios__icon-circle {
    width: 60px;
    height: 60px;
    min-width: 60px;
  }

  #beneficios-para-todos .beneficios__icon-circle i {
    font-size: 1.75rem;
  }

  #beneficios-para-todos .beneficios__card-title {
    font-size: 1rem;
  }
}

/* ================================================ */
/* Responsividade - Mobile                          */
/* ================================================ */

@media (max-width: 767.98px) {
  #beneficios-para-todos .beneficios__title {
    font-size: 1.75rem;
  }

  #beneficios-para-todos .beneficios__subtitle {
    font-size: 0.95rem;
  }

  #beneficios-para-todos .beneficios__tabs {
    flex-direction: column;
    border-bottom: none;
  }

  #beneficios-para-todos .beneficios__tabs .nav-item {
    max-width: 100%;
  }

  #beneficios-para-todos .beneficios__tabs .nav-link {
    font-size: 1rem;
    padding: 1rem;
    border-bottom: 2px solid rgba(15, 92, 140, 0.1);
    border-left: 3px solid transparent;
  }

  #beneficios-para-todos .beneficios__tabs .nav-link.active {
    border-bottom: 2px solid rgba(15, 92, 140, 0.1);
    border-left-color: var(--azul-principal);
  }

  #beneficios-para-todos .beneficios__card {
    padding: 1.5rem;
    flex-direction: column;
    align-items: center;
    text-align: center;
    height: 280px;
  }

  #beneficios-para-todos .beneficios__icon-circle {
    width: 65px;
    height: 65px;
    min-width: 65px;
  }

  #beneficios-para-todos .beneficios__card-title {
    font-size: 1rem;
  }

  #beneficios-para-todos .beneficios__cta {
    font-size: 1rem;
    padding: 0.875rem 2rem;
  }
}

/* ================================================ */
/* Responsividade - Mobile Pequeno                  */
/* ================================================ */

@media (max-width: 575.98px) {
  #beneficios-para-todos .beneficios__title {
    font-size: 1.5rem;
  }

  #beneficios-para-todos .beneficios__subtitle {
    font-size: 0.9rem;
  }

  #beneficios-para-todos .beneficios__tabs .nav-link {
    font-size: 0.95rem;
    padding: 0.875rem;
    gap: 0.5rem;
  }

  #beneficios-para-todos .beneficios__tabs .nav-link i {
    font-size: 1.25rem;
  }

  #beneficios-para-todos .beneficios__icon-circle {
    width: 60px;
    height: 60px;
    min-width: 60px;
  }

  #beneficios-para-todos .beneficios__icon-circle i {
    font-size: 1.5rem;
  }

  #beneficios-para-todos .beneficios__card-title {
    font-size: 0.95rem;
  }

  #beneficios-para-todos .beneficios__cta {
    font-size: 0.95rem;
    padding: 0.75rem 1.75rem;
    width: 100%;
    justify-content: center;
  }
}

/* ============================================== */
/* SEÇÃO: Trilha Aplicada - ConneCT               */
/* ============================================== */

#trilha-aplicada {
  background: var(--branco-gelo);
  position: relative;
  overflow: hidden;
}

#trilha-aplicada .container-fluid {
  position: relative;
  z-index: 2;
  padding-left: 3rem;
  padding-right: 3rem;
}

@media (max-width: 767.98px) {
  #trilha-aplicada .container-fluid {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

/* Título Principal */
#trilha-aplicada .trilha__title {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-preto);
}

#trilha-aplicada .trilha__highlight {
  position: relative;
  display: inline-block;
  background: linear-gradient(
    90deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 50%,
    var(--azul-principal) 100%
  );
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: text-shine 3s ease-in-out infinite;
}

#trilha-aplicada .trilha__highlight::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 10px;
  width: 100%;
  height: 10px;
  background: linear-gradient(90deg, var(--azul-principal), var(--azul-claro));
  border-radius: 4px;
  opacity: 0.3;
}

/* Subtítulo */
#trilha-aplicada .trilha__subtitle {
  font-size: 1.1rem;
  color: var(--azul-preto);
  line-height: 1.6;
  max-width: 1000px;
  margin: 0 auto;
}

/* Título de Seção */
#trilha-aplicada .trilha__section-title {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 600;
  color: var(--azul-principal);
}

/* Cards de Gestão do Projeto */
#trilha-aplicada .trilha__card {
  background: var(--branco-gelo);
  border-radius: 16px;
  padding: 2rem;
  height: 350px;
  display: flex;
  flex-direction: column;
  border: 2px solid rgba(15, 92, 140, 0.1);
  transition: var(--transition-medium);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

#trilha-aplicada .trilha__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-claro);
}

/* Header do Card */
#trilha-aplicada .trilha__card-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: 1.5rem;
}

/* Ícone Circular */
#trilha-aplicada .trilha__icon-circle {
  width: 80px;
  height: 80px;
  min-width: 80px;
  border-radius: 50%;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  transition: var(--transition-medium);
}

#trilha-aplicada .trilha__card:hover .trilha__icon-circle {
  transform: scale(1.1) rotate(5deg);
}

#trilha-aplicada .trilha__icon-circle i {
  font-size: 2.25rem;
  color: var(--branco-gelo);
}

/* Título do Card */
#trilha-aplicada .trilha__card-title {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--azul-principal);
  margin: 0;
  line-height: 1.4;
}

/* Texto do Card */
#trilha-aplicada .trilha__card-text {
  font-size: 1rem;
  color: var(--azul-preto);
  line-height: 1.6;
  margin: 0;
  text-align: center;
}

/* Seção de Ferramentas */
#trilha-aplicada .trilha__ferramentas {
  background: linear-gradient(
    135deg,
    rgba(15, 92, 140, 0.05) 0%,
    rgba(84, 172, 191, 0.05) 100%
  );
  border-radius: 20px;
  padding: 3rem 2.5rem;
  border: 2px solid rgba(15, 92, 140, 0.1);
}

#trilha-aplicada .trilha__ferramentas-title {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--azul-principal);
}

#trilha-aplicada .trilha__ferramentas-subtitle {
  font-size: 1rem;
  color: var(--azul-preto);
  font-style: italic;
  opacity: 0.85;
}

/* Cards de Ferramentas */
#trilha-aplicada .trilha__tool {
  background: var(--branco-gelo);
  border-radius: 12px;
  padding: 1.5rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  border: 2px solid rgba(15, 92, 140, 0.08);
  transition: var(--transition-medium);
  height: 100%;
}

#trilha-aplicada .trilha__tool:hover {
  transform: translateX(5px);
  box-shadow: 0 4px 12px rgba(15, 92, 140, 0.12);
  border-color: var(--azul-claro);
}

/* Ícone da Ferramenta */
#trilha-aplicada .trilha__tool-icon {
  width: 50px;
  height: 50px;
  min-width: 50px;
  border-radius: 10px;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-medium);
}

#trilha-aplicada .trilha__tool:hover .trilha__tool-icon {
  transform: scale(1.1);
}

#trilha-aplicada .trilha__tool-icon i {
  font-size: 1.5rem;
  color: var(--branco-gelo);
}

/* Texto da Ferramenta */
#trilha-aplicada .trilha__tool-text {
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--azul-preto);
  line-height: 1.5;
}

/* CTA Button */
#trilha-aplicada .trilha__cta {
  font-size: 1.1rem;
  font-weight: 600;
  padding: 1rem 2.5rem;
  border-radius: 50px;
  text-transform: none;
  transition: var(--transition-medium);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.2);
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  border: none;
  color: var(--branco-gelo);
}

#trilha-aplicada .trilha__cta::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
  transform: translate(-50%, -50%);
  transition:
    width 0.6s ease,
    height 0.6s ease;
}

#trilha-aplicada .trilha__cta:hover {
  transform: translateY(-3px) scale(1.05);
  box-shadow:
    0 8px 25px rgba(15, 92, 140, 0.4),
    0 0 30px rgba(84, 172, 191, 0.3);
  background: linear-gradient(
    135deg,
    var(--azul-claro) 0%,
    var(--azul-principal) 100%
  );
}

#trilha-aplicada .trilha__cta:hover::before {
  width: 400px;
  height: 400px;
}

#trilha-aplicada .trilha__cta i {
  transition: var(--transition-medium);
}

#trilha-aplicada .trilha__cta:hover i {
  transform: translateX(5px) rotate(10deg);
}

/* ================================================ */
/* Responsividade - Tablets                         */
/* ================================================ */

@media (max-width: 991.98px) {
  #trilha-aplicada .trilha__title {
    font-size: 2rem;
  }

  #trilha-aplicada .trilha__subtitle {
    font-size: 1rem;
  }

  #trilha-aplicada .trilha__section-title {
    font-size: 1.75rem;
  }

  #trilha-aplicada .trilha__icon-circle {
    width: 70px;
    height: 70px;
    min-width: 70px;
  }

  #trilha-aplicada .trilha__icon-circle i {
    font-size: 2rem;
  }

  #trilha-aplicada .trilha__card-title {
    font-size: 1.15rem;
  }

  #trilha-aplicada .trilha__card-text {
    font-size: 0.95rem;
  }

  #trilha-aplicada .trilha__ferramentas {
    padding: 2.5rem 2rem;
  }

  #trilha-aplicada .trilha__ferramentas-title {
    font-size: 1.5rem;
  }
}

/* ================================================ */
/* Responsividade - Mobile                          */
/* ================================================ */

@media (max-width: 767.98px) {
  #trilha-aplicada .trilha__title {
    font-size: 1.75rem;
  }

  #trilha-aplicada .trilha__subtitle {
    font-size: 0.95rem;
  }

  #trilha-aplicada .trilha__section-title {
    font-size: 1.5rem;
  }

  #trilha-aplicada .trilha__card {
    padding: 1.75rem;
  }

  #trilha-aplicada .trilha__icon-circle {
    width: 65px;
    height: 65px;
    min-width: 65px;
  }

  #trilha-aplicada .trilha__icon-circle i {
    font-size: 1.75rem;
  }

  #trilha-aplicada .trilha__card-title {
    font-size: 1.1rem;
  }

  #trilha-aplicada .trilha__ferramentas {
    padding: 2rem 1.5rem;
  }

  #trilha-aplicada .trilha__ferramentas-title {
    font-size: 1.35rem;
  }

  #trilha-aplicada .trilha__tool {
    flex-direction: column;
    text-align: center;
    padding: 1.25rem;
    height: 160px;
  }

  #trilha-aplicada .trilha__tool:hover {
    transform: translateY(-3px);
  }

  #trilha-aplicada .trilha__tool-icon {
    width: 55px;
    height: 55px;
    min-width: 55px;
  }

  #trilha-aplicada .trilha__cta {
    font-size: 1rem;
    padding: 0.875rem 2rem;
  }
}

/* ================================================ */
/* Responsividade - Mobile Pequeno                  */
/* ================================================ */

@media (max-width: 575.98px) {
  #trilha-aplicada .trilha__title {
    font-size: 1.5rem;
  }

  #trilha-aplicada .trilha__subtitle {
    font-size: 0.9rem;
  }

  #trilha-aplicada .trilha__section-title {
    font-size: 1.35rem;
  }

  #trilha-aplicada .trilha__card {
    padding: 1.5rem;
  }

  #trilha-aplicada .trilha__icon-circle {
    width: 60px;
    height: 60px;
    min-width: 60px;
  }

  #trilha-aplicada .trilha__icon-circle i {
    font-size: 1.5rem;
  }

  #trilha-aplicada .trilha__card-title {
    font-size: 1rem;
  }

  #trilha-aplicada .trilha__card-text {
    font-size: 0.9rem;
  }

  #trilha-aplicada .trilha__ferramentas {
    padding: 1.75rem 1.25rem;
  }

  #trilha-aplicada .trilha__ferramentas-title {
    font-size: 1.25rem;
  }

  #trilha-aplicada .trilha__tool-text {
    font-size: 0.9rem;
  }

  #trilha-aplicada .trilha__cta {
    font-size: 0.95rem;
    padding: 0.75rem 1.75rem;
    width: 100%;
    justify-content: center;
  }
}

/* ============================================== */
/* SEÇÃO: Hub CT-12 - ConneCT                     */
/* ============================================== */

#hub-ct-12 {
  background: linear-gradient(
    135deg,
    rgba(84, 172, 191, 0.15) 0%,
    var(--branco-gelo) 100%
  );
  position: relative;
  overflow: hidden;
}

#hub-ct-12 .container-fluid {
  position: relative;
  z-index: 2;
  padding-left: 3rem;
  padding-right: 3rem;
}

@media (max-width: 767.98px) {
  #hub-ct-12 .container-fluid {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

/* Título Principal */
#hub-ct-12 .hub__title {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-preto);
}

#hub-ct-12 .hub__highlight {
  position: relative;
  display: inline-block;
  background: linear-gradient(
    90deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 50%,
    var(--azul-principal) 100%
  );
  background-size: 200% 100%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: text-shine 3s ease-in-out infinite;
}

#hub-ct-12 .hub__highlight::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 10px;
  width: 100%;
  height: 10px;
  background: linear-gradient(90deg, var(--azul-principal), var(--azul-claro));
  border-radius: 4px;
  opacity: 0.3;
}

/* Subtítulo */
#hub-ct-12 .hub__subtitle {
  font-size: 1.1rem;
  color: var(--azul-preto);
  line-height: 1.6;
  max-width: 900px;
  margin: 0 auto;
}

/* Destaques */
#hub-ct-12 .hub__destaques {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

#hub-ct-12 .hub__destaque {
  background: var(--branco);
  border-radius: 12px;
  padding: 1.5rem;
  display: flex;
  align-items: center;
  gap: 1.25rem;
  border: 2px solid rgba(15, 92, 140, 0.1);
  transition: var(--transition-medium);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

#hub-ct-12 .hub__destaque:hover {
  transform: translateX(8px);
  box-shadow: 0 6px 16px rgba(15, 92, 140, 0.15);
  border-color: var(--azul-claro);
}

/* Ícone do Destaque */
#hub-ct-12 .hub__destaque-icon {
  width: 60px;
  height: 60px;
  min-width: 60px;
  border-radius: 12px;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
  transition: var(--transition-medium);
}

#hub-ct-12 .hub__destaque:hover .hub__destaque-icon {
  transform: scale(1.1) rotate(5deg);
}

#hub-ct-12 .hub__destaque-icon i {
  font-size: 1.75rem;
  color: var(--branco-gelo);
}

/* Texto do Destaque */
#hub-ct-12 .hub__destaque-text {
  font-size: 1rem;
  font-weight: 500;
  color: var(--azul-preto);
  line-height: 1.5;
}

/* Localização */
#hub-ct-12 .hub__localizacao {
  background: linear-gradient(
    135deg,
    rgba(15, 92, 140, 0.08) 0%,
    rgba(84, 172, 191, 0.08) 100%
  );
  border-radius: 16px;
  padding: 2rem;
  border: 2px solid rgba(15, 92, 140, 0.2);
}

#hub-ct-12 .hub__localizacao-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
}

/* Ícone da Localização */
#hub-ct-12 .hub__localizacao-icon {
  width: 50px;
  height: 50px;
  min-width: 50px;
  border-radius: 10px;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  display: flex;
  align-items: center;
  justify-content: center;
}

#hub-ct-12 .hub__localizacao-icon i {
  font-size: 1.5rem;
  color: var(--branco-gelo);
}

/* Título da Localização */
#hub-ct-12 .hub__localizacao-title {
  font-family: var(--font-heading);
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--azul-preto);
  margin: 0;
}

/* Texto da Localização */
#hub-ct-12 .hub__localizacao-text {
  font-size: 1rem;
  color: var(--azul-preto);
  line-height: 1.6;
  margin: 0;
}

/* Mapa */
#hub-ct-12 .hub__mapa {
  height: 100%;
  min-height: 450px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  border: 3px solid var(--branco);
  transition: var(--transition-medium);
}

#hub-ct-12 .hub__mapa:hover {
  box-shadow: 0 12px 32px rgba(15, 92, 140, 0.2);
  transform: translateY(-4px);
}

#hub-ct-12 .hub__mapa iframe {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 450px;
}

/* CTA Button */
#hub-ct-12 .hub__cta {
  font-size: 1.1rem;
  font-weight: 600;
  padding: 1rem 2.5rem;
  border-radius: 50px;
  text-transform: none;
  transition: var(--transition-medium);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.2);
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  border: none;
  color: var(--branco-gelo);
}

#hub-ct-12 .hub__cta::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
  transform: translate(-50%, -50%);
  transition:
    width 0.6s ease,
    height 0.6s ease;
}

#hub-ct-12 .hub__cta:hover {
  transform: translateY(-3px) scale(1.05);
  box-shadow:
    0 8px 25px rgba(15, 92, 140, 0.4),
    0 0 30px rgba(84, 172, 191, 0.3);
  background: linear-gradient(
    135deg,
    var(--azul-claro) 0%,
    var(--azul-principal) 100%
  );
}

#hub-ct-12 .hub__cta:hover::before {
  width: 400px;
  height: 400px;
}

#hub-ct-12 .hub__cta i {
  transition: var(--transition-medium);
}

#hub-ct-12 .hub__cta:hover i {
  transform: translateX(5px) rotate(10deg);
}

/* ================================================ */
/* Responsividade - Tablets                         */
/* ================================================ */

@media (max-width: 991.98px) {
  #hub-ct-12 .hub__title {
    font-size: 2rem;
  }

  #hub-ct-12 .hub__subtitle {
    font-size: 1rem;
  }

  #hub-ct-12 .hub__destaque {
    padding: 1.25rem;
  }

  #hub-ct-12 .hub__destaque-icon {
    width: 55px;
    height: 55px;
    min-width: 55px;
  }

  #hub-ct-12 .hub__destaque-icon i {
    font-size: 1.5rem;
  }

  #hub-ct-12 .hub__destaque-text {
    font-size: 0.95rem;
  }

  #hub-ct-12 .hub__localizacao {
    padding: 1.75rem;
  }

  #hub-ct-12 .hub__localizacao-title {
    font-size: 1.25rem;
  }
}

/* ================================================ */
/* Responsividade - Mobile                          */
/* ================================================ */

@media (max-width: 767.98px) {
  #hub-ct-12 .hub__title {
    font-size: 1.75rem;
  }

  #hub-ct-12 .hub__subtitle {
    font-size: 0.95rem;
  }

  #hub-ct-12 .hub__destaque {
    padding: 1.25rem;
    flex-direction: column;
    text-align: center;
  }

  #hub-ct-12 .hub__destaque:hover {
    transform: translateY(-4px);
  }

  #hub-ct-12 .hub__destaque-icon {
    width: 60px;
    height: 60px;
    min-width: 60px;
  }

  #hub-ct-12 .hub__localizacao {
    padding: 1.5rem;
  }

  #hub-ct-12 .hub__localizacao-header {
    flex-direction: column;
    text-align: center;
  }

  #hub-ct-12 .hub__localizacao-text {
    text-align: center;
  }

  #hub-ct-12 .hub__mapa {
    min-height: 350px;
  }

  #hub-ct-12 .hub__mapa iframe {
    min-height: 350px;
  }

  #hub-ct-12 .hub__cta {
    font-size: 1rem;
    padding: 0.875rem 2rem;
  }
}

/* ================================================ */
/* Responsividade - Mobile Pequeno                  */
/* ================================================ */

@media (max-width: 575.98px) {
  #hub-ct-12 .hub__title {
    font-size: 1.5rem;
  }

  #hub-ct-12 .hub__subtitle {
    font-size: 0.9rem;
  }

  #hub-ct-12 .hub__destaque {
    padding: 1rem;
    height: 160px;
  }

  #hub-ct-12 .hub__destaque-icon {
    width: 55px;
    height: 55px;
    min-width: 55px;
  }

  #hub-ct-12 .hub__destaque-icon i {
    font-size: 1.5rem;
  }

  #hub-ct-12 .hub__destaque-text {
    font-size: 0.9rem;
  }

  #hub-ct-12 .hub__localizacao {
    padding: 1.25rem;
  }

  #hub-ct-12 .hub__localizacao-icon {
    width: 45px;
    height: 45px;
    min-width: 45px;
  }

  #hub-ct-12 .hub__localizacao-icon i {
    font-size: 1.25rem;
  }

  #hub-ct-12 .hub__localizacao-title {
    font-size: 1.15rem;
  }

  #hub-ct-12 .hub__localizacao-text {
    font-size: 0.9rem;
  }

  #hub-ct-12 .hub__mapa {
    min-height: 300px;
  }

  #hub-ct-12 .hub__mapa iframe {
    min-height: 300px;
  }

  #hub-ct-12 .hub__cta {
    font-size: 0.95rem;
    padding: 0.75rem 1.75rem;
    width: 100%;
    justify-content: center;
  }
}

/* ============================================== */
/* SEÇÃO: Estatísticas - ConneCT                  */
/* ============================================== */

#estatisticas {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 100%
  );
  position: relative;
  overflow: hidden;
}

/* Efeito decorativo de fundo */
#estatisticas::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    rgba(15, 92, 140, 0.05) 0%,
    transparent 70%
  );
  border-radius: 50%;
  z-index: 0;
  animation: float 6s ease-in-out infinite;
}

#estatisticas::after {
  content: "";
  position: absolute;
  bottom: -30%;
  left: -5%;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(84, 172, 191, 0.03) 0%,
    transparent 70%
  );
  border-radius: 50%;
  z-index: 0;
  animation: float-reverse 8s ease-in-out infinite;
}

@keyframes float {
  0%,
  100% {
    transform: translateY(0) translateX(0);
  }

  50% {
    transform: translateY(-20px) translateX(10px);
  }
}

@keyframes float-reverse {
  0%,
  100% {
    transform: translateY(0) translateX(0);
  }

  50% {
    transform: translateY(20px) translateX(-10px);
  }
}

@keyframes badge-shine {
  0% {
    left: -100%;
  }

  50%,
  100% {
    left: 100%;
  }
}

/* Título */
#estatisticas .estatisticas__title {
  font-size: clamp(2rem, 5vw, 2.75rem);
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1rem;
  line-height: 1.2;
  font-family: var(--font-heading);
}

#estatisticas .estatisticas__highlight {
  background: linear-gradient(135deg, var(--azul-claro) 0%, #ffffff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  background-size: 200% auto;
  animation: text-shine 3s linear infinite;
  position: relative;
}

@keyframes text-shine {
  0% {
    background-position: 0% center;
  }

  50% {
    background-position: 100% center;
  }

  100% {
    background-position: 0% center;
  }
}

#estatisticas .estatisticas__highlight::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 5px;
  width: 100%;
  height: 10px;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 4px;
  opacity: 0.3;
}

/* Subtítulo */
#estatisticas .estatisticas__subtitle {
  font-size: 1.125rem;
  color: var(--branco-gelo);
  max-width: 600px;
  margin: 0 auto 2rem;
}

/* Card de Estatística */
#estatisticas .estatisticas__card {
  background: #fff;
  padding: 3rem 2rem;
  border-radius: 20px;
  text-align: center;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  transition: var(--transition-medium);
  position: relative;
  overflow: hidden;
  height: 100%;
  border: 2px solid transparent;
}

/* Efeito de fundo no hover */
#estatisticas .estatisticas__card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  opacity: 0;
  transition: var(--transition-medium);
  z-index: 0;
}

#estatisticas .estatisticas__card:hover::before {
  opacity: 0.03;
}

#estatisticas .estatisticas__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
  border-color: var(--azul-claro);
}

/* Card destaque (para 1 estatística) */
#estatisticas .estatisticas__card--destaque {
  padding: 4rem 3rem;
  background: linear-gradient(135deg, var(--branco-gelo) 0%, #ffffff 100%);
}

/* Wrapper do ícone */
#estatisticas .estatisticas__icon-wrapper {
  width: 100px;
  height: 100px;
  margin: 0 auto 1.5rem;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.3);
  transition: var(--transition-medium);
  position: relative;
  z-index: 1;
}

#estatisticas .estatisticas__card:hover .estatisticas__icon-wrapper {
  transform: scale(1.1) rotate(5deg);
  box-shadow: 0 12px 35px rgba(15, 92, 140, 0.4);
}

/* Ícone */
#estatisticas .estatisticas__icon {
  font-size: 2.5rem;
  color: var(--branco-gelo);
  transition: var(--transition-fast);
}

#estatisticas .estatisticas__card:hover .estatisticas__icon {
  transform: scale(1.1);
}

/* Número da estatística */
#estatisticas .estatisticas__number {
  font-size: clamp(3rem, 6vw, 4rem);
  font-weight: 800;
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 100%
  );
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 1rem;
  line-height: 1;
  font-family: var(--font-heading);
  position: relative;
  z-index: 1;
}

/* Label da estatística */
#estatisticas .estatisticas__label {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  margin: 0;
  line-height: 1.4;
  position: relative;
  z-index: 1;
}

/* Responsividade */
@media (max-width: 991.98px) {
  #estatisticas .estatisticas__card {
    padding: 2.5rem 1.5rem;
  }

  #estatisticas .estatisticas__icon-wrapper {
    width: 80px;
    height: 80px;
    margin-bottom: 1.25rem;
  }

  #estatisticas .estatisticas__icon {
    font-size: 2rem;
  }

  #estatisticas .estatisticas__number {
    font-size: clamp(2.5rem, 5vw, 3.5rem);
  }

  #estatisticas .estatisticas__label {
    font-size: 1rem;
  }
}

@media (max-width: 767.98px) {
  #estatisticas .estatisticas__card {
    padding: 2rem 1.25rem;
  }

  #estatisticas .estatisticas__icon-wrapper {
    width: 70px;
    height: 70px;
    margin-bottom: 1rem;
  }

  #estatisticas .estatisticas__icon {
    font-size: 1.75rem;
  }
}

/* ============================================== */
/* SEÇÃO: Depoimentos - ConneCT                   */
/* ============================================== */

#depoimentos {
  background: linear-gradient(180deg, var(--branco-gelo) 0%, #ffffff 100%);
  position: relative;
  overflow: hidden;
}

/* Título da Seção */
#depoimentos .depoimentos__title {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-principal);
}

#depoimentos .depoimentos__highlight {
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  position: relative;
  display: inline-block;
}

@keyframes text-shine {
  0% {
    background-position: 0% 50%;
  }

  50% {
    background-position: 100% 50%;
  }

  100% {
    background-position: 0% 50%;
  }
}

#depoimentos .depoimentos__highlight::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(
    90deg,
    var(--azul-principal),
    var(--azul-claro),
    var(--azul-suave)
  );
  border-radius: 2px;
}

/* Subtítulo */
#depoimentos .depoimentos__subtitle {
  font-family: var(--font-primary);
  font-size: 1.125rem;
  color: #6c757d;
  margin: 0;
}

/* Card de Depoimento */
#depoimentos .depoimentos__card {
  background: #ffffff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.07);
  transition: var(--transition-medium);
  height: 538px;
  display: flex;
  flex-direction: column;
  position: relative;
}

#depoimentos .depoimentos__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.12);
}

/* Wrapper da Foto */
#depoimentos .depoimentos__photo-wrapper {
  width: 100%;
  padding: 2rem 2rem 0 2rem;
  display: flex;
  justify-content: center;
}

/* Foto Circular */
#depoimentos .depoimentos__photo {
  width: 150px;
  height: 150px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid var(--azul-principal);
  transition: var(--transition-medium);
}

#depoimentos .depoimentos__card:hover .depoimentos__photo {
  transform: scale(1.05);
  border-color: var(--azul-claro);
}

/* Header do Card (Nome e Perfil) */
#depoimentos .depoimentos__header {
  padding: 1.5rem 1.5rem 0 1.5rem;
  text-align: center;
}

#depoimentos .depoimentos__name {
  font-family: var(--font-primary);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 0.5rem;
}

#depoimentos .depoimentos__role {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 500;
  color: var(--azul-petroleo);
  margin: 0;
  /* padding-bottom: 1rem; */
}

#depoimentos .depoimentos__empresa {
  font-family: var(--font-primary);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--azul-petroleo);
  margin: 0;
  padding-bottom: 1rem;
}

/* Conteúdo do Depoimento */
#depoimentos .depoimentos__content {
  padding: 0 1.5rem 1.5rem 1.5rem;
  flex-grow: 1;
  display: flex;
  align-items: flex-start;
  min-height: 180px;
}

#depoimentos .depoimentos__text {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  line-height: 1.6;
  color: #495057;
  margin: 0;
  text-align: left;
  hyphens: auto;
  word-spacing: normal;
}

/* Barra Inferior Decorativa */
#depoimentos .depoimentos__footer {
  height: 6px;
  background: linear-gradient(
    90deg,
    var(--azul-principal) 0%,
    var(--azul-claro) 50%,
    var(--azul-suave) 100%
  );
  transition: var(--transition-medium);
}

#depoimentos .depoimentos__card:hover .depoimentos__footer {
  height: 8px;
}

/* Responsividade */
@media (max-width: 991.98px) {
  #depoimentos .depoimentos__title {
    font-size: 2rem;
  }

  #depoimentos .depoimentos__subtitle {
    font-size: 1rem;
  }

  #depoimentos .depoimentos__photo {
    width: 130px;
    height: 130px;
  }

  #depoimentos .depoimentos__name {
    font-size: 1.35rem;
  }

  #depoimentos .depoimentos__empresa {
    font-size: 0.8rem;
  }

  #depoimentos .depoimentos__content {
    min-height: 160px;
  }
}

/* ================================================ */
/* Swiper - Depoimentos                             */
/* ================================================ */

#depoimentos .depoimentos__swiper-wrapper {
  position: relative;
  padding: 0 50px;
}

#depoimentos .depoimentos__swiper {
  padding: 20px 10px 60px;
}

/* Centralizar o swiper-wrapper */
#depoimentos .swiper-wrapper {
  justify-content: center;
}

/* Navegação Swiper */
#depoimentos .depoimentos__swiper-next,
#depoimentos .depoimentos__swiper-prev {
  width: 45px;
  height: 45px;
  background: #0056b3;
  border-radius: 50%;
  color: #ffffff;
  transition: all 0.3s ease;
}

#depoimentos .depoimentos__swiper-next::after,
#depoimentos .depoimentos__swiper-prev::after {
  font-size: 18px;
  font-weight: bold;
}

#depoimentos .depoimentos__swiper-next:hover,
#depoimentos .depoimentos__swiper-prev:hover {
  background: #003d82;
  transform: scale(1.1);
}

/* Paginação Swiper */
#depoimentos .depoimentos__swiper-pagination {
  bottom: 20px !important;
}

#depoimentos .depoimentos__swiper-pagination .swiper-pagination-bullet {
  width: 12px;
  height: 12px;
  background: #0056b3;
  opacity: 0.3;
  transition: all 0.3s ease;
}

#depoimentos .depoimentos__swiper-pagination .swiper-pagination-bullet-active {
  opacity: 1;
  transform: scale(1.3);
  background: #0056b3;
}

@media (max-width: 1366px) {
  /* Centralizar o swiper-wrapper */
  #depoimentos .swiper-wrapper {
    justify-content: left;
  }
}

@media (max-width: 991.98px) {
  #depoimentos .depoimentos__swiper-wrapper {
    padding: 0 40px;
  }
}

@media (max-width: 767.98px) {
  #depoimentos .depoimentos__title {
    font-size: 1.75rem;
  }

  #depoimentos .depoimentos__swiper-wrapper {
    padding: 0 30px;
  }

  #depoimentos .depoimentos__card {
    max-width: 400px;
    margin: 0 auto;
  }

  #depoimentos .depoimentos__photo {
    width: 120px;
    height: 120px;
  }

  #depoimentos .depoimentos__name {
    font-size: 1.25rem;
  }

  #depoimentos .depoimentos__empresa {
    font-size: 0.75rem;
  }

  #depoimentos .depoimentos__text {
    font-size: 0.9rem;
  }

  #depoimentos .depoimentos__content {
    min-height: 140px;
  }
}

/* ============================================== */
/* Footer Styles - ConneCT                        */
/* ============================================== */

#footer {
  background: linear-gradient(
    135deg,
    var(--azul-preto) 0%,
    var(--azul-petroleo) 100%
  );
  color: var(--branco-gelo);
  padding: 4rem 0 0;
  position: relative;
  overflow: hidden;
}

/* Localização */
#footer .footer__location {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  color: var(--azul-suave);
  font-size: 0.95rem;
  margin-top: 1.2rem;
  opacity: 0.9;
  font-weight: 500;
  max-width: 350px;
}

#footer .footer__location i {
  color: var(--azul-claro);
  font-size: 1.15rem;
  min-width: 20px;
}

/* Efeito de fundo decorativo */
#footer::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(
    90deg,
    var(--azul-claro),
    var(--azul-suave),
    var(--azul-claro)
  );
  z-index: 1;
}

/* Logo e Brand */
#footer .footer__logo {
  height: 65px;
  width: auto;
  transition: var(--transition-fast);
  filter: brightness(1);
}

#footer .footer__logo-link:hover .footer__logo {
  filter: brightness(1.15);
  transform: scale(1.05);
}

#footer .footer__description {
  color: var(--azul-suave);
  font-size: 0.9rem;
  line-height: 1.8;
  max-width: 350px;
  opacity: 0.9;
}

/* Redes Sociais */
#footer .footer__social {
  display: flex;
  gap: 0.75rem;
  flex-wrap: wrap;
}

#footer .footer__social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  background: rgba(187, 232, 242, 0.15);
  border: 2px solid var(--azul-suave);
  border-radius: 50%;
  color: var(--azul-suave);
  font-size: 1.15rem;
  transition: var(--transition-fast);
  text-decoration: none;
}

#footer .footer__social-link:hover {
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  border-color: var(--branco-gelo);
  color: var(--branco-gelo);
  transform: translateY(-4px) scale(1.1);
  box-shadow: 0 6px 20px rgba(84, 172, 191, 0.4);
}

/* Títulos das Seções */
#footer .footer__title {
  color: var(--azul-suave);
  font-family: var(--font-heading);
  font-size: 1.15rem;
  font-weight: 600;
  margin-bottom: 1.5rem;
  position: relative;
  padding-bottom: 0.75rem;
}

#footer .footer__title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 40px;
  height: 3px;
  background: linear-gradient(90deg, var(--azul-claro), var(--azul-suave));
  border-radius: 2px;
}

/* Menus de Navegação */
#footer .footer__menu {
  list-style: none;
  padding: 0;
  margin: 0;
}

#footer .footer__menu li {
  margin-bottom: 0.7rem;
}

#footer .footer__menu a {
  color: var(--branco-gelo);
  text-decoration: none;
  font-size: 0.9rem;
  transition: var(--transition-fast);
  display: inline-block;
  position: relative;
  opacity: 0.85;
}

#footer .footer__menu a::before {
  content: "→";
  position: absolute;
  left: -20px;
  opacity: 0;
  transition: var(--transition-fast);
  color: var(--azul-claro);
}

#footer .footer__menu a:hover {
  color: var(--azul-suave);
  padding-left: 8px;
  opacity: 1;
}

#footer .footer__menu a:hover::before {
  left: -15px;
  opacity: 1;
}

/* Lista de Contatos */
#footer .footer__contact-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#footer .footer__contact-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  margin-bottom: 1.2rem;
  background: rgba(187, 232, 242, 0.08);
  padding: 0.9rem;
  border-radius: 8px;
  border-left: 3px solid var(--azul-claro);
  transition: var(--transition-fast);
}

#footer .footer__contact-list li:hover {
  background: rgba(187, 232, 242, 0.15);
  border-left-color: var(--azul-suave);
  transform: translateX(5px);
}

#footer .footer__contact-list li i {
  color: var(--azul-claro);
  font-size: 1.2rem;
  margin-top: 0.1rem;
  min-width: 20px;
}

#footer .footer__contact-list li div {
  display: flex;
  flex-direction: column;
}

#footer .footer__contact-label {
  color: var(--azul-suave);
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  font-weight: 600;
  margin-bottom: 0.25rem;
}

#footer .footer__contact-list a {
  color: var(--branco-gelo);
  text-decoration: none;
  font-size: 0.95rem;
  transition: var(--transition-fast);
}

#footer .footer__contact-list a:hover {
  color: var(--azul-suave);
}

/* Linha Divisória */
#footer .footer__divider {
  border-color: rgba(187, 232, 242, 0.2);
  margin: 2.5rem 0 1.5rem;
  opacity: 0.5;
}

/* Rodapé Inferior */
#footer .footer__bottom {
  padding-bottom: 1.5rem;
}

#footer .footer__copyright {
  color: var(--azul-suave);
  font-size: 0.85rem;
  opacity: 0.85;
}

/* Link Desenvolvedor */
#footer .footer__bottom .dev__link {
  color: var(--azul-suave);
  text-decoration: none;
  font-size: 0.85rem;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  transition: var(--transition-fast);
  opacity: 0.85;
}

#footer .footer__bottom .dev__link:hover {
  color: var(--branco-gelo);
  opacity: 1;
}

#footer .footer__bottom .dev__link:hover .dev__logo svg {
  filter: brightness(1.2);
  transform: scale(1.1);
}

#footer .footer__bottom .dev__dir {
  opacity: 0.8;
}

#footer .footer__bottom .dev__arco {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-weight: 500;
}

#footer .footer__bottom .dev__logo {
  display: inline-flex;
  align-items: center;
}

#footer .footer__bottom .dev__logo svg {
  width: 22px;
  height: 22px;
  transition: var(--transition-fast);
}

/* Responsivo Footer */
@media (max-width: 991.98px) {
  #footer {
    padding: 3rem 0 0;
  }

  #footer .footer__description {
    max-width: 100%;
  }

  #footer .footer__contact-list li {
    padding: 0.75rem;
  }
}

@media (max-width: 767.98px) {
  #footer .footer__title {
    margin-bottom: 1rem;
    font-size: 1rem;
  }

  #footer .footer__logo {
    height: 55px;
  }

  #footer .footer__social {
    justify-content: center;
  }

  #footer .footer__bottom {
    text-align: center;
  }

  #footer .footer__bottom .row > div {
    text-align: center !important;
  }

  #footer .footer__menu a:hover::before {
    display: none;
  }
}

/* ============================================== */
/* PÁGINA EMPRESAS - ConneCT                      */
/* ============================================== */

/* Seção 1: Hero */
#empresas .hero-section {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 100%
  );
  color: var(--branco-gelo);
  padding: 4rem 0 7rem;
  position: relative;
  overflow: hidden;
}

#empresas .hero-section::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
  height: 100%;
  background: radial-gradient(
    circle at top right,
    rgba(84, 172, 191, 0.15),
    transparent 70%
  );
  pointer-events: none;
}

#empresas .hero-section__content {
  position: relative;
  z-index: 1;
  text-align: center;
}

#empresas .hero-section__headline {
  font-family: var(--font-primary);
  font-size: 2.75rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.5rem;
  color: var(--branco-gelo);
}

#empresas .hero-section__headline-destaque {
  color: var(--azul-suave);
  position: relative;
  display: inline-block;
}

#empresas .hero-section__headline-destaque::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--azul-claro);
  border-radius: 2px;
}

#empresas .hero-section__subheadline {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: 2.5rem;
  color: var(--azul-suave);
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

#empresas .hero-section__ctas {
  display: flex;
  gap: 1.5rem;
  justify-content: center;
  flex-wrap: wrap;
}

#empresas .hero-section__cta-btn {
  padding: 0.875rem 2rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 8px;
  transition: var(--transition-medium);
  position: relative;
  overflow: hidden;
}

#empresas .hero-section__cta-btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  transform: translate(-50%, -50%);
  transition:
    width var(--transition-medium),
    height var(--transition-medium);
}

#empresas .hero-section__cta-btn:hover::before {
  width: 300px;
  height: 300px;
}

#empresas .hero-section__cta-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

#empresas .hero-section__cta-btn:active {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

/* Steps Cards */
#empresas .hero-section__steps {
  margin-top: 4rem;
}

#empresas .hero-section__steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  max-width: 1200px;
  margin: 0 auto;
}

#empresas .hero-section__step-card {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 12px;
  padding: 2rem 1.5rem;
  text-align: center;
  transition: var(--transition-medium);
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

#empresas .hero-section__step-card:hover {
  transform: translateY(-5px);
  background: rgba(255, 255, 255, 0.15);
  border-color: var(--azul-suave);
}

#empresas .hero-section__step-number {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, var(--azul-suave), var(--azul-claro));
  color: var(--azul-petroleo);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 auto 1rem;
  transition: var(--transition-medium);
}

#empresas .hero-section__step-card:hover .hero-section__step-number {
  transform: scale(1.1);
}

#empresas .hero-section__step-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--branco-gelo);
  line-height: 1.6;
  margin: 0;
}

/* Carousel Hint */
#empresas .carousel-hint {
  text-align: center;
  margin-top: 1rem;
  font-family: var(--font-primary);
  font-size: 0.9rem;
  color: var(--azul-preto);
  opacity: 0.8;
}

/* Steps Cards da Como Funciona */
#empresas .como-funciona-section__steps {
  margin-top: 4rem;
}

#empresas .como-funciona-section__steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  max-width: 1200px;
  margin: 0 auto;
}

#empresas .como-funciona-section__step-card {
  background: white;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 12px;
  padding: 2rem 1.5rem;
  text-align: center;
  transition: var(--transition-medium);
  min-height: 220px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
}

#empresas .como-funciona-section__step-card:hover {
  transform: translateY(-5px);
  background: rgba(255, 255, 255, 0.95);
  border-color: var(--azul-suave);
}

#empresas .como-funciona-section__step-number {
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, var(--azul-suave), var(--azul-claro));
  color: var(--azul-petroleo);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 auto 1rem;
  transition: var(--transition-medium);
}

#empresas
  .como-funciona-section__step-card:hover
  .como-funciona-section__step-number {
  transform: scale(1.1);
}

#empresas .como-funciona-section__step-text {
  font-family: var(--font-primary);
  font-size: 0.9375rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

#empresas .como-funciona-section__step-title {
  font-family: var(--font-primary);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin: 0 0 0.5rem;
  line-height: 1.3;
}

/* Seção 2: Como funciona */
#empresas .como-funciona-section {
  background: linear-gradient(to bottom, var(--azul-suave), var(--branco-gelo));
}

#empresas .como-funciona-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1.5rem;
}

#empresas .como-funciona-section__text {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  line-height: 1.7;
  margin-bottom: 1rem;
}

#empresas .como-funciona-section__timeline {
  margin-top: 3rem;
  position: relative;
}

#empresas .como-funciona-section__timeline::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--azul-principal), var(--azul-claro));
  z-index: 0;
}

#empresas .como-funciona-section__step {
  background: white;
  padding: 1.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  height: 100%;
  transition: var(--transition-medium);
  border: 2px solid transparent;
  position: relative;
  z-index: 1;
}

#empresas .como-funciona-section__step:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 24px rgba(15, 92, 140, 0.15);
  border-color: var(--azul-claro);
}

#empresas .como-funciona-section__step-number {
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 auto 1rem;
}

#empresas .como-funciona-section__step-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  text-align: center;
  margin: 0;
}

#empresas .como-funciona-section__cta-card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  border-left: 4px solid var(--azul-principal);
  transition: var(--transition-medium);
  min-height: 180px;
}

#empresas .como-funciona-section__cta-card:hover {
  transform: translateX(5px);
  box-shadow: 0 8px 24px rgba(15, 92, 140, 0.15);
}

#empresas .como-funciona-section__cta-microcopy {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
  line-height: 1.5;
}

/* Seção 3: Ganhos */
#empresas .ganhos-section {
  background: linear-gradient(to bottom, var(--branco-gelo), var(--azul-suave));
}

#empresas .ganhos-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
}

#empresas .ganhos-section__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

#empresas .ganhos-section__list-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  line-height: 1.5;
}

#empresas .ganhos-section__list-item i {
  color: var(--azul-principal);
  font-size: 1.25rem;
  flex-shrink: 0;
}

#empresas .ganhos-section__card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  min-height: 305px;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
}

#empresas .ganhos-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-claro);
}

#empresas .ganhos-section__card-icon {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#empresas .ganhos-section__card:hover .ganhos-section__card-icon {
  transform: scale(1.1) rotate(5deg);
}

#empresas .ganhos-section__card-title {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#empresas .ganhos-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

/* Seção 4: Tipo de desafio */
#empresas .tipo-desafio-section {
  background: linear-gradient(
    to bottom,
    var(--azul-petroleo),
    var(--azul-principal)
  );
  color: white;
}

#empresas .tipo-desafio-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: white;
  margin-bottom: 1rem;
}

#empresas .tipo-desafio-section__subheadline {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-suave);
  line-height: 1.7;
  margin-bottom: 0;
}

#empresas .tipo-desafio-section__content {
  background: rgba(255, 255, 255, 0.1);
  padding: 2.5rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
  border-left: 5px solid var(--azul-suave);
}

#empresas .tipo-desafio-section__text {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: var(--azul-suave);
  line-height: 1.7;
  margin-bottom: 1rem;
}

#empresas .tipo-desafio-section__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

#empresas .tipo-desafio-section__list-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: white;
  line-height: 1.5;
}

#empresas .tipo-desafio-section__list-item i {
  color: var(--azul-suave);
  font-size: 1.1rem;
  flex-shrink: 0;
}

/* Cards de Requisitos */
#empresas .tipo-desafio-section__cards {
  margin-top: 3rem;
}

#empresas .tipo-desafio-section__card {
  background: rgba(255, 255, 255, 0.1);
  padding: 2rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
  min-height: 320px;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
}

#empresas .tipo-desafio-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(255, 255, 255, 0.2);
  border-color: var(--azul-suave);
}

#empresas .tipo-desafio-section__card-icon {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-suave), var(--azul-claro));
  color: var(--azul-petroleo);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#empresas .tipo-desafio-section__card:hover .tipo-desafio-section__card-icon {
  transform: scale(1.1) rotate(5deg);
}

#empresas .tipo-desafio-section__card-title {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 700;
  color: white;
  margin-bottom: 1rem;
}

#empresas .tipo-desafio-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-suave);
  line-height: 1.6;
  margin: 0;
}

/* Seção 5: Expectativas */
#empresas .expectativas-section {
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  color: white;
}

#empresas .expectativas-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: white;
  margin-bottom: 1rem;
}

#empresas .expectativas-section__subtitle {
  font-family: var(--font-primary);
  font-size: 1.15rem;
  color: var(--azul-suave);
  margin-bottom: 2rem;
}

#empresas .expectativas-section__content {
  background: rgba(255, 255, 255, 0.1);
  padding: 2.5rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
}

#empresas .expectativas-section__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#empresas .expectativas-section__list-item {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: white;
  line-height: 1.6;
  margin-bottom: 1.25rem;
  padding-left: 2.5rem;
  position: relative;
}

#empresas .expectativas-section__list-item i {
  position: absolute;
  left: 0;
  top: 3px;
  color: var(--azul-suave);
  font-size: 1.5rem;
}

/* Cards de Expectativas */
#empresas .expectativas-section__cards {
  margin-top: 2rem;
}

#empresas .expectativas-section__card {
  background: rgba(255, 255, 255, 0.1);
  padding: 2rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
  min-height: 320px;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
}

#empresas .expectativas-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(255, 255, 255, 0.2);
  border-color: var(--azul-suave);
}

#empresas .expectativas-section__card-icon {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-suave), var(--azul-claro));
  color: var(--azul-petroleo);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#empresas .expectativas-section__card:hover .expectativas-section__card-icon {
  transform: scale(1.1) rotate(5deg);
}

#empresas .expectativas-section__card-title {
  font-family: var(--font-primary);
  font-size: 1rem;
  font-weight: 700;
  color: white;
  margin-bottom: 1rem;
}

#empresas .expectativas-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-suave);
  line-height: 1.6;
  margin: 0;
}

/* Seção 6: Custeio */
#empresas .custeio-section {
  background: linear-gradient(to bottom, white, var(--azul-suave));
}

#empresas .custeio-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
}

#empresas .custeio-section__content {
  background: white;
  padding: 2.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
}

#empresas .custeio-section__text {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}

#empresas .custeio-section__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

#empresas .custeio-section__list-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: var(--azul-petroleo);
  line-height: 1.5;
}

#empresas .custeio-section__list-item i {
  color: var(--azul-principal);
  font-size: 1.1rem;
  flex-shrink: 0;
}

#empresas .custeio-section__link {
  margin-top: 2rem;
  text-align: center;
}

/* Seção 7: Checklist */
#empresas .checklist-section {
  background: linear-gradient(to bottom, var(--azul-suave), white);
  padding-bottom: 6rem !important;
}

#empresas .checklist-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#empresas .checklist-section__subtitle {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-principal);
  margin-bottom: 2rem;
}

#empresas .checklist-section__content {
  background: var(--branco-gelo);
  padding: 2.5rem;
  border-radius: 12px;
  border: 2px solid var(--azul-claro);
}

#empresas .checklist-section__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#empresas .checklist-section__list-item {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin-bottom: 1.25rem;
  padding-left: 2.5rem;
  position: relative;
}

#empresas .checklist-section__list-item i {
  position: absolute;
  left: 0;
  top: 3px;
  color: var(--azul-principal);
  font-size: 1.5rem;
}

/* Cards de Checklist */
#empresas .checklist-section__cards {
  margin-top: 2rem;
}

#empresas .checklist-section__card {
  background: var(--branco-gelo);
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  min-height: 300px;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
}

#empresas .checklist-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-claro);
}

#empresas .checklist-section__card-icon {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#empresas .checklist-section__card:hover .checklist-section__card-icon {
  transform: scale(1.1) rotate(5deg);
}

#empresas .checklist-section__card-title {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#empresas .checklist-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

/* ================================================ */
/* Responsividade                                  */
/* ================================================ */
/* Notebooks */
@media (max-width: 1366px) {
  #empresas .ganhos-section__card {
    min-height: 330px;
  }

  #empresas .expectativas-section__card {
    min-height: 350px;
  }

  #empresas .como-funciona-section__cta-card {
    min-height: 180px;
  }
}

/* Tablets */
@media (max-width: 991.98px) {
  #empresas .ganhos-section__card {
    min-height: 280px;
  }

  #empresas .expectativas-section__card {
    min-height: 310px;
  }

  #empresas .como-funciona-section__cta-card {
    min-height: 220px;
  }

  #empresas .hero-section__headline {
    font-size: 2.25rem;
  }

  #empresas .como-funciona-section__cta-microcopy {
    font-size: 1rem;
  }

  #empresas .hero-section__subheadline {
    font-size: 1.1rem;
  }

  #empresas .hero-section__steps-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }

  #empresas .como-funciona-section__steps-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }

  #empresas .como-funciona-section__title,
  #empresas .ganhos-section__title,
  #empresas .tipo-desafio-section__title,
  #empresas .expectativas-section__title,
  #empresas .custeio-section__title,
  #empresas .checklist-section__title {
    font-size: 2rem;
  }
}

/* Mobile */
@media (max-width: 767.98px) {
  #empresas .hero-section {
    padding: 3rem 0 4rem;
  }

  #empresas .hero-section__headline {
    font-size: 1.85rem;
  }

  #empresas .hero-section__subheadline {
    font-size: 1rem;
  }

  #empresas .hero-section__ctas {
    flex-direction: column;
    gap: 1rem;
  }

  #empresas .hero-section__cta-btn {
    width: 100%;
  }

  #empresas .como-funciona-section__title,
  #empresas .ganhos-section__title,
  #empresas .tipo-desafio-section__title,
  #empresas .expectativas-section__title,
  #empresas .custeio-section__title,
  #empresas .checklist-section__title {
    font-size: 1.75rem;
  }

  #empresas .como-funciona-section__timeline::before {
    display: none;
  }

  /* Cards em coluna no mobile */
  #empresas .tipo-desafio-section__cards .col-lg-4 {
    margin-bottom: 2rem;
  }

  #empresas .expectativas-section__cards .col-lg-3 {
    margin-bottom: 2rem;
  }

  #empresas .checklist-section__cards .col-lg-4 {
    margin-bottom: 2rem;
  }
}

/* Estilos únicos para botões CTA */
#empresas .cta-send:hover::before {
  background: rgba(255, 255, 255, 0.3);
}

#empresas .cta-send:hover {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
}

#empresas .cta-contact {
  background: white;
  color: var(--azul-petroleo);
  border-color: var(--azul-principal);
}

#empresas .cta-contact:hover::before {
  background: rgba(84, 172, 191, 0.2);
}

#empresas .cta-contact:hover {
  background: var(--azul-principal);
  color: white;
  box-shadow: 0 8px 20px rgba(84, 172, 191, 0.3);
}

#empresas .cta-contact:active {
  background: var(--azul-petroleo);
  color: white;
  box-shadow: 0 4px 10px rgba(84, 172, 191, 0.2);
}

#empresas .custeio-cta {
  background: white;
  color: var(--azul-petroleo);
  border-color: var(--azul-principal);
}

#empresas .custeio-cta:hover::before {
  background: rgba(84, 172, 191, 0.2);
}

#empresas .custeio-cta:hover {
  background: var(--azul-principal);
  color: white;
  box-shadow: 0 8px 20px rgba(84, 172, 191, 0.3);
}

#empresas .custeio-cta:active {
  background: var(--azul-petroleo);
  color: white;
  box-shadow: 0 4px 10px rgba(84, 172, 191, 0.2);
}

#empresas .checklist-cta:hover::before {
  background: rgba(255, 255, 255, 0.3);
}

#empresas .checklist-cta:hover {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
}

#empresas .checklist-cta:active {
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

/* ============================================== */
/* PÁGINA ESTUDANTES - ConneCT                    */
/* ============================================== */

/* Seção 1: Hero */
#estudantes .hero-section {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 100%
  );
  color: var(--branco-gelo);
  padding: 4rem 0 5rem;
  position: relative;
  overflow: hidden;
}

#estudantes .hero-section::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
  height: 100%;
  background: radial-gradient(
    circle at top right,
    rgba(84, 172, 191, 0.15),
    transparent 70%
  );
  pointer-events: none;
}

#estudantes .hero-section__content {
  position: relative;
  z-index: 1;
  text-align: center;
}

#estudantes .hero-section__headline {
  font-family: var(--font-primary);
  font-size: 2.75rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.5rem;
  color: var(--branco-gelo);
}

#estudantes .hero-section__headline-destaque {
  color: var(--azul-suave);
  position: relative;
  display: inline-block;
}

#estudantes .hero-section__headline-destaque::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--azul-claro);
  border-radius: 2px;
}

#estudantes .hero-section__subheadline {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: 2.5rem;
  color: var(--azul-suave);
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

#estudantes .hero-section__ctas {
  display: flex;
  gap: 2rem;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}

#estudantes .hero-section__cta-btn {
  padding: 0.875rem 2rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 8px;
  transition: var(--transition-medium);
  position: relative;
  overflow: hidden;
}

#estudantes .hero-section__cta-btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  transform: translate(-50%, -50%);
  transition:
    width var(--transition-medium),
    height var(--transition-medium);
}

#estudantes .hero-section__cta-btn:hover::before {
  width: 300px;
  height: 300px;
}

#estudantes .hero-section__cta-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

#estudantes .hero-section__cta-link {
  color: var(--azul-suave);
  font-size: 1.05rem;
  font-weight: 500;
  text-decoration: none;
  transition: var(--transition-medium);
  display: inline-flex;
  align-items: center;
}

#estudantes .hero-section__cta-link:hover {
  color: white;
  transform: translateX(5px);
}

/* Seção 2: Como funciona */
#estudantes .como-funciona-section {
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--branco-gelo)
  );
}

#estudantes .como-funciona-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: white;
  margin-bottom: 1.5rem;
}

#estudantes .como-funciona-section__text {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: white;
  line-height: 1.7;
  margin-bottom: 1rem;
}

#estudantes .como-funciona-section__timeline {
  margin-top: 3rem;
}

#estudantes .como-funciona-section__step {
  background: white;
  padding: 1.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  height: 100%;
  transition: var(--transition-medium);
  border: 2px solid transparent;
}

#estudantes .como-funciona-section__step:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 24px rgba(15, 92, 140, 0.15);
  border-color: var(--azul-claro);
}

#estudantes .como-funciona-section__step-number {
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 auto 1rem;
}

#estudantes .como-funciona-section__step-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  text-align: center;
  margin: 0;
}

#estudantes .como-funciona-section__cta-card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  border-left: 4px solid var(--azul-principal);
  transition: var(--transition-medium);
  min-height: 180px;
}

#estudantes .como-funciona-section__cta-card:hover {
  transform: translateX(5px);
  box-shadow: 0 8px 24px rgba(15, 92, 140, 0.15);
}

#estudantes .como-funciona-section__cta-microcopy {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
  line-height: 1.5;
}

/* Seção 3: Por que participar */
#estudantes .por-que-section {
  background: linear-gradient(
    to bottom,
    var(--branco-gelo),
    var(--azul-principal)
  );
}

#estudantes .por-que-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#estudantes .por-que-section__highlight {
  color: var(--azul-principal);
  position: relative;
}

#estudantes .por-que-section__card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  min-height: 360px;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
}

#estudantes .por-que-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-claro);
}

#estudantes .por-que-section__card-icon {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#estudantes .por-que-section__card:hover .por-que-section__card-icon {
  transform: scale(1.1) rotate(5deg);
}

#estudantes .por-que-section__card-title {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#estudantes .por-que-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

/* Seção 4: Tipo de desafio */
#estudantes .tipo-desafio-section {
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--azul-claro)
  );
}

#estudantes .tipo-desafio-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: white;
  margin-bottom: 2rem;
}

#estudantes .tipo-desafio-section__content {
  background: var(--branco-gelo);
  padding: 2.5rem;
  border-radius: 12px;
  border-left: 5px solid var(--azul-principal);
}

#estudantes .tipo-desafio-section__text {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-principal);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}

#estudantes .tipo-desafio-section__list {
  list-style: none;
  padding: 0;
  margin-top: 2rem;
}

#estudantes .tipo-desafio-section__list-item {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: var(--azul-principal);
  line-height: 1.6;
  margin-bottom: 1rem;
  padding-left: 2.5rem;
  position: relative;
}

#estudantes .tipo-desafio-section__list-item i {
  position: absolute;
  left: 0;
  top: 3px;
  color: var(--azul-principal);
  font-size: 1.5rem;
}

/* Seção 5: Expectativas */
#estudantes .expectativas-section {
  background: linear-gradient(to bottom, var(--azul-claro), var(--branco-gelo));
  color: white;
}

#estudantes .expectativas-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#estudantes .expectativas-section__subtitle {
  font-family: var(--font-primary);
  font-size: 1.15rem;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
}

#estudantes .expectativas-section__content {
  background: rgba(255, 255, 255, 0.1);
  padding: 2.5rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
}

#estudantes .expectativas-section__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#estudantes .expectativas-section__list-item {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin-bottom: 1.25rem;
  padding-left: 2.5rem;
  position: relative;
}

#estudantes .expectativas-section__list-item i {
  position: absolute;
  left: 0;
  top: 3px;
  color: var(--azul-suave);
  font-size: 1.5rem;
}

/* Cards de Expectativas */
#estudantes .expectativas-section__card {
  background: rgba(255, 255, 255, 0.1);
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  min-height: 270px;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
  backdrop-filter: blur(10px);
}

#estudantes .expectativas-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.2);
  border-color: var(--azul-claro);
}

#estudantes .expectativas-section__card-icon {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#estudantes .expectativas-section__card:hover .expectativas-section__card-icon {
  transform: scale(1.1) rotate(5deg);
}

#estudantes .expectativas-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

/* Seção 6: Bolsa */
#estudantes .bolsa-section {
  background: var(--branco-gelo);
}

#estudantes .bolsa-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
}

#estudantes .bolsa-section__content {
  background: white;
  padding: 2.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
}

#estudantes .bolsa-section__text {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}

#estudantes .bolsa-section__link {
  margin-top: 2rem;
  text-align: center;
}

/* Seção 7: Checklist */
#estudantes .checklist-section {
  background: linear-gradient(to bottom, var(--branco-gelo), var(--azul-claro));
  padding-bottom: 6rem !important;
}

#estudantes .checklist-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#estudantes .checklist-section__subtitle {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
}

#estudantes .checklist-section__content {
  background: var(--branco-gelo);
  padding: 2.5rem;
  border-radius: 12px;
  border: 2px solid var(--azul-claro);
}

#estudantes .checklist-section__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#estudantes .checklist-section__list-item {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin-bottom: 1.25rem;
  padding-left: 2.5rem;
  position: relative;
}

#estudantes .checklist-section__list-item i {
  position: absolute;
  left: 0;
  top: 3px;
  color: var(--azul-principal);
  font-size: 1.5rem;
}

/* Cards de Checklist */
#estudantes .checklist-section__card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  min-height: 270px;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
}

#estudantes .checklist-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-claro);
}

#estudantes .checklist-section__card-icon {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#estudantes .checklist-section__card:hover .checklist-section__card-icon {
  transform: scale(1.1) rotate(5deg);
}

#estudantes .checklist-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

/* Botões customizados replicando padrão do site */
#estudantes .bolsa-section__btn,
#estudantes .checklist-section__btn {
  position: relative;
  overflow: hidden;
  transition: var(--transition-medium);
}

#estudantes .bolsa-section__btn::before,
#estudantes .checklist-section__btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  transition:
    width var(--transition-medium),
    height var(--transition-medium);
}

#estudantes .bolsa-section__btn::before {
  background: rgba(15, 92, 140, 0.1);
}

#estudantes .checklist-section__btn::before {
  background: rgba(255, 255, 255, 0.2);
}

#estudantes .bolsa-section__btn:hover::before,
#estudantes .checklist-section__btn:hover::before {
  width: 300px;
  height: 300px;
}

#estudantes .bolsa-section__btn:hover,
#estudantes .checklist-section__btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

#estudantes .bolsa-section__btn i,
#estudantes .checklist-section__btn i {
  transition: var(--transition-medium);
}

#estudantes .bolsa-section__btn:hover i,
#estudantes .checklist-section__btn:hover i {
  transform: scale(1.1);
}

/* Classe para destacar palavras nos títulos */
#estudantes .section-highlight {
  color: var(--azul-principal);
}

#estudantes .como-funciona-highlight {
  color: var(--azul-claro);
}

#estudantes .tipo-desafio-highlight {
  color: var(--azul-claro);
}

/* ================================================ */
/* Responsividade                                  */
/* ================================================ */

/* Tablets */
@media (max-width: 991.98px) {
  #estudantes .por-que-section__card {
    min-height: 280px;
  }
  #estudantes .como-funciona-section__step {
    min-height: 220px;
  }
  #estudantes .como-funciona-section__cta-card {
    min-height: 220px;
  }
  #estudantes .hero-section__headline {
    font-size: 2.25rem;
  }

  #estudantes .hero-section__subheadline {
    font-size: 1.1rem;
  }

  #estudantes .como-funciona-section__title,
  #estudantes .por-que-section__title,
  #estudantes .tipo-desafio-section__title,
  #estudantes .expectativas-section__title,
  #estudantes .bolsa-section__title,
  #estudantes .checklist-section__title {
    font-size: 2rem;
  }
}

/* Mobile */
@media (max-width: 767.98px) {
  #estudantes .hero-section {
    padding: 3rem 0 4rem;
  }

  #estudantes .hero-section__headline {
    font-size: 1.85rem;
  }

  #estudantes .hero-section__subheadline {
    font-size: 1rem;
  }

  #estudantes .hero-section__ctas {
    flex-direction: column;
    gap: 1rem;
  }

  #estudantes .hero-section__cta-btn {
    width: 100%;
  }

  #estudantes .como-funciona-section__title,
  #estudantes .por-que-section__title,
  #estudantes .tipo-desafio-section__title,
  #estudantes .expectativas-section__title,
  #estudantes .bolsa-section__title,
  #estudantes .checklist-section__title {
    font-size: 1.75rem;
  }

  #estudantes .tipo-desafio-section__content,
  #estudantes .expectativas-section__content,
  #estudantes .bolsa-section__content,
  #estudantes .checklist-section__content {
    padding: 1.5rem;
  }
}

/* Carousel Hint */
#estudantes .carousel-hint {
  text-align: center;
  margin-top: 1rem;
  font-family: var(--font-primary);
  font-size: 0.9rem;
  color: var(--azul-petroleo);
  opacity: 0.8;
}

/* ============================================== */
/* PÁGINA PROFESSORES - ConneCT                   */
/* ============================================== */

/* Seção 1: Hero */
#professores .hero-section {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 100%
  );
  color: var(--branco-gelo);
  padding: 4rem 0 5rem;
  position: relative;
  overflow: hidden;
}

#professores .hero-section::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
  height: 100%;
  background: radial-gradient(
    circle at top right,
    rgba(84, 172, 191, 0.15),
    transparent 70%
  );
  pointer-events: none;
}

#professores .hero-section__content {
  position: relative;
  z-index: 1;
  text-align: center;
}

#professores .hero-section__headline {
  font-family: var(--font-primary);
  font-size: 2.75rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.5rem;
  color: var(--branco-gelo);
}

#professores .hero-section__headline-destaque {
  color: var(--azul-suave);
  position: relative;
  display: inline-block;
}

#professores .hero-section__subheadline {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: 2.5rem;
  color: var(--azul-suave);
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

#professores .hero-section__ctas {
  display: flex;
  gap: 2rem;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}

#professores .hero-section__cta-btn {
  padding: 0.875rem 2rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 8px;
  transition: var(--transition-medium);
  position: relative;
  overflow: hidden;
}

#professores .hero-section__cta-btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  transform: translate(-50%, -50%);
  transition:
    width var(--transition-medium),
    height var(--transition-medium);
}

#professores .hero-section__cta-btn:hover::before {
  width: 300px;
  height: 300px;
}

#professores .hero-section__cta-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

/* Estilos para botões outline primários */
#professores .btn-outline-primary {
  padding: 0.875rem 2rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 8px;
  border: 2px solid var(--azul-principal);
  color: var(--azul-principal);
  background: transparent;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

#professores .btn-outline-primary::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: var(--azul-principal);
  transform: translate(-50%, -50%);
  transition:
    width 0.3s ease,
    height 0.3s ease;
  z-index: -1;
}

#professores .btn-outline-primary:hover::before {
  width: 300px;
  height: 300px;
}

#professores .btn-outline-primary:hover {
  color: white !important;
  border-color: var(--azul-principal);
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

#professores .btn-outline-primary i {
  transition: transform 0.3s ease;
}

#professores .btn-outline-primary:hover i {
  transform: translateX(3px);
}

/* Estilos para botões primários grandes */
#professores .btn-primary.btn-lg {
  padding: 1rem 2.5rem;
  font-size: 1.2rem;
  font-weight: 600;
  border-radius: 8px;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
}

#professores .btn-primary.btn-lg::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  transform: translate(-50%, -50%);
  transition:
    width 0.3s ease,
    height 0.3s ease;
}

#professores .btn-primary.btn-lg:hover::before {
  width: 300px;
  height: 300px;
}

#professores .btn-primary.btn-lg:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
}

#professores .hero-section__cta-link {
  color: var(--azul-suave);
  font-size: 1.05rem;
  font-weight: 500;
  text-decoration: none;
  transition: var(--transition-medium);
  display: inline-flex;
  align-items: center;
}

#professores .hero-section__cta-link:hover {
  color: white;
  transform: translateX(5px);
}

/* Seção 2: Como funciona */
#professores .como-funciona-section {
  background: linear-gradient(
    to bottom,
    var(--azul-petroleo),
    var(--azul-principal)
  );
}

#professores .como-funciona-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1.5rem;
}

#professores .como-funciona-section__highlight {
  color: var(--azul-suave);
}

#professores .como-funciona-section__text {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--branco-gelo);
  line-height: 1.7;
  margin-bottom: 1rem;
}

#professores .como-funciona-section__timeline {
  margin-top: 3rem;
}

#professores .como-funciona-section__step {
  background: white;
  padding: 1.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  height: 100%;
  transition: var(--transition-medium);
  border: 2px solid transparent;
}

#professores .como-funciona-section__step:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 24px rgba(15, 92, 140, 0.15);
  border-color: var(--azul-claro);
}

#professores .como-funciona-section__step-number {
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 auto 1rem;
}

#professores .como-funciona-section__step-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  text-align: center;
  margin: 0;
}

#professores .como-funciona-section__cta-card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  border-left: 4px solid var(--azul-principal);
  transition: var(--transition-medium);
  min-height: 185px;
}

#professores .como-funciona-section__cta-card:hover {
  transform: translateX(5px);
  box-shadow: 0 8px 24px rgba(15, 92, 140, 0.15);
}

#professores .como-funciona-section__cta-microcopy {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
  line-height: 1.5;
}

/* Seção 3: Por que ser mentor */
#professores .por-que-section {
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--azul-claro)
  );
}

#professores .por-que-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#professores .por-que-section__highlight {
  color: var(--azul-suave);
  position: relative;
}

#professores .por-que-section__card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  min-height: 355px;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
}

#professores .por-que-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-claro);
}

#professores .por-que-section__card-icon {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#professores .por-que-section__card:hover .por-que-section__card-icon {
  transform: scale(1.1) rotate(5deg);
}

#professores .por-que-section__card-title {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#professores .por-que-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

/* Seção 4: Tipo de projeto */
#professores .tipo-projeto-section {
  background: linear-gradient(to bottom, var(--azul-claro), var(--branco-gelo));
}

#professores .tipo-projeto-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
}

#professores .tipo-projeto-section__highlight {
  color: var(--azul-principal);
}

#professores .tipo-projeto-section__content {
  background: var(--branco-gelo);
  padding: 2.5rem;
  border-radius: 12px;
  border-left: 5px solid var(--azul-principal);
}

#professores .tipo-projeto-section__text {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}

#professores .tipo-projeto-section__list {
  list-style: none;
  padding: 0;
  margin-top: 2rem;
}

#professores .tipo-projeto-section__list-item {
  font-family: var(--font-primary);
  font-size: 1.05rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin-bottom: 1rem;
  padding-left: 2.5rem;
  position: relative;
}

#professores .tipo-projeto-section__list-item i {
  position: absolute;
  left: 0;
  top: 3px;
  color: var(--azul-principal);
  font-size: 1.5rem;
}

/* Seção 5: Expectativas */
#professores .expectativas-section {
  background: linear-gradient(to bottom, var(--branco-gelo), var(--azul-claro));
  color: white;
}

#professores .expectativas-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#professores .expectativas-section__highlight {
  color: var(--azul-principal);
}

#professores .expectativas-section__subtitle {
  font-family: var(--font-primary);
  font-size: 1.15rem;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
}

#professores .expectativas-section__content {
  background: rgba(255, 255, 255, 0.1);
  padding: 2.5rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
}

#professores .expectativas-section__card {
  background: rgba(255, 255, 255, 0.15);
  padding: 2rem;
  border-radius: 12px;
  height: 100%;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
  backdrop-filter: blur(5px);
}

#professores .expectativas-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(255, 255, 255, 0.2);
  border-color: var(--azul-suave);
}

#professores .expectativas-section__icon-circle {
  width: 70px;
  height: 70px;
  background: rgba(255, 255, 255, 0.2);
  color: var(--azul-petroleo);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
  border: 2px solid rgba(255, 255, 255, 0.3);
}

#professores
  .expectativas-section__card:hover
  .expectativas-section__icon-circle {
  transform: scale(1.1) rotate(5deg);
  background: rgba(255, 255, 255, 0.3);
}

#professores .expectativas-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

/* Seção 6: Bolsa */
#professores .bolsa-section {
  background: linear-gradient(
    to bottom,
    var(--azul-claro),
    var(--azul-principal)
  );
}

#professores .bolsa-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
}

#professores .bolsa-section__highlight {
  color: var(--azul-suave);
}

#professores .bolsa-section__content {
  background: white;
  padding: 2.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
}

#professores .bolsa-section__text {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}

#professores .bolsa-section__link {
  margin-top: 2rem;
  text-align: center;
}

/* Seção 7: Checklist */
#professores .checklist-section {
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  padding-bottom: 6rem !important;
}

#professores .checklist-section__title {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1rem;
}

#professores .checklist-section__highlight {
  color: var(--azul-suave);
}

#professores .checklist-section__subtitle {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--branco-gelo);
  margin-bottom: 2rem;
}

#professores .checklist-section__content {
  background: rgba(255, 255, 255, 0.1);
  padding: 2.5rem;
  border-radius: 12px;
  border: 2px solid var(--azul-claro);
  backdrop-filter: blur(10px);
}

#professores .checklist-section__card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 4px 12px rgba(4, 41, 64, 0.08);
  min-height: 300px;
  transition: var(--transition-medium);
  text-align: center;
  border: 2px solid transparent;
}

#professores .checklist-section__card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 28px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-claro);
}

#professores .checklist-section__icon-circle {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#professores .checklist-section__card:hover .checklist-section__icon-circle {
  transform: scale(1.1) rotate(5deg);
}

#professores .checklist-section__card-text {
  font-family: var(--font-primary);
  font-size: 1rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin: 0;
}

/* ================================================ */
/* Responsividade                                  */
/* ================================================ */

/* Tablets */
@media (max-width: 991.98px) {
  #professores .como-funciona-section__cta-card {
    min-height: 250px;
  }

  #professores .checklist-section__card {
    min-height: 300px;
  }

  #professores .por-que-section__card {
    min-height: 310px;
  }

  #professores .hero-section__headline {
    font-size: 2.25rem;
  }

  #professores .hero-section__subheadline {
    font-size: 1.1rem;
  }

  #professores .como-funciona-section__title,
  #professores .por-que-section__title,
  #professores .tipo-projeto-section__title,
  #professores .expectativas-section__title,
  #professores .bolsa-section__title,
  #professores .checklist-section__title {
    font-size: 2rem;
  }
}

/* Mobile */
@media (max-width: 767.98px) {
  #professores .hero-section {
    padding: 3rem 0 4rem;
  }

  #professores .hero-section__headline {
    font-size: 1.85rem;
  }

  #professores .hero-section__subheadline {
    font-size: 1rem;
  }

  #professores .hero-section__ctas {
    flex-direction: column;
    gap: 1rem;
  }

  #professores .hero-section__cta-btn {
    width: 100%;
  }

  #professores .como-funciona-section__title,
  #professores .por-que-section__title,
  #professores .tipo-projeto-section__title,
  #professores .expectativas-section__title,
  #professores .bolsa-section__title,
  #professores .checklist-section__title {
    font-size: 1.75rem;
  }

  #professores .tipo-projeto-section__content,
  #professores .expectativas-section__content,
  #professores .bolsa-section__content,
  #professores .checklist-section__content {
    padding: 1.5rem;
  }
}

/* ============================================== */
/* PÁGINA SOBRE - ESTILOS INLINE REFINADOS       */
/* ============================================== */

/* SEÇÃO 1: HERO */
#sobre .hero-section {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 50%,
    var(--azul-claro) 100%
  );
  padding: 120px 0 80px;
  color: var(--branco-gelo);
  position: relative;
  overflow: hidden;
}

#sobre .hero-section::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    rgba(84, 172, 191, 0.15) 0%,
    transparent 70%
  );
  border-radius: 50%;
  animation: float 8s ease-in-out infinite;
}

@keyframes float {
  0%,
  100% {
    transform: translate(0, 0);
  }

  50% {
    transform: translate(-20px, -20px);
  }
}

#sobre .hero-section__headline {
  font-size: 3.5rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  font-family: var(--font-primary);
}

#sobre .hero-section__subheadline {
  font-size: 1.25rem;
  font-weight: 400;
  line-height: 1.8;
  opacity: 0.95;
  font-family: var(--font-primary);
}

/* SEÇÃO 2: O QUE É */
#sobre .o-que-e-section {
  padding: 80px 0;
  background: var(--azul-suave);
  position: relative;
}

#sobre .o-que-e-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: -10%;
  width: 300px;
  height: 300px;
  background: radial-gradient(
    circle,
    rgba(15, 92, 140, 0.1) 0%,
    transparent 70%
  );
  border-radius: 50%;
}

#sobre .o-que-e-section__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
  font-family: var(--font-heading);
}

#sobre .o-que-e-section__text {
  font-size: 1.125rem;
  line-height: 1.8;
  color: var(--azul-preto);
  font-family: var(--font-primary);
}

#sobre .o-que-e-section__highlight {
  color: var(--azul-principal);
  font-weight: 700;
  position: relative;
  display: inline-block;
}

#sobre .o-que-e-section__highlight::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 8px;
  background: linear-gradient(90deg, var(--azul-claro), var(--azul-suave));
  opacity: 0.4;
  z-index: -1;
}

/* SEÇÃO 3: POR QUE EXISTE */
#sobre .por-que-existe-section {
  padding: 80px 0;
  background: linear-gradient(
    to bottom,
    var(--azul-suave) 50%,
    var(--branco-gelo) 100%
  );
  position: relative;
}

#sobre .por-que-existe-section::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: -5%;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(84, 172, 191, 0.08) 0%,
    transparent 70%
  );
  border-radius: 50%;
}

#sobre .por-que-existe-section__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
  font-family: var(--font-heading);
}

#sobre .por-que-existe-section__text {
  font-size: 1.125rem;
  line-height: 1.8;
  color: var(--azul-preto);
  margin-bottom: 1.5rem;
  font-family: var(--font-primary);
}

#sobre .por-que-existe-section__highlight {
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 700;
  position: relative;
}

/* SEÇÃO 4: BENEFÍCIOS (TABS) */
#sobre .beneficios-section {
  padding: 80px 0;
  background: var(--branco-gelo);
  position: relative;
  overflow: hidden;
}

#sobre .beneficios-section::before {
  content: "";
  position: absolute;
  top: -20%;
  left: 10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    rgba(15, 92, 140, 0.05) 0%,
    transparent 70%
  );
  border-radius: 50%;
  animation: float 10s ease-in-out infinite;
}

#sobre .beneficios-section::after {
  content: "";
  position: absolute;
  bottom: -15%;
  right: 5%;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(84, 172, 191, 0.08) 0%,
    transparent 70%
  );
  border-radius: 50%;
  animation: float 12s ease-in-out infinite reverse;
}

#sobre .beneficios-section__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 3rem;
  font-family: var(--font-heading);
  position: relative;
  z-index: 2;
}

#sobre .beneficios-section__highlight {
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
  position: relative;
}

#sobre .beneficios-section__highlight::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, var(--azul-claro), var(--azul-suave));
}

#sobre .beneficios-section__tabs {
  background: #fff;
  border-radius: 16px;
  padding: 2.5rem;
  box-shadow: 0 10px 40px rgba(15, 92, 140, 0.15);
  position: relative;
  z-index: 2;
  border: 1px solid rgba(84, 172, 191, 0.2);
}

#sobre .beneficios-section__nav {
  border-bottom: 2px solid var(--azul-suave);
  margin-bottom: 2rem;
  justify-content: center;
}

#sobre .beneficios-section__nav .nav-link {
  color: var(--azul-petroleo);
  font-weight: 600;
  font-size: 1.125rem;
  padding: 1rem 1.5rem;
  border: none;
  border-bottom: 3px solid transparent;
  transition: all 0.3s ease;
  font-family: var(--font-primary);
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

#sobre .beneficios-section__nav .nav-link::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--azul-principal), var(--azul-claro));
  transition: width 0.3s ease;
}

#sobre .beneficios-section__nav .nav-link:hover {
  color: var(--azul-principal);
  transform: translateY(-2px);
}

#sobre .beneficios-section__nav .nav-link i {
  font-size: 1.25rem;
  transition: transform 0.3s ease;
}

#sobre .beneficios-section__nav .nav-link:hover i {
  transform: scale(1.1);
}

#sobre .beneficios-section__nav .nav-link.active {
  color: var(--azul-principal);
  background: linear-gradient(
    135deg,
    rgba(15, 92, 140, 0.05),
    rgba(84, 172, 191, 0.05)
  );
  border-radius: 8px 8px 0 0;
}

#sobre .beneficios-section__nav .nav-link.active i {
  color: var(--azul-principal);
}

#sobre .beneficios-section__tab-content {
  padding: 1.5rem 0;
}

#sobre .beneficios-section__list {
  list-style: none;
  padding: 0;
  margin-bottom: 2rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

#sobre .beneficios-section__item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1.25rem;
  font-size: 1.125rem;
  color: var(--azul-preto);
  font-family: var(--font-primary);
  padding: 0.75rem;
  border-radius: 8px;
  transition: all 0.3s ease;
}

#sobre .beneficios-section__item:hover {
  background: linear-gradient(
    135deg,
    rgba(187, 232, 242, 0.3),
    rgba(84, 172, 191, 0.1)
  );
  transform: scale(1.02);
}

#sobre .beneficios-section__item i {
  color: #fff;
  font-size: 1rem;
  flex-shrink: 0;
  margin-top: 0;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  border-radius: 50%;
  box-shadow: 0 4px 10px rgba(15, 92, 140, 0.3);
}

#sobre .beneficios-section__cta {
  text-align: center;
  margin-top: 2rem;
}

#sobre .beneficios-section__cta .btn {
  padding: 0.875rem 2rem;
  font-size: 1.125rem;
  font-weight: 600;
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  border-radius: 50px;
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.2);
}

#sobre .beneficios-section__cta .btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.3);
  transform: translate(-50%, -50%);
  transition:
    width 0.6s ease,
    height 0.6s ease;
}

#sobre .beneficios-section__cta .btn:hover::before {
  width: 300px;
  height: 300px;
}

#sobre .beneficios-section__cta .btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.3);
}

#sobre .beneficios-section__cta .btn i {
  margin-left: 0.5rem;
  transition: transform 0.3s ease;
  position: relative;
  z-index: 1;
}

#sobre .beneficios-section__cta .btn:hover i {
  transform: translateX(5px);
}

/* SEÇÃO 5: GOVERNANÇA */
#sobre .governanca-section {
  padding: 80px 0;
  background: linear-gradient(
    to bottom,
    var(--branco-gelo) 0%,
    var(--azul-suave) 100%
  );
  position: relative;
}

#sobre .governanca-section::before {
  content: "";
  position: absolute;
  top: 10%;
  right: -5%;
  width: 350px;
  height: 350px;
  background: radial-gradient(
    circle,
    rgba(15, 92, 140, 0.05) 0%,
    transparent 70%
  );
  border-radius: 50%;
}

#sobre .governanca-section__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1.5rem;
  font-family: var(--font-heading);
}

#sobre .governanca-section__highlight {
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
}

#sobre .governanca-section__subtitle {
  font-size: 1.125rem;
  line-height: 1.8;
  color: var(--azul-preto);
  margin-bottom: 3rem;
  font-family: var(--font-primary);
}

#sobre .governanca-section__card {
  background: #fff;
  border-radius: 16px;
  padding: 2.5rem;
  height: 100%;
  transition: all 0.4s ease;
  border: 2px solid rgba(84, 172, 191, 0.2);
  position: relative;
  overflow: hidden;
}

#sobre .governanca-section__card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    135deg,
    rgba(187, 232, 242, 0.1) 0%,
    rgba(84, 172, 191, 0.05) 100%
  );
  opacity: 0;
  transition: opacity 0.4s ease;
}

#sobre .governanca-section__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-claro);
}

#sobre .governanca-section__card:hover::before {
  opacity: 1;
}

#sobre .governanca-section__card-icon {
  width: 80px;
  height: 80px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 1.5rem;
  position: relative;
  z-index: 1;
  box-shadow: 0 8px 20px rgba(15, 92, 140, 0.3);
  transition: all 0.4s ease;
}

#sobre .governanca-section__card:hover .governanca-section__card-icon {
  transform: scale(1.1) rotate(5deg);
  box-shadow: 0 12px 30px rgba(15, 92, 140, 0.4);
}

#sobre .governanca-section__card-icon i {
  font-size: 2.25rem;
  color: #fff;
  transition: transform 0.4s ease;
}

#sobre .governanca-section__card:hover .governanca-section__card-icon i {
  transform: scale(1.1);
}

#sobre .governanca-section__card-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
  font-family: var(--font-primary);
  position: relative;
  z-index: 1;
}

#sobre .governanca-section__card-text {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--azul-preto);
  margin: 0;
  font-family: var(--font-primary);
  position: relative;
  z-index: 1;
}

/* SEÇÃO 6: TRAJETÓRIA (TIMELINE) */
#sobre .trajetoria-section {
  padding: 60px 0;
  background: var(--azul-suave);
  position: relative;
  overflow: hidden;
}

#sobre .trajetoria-section::before {
  content: "";
  position: absolute;
  top: 20%;
  left: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    rgba(84, 172, 191, 0.1) 0%,
    transparent 70%
  );
  border-radius: 50%;
}

#sobre .trajetoria-section__title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 4rem;
  font-family: var(--font-heading);
  position: relative;
  z-index: 2;
}

#sobre .trajetoria-section__highlight {
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-weight: 800;
}

#sobre .trajetoria-section__timeline {
  position: relative;
  padding-left: 0;
  z-index: 2;
}

#sobre .trajetoria-section__timeline::before {
  content: "";
  position: absolute;
  left: 80px;
  top: 20px;
  bottom: 20px;
  width: 4px;
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--azul-claro),
    var(--azul-suave)
  );
  border-radius: 2px;
  box-shadow: 0 0 10px rgba(15, 92, 140, 0.3);
}

#sobre .trajetoria-section__item {
  position: relative;
  display: flex;
  gap: 2rem;
  margin-bottom: 3rem;
}

#sobre .trajetoria-section__item:last-child {
  margin-bottom: 0;
}

#sobre .trajetoria-section__year {
  flex-shrink: 0;
  width: 90px;
  height: 90px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  font-weight: 700;
  color: #fff;
  z-index: 2;
  position: relative;
  font-family: var(--font-primary);
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.4);
  border: 4px solid #fff;
  transition: all 0.4s ease;
}

#sobre .trajetoria-section__item:hover .trajetoria-section__year {
  transform: scale(1.15) rotate(-5deg);
  box-shadow: 0 12px 35px rgba(15, 92, 140, 0.5);
}

#sobre .trajetoria-section__content {
  flex: 1;
  background: #fff;
  border-radius: 16px;
  padding: 2.5rem;
  box-shadow: 0 8px 30px rgba(15, 92, 140, 0.1);
  transition: all 0.4s ease;
  position: relative;
  border: 2px solid rgba(84, 172, 191, 0.15);
  overflow: hidden;
}

#sobre .trajetoria-section__content::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 5px;
  height: 100%;
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--azul-claro)
  );
  transform: scaleY(0);
  transition: transform 0.4s ease;
}

#sobre .trajetoria-section__content:hover {
  transform: translateX(15px);
  box-shadow: 0 12px 40px rgba(15, 92, 140, 0.2);
  border-color: var(--azul-claro);
}

#sobre .trajetoria-section__content:hover::before {
  transform: scaleY(1);
}

#sobre .trajetoria-section__item-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 0.75rem;
  font-family: var(--font-primary);
  transition: color 0.3s ease;
}

#sobre .trajetoria-section__content:hover .trajetoria-section__item-title {
  color: var(--azul-claro);
}

#sobre .trajetoria-section__item-text {
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--azul-preto);
  margin: 0;
  font-family: var(--font-primary);
}

#sobre .trajetoria-section__item-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

#sobre .trajetoria-section__item-list li {
  font-size: 0.875rem;
  line-height: 1.5;
  color: var(--azul-preto);
  font-family: var(--font-primary);
  padding-left: 1.1rem;
  position: relative;
}

#sobre .trajetoria-section__item-list li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--azul-principal);
  font-weight: 700;
}

/* SEÇÃO 7: CTAs FINAIS */
#sobre .ctas-finais-section {
  padding: 100px 0;
  background: var(--azul-suave);
  color: var(--azul-petroleo);
}

#sobre .ctas-finais-section__title {
  font-size: 2.75rem;
  font-weight: 700;
  margin-bottom: 2.5rem;
  font-family: var(--font-heading);
}

#sobre .ctas-finais-section__highlight {
  color: var(--azul-principal);
  font-weight: 800;
  text-shadow: 0 2px 10px rgba(187, 232, 242, 0.5);
}

#sobre .ctas-finais-section__buttons {
  display: flex;
  gap: 1.5rem;
  justify-content: center;
  flex-wrap: wrap;
}

#sobre .ctas-finais-section__buttons .btn {
  padding: 1.125rem 3rem;
  font-size: 1.25rem;
  font-weight: 600;
  transition: all 0.4s ease;
  font-family: var(--font-primary);
  border-radius: 50px;
  position: relative;
  overflow: hidden;
}

#sobre .ctas-finais-section__buttons .btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  transform: translate(-50%, -50%);
  transition:
    width 0.6s ease,
    height 0.6s ease;
}

#sobre .ctas-finais-section__buttons .btn:hover::after {
  width: 400px;
  height: 400px;
}

#sobre .ctas-finais-section__buttons .btn-primary {
  background: var(--azul-principal);
  color: var(--branco-gelo);
  border: 3px solid var(--azul-principal);
  box-shadow: 0 6px 20px rgba(15, 92, 140, 0.3);
}

#sobre .ctas-finais-section__buttons .btn-primary:hover {
  background: var(--azul-claro);
  color: var(--branco-gelo);
  border-color: var(--azul-claro);
  transform: translateY(-5px) scale(1.05);
  box-shadow: 0 12px 30px rgba(84, 172, 191, 0.4);
}

#sobre .ctas-finais-section__buttons .btn-outline-primary {
  background: transparent;
  color: var(--azul-principal);
  border: 3px solid var(--azul-principal);
}

#sobre .ctas-finais-section__buttons .btn-outline-primary:hover {
  background: var(--azul-principal);
  color: var(--branco-gelo);
  transform: translateY(-5px) scale(1.05);
  box-shadow: 0 12px 30px rgba(15, 92, 140, 0.4);
}

#sobre .ctas-finais-section__buttons .btn i {
  margin-left: 0.5rem;
  transition: transform 0.3s ease;
}

#sobre .ctas-finais-section__buttons .btn:hover i {
  transform: translateX(5px);
}

/* ============================================== */
/* CAROUSEL HINTS - SOBRE PAGE                   */
/* ============================================== */

#sobre .carousel-hint {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(15, 92, 140, 0.9);
  color: #fff;
  padding: 0.75rem 1.5rem;
  border-radius: 25px;
  font-size: 0.875rem;
  font-weight: 600;
  font-family: var(--font-primary);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.3);
  z-index: 10;
  animation: fadeInUp 0.5s ease-out;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

#sobre .carousel-hint i {
  margin-right: 0.5rem;
  font-size: 1rem;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
  }
}

/* Tablets - 992px */
@media (max-width: 991.98px) {
  #sobre .beneficios-section__item {
    min-height: 150px;
  }

  #sobre .hero-section {
    padding: 80px 0 60px;
  }

  #sobre .hero-section__headline {
    font-size: 2.75rem;
  }

  #sobre .hero-section__subheadline {
    font-size: 1.125rem;
  }

  #sobre .o-que-e-section,
  #sobre .por-que-existe-section,
  #sobre .beneficios-section,
  #sobre .governanca-section,
  #sobre .trajetoria-section {
    padding: 60px 0;
  }

  #sobre .ctas-finais-section {
    padding: 80px 0;
  }

  #sobre .ctas-finais-section__title {
    font-size: 2.25rem;
  }
}

/* Mobile - 768px */
@media (max-width: 767.98px) {
  #sobre .hero-section__headline {
    font-size: 2.25rem;
  }

  #sobre .hero-section__subheadline {
    font-size: 1rem;
  }

  #sobre .o-que-e-section__title,
  #sobre .por-que-existe-section__title,
  #sobre .beneficios-section__title,
  #sobre .governanca-section__title,
  #sobre .trajetoria-section__title {
    font-size: 2rem;
  }

  #sobre .beneficios-section__nav .nav-link {
    font-size: 1rem;
    padding: 0.75rem 1rem;
  }

  #sobre .beneficios-section__item {
    font-size: 1rem;
  }

  #sobre .beneficios-section__list {
    grid-template-columns: 1fr;
  }

  #sobre .trajetoria-section__timeline::before {
    left: 40px;
  }

  #sobre .trajetoria-section__year {
    width: 60px;
    height: 60px;
    font-size: 1rem;
  }

  #sobre .trajetoria-section__item {
    gap: 1.5rem;
  }

  #sobre .ctas-finais-section__title {
    font-size: 1.875rem;
  }

  #sobre .ctas-finais-section__buttons {
    flex-direction: column;
    align-items: stretch;
  }

  #sobre .ctas-finais-section__buttons .btn {
    width: 100%;
  }
}

/* Mobile pequeno - 576px */
@media (max-width: 575.98px) {
  #sobre .trajetoria-section__content {
    min-height: 210px;
  }

  #sobre .hero-section {
    padding: 60px 0 40px;
  }

  #sobre .hero-section__headline {
    font-size: 1.875rem;
  }

  #sobre .o-que-e-section,
  #sobre .por-que-existe-section,
  #sobre .beneficios-section,
  #sobre .governanca-section,
  #sobre .trajetoria-section {
    padding: 40px 0;
  }

  #sobre .ctas-finais-section {
    padding: 60px 0;
  }

  #sobre .beneficios-section__tabs {
    padding: 1.5rem;
  }

  #sobre .beneficios-section__nav .nav-link {
    font-size: 0.9375rem;
    padding: 0.625rem 0.75rem;
  }

  #sobre .trajetoria-section__content {
    padding: 1.5rem;
  }

  #sobre .ctas-finais-section__buttons .btn {
    font-size: 1.125rem;
    padding: 0.875rem 2rem;
  }
}

/* ================================================ */
/* DO DESAFIO AO PROJETO - Estilos Inline          */
/* ================================================ */

/* Hero Section */
#do-desafio-ao-projeto .hero-section {
  padding: 120px 0 80px;
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 100%
  );
  color: var(--branco-gelo);
  position: relative;
  overflow: hidden;
}

#do-desafio-ao-projeto .hero-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(
    circle at 20% 50%,
    rgba(84, 172, 191, 0.1) 0%,
    transparent 50%
  );
  pointer-events: none;
}

#do-desafio-ao-projeto .hero-section__content {
  position: relative;
  z-index: 2;
  text-align: center;
}

#do-desafio-ao-projeto .hero-section__headline {
  font-family: var(--font-primary);
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.5rem;
}

#do-desafio-ao-projeto .hero-section__headline-destaque {
  color: var(--azul-suave);
  position: relative;
  display: inline-block;
}

#do-desafio-ao-projeto .hero-section__headline-destaque::after {
  content: "";
  position: absolute;
  bottom: 5px;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--azul-claro);
  animation: expandWidth 1s ease-out forwards;
}

@keyframes expandWidth {
  from {
    width: 0;
  }

  to {
    width: 100%;
  }
}

/* Destaque para títulos das seções */
#do-desafio-ao-projeto .section-highlight {
  position: relative;
  display: inline-block;
}

#do-desafio-ao-projeto .section-highlight::after {
  content: "";
  position: absolute;
  bottom: 5px;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--azul-claro);
  animation: expandWidth 1s ease-out forwards;
}

#do-desafio-ao-projeto .hero-section__subheadline {
  font-family: var(--font-primary);
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: 2.5rem;
  opacity: 0.95;
}

#do-desafio-ao-projeto .hero-section__bullets {
  list-style: none;
  padding: 0;
  margin: 2.5rem 0;
}

#do-desafio-ao-projeto .hero-section__bullets li {
  font-size: 1.1rem;
  line-height: 1.8;
  margin-bottom: 1rem;
  padding-left: 2rem;
  position: relative;
}

#do-desafio-ao-projeto .hero-section__bullets li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--azul-suave);
  font-weight: 700;
  font-size: 1.3rem;
}

#do-desafio-ao-projeto .hero-section__cards {
  margin: 2.5rem 0;
}

#do-desafio-ao-projeto .hero-section__card {
  background: transparent;
  padding: 1.5rem;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  margin-bottom: 1rem;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  transition: var(--transition-medium);
  min-height: 110px;
}

#do-desafio-ao-projeto .hero-section__card:hover {
  border-color: var(--azul-suave);
  transform: translateY(-2px);
}

#do-desafio-ao-projeto .hero-section__card-icon {
  color: var(--azul-suave);
  font-size: 1.5rem;
  flex-shrink: 0;
}

#do-desafio-ao-projeto .hero-section__card-text {
  color: var(--branco-gelo);
  margin: 0;
  line-height: 1.6;
}

#do-desafio-ao-projeto .hero-section__ctas {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 2.5rem;
  justify-content: center;
}

#do-desafio-ao-projeto .hero-section__cta-btn {
  padding: 1rem 2.5rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 50px;
  border: 2px solid transparent;
  transition: var(--transition-medium);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
}

#do-desafio-ao-projeto .hero-section__cta-btn--primary {
  background: var(--azul-claro);
  color: var(--azul-petroleo);
}

#do-desafio-ao-projeto .hero-section__cta-btn--primary::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.3),
    transparent
  );
  transition: left 0.5s;
}

#do-desafio-ao-projeto .hero-section__cta-btn--primary:hover::before {
  left: 100%;
}

#do-desafio-ao-projeto .hero-section__cta-btn--primary:hover {
  background: var(--azul-suave);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(84, 172, 191, 0.3);
}

#do-desafio-ao-projeto .hero-section__cta-btn--secondary {
  background: transparent;
  color: var(--branco-gelo);
  border-color: var(--branco-gelo);
}

#do-desafio-ao-projeto .hero-section__cta-btn--secondary:hover {
  background: var(--branco-gelo);
  color: var(--azul-principal);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(248, 248, 248, 0.2);
}

/* Visão Geral Section */
#do-desafio-ao-projeto .visao-geral-section {
  padding: 80px 0;
  background: linear-gradient(
    to bottom,
    var(--azul-petroleo),
    var(--azul-principal)
  );
  color: var(--branco-gelo);
}

#do-desafio-ao-projeto .visao-geral-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 2rem;
  text-align: center;
}

#do-desafio-ao-projeto .visao-geral-section__content {
  background: rgba(255, 255, 255, 0.1);
  padding: 3rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

#do-desafio-ao-projeto .visao-geral-section__text {
  font-size: 1.2rem;
  line-height: 1.8;
  color: var(--branco-gelo);
  margin-bottom: 1.5rem;
}

#do-desafio-ao-projeto .visao-geral-section__text:last-child {
  margin-bottom: 0;
}

/* Etapas Section */
#do-desafio-ao-projeto .etapas-section {
  padding: 80px 0;
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--azul-claro)
  );
  color: var(--branco-gelo);
}

#do-desafio-ao-projeto .etapas-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 3rem;
  text-align: center;
}

#do-desafio-ao-projeto .etapas-section__timeline {
  position: relative;
  padding: 2rem 0;
}

/* Timeline vertical line */
#do-desafio-ao-projeto .etapas-section__timeline::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(to bottom, var(--branco-gelo), var(--azul-claro));
  transform: translateX(-50%);
}

#do-desafio-ao-projeto .etapas-section__step {
  position: relative;
  margin-bottom: 4rem;
}

#do-desafio-ao-projeto .etapas-section__step:last-child {
  margin-bottom: 0;
}

#do-desafio-ao-projeto .etapas-section__step-card {
  background: rgba(255, 255, 255, 0.25);
  padding: 2rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.3);
  transition: var(--transition-medium);
  position: relative;
}

#do-desafio-ao-projeto .etapas-section__step-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(4, 41, 64, 0.15);
  border-color: var(--azul-principal);
}

#do-desafio-ao-projeto .etapas-section__step-number {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 700;
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.3);
  z-index: 10;
}

#do-desafio-ao-projeto .etapas-section__step--left .etapas-section__step-card {
  margin-right: calc(50% + 50px);
}

#do-desafio-ao-projeto .etapas-section__step--right .etapas-section__step-card {
  margin-left: calc(50% + 50px);
}

#do-desafio-ao-projeto .etapas-section__step-title {
  font-family: var(--font-primary);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1rem;
}

#do-desafio-ao-projeto .etapas-section__step-description {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--branco-gelo);
  margin-bottom: 0;
}

#do-desafio-ao-projeto .etapas-section__step-link {
  display: inline-block;
  margin-top: 1rem;
  font-size: 0.95rem;
  color: var(--branco-gelo);
  text-decoration: none;
  font-weight: 500;
  transition: var(--transition-medium);
}

#do-desafio-ao-projeto .etapas-section__step-link:hover {
  color: var(--azul-suave);
  transform: translateX(5px);
}

#do-desafio-ao-projeto .etapas-section__note {
  margin-top: 3rem;
  padding: 1.5rem;
  background: rgba(255, 255, 255, 0.2);
  border-left: 4px solid var(--azul-suave);
  border-radius: 8px;
  font-style: italic;
  color: var(--branco-gelo);
}

/* Ponte Metodologia Section */
#do-desafio-ao-projeto .ponte-section {
  padding: 80px 0;
  background: linear-gradient(to bottom, var(--azul-claro), var(--branco-gelo));
  color: var(--azul-petroleo);
}

#do-desafio-ao-projeto .ponte-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  text-align: center;
}

#do-desafio-ao-projeto .ponte-section__text {
  font-size: 1.2rem;
  line-height: 1.8;
  margin-bottom: 2rem;
  text-align: center;
  opacity: 0.95;
}

#do-desafio-ao-projeto .ponte-section__cta {
  text-align: center;
}

#do-desafio-ao-projeto .ponte-section__cta-btn {
  padding: 1rem 2.5rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 50px;
  background: var(--azul-claro);
  color: var(--azul-petroleo);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: var(--transition-medium);
  border: 2px solid transparent;
}

#do-desafio-ao-projeto .ponte-section__cta-btn:hover {
  background: var(--azul-suave);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(84, 172, 191, 0.3);
}

/* Checklist Empresa Section */
#do-desafio-ao-projeto .checklist-empresa-section {
  padding: 80px 0;
  background: linear-gradient(to bottom, var(--branco-gelo), var(--azul-claro));
}

#do-desafio-ao-projeto .checklist-empresa-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 3rem;
  text-align: center;
}

#do-desafio-ao-projeto .checklist-empresa-section__content {
  background: transparent;
  padding: 3rem;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(4, 41, 64, 0.08);
  border-left: 4px solid var(--azul-principal);
}

#do-desafio-ao-projeto .checklist-empresa-section__list {
  list-style: none;
  padding: 0;
  margin: 0 0 2.5rem 0;
}

#do-desafio-ao-projeto .checklist-empresa-section__list li {
  font-size: 1.1rem;
  line-height: 1.8;
  margin-bottom: 1.2rem;
  padding-left: 2.5rem;
  position: relative;
  color: var(--azul-petroleo);
}

#do-desafio-ao-projeto .checklist-empresa-section__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5rem;
  width: 20px;
  height: 20px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#do-desafio-ao-projeto .checklist-empresa-section__list li::after {
  content: "✓";
  position: absolute;
  left: 5px;
  top: 0.35rem;
  color: white;
  font-weight: 700;
  font-size: 0.9rem;
}

#do-desafio-ao-projeto .checklist-empresa-section__cards {
  margin: 0 0 2.5rem 0;
}

#do-desafio-ao-projeto .checklist-empresa-section__card {
  background: var(--azul-claro);
  padding: 1.5rem;
  border-radius: 12px;
  text-align: center;
  margin-bottom: 1rem;
  transition: var(--transition-medium);
  min-height: 240px;
}

#do-desafio-ao-projeto .checklist-empresa-section__card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
}

#do-desafio-ao-projeto .checklist-empresa-section__card-icon {
  color: var(--azul-petroleo);
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
}

#do-desafio-ao-projeto .checklist-empresa-section__card-text {
  color: var(--azul-petroleo);
  margin: 0;
  line-height: 1.6;
  font-size: 0.95rem;
}

#do-desafio-ao-projeto .checklist-empresa-section__cta {
  text-align: center;
}

#do-desafio-ao-projeto .checklist-empresa-section__cta-btn {
  padding: 1rem 2.5rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 50px;
  background: var(--azul-principal);
  color: white;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: var(--transition-medium);
  border: 2px solid var(--azul-principal);
}

#do-desafio-ao-projeto .checklist-empresa-section__cta-btn:hover {
  background: var(--azul-claro);
  border-color: var(--azul-claro);
  color: var(--azul-petroleo);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(15, 92, 140, 0.3);
}

/* Checklist Pitch Section */
#do-desafio-ao-projeto .checklist-pitch-section {
  padding: 80px 0;
  background: linear-gradient(
    to bottom,
    var(--azul-claro),
    var(--azul-principal)
  );
  color: var(--branco-gelo);
}

#do-desafio-ao-projeto .checklist-pitch-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 3rem;
  text-align: center;
}

#do-desafio-ao-projeto .checklist-pitch-section__content {
  background: rgba(255, 255, 255, 0.1);
  padding: 3rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

#do-desafio-ao-projeto .checklist-pitch-section__list {
  list-style: none;
  padding: 0;
  margin: 0 0 2.5rem 0;
}

#do-desafio-ao-projeto .checklist-pitch-section__list li {
  font-size: 1.1rem;
  line-height: 1.8;
  margin-bottom: 1.2rem;
  padding-left: 2.5rem;
  position: relative;
  color: var(--branco-gelo);
}

#do-desafio-ao-projeto .checklist-pitch-section__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5rem;
  width: 20px;
  height: 20px;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-suave));
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#do-desafio-ao-projeto .checklist-pitch-section__list li::after {
  content: "✓";
  position: absolute;
  left: 5px;
  top: 0.35rem;
  color: white;
  font-weight: 700;
  font-size: 0.9rem;
}

#do-desafio-ao-projeto .checklist-pitch-section__cards {
  margin: 0 0 2.5rem 0;
}

#do-desafio-ao-projeto .checklist-pitch-section__card {
  background: rgba(255, 255, 255, 0.2);
  padding: 1.5rem;
  border-radius: 12px;
  text-align: center;
  margin-bottom: 1rem;
  transition: var(--transition-medium);
  backdrop-filter: blur(5px);
  border: 1px solid rgba(255, 255, 255, 0.3);
  min-height: 150px;
}

#do-desafio-ao-projeto .checklist-pitch-section__card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  border-color: var(--azul-suave);
}

#do-desafio-ao-projeto .checklist-pitch-section__card-icon {
  color: var(--azul-suave);
  font-size: 1.5rem;
  margin-bottom: 0.5rem;
}

#do-desafio-ao-projeto .checklist-pitch-section__card-text {
  color: var(--branco-gelo);
  margin: 0;
  line-height: 1.6;
  font-size: 0.95rem;
}

#do-desafio-ao-projeto .checklist-pitch-section__cta {
  text-align: center;
}

#do-desafio-ao-projeto .checklist-pitch-section__cta-btn {
  padding: 1rem 2.5rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 50px;
  background: var(--azul-claro);
  color: white;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: var(--transition-medium);
  border: 2px solid var(--azul-claro);
}

#do-desafio-ao-projeto .checklist-pitch-section__cta-btn:hover {
  background: var(--azul-suave);
  border-color: var(--azul-suave);
  color: var(--azul-petroleo);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(84, 172, 191, 0.3);
}

/* Carrosséis responsivos para checklist sections */
#do-desafio-ao-projeto .checklist-empresa-section__cards .carousel,
#do-desafio-ao-projeto .checklist-pitch-section__cards .carousel,
#do-desafio-ao-projeto .hero-section__cards .carousel,
#do-desafio-ao-projeto .etapas-section__timeline .carousel {
  margin-bottom: 1rem;
}

#do-desafio-ao-projeto .etapas-section__timeline .etapas-section__step-card {
  min-height: 300px;
}

/* Ajustes para step-number no carrossel */
#do-desafio-ao-projeto
  .etapas-section__timeline
  .carousel
  .etapas-section__step-number {
  position: static;
  margin-bottom: 1rem;
  display: block;
  text-align: center;
  height: auto;
  transform: none;
  left: auto;
  top: auto;
}

/* Carousel Hint */
#do-desafio-ao-projeto .carousel-hint {
  text-align: center;
  margin: 1rem 0;
  font-size: 0.9rem;
  color: var(--azul-petroleo);
  opacity: 0.8;
  animation: fadeInOut 3s ease-in-out;
}

#do-desafio-ao-projeto .carousel-hint i {
  margin-right: 0.5rem;
}

@keyframes fadeInOut {
  0%,
  100% {
    opacity: 0;
  }

  50% {
    opacity: 1;
  }
}

/* Tablets - 992px */
@media (max-width: 991.98px) {
  #do-desafio-ao-projeto .checklist-pitch-section__card {
    min-height: 170px;
  }

  #do-desafio-ao-projeto .checklist-empresa-section__card {
    min-height: 220px;
  }

  #do-desafio-ao-projeto .hero-section__card {
    min-height: 130px;
  }

  #do-desafio-ao-projeto .etapas-section__timeline .etapas-section__step-card {
    min-height: 580px;
  }

  #do-desafio-ao-projeto .hero-section {
    padding: 80px 0 60px;
  }

  #do-desafio-ao-projeto .hero-section__headline {
    font-size: 2.5rem;
  }

  #do-desafio-ao-projeto .hero-section__subheadline {
    font-size: 1.25rem;
  }

  #do-desafio-ao-projeto .etapas-section__timeline::before {
    display: none;
  }

  #do-desafio-ao-projeto .etapas-section__step-number {
    left: 30px;
    transform: translate(-50%, -50%);
  }

  #do-desafio-ao-projeto .etapas-section__step--left .etapas-section__step-card,
  #do-desafio-ao-projeto
    .etapas-section__step--right
    .etapas-section__step-card {
    margin-left: 70px;
    margin-right: 0;
  }

  #do-desafio-ao-projeto .visao-geral-section__content,
  #do-desafio-ao-projeto .checklist-empresa-section__content,
  #do-desafio-ao-projeto .checklist-pitch-section__content {
    padding: 2rem;
  }
}

/* Mobile - 768px */
@media (max-width: 767.98px) {
  #do-desafio-ao-projeto .hero-section {
    padding: 60px 0 40px;
  }

  #do-desafio-ao-projeto .hero-section__headline {
    font-size: 2rem;
  }

  #do-desafio-ao-projeto .hero-section__subheadline {
    font-size: 1.1rem;
  }

  #do-desafio-ao-projeto .hero-section__bullets li {
    font-size: 1rem;
  }

  #do-desafio-ao-projeto .hero-section__ctas {
    flex-direction: column;
  }

  #do-desafio-ao-projeto .hero-section__cta-btn {
    width: 100%;
    justify-content: center;
  }

  #do-desafio-ao-projeto .visao-geral-section,
  #do-desafio-ao-projeto .etapas-section,
  #do-desafio-ao-projeto .ponte-section,
  #do-desafio-ao-projeto .checklist-empresa-section,
  #do-desafio-ao-projeto .checklist-pitch-section {
    padding: 60px 0;
  }

  #do-desafio-ao-projeto .visao-geral-section__headline,
  #do-desafio-ao-projeto .etapas-section__headline,
  #do-desafio-ao-projeto .ponte-section__headline,
  #do-desafio-ao-projeto .checklist-empresa-section__headline,
  #do-desafio-ao-projeto .checklist-pitch-section__headline {
    font-size: 2rem;
  }

  #do-desafio-ao-projeto .etapas-section__step-card {
    padding: 1.5rem;
  }

  #do-desafio-ao-projeto .etapas-section__step-title {
    font-size: 1.25rem;
  }

  #do-desafio-ao-projeto .etapas-section__step-description {
    font-size: 1rem;
  }

  #do-desafio-ao-projeto .visao-geral-section__content,
  #do-desafio-ao-projeto .checklist-empresa-section__content,
  #do-desafio-ao-projeto .checklist-pitch-section__content {
    padding: 1.5rem;
  }

  #do-desafio-ao-projeto .visao-geral-section__text,
  #do-desafio-ao-projeto .ponte-section__text {
    font-size: 1.05rem;
  }
}

/* Mobile pequeno - 576px */
@media (max-width: 575.98px) {
  #do-desafio-ao-projeto .hero-section__headline {
    font-size: 1.75rem;
  }

  #do-desafio-ao-projeto .hero-section__subheadline {
    font-size: 1rem;
  }

  #do-desafio-ao-projeto .etapas-section__step-number {
    width: 50px;
    height: 50px;
    font-size: 1.25rem;
  }
}

/* ================================================ */
/* TRILHA APLICADA - Estilos Inline                */
/* ================================================ */

/* Hero Section */
#trilha-aplicada .hero-section {
  padding: 120px 0 80px;
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 100%
  );
  color: var(--branco-gelo);
  position: relative;
  overflow: hidden;
}

#trilha-aplicada .hero-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(
    circle at 20% 50%,
    rgba(84, 172, 191, 0.1) 0%,
    transparent 50%
  );
  pointer-events: none;
}

#trilha-aplicada .hero-section__content {
  position: relative;
  z-index: 2;
  text-align: center;
}

#trilha-aplicada .hero-section__headline {
  font-family: var(--font-primary);
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.5rem;
}

#trilha-aplicada .hero-section__headline-destaque {
  color: var(--azul-suave);
  position: relative;
  display: inline-block;
}

#trilha-aplicada .hero-section__headline-destaque::after {
  content: "";
  position: absolute;
  bottom: 5px;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--azul-claro);
  animation: expandWidth 1s ease-out forwards;
}

@keyframes expandWidth {
  from {
    width: 0;
  }
  to {
    width: 100%;
  }
}

#trilha-aplicada .hero-section__subheadline {
  font-family: var(--font-primary);
  font-size: 1.5rem;
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: 2.5rem;
  opacity: 0.95;
}

#trilha-aplicada .hero-section__bullets {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: 1rem;
  list-style: none;
  padding: 0;
  margin: 2.5rem 0;
  justify-content: center;
}

#trilha-aplicada .hero-section__bullets li {
  background: rgba(255, 255, 255, 0.1);
  padding: 1.5rem;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--branco-gelo);
  flex: 1 1 300px;
  max-width: 400px;
  text-align: center;
  position: relative;
  transition: var(--transition-medium);
}

#trilha-aplicada .hero-section__bullets li:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
  background: rgba(255, 255, 255, 0.15);
}

#trilha-aplicada .hero-section__bullets-item {
  background: rgba(255, 255, 255, 0.1);
  padding: 1.5rem;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--branco-gelo);
  flex: 1 1 300px;
  max-width: 400px;
  text-align: center;
  position: relative;
  transition: var(--transition-medium);
}

#trilha-aplicada .hero-section__bullets-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
  background: rgba(255, 255, 255, 0.15);
}

#trilha-aplicada .hero-section__bullets-item::before {
  content: "✓";
  position: absolute;
  top: 1rem;
  left: 1rem;
  color: var(--azul-suave);
  font-weight: 700;
  font-size: 1.3rem;
}

#trilha-aplicada .hero-section__ctas {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 2.5rem;
  justify-content: center;
}

#trilha-aplicada .hero-section__cta-btn {
  padding: 1rem 2.5rem;
  font-size: 1.1rem;
  font-weight: 600;
  border-radius: 50px;
  border: 2px solid transparent;
  transition: var(--transition-medium);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  position: relative;
  overflow: hidden;
}

#trilha-aplicada .hero-section__cta-btn--primary {
  background: var(--azul-claro);
  color: var(--azul-petroleo);
}

#trilha-aplicada .hero-section__cta-btn--primary::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.3),
    transparent
  );
  transition: left 0.5s;
}

#trilha-aplicada .hero-section__cta-btn--primary:hover::before {
  left: 100%;
}

#trilha-aplicada .hero-section__cta-btn--primary:hover {
  background: var(--azul-suave);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(84, 172, 191, 0.3);
}

#trilha-aplicada .hero-section__cta-btn--secondary {
  background: transparent;
  color: var(--branco-gelo);
  border-color: var(--branco-gelo);
}

#trilha-aplicada .hero-section__cta-btn--secondary:hover {
  background: var(--branco-gelo);
  color: var(--azul-principal);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(248, 248, 248, 0.2);
}

/* Planejamento Section */
#trilha-aplicada .planejamento-section {
  padding: 80px 0;
  background: linear-gradient(to bottom, white, var(--branco-gelo));
}

#trilha-aplicada .planejamento-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 2rem;
  text-align: center;
}

#trilha-aplicada .planejamento-section__text {
  font-size: 1.2rem;
  line-height: 1.8;
  color: var(--azul-petroleo);
  margin-bottom: 1.5rem;
  text-align: center;
}

#trilha-aplicada .planejamento-section__cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  margin-top: 3rem;
}

#trilha-aplicada .planejamento-section__card {
  background: white;
  padding: 2.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(4, 41, 64, 0.1);
  border-left: 4px solid var(--azul-principal);
  transition: var(--transition-medium);
}

#trilha-aplicada .planejamento-section__card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(4, 41, 64, 0.15);
}

#trilha-aplicada .planejamento-section__card-title {
  font-family: var(--font-primary);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1rem;
}

#trilha-aplicada .planejamento-section__card-text {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--azul-petroleo);
  margin-bottom: 0;
}

/* Como Conduzimos Section */
#trilha-aplicada .como-conduzimos-section {
  padding: 80px 0;
  background: linear-gradient(to bottom, var(--branco-gelo), var(--azul-claro));
}

#trilha-aplicada .como-conduzimos-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1.5rem;
  text-align: center;
}

#trilha-aplicada .como-conduzimos-section__subheadline {
  font-size: 1.2rem;
  line-height: 1.7;
  color: var(--azul-petroleo);
  margin-bottom: 3rem;
  text-align: center;
  opacity: 0.9;
}

#trilha-aplicada .como-conduzimos-section__cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
}

#trilha-aplicada .como-conduzimos-section__card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  border: 2px solid rgba(15, 92, 140, 0.1);
  transition: var(--transition-medium);
  text-align: center;
  max-width: 300px;
}

#trilha-aplicada .como-conduzimos-section__card:hover {
  border-color: var(--azul-principal);
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(4, 41, 64, 0.15);
}

#trilha-aplicada .como-conduzimos-section__card-icon {
  width: 70px;
  height: 70px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  margin: 0 auto 1.5rem;
  transition: var(--transition-medium);
}

#trilha-aplicada
  .como-conduzimos-section__card:hover
  .como-conduzimos-section__card-icon {
  transform: scale(1.1) rotate(5deg);
}

#trilha-aplicada .como-conduzimos-section__card-title {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1rem;
}

#trilha-aplicada .como-conduzimos-section__card-text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--azul-petroleo);
  margin-bottom: 0;
}

/* Caixa de Ferramentas Section */
#trilha-aplicada .ferramentas-section {
  padding: 80px 0;
  background: linear-gradient(
    to bottom,
    var(--azul-claro),
    var(--azul-principal)
  );
  color: var(--branco-gelo);
}

#trilha-aplicada .ferramentas-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  text-align: center;
}

#trilha-aplicada .ferramentas-section__subheadline {
  font-size: 1.2rem;
  line-height: 1.7;
  margin-bottom: 3rem;
  text-align: center;
  opacity: 0.95;
}

#trilha-aplicada .ferramentas-section__list {
  background: rgba(255, 255, 255, 0.1);
  padding: 3rem;
  border-radius: 12px;
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
}

#trilha-aplicada .ferramentas-section__cards {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
}

#trilha-aplicada .ferramentas-section__card {
  background: rgba(255, 255, 255, 0.15);
  padding: 1.5rem;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.3);
  text-align: center;
  transition: var(--transition-medium);
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-basis: 30%;
}

#trilha-aplicada .ferramentas-section__card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
  background: rgba(255, 255, 255, 0.2);
}

#trilha-aplicada .ferramentas-section__card-icon {
  font-size: 2rem;
  color: var(--azul-suave);
  margin-bottom: 1rem;
}

#trilha-aplicada .ferramentas-section__card-text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--branco-gelo);
  margin: 0;
}

#trilha-aplicada .ferramentas-section__observacao {
  margin-top: 2rem;
  padding: 1.5rem;
  background: rgba(187, 232, 242, 0.2);
  border-left: 4px solid var(--azul-suave);
  border-radius: 8px;
  font-size: 0.95rem;
  font-style: italic;
  line-height: 1.6;
}

/* Empresas Section */
#trilha-aplicada .empresas-section {
  padding: 80px 0;
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--azul-claro)
  );
}

#trilha-aplicada .empresas-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1.5rem;
  text-align: center;
}

#trilha-aplicada .empresas-section__subheadline {
  font-size: 1.2rem;
  line-height: 1.7;
  color: var(--branco-gelo);
  margin-bottom: 3rem;
  text-align: center;
  opacity: 0.9;
}

#trilha-aplicada .empresas-section__content {
  background: white;
  padding: 3rem;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(4, 41, 64, 0.08);
  border-left: 4px solid var(--azul-principal);
}

#trilha-aplicada .empresas-section__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#trilha-aplicada .empresas-section__list li {
  font-size: 1.1rem;
  line-height: 1.8;
  margin-bottom: 1.2rem;
  padding-left: 2.5rem;
  position: relative;
  color: var(--azul-petroleo);
}

#trilha-aplicada .empresas-section__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5rem;
  width: 20px;
  height: 20px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  border-radius: 4px;
}

#trilha-aplicada .empresas-section__list li::after {
  content: "✓";
  position: absolute;
  left: 5px;
  top: 0.35rem;
  color: white;
  font-weight: 700;
  font-size: 0.9rem;
}

#trilha-aplicada .empresas-section__cards {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
}

#trilha-aplicada .empresas-section__card {
  background: rgba(15, 92, 140, 0.1);
  padding: 1.5rem;
  border-radius: 12px;
  border: 1px solid rgba(15, 92, 140, 0.2);
  text-align: center;
  transition: var(--transition-medium);
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-basis: 45%;
}

#trilha-aplicada .empresas-section__card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(4, 41, 64, 0.15);
  background: rgba(15, 92, 140, 0.15);
}

#trilha-aplicada .empresas-section__card-icon {
  font-size: 2rem;
  color: var(--azul-principal);
  margin-bottom: 1rem;
}

#trilha-aplicada .empresas-section__card-text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--azul-petroleo);
  margin: 0;
}

/* Alunos e Professores Section */
#trilha-aplicada .alunos-section {
  padding: 80px 0;
  background: linear-gradient(to bottom, var(--azul-claro), var(--branco-gelo));
}

#trilha-aplicada .alunos-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1.5rem;
  text-align: center;
}

#trilha-aplicada .alunos-section__subheadline {
  font-size: 1.2rem;
  line-height: 1.7;
  color: var(--azul-petroleo);
  margin-bottom: 3rem;
  text-align: center;
  opacity: 0.9;
}

#trilha-aplicada .alunos-section__content {
  background: white;
  padding: 3rem;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(4, 41, 64, 0.08);
  border-left: 4px solid var(--azul-claro);
}

#trilha-aplicada .alunos-section__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#trilha-aplicada .alunos-section__list li {
  font-size: 1.1rem;
  line-height: 1.8;
  margin-bottom: 1.2rem;
  padding-left: 2.5rem;
  position: relative;
  color: var(--azul-petroleo);
}

#trilha-aplicada .alunos-section__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5rem;
  width: 20px;
  height: 20px;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-suave));
  border-radius: 4px;
}

#trilha-aplicada .alunos-section__list li::after {
  content: "✓";
  position: absolute;
  left: 5px;
  top: 0.35rem;
  color: white;
  font-weight: 700;
  font-size: 0.9rem;
}

#trilha-aplicada .alunos-section__cards {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
}

#trilha-aplicada .alunos-section__card {
  background: rgba(84, 172, 191, 0.1);
  padding: 1.5rem;
  border-radius: 12px;
  border: 1px solid rgba(84, 172, 191, 0.2);
  text-align: center;
  transition: var(--transition-medium);
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-basis: 45%;
}

#trilha-aplicada .alunos-section__card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 20px rgba(4, 41, 64, 0.15);
  background: rgba(84, 172, 191, 0.15);
}

#trilha-aplicada .alunos-section__card-icon {
  font-size: 2rem;
  color: var(--azul-claro);
  margin-bottom: 1rem;
}

#trilha-aplicada .alunos-section__card-text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--azul-petroleo);
  margin: 0;
}

/* CTAs Finais Section */
#trilha-aplicada .ctas-finais-section {
  padding: 80px 0;
  background: linear-gradient(to bottom, var(--branco-gelo), white);
  color: var(--branco-gelo);
}

#trilha-aplicada .ctas-finais-section__headline {
  font-family: var(--font-heading);
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 2.5rem;
  text-align: center;
  color: var(--azul-petroleo);
}

#trilha-aplicada .ctas-finais-section__buttons {
  display: flex;
  gap: 1.5rem;
  justify-content: center;
  flex-wrap: wrap;
}

#trilha-aplicada .ctas-finais-section__cta-btn {
  padding: 1.25rem 3rem;
  font-size: 1.2rem;
  font-weight: 600;
  border-radius: 50px;
  border: 2px solid rgba(255, 255, 255, 0.3);
  transition: var(--transition-medium);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  background: var(--branco-gelo);
  backdrop-filter: blur(10px);
  color: var(--azul-principal);
}

#trilha-aplicada .ctas-finais-section__cta-btn:hover {
  background: var(--azul-suave);
  border-color: var(--azul-suave);
  color: var(--azul-petroleo);
  transform: translateY(-3px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

/* Carousel Hints */
#trilha-aplicada .carousel-hint {
  text-align: center;
  margin-top: 1rem;
  font-size: 0.9rem;
  color: var(--azul-petroleo);
  opacity: 0.8;
}

#trilha-aplicada .section-title-highlight {
  color: var(--azul-petroleo);
  font-weight: 700;
  position: relative;
}

#trilha-aplicada .section-title-highlight::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--azul-claro);
}

/* ================================================ */
/* RESPONSIVIDADE                                   */
/* ================================================ */

/* Tablets - 992px */
@media (max-width: 991.98px) {
  #trilha-aplicada .hero-section__bullets-item {
    min-height: 160px;
  }
  #trilha-aplicada .ferramentas-section__card {
    min-height: 220px;
  }
  #trilha-aplicada .empresas-section__card {
    min-height: 220px;
  }
  #trilha-aplicada .alunos-section__card {
    min-height: 270px;
  }
  #trilha-aplicada .hero-section {
    padding: 80px 0 60px;
  }

  #trilha-aplicada .hero-section__headline {
    font-size: 2.5rem;
  }

  #trilha-aplicada .hero-section__subheadline {
    font-size: 1.25rem;
  }

  #trilha-aplicada .planejamento-section__cards {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  #trilha-aplicada .como-conduzimos-section__cards {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }

  #trilha-aplicada .empresas-section__cards {
    gap: 1rem;
  }

  #trilha-aplicada .empresas-section__card {
    flex-basis: 48%;
  }

  #trilha-aplicada .alunos-section__cards {
    gap: 1rem;
  }

  #trilha-aplicada .alunos-section__card {
    flex-basis: 48%;
  }

  #trilha-aplicada .ferramentas-section__cards {
    gap: 1rem;
  }

  #trilha-aplicada .ferramentas-section__card {
    flex-basis: 48%;
  }
}

/* Mobile - 768px */
@media (max-width: 767.98px) {
  #trilha-aplicada .hero-section {
    padding: 60px 0 40px;
  }

  #trilha-aplicada .hero-section__headline {
    font-size: 2rem;
  }

  #trilha-aplicada .hero-section__subheadline {
    font-size: 1.1rem;
  }

  #trilha-aplicada .hero-section__bullets {
    flex-direction: column;
    align-items: center;
  }

  #trilha-aplicada .hero-section__bullets li {
    flex: none;
    width: 100%;
    max-width: none;
  }

  #trilha-aplicada .hero-section__ctas {
    flex-direction: column;
  }

  #trilha-aplicada .hero-section__cta-btn {
    width: 100%;
    justify-content: center;
  }

  #trilha-aplicada .planejamento-section,
  #trilha-aplicada .como-conduzimos-section,
  #trilha-aplicada .ferramentas-section,
  #trilha-aplicada .empresas-section,
  #trilha-aplicada .alunos-section,
  #trilha-aplicada .ctas-finais-section {
    padding: 60px 0;
  }

  #trilha-aplicada .planejamento-section__headline,
  #trilha-aplicada .como-conduzimos-section__headline,
  #trilha-aplicada .ferramentas-section__headline,
  #trilha-aplicada .empresas-section__headline,
  #trilha-aplicada .alunos-section__headline,
  #trilha-aplicada .ctas-finais-section__headline {
    font-size: 2rem;
  }

  #trilha-aplicada .como-conduzimos-section__cards {
    grid-template-columns: 1fr;
  }

  #trilha-aplicada .planejamento-section__card,
  #trilha-aplicada .empresas-section__content,
  #trilha-aplicada .alunos-section__content {
    padding: 2rem;
  }

  #trilha-aplicada .ferramentas-section__list {
    padding: 2rem;
  }

  #trilha-aplicada .ctas-finais-section__buttons {
    flex-direction: column;
  }

  #trilha-aplicada .ctas-finais-section__cta-btn {
    width: 100%;
    justify-content: center;
  }

  #trilha-aplicada .empresas-section__card {
    flex-basis: 100%;
  }

  #trilha-aplicada .alunos-section__card {
    flex-basis: 100%;
  }

  #trilha-aplicada .ferramentas-section__card {
    flex-basis: 100%;
  }
}

/* Mobile pequeno - 576px */
@media (max-width: 575.98px) {
  #trilha-aplicada .hero-section__headline {
    font-size: 1.75rem;
  }

  #trilha-aplicada .hero-section__subheadline {
    font-size: 1rem;
  }

  #trilha-aplicada .planejamento-section__card,
  #trilha-aplicada .empresas-section__content,
  #trilha-aplicada .alunos-section__content,
  #trilha-aplicada .ferramentas-section__list {
    padding: 1.5rem;
  }
}

/* ================================================ */
/* HUB CT-12 - Estilos Inline                      */
/* ================================================ */

/* Hero Section - Horizontal Baixo */
#hub-ct-12 .hero-section {
  padding: 80px 0 60px;
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 100%
  );
  color: var(--branco-gelo);
  position: relative;
  overflow: hidden;
}

#hub-ct-12 .hero-section::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(
    circle at 20% 50%,
    rgba(84, 172, 191, 0.1) 0%,
    transparent 50%
  );
  pointer-events: none;
}

#hub-ct-12 .hero-section__content {
  position: relative;
  z-index: 2;
}

#hub-ct-12 .hero-section__headline {
  font-family: var(--font-primary);
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.5rem;
}

#hub-ct-12 .hero-section__subheadline {
  font-family: var(--font-primary);
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.6;
  margin-bottom: 0;
  opacity: 0.95;
}

#hub-ct-12 .hero-section__card {
  background: white;
  padding: 2rem;
  border-radius: 12px;
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.2);
  border-left: 4px solid var(--azul-claro);
}

#hub-ct-12 .hero-section__card-title {
  font-family: var(--font-primary);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1rem;
}

#hub-ct-12 .hero-section__card-subtitle {
  font-size: 1.1rem;
  color: var(--azul-petroleo);
  margin-bottom: 0;
  font-weight: 500;
}

/* Galeria Section */
#hub-ct-12 .galeria-section {
  padding: 80px 0;
  background: linear-gradient(
    to bottom,
    var(--azul-principal),
    var(--azul-claro)
  );
}

#hub-ct-12 .galeria-section__headline {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1.5rem;
  text-align: center;
}

#hub-ct-12 .galeria-section__carousel-wrapper {
  margin-bottom: 0;
}

#hub-ct-12 .galeria-section__carousels {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-bottom: 3rem;
}

#hub-ct-12 .galeria-section__carousel-title {
  font-family: var(--font-primary);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1.5rem;
  text-align: center;
}

#hub-ct-12 .galeria-section__carousel {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(4, 41, 64, 0.1);
}

#hub-ct-12 .galeria-section__carousel-item {
  height: 500px;
  background: var(--azul-petroleo);
  position: relative;
}

#hub-ct-12 .galeria-section__carousel-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#hub-ct-12 .galeria-section__carousel-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(
    to top,
    rgba(4, 41, 64, 0.9) 0%,
    transparent 100%
  );
  padding: 2rem 1.5rem 1rem;
  color: white;
}

#hub-ct-12 .galeria-section__carousel-caption p {
  margin: 0;
  font-size: 1.1rem;
  font-weight: 500;
}

/* Controles do carousel */
#hub-ct-12 .carousel-control-prev,
#hub-ct-12 .carousel-control-next {
  width: 50px;
  height: 50px;
  background: rgba(15, 92, 140, 0.8);
  border-radius: 50%;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.9;
  transition: var(--transition-medium);
}

#hub-ct-12 .carousel-control-prev {
  left: 20px;
}

#hub-ct-12 .carousel-control-next {
  right: 20px;
}

#hub-ct-12 .carousel-control-prev:hover,
#hub-ct-12 .carousel-control-next:hover {
  opacity: 1;
  background: var(--azul-principal);
}

/* Localização Section */
#hub-ct-12 .localizacao-section {
  padding: 80px 0;
  background: linear-gradient(to bottom, var(--azul-claro), var(--azul-suave));
}

#hub-ct-12 .localizacao-section__headline {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1.5rem;
  text-align: center;
}

#hub-ct-12 .localizacao-section__content {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 3rem;
  border-radius: 12px;
  border-left: 4px solid var(--azul-principal);
}

#hub-ct-12 .localizacao-section__item {
  margin-bottom: 2rem;
}

#hub-ct-12 .localizacao-section__item:last-child {
  margin-bottom: 0;
}

#hub-ct-12 .localizacao-section__item-title {
  font-family: var(--font-primary);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 0.75rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

#hub-ct-12 .localizacao-section__item-title i {
  font-size: 1.5rem;
}

#hub-ct-12 .localizacao-section__item-text {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--azul-principal);
  margin-bottom: 0.5rem;
}

#hub-ct-12 .localizacao-section__item-link {
  color: var(--azul-principal);
  text-decoration: none;
  font-weight: 500;
  transition: var(--transition-medium);
}

#hub-ct-12 .localizacao-section__item-link:hover {
  color: var(--azul-claro);
}

/* Nossa Infraestrutura Section */
#hub-ct-12 .infraestrutura-section {
  padding: 80px 0;
  background: linear-gradient(to bottom, var(--azul-suave), var(--azul-claro));
}

#hub-ct-12 .infraestrutura-section__headline {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1rem;
  text-align: center;
}

#hub-ct-12 .infraestrutura-section__subheadline {
  font-family: var(--font-primary);
  font-size: 1.1rem;
  color: var(--branco-gelo);
  line-height: 1.7;
  text-align: center;
  max-width: 860px;
  margin: 0 auto 2.5rem;
  opacity: 0.9;
}

#hub-ct-12 .infraestrutura-section__cards {
  /* Grid removido para usar Bootstrap */
}

#hub-ct-12 .infraestrutura-section__card {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 2.5rem;
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(4, 41, 64, 0.1);
  border: 2px solid rgba(15, 92, 140, 0.1);
  transition: var(--transition-medium);
}

#hub-ct-12 .infraestrutura-section__card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(4, 41, 64, 0.15);
  border-color: var(--azul-principal);
}

#hub-ct-12 .infraestrutura-section__card-title {
  font-family: var(--font-primary);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1rem;
}

#hub-ct-12 .infraestrutura-section__card-description {
  font-size: 1.05rem;
  line-height: 1.7;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
}

#hub-ct-12 .infraestrutura-section__card-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

#hub-ct-12 .infraestrutura-section__card-list li {
  font-size: 1rem;
  line-height: 1.8;
  margin-bottom: 0.75rem;
  padding-left: 1.75rem;
  position: relative;
  color: var(--azul-principal);
}

#hub-ct-12 .infraestrutura-section__card-list li::before {
  content: "●";
  position: absolute;
  left: 0;
  color: var(--azul-claro);
  font-size: 1.2rem;
}

/* O Que Oferecemos Section */
#hub-ct-12 .oferecemos-section {
  padding: 80px 0;
  background: linear-gradient(
    to bottom,
    var(--azul-claro),
    var(--azul-principal)
  );
}

#hub-ct-12 .oferecemos-section__headline {
  font-family: var(--font-heading);
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--branco-gelo);
  margin-bottom: 1.5rem;
  text-align: center;
}

#hub-ct-12 .oferecemos-section__items {
  /* Flex removido para usar Bootstrap */
}

#hub-ct-12 .oferecemos-section__item {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 1.5rem 2rem;
  border-radius: 50px;
  border: 2px solid rgba(15, 92, 140, 0.2);
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: var(--transition-medium);
  box-shadow: 0 2px 10px rgba(4, 41, 64, 0.08);
}

#hub-ct-12 .oferecemos-section__item:hover {
  border-color: var(--azul-principal);
  background: rgba(255, 255, 255, 0.5);
  transform: translateY(-3px);
  box-shadow: 0 4px 20px rgba(4, 41, 64, 0.12);
}

#hub-ct-12 .oferecemos-section__item-icon {
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  flex-shrink: 0;
}

#hub-ct-12 .oferecemos-section__item-text {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--branco-gelo);
  margin: 0;
}

/* Highlights nos títulos */
#hub-ct-12 .galeria-section__highlight,
#hub-ct-12 .localizacao-section__highlight,
#hub-ct-12 .infraestrutura-section__highlight,
#hub-ct-12 .oferecemos-section__highlight,
#hub-ct-12 .hero-section__highlight {
  color: var(--azul-petroleo);
}

/* Carousel Hint */
#hub-ct-12 .carousel-hint {
  text-align: center;
  margin-top: 1rem;
  font-family: var(--font-primary);
  font-size: 0.9rem;
  color: var(--azul-preto);
  opacity: 0.8;
}

#hub-ct-12 .carousel-hint i {
  margin-right: 0.5rem;
  font-size: 1.1rem;
}

/* Desktop Grid Fixes */
#hub-ct-12 .infraestrutura-section__cards.desktop {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 2rem !important;
  justify-content: center !important;
}

#hub-ct-12
  .infraestrutura-section__cards.desktop
  .infraestrutura-section__card {
  flex: 1 1 300px !important;
  max-width: 400px !important;
}

#hub-ct-12 .infraestrutura-section__cards.tablet {
  display: none;
}

#hub-ct-12 .infraestrutura-section__cards.mobile {
  display: none;
}

#hub-ct-12 .oferecemos-section__items.desktop {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 1rem !important;
  justify-content: center !important;
}

#hub-ct-12 .oferecemos-section__items.desktop .oferecemos-section__item {
  flex: 1 1 200px !important;
  max-width: 250px !important;
}

#hub-ct-12 .oferecemos-section__items.tablet {
  display: none;
}

#hub-ct-12 .oferecemos-section__items.mobile {
  display: none;
}

/* Tablets - 992px */
@media (max-width: 991.98px) {
  #hub-ct-12 .infraestrutura-section__card {
    min-height: 470px;
  }

  #hub-ct-12 .oferecemos-section__item {
    min-height: 120px;
  }

  #hub-ct-12 .hero-section {
    padding: 60px 0 50px;
  }

  #hub-ct-12 .hero-section__headline {
    font-size: 2.5rem;
  }

  #hub-ct-12 .hero-section__subheadline {
    font-size: 1.15rem;
  }

  #hub-ct-12 .hero-section__card {
    margin-top: 2rem;
  }

  #hub-ct-12 .galeria-section__carousels {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  #hub-ct-12 .galeria-section__carousel-item {
    height: 400px;
  }

  #hub-ct-12 .infraestrutura-section__cards.desktop {
    display: none !important;
  }

  #hub-ct-12 .infraestrutura-section__cards.tablet {
    display: block !important;
  }

  #hub-ct-12 .oferecemos-section__items.desktop {
    display: none !important;
  }

  #hub-ct-12 .oferecemos-section__items.tablet {
    display: block !important;
  }
}

/* Mobile - 768px */
@media (max-width: 767.98px) {
  #hub-ct-12 .hero-section {
    padding: 50px 0 40px;
  }

  #hub-ct-12 .hero-section__headline {
    font-size: 2rem;
  }

  #hub-ct-12 .hero-section__subheadline {
    font-size: 1.05rem;
  }

  #hub-ct-12 .galeria-section,
  #hub-ct-12 .localizacao-section,
  #hub-ct-12 .infraestrutura-section,
  #hub-ct-12 .oferecemos-section {
    padding: 60px 0;
  }

  #hub-ct-12 .galeria-section__headline,
  #hub-ct-12 .localizacao-section__headline,
  #hub-ct-12 .infraestrutura-section__headline,
  #hub-ct-12 .oferecemos-section__headline {
    font-size: 2rem;
  }

  #hub-ct-12 .galeria-section__carousel-item {
    height: 300px;
  }

  #hub-ct-12 .localizacao-section__content,
  #hub-ct-12 .infraestrutura-section__card {
    padding: 2rem;
  }

  #hub-ct-12 .carousel-control-prev,
  #hub-ct-12 .carousel-control-next {
    width: 40px;
    height: 40px;
  }

  #hub-ct-12 .carousel-control-prev {
    left: 10px;
  }

  #hub-ct-12 .carousel-control-next {
    right: 10px;
  }

  #hub-ct-12 .oferecemos-section__item {
    padding: 1.25rem 1.5rem;
  }

  #hub-ct-12 .oferecemos-section__item-text {
    font-size: 1rem;
  }

  #hub-ct-12 .infraestrutura-section__cards.tablet {
    display: none !important;
  }

  #hub-ct-12 .infraestrutura-section__cards.mobile {
    display: block !important;
  }

  #hub-ct-12 .oferecemos-section__items.tablet {
    display: none !important;
  }

  #hub-ct-12 .oferecemos-section__items.mobile {
    display: block !important;
  }
}

/* Mobile pequeno - 576px */
@media (max-width: 575.98px) {
  #hub-ct-12 .infraestrutura-section__card {
    min-height: 410px;
  }

  #hub-ct-12 .hero-section__headline {
    font-size: 1.75rem;
  }

  #hub-ct-12 .hero-section__subheadline {
    font-size: 1rem;
  }

  #hub-ct-12 .hero-section__card,
  #hub-ct-12 .localizacao-section__content,
  #hub-ct-12 .infraestrutura-section__card {
    padding: 1.5rem;
  }

  #hub-ct-12 .galeria-section__carousel-item {
    height: 250px;
  }
}

/* ============================================== */
/* SEÇÃO: Notícias - ConneCT                      */
/* ============================================== */

#noticias {
  background: linear-gradient(180deg, var(--branco-gelo) 0%, #ffffff 100%);
  min-height: 70vh;
  position: relative;
}

#noticias .noticias__title {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 800;
  color: var(--dark);
  margin-bottom: 20px;
  line-height: 1.2;
}

#noticias .noticias__highlight {
  color: var(--azul-principal);
  position: relative;
}

#noticias .noticias__subtitle {
  font-size: 1.1rem;
  color: var(--text-secondary);
  line-height: 1.8;
  max-width: 700px;
  margin: 0 auto;
}

/* Filtro */
#noticias .noticias__filtro {
  background: #ffffff;
  padding: 20px 30px;
  border-radius: 15px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: stretch;
  gap: 20px;
  flex-wrap: wrap;
}

#noticias .noticias__filtro-grupo {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1;
  min-width: 280px;
}

#noticias .noticias__filtro-label {
  font-weight: 600;
  color: var(--dark);
  margin: 0;
  display: flex;
  align-items: center;
  white-space: nowrap;
  font-size: 0.95rem;
}

#noticias .noticias__filtro-select {
  flex: 1;
  min-width: 180px;
  padding: 10px 15px;
  border: 2px solid var(--branco-gelo);
  border-radius: 10px;
  font-size: 1rem;
  color: var(--dark);
  background-color: var(--branco-gelo);
  cursor: pointer;
  transition: var(--transition-fast);
}

#noticias .noticias__filtro-select:hover,
#noticias .noticias__filtro-select:focus {
  border-color: var(--azul-principal);
  outline: none;
  box-shadow: 0 0 0 3px rgba(15, 92, 140, 0.1);
}

/* Campo de Busca */
#noticias .noticias__busca-wrapper {
  position: relative;
  flex: 1;
  min-width: 250px;
  display: flex;
  align-items: center;
}

#noticias .noticias__filtro-input {
  width: 100%;
  padding: 10px 95px 10px 15px;
  border: 2px solid var(--branco-gelo);
  border-radius: 10px;
  font-size: 1rem;
  color: var(--dark);
  background-color: var(--branco-gelo);
  transition: var(--transition-fast);
}

#noticias .noticias__filtro-input::placeholder {
  color: var(--text-secondary);
  opacity: 0.7;
}

#noticias .noticias__filtro-input:hover,
#noticias .noticias__filtro-input:focus {
  border-color: var(--azul-principal);
  outline: none;
  box-shadow: 0 0 0 3px rgba(15, 92, 140, 0.1);
  background-color: #ffffff;
}

#noticias .noticias__busca-btn {
  position: absolute;
  right: 5px;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: #ffffff;
  border: none;
  border-radius: 8px;
  padding: 8px 16px;
  cursor: pointer;
  transition: var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  box-shadow: 0 2px 8px rgba(15, 92, 140, 0.2);
}

#noticias .noticias__busca-btn:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 12px rgba(15, 92, 140, 0.3);
}

#noticias .noticias__limpar-btn {
  position: absolute;
  right: 55px;
  background: transparent;
  color: var(--text-secondary);
  border: none;
  padding: 5px;
  cursor: pointer;
  transition: var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
}

#noticias .noticias__limpar-btn:hover {
  color: #dc3545;
  transform: scale(1.1);
}

/* Card de Notícia */
#noticias .noticias__card {
  background: #ffffff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.08);
  transition: var(--transition-medium);
  display: flex;
  flex-direction: column;
}

#noticias .noticias__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(15, 92, 140, 0.15);
}

/* Imagem do Card */
#noticias .noticias__card-image-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
}

#noticias .noticias__card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-slow);
}

#noticias .noticias__card:hover #noticias .noticias__card-image {
  transform: scale(1.08);
}

#noticias .noticias__card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(4, 41, 64, 0.6) 100%
  );
  opacity: 0;
  transition: var(--transition-medium);
}

#noticias .noticias__card:hover #noticias .noticias__card-overlay {
  opacity: 1;
}

/* Badges no Card */
#noticias .noticias__badges {
  position: absolute;
  top: 15px;
  right: 15px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-end;
}

#noticias .noticias__badge-destaque,
#noticias .noticias__badge-nova {
  padding: 6px 14px;
  border-radius: 50px;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  display: flex;
  align-items: center;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  animation: fadeInDown 0.5s ease;
}

#noticias .noticias__badge-destaque {
  background: linear-gradient(135deg, #ffd700, #ffa500);
  color: #ffffff;
}

#noticias .noticias__badge-nova {
  background: linear-gradient(135deg, #ff6b6b, #ee5a6f);
  color: #ffffff;
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Corpo do Card */
#noticias .noticias__card-body {
  padding: 25px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}

/* Categoria */
#noticias .noticias__categoria {
  display: inline-flex;
  align-items: center;
  background: var(--branco-gelo);
  color: var(--azul-principal);
  padding: 5px 12px;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  width: fit-content;
}

/* Título do Card */
#noticias .noticias__card-title {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--dark);
  margin: 0;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: var(--transition-fast);
}

#noticias .noticias__card:hover #noticias .noticias__card-title {
  color: var(--azul-principal);
}

/* Subtítulo do Card */
#noticias .noticias__card-subtitulo {
  font-size: 0.95rem;
  color: var(--text-secondary);
  margin: 0;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Data */
#noticias .noticias__card-data {
  display: flex;
  align-items: center;
  font-size: 0.9rem;
  color: var(--text-secondary);
  font-weight: 500;
}

/* Descrição */
#noticias .noticias__card-description {
  font-size: 0.95rem;
  color: #666;
  line-height: 1.7;
  margin: 0;
  flex: 1;
}

/* Botão do Card */
#noticias .noticias__card-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: #ffffff;
  padding: 12px 24px;
  border-radius: 50px;
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
  transition: var(--transition-medium);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.2);
  position: relative;
  overflow: hidden;
  margin-top: auto;
}

#noticias .noticias__card-btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.3),
    transparent
  );
  transition: var(--transition-medium);
}

#noticias .noticias__card-btn:hover {
  transform: translateX(5px);
  box-shadow: 0 6px 25px rgba(15, 92, 140, 0.3);
  color: #ffffff;
}

#noticias .noticias__card-btn:hover::before {
  left: 100%;
}

/* Paginação */
.noticias__paginacao {
  background: #ffffff;
  padding: 30px;
  border-radius: 15px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

.noticias__paginacao-lista {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0 0 15px 0;
  flex-wrap: wrap;
}

.noticias__paginacao-item {
  margin: 0;
}

.noticias__paginacao-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 45px;
  height: 45px;
  padding: 0 15px;
  background: var(--branco-gelo);
  color: var(--dark);
  border-radius: 10px;
  font-weight: 600;
  text-decoration: none;
  transition: var(--transition-fast);
  border: 2px solid transparent;
}

.noticias__paginacao-link:hover {
  background: var(--azul-principal);
  color: #ffffff;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(15, 92, 140, 0.2);
}

.noticias__paginacao-link.active {
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: #ffffff;
  border-color: var(--azul-principal);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.3);
}

.noticias__paginacao-prev,
.noticias__paginacao-next {
  min-width: auto;
  padding: 0 20px;
  gap: 8px;
}

.noticias__paginacao-ellipsis {
  display: flex;
  align-items: center;
  padding: 0 10px;
  color: var(--text-secondary);
  font-weight: 600;
}

.noticias__paginacao-info {
  text-align: center;
  color: var(--text-secondary);
  font-size: 0.95rem;
  font-weight: 500;
}

/* Estado Vazio */
#noticias .noticias__vazio {
  background: #ffffff;
  padding: 60px 40px;
  border-radius: 20px;
  text-align: center;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

#noticias .noticias__vazio i {
  font-size: 4rem;
  color: var(--azul-principal);
  opacity: 0.3;
  margin-bottom: 20px;
}

#noticias .noticias__vazio h3 {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 15px;
}

#noticias .noticias__vazio p {
  font-size: 1.1rem;
  color: var(--text-secondary);
  line-height: 1.7;
  margin-bottom: 25px;
}

/* Responsividade */
@media (max-width: 991.98px) {
  #noticias .noticias__title {
    font-size: 2.2rem;
  }

  #noticias .noticias__filtro {
    padding: 15px 20px;
    gap: 15px;
  }

  #noticias .noticias__filtro-grupo {
    flex-direction: column;
    align-items: stretch;
    min-width: 100%;
    gap: 8px;
  }

  #noticias .noticias__filtro-label {
    font-size: 0.9rem;
  }

  #noticias .noticias__filtro-select {
    width: 100%;
    min-width: 100%;
  }

  #noticias .noticias__busca-wrapper {
    min-width: 100%;
  }

  #noticias .noticias__filtro-input {
    font-size: 0.95rem;
  }
}

@media (max-width: 767.98px) {
  #noticias {
    padding: 40px 0;
  }

  #noticias .noticias__title {
    font-size: 1.8rem;
    margin-bottom: 15px;
  }

  #noticias .noticias__subtitle {
    font-size: 1rem;
  }

  #noticias .noticias__card-body {
    padding: 20px;
  }

  #noticias .noticias__card-title {
    font-size: 1.2rem;
  }

  #noticias .noticias__paginacao {
    padding: 20px 15px;
  }

  #noticias .noticias__paginacao-link {
    min-width: 40px;
    height: 40px;
    font-size: 0.9rem;
  }

  #noticias .noticias__paginacao-prev,
  #noticias .noticias__paginacao-next {
    padding: 0 15px;
  }

  #noticias .noticias__vazio {
    padding: 40px 25px;
  }

  #noticias .noticias__vazio i {
    font-size: 3rem;
  }

  #noticias .noticias__vazio h3 {
    font-size: 1.4rem;
  }
}
/* ============================================== */
/* PÁGINA: Notícia Individual - ConneCT           */
/* ============================================== */

#noticia-single {
  background: #ffffff;
}

/* Hero da Notícia */
#noticia-single .noticia__hero {
  position: relative;
  min-height: 60vh;
  display: flex;
  align-items: flex-end;
  padding: 80px 0 60px;
  overflow: hidden;
}

#noticia-single .noticia__hero-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  filter: brightness(0.6);
}

#noticia-single .noticia__hero-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(4, 41, 64, 0.8) 100%
  );
  z-index: 1;
}

#noticia-single .noticia__hero-content {
  position: relative;
  z-index: 2;
  color: #ffffff;
}

#noticia-single .noticia__categoria {
  display: inline-flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  color: #ffffff;
  padding: 8px 16px;
  border-radius: 50px;
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 20px;
  text-decoration: none;
  transition: var(--transition-fast);
  border: 1px solid rgba(255, 255, 255, 0.3);
}

#noticia-single .noticia__categoria:hover {
  background: rgba(255, 255, 255, 0.3);
  color: #ffffff;
  transform: translateY(-2px);
}

#noticia-single .noticia__titulo {
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 800;
  color: #ffffff;
  line-height: 1.2;
  margin-bottom: 20px;
  text-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

#noticia-single .noticia__subtitulo {
  font-size: 1.3rem;
  color: rgba(255, 255, 255, 0.95);
  line-height: 1.6;
  margin-bottom: 25px;
  font-weight: 400;
}

#noticia-single .noticia__meta {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

#noticia-single .noticia__meta-item {
  display: flex;
  align-items: center;
  color: rgba(255, 255, 255, 0.9);
  font-size: 1rem;
  font-weight: 500;
}

#noticia-single .noticia__meta-destaque {
  display: inline-flex;
  align-items: center;
  background: linear-gradient(135deg, #ffd700, #ffa500);
  color: #ffffff;
  padding: 6px 14px;
  border-radius: 50px;
  font-size: 0.85rem;
  font-weight: 700;
  box-shadow: 0 4px 12px rgba(255, 215, 0, 0.3);
}

/* Conteúdo */
#noticia-single .noticia__conteudo {
  background: #ffffff;
}

#noticia-single .noticia__texto {
  font-size: 1.1rem;
  line-height: 1.8;
  color: #333;
}

#noticia-single .noticia__texto p {
  margin-bottom: 1.5rem;
}

#noticia-single .noticia__texto h2,
#noticia-single .noticia__texto h3,
#noticia-single .noticia__texto h4 {
  color: var(--azul-principal);
  margin-top: 2rem;
  margin-bottom: 1rem;
  font-weight: 700;
}

#noticia-single .noticia__texto img {
  max-width: 100%;
  height: auto;
  border-radius: 15px;
  margin: 2rem 0;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}

#noticia-single .noticia__texto ul,
#noticia-single .noticia__texto ol {
  margin: 1.5rem 0;
  padding-left: 2rem;
}

#noticia-single .noticia__texto li {
  margin-bottom: 0.75rem;
}

/* Galeria */
#noticia-single .noticia__galeria {
  background: var(--branco-gelo);
  padding: 40px;
  border-radius: 20px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

#noticia-single .noticia__galeria-titulo {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 30px;
  display: flex;
  align-items: center;
}

#noticia-single .noticia__galeria-item {
  position: relative;
  display: block;
  aspect-ratio: 1 / 1;
  border-radius: 15px;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
  transition: var(--transition-medium);
}

#noticia-single .noticia__galeria-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.2);
}

#noticia-single .noticia__galeria-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-slow);
}

#noticia-single .noticia__galeria-item:hover img {
  transform: scale(1.1);
}

#noticia-single .noticia__galeria-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(15, 92, 140, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: var(--transition-medium);
}

#noticia-single
  .noticia__galeria-item:hover
  #noticia-single
  .noticia__galeria-overlay {
  opacity: 1;
}

#noticia-single .noticia__galeria-overlay i {
  font-size: 2.5rem;
  color: #ffffff;
}

/* Compartilhar */
#noticia-single .noticia__compartilhar {
  background: var(--branco-gelo);
  padding: 30px;
  border-radius: 15px;
  text-align: center;
}

#noticia-single .noticia__compartilhar-titulo {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--dark);
  margin-bottom: 20px;
}

#noticia-single .noticia__compartilhar-btns {
  display: flex;
  justify-content: center;
  gap: 15px;
  flex-wrap: wrap;
}

#noticia-single .noticia__share-btn {
  width: 50px;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #ffffff;
  font-size: 1.5rem;
  text-decoration: none;
  transition: var(--transition-fast);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

#noticia-single .noticia__share-btn:hover {
  transform: translateY(-5px) scale(1.1);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25);
  color: #ffffff;
}

#noticia-single .noticia__share-btn--facebook {
  background: #1877f2;
}

#noticia-single .noticia__share-btn--twitter {
  background: #1da1f2;
}

#noticia-single .noticia__share-btn--linkedin {
  background: #0a66c2;
}

#noticia-single .noticia__share-btn--whatsapp {
  background: #25d366;
}

/* Voltar */
#noticia-single .noticia__voltar-btn {
  display: inline-flex;
  align-items: center;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: #ffffff;
  padding: 12px 30px;
  border-radius: 50px;
  font-size: 1rem;
  font-weight: 600;
  text-decoration: none;
  transition: var(--transition-medium);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.2);
}

#noticia-single .noticia__voltar-btn:hover {
  transform: translateX(-5px);
  box-shadow: 0 6px 25px rgba(15, 92, 140, 0.3);
  color: #ffffff;
}

/* Notícias Relacionadas */
#noticia-single .noticia__relacionadas {
  background: var(--branco-gelo) !important;
}

#noticia-single .noticia__relacionadas-titulo {
  font-size: clamp(1.8rem, 4vw, 2.5rem);
  font-weight: 800;
  color: var(--dark);
}

#noticia-single .noticia__card-relacionada {
  background: #ffffff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.08);
  transition: var(--transition-medium);
}

#noticia-single .noticia__card-relacionada:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(15, 92, 140, 0.15);
}

#noticia-single .noticia__card-link {
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  height: 100%;
}

#noticia-single .noticia__card-img {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
}

#noticia-single .noticia__card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-slow);
}

#noticia-single
  .noticia__card-relacionada:hover
  #noticia-single
  .noticia__card-img
  img {
  transform: scale(1.08);
}

#noticia-single .noticia__card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(4, 41, 64, 0.6) 100%
  );
  opacity: 0;
  transition: var(--transition-medium);
}

#noticia-single
  .noticia__card-relacionada:hover
  #noticia-single
  .noticia__card-overlay {
  opacity: 1;
}

#noticia-single .noticia__card-body {
  padding: 25px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}

#noticia-single .noticia__card-data {
  font-size: 0.9rem;
  color: var(--text-secondary);
  font-weight: 500;
  display: flex;
  align-items: center;
}

#noticia-single .noticia__card-titulo {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--dark);
  line-height: 1.3;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: var(--transition-fast);
}

#noticia-single
  .noticia__card-relacionada:hover
  #noticia-single
  .noticia__card-titulo {
  color: var(--azul-principal);
}

#noticia-single .noticia__card-cta {
  display: inline-flex;
  align-items: center;
  color: var(--azul-principal);
  font-weight: 600;
  font-size: 0.95rem;
  margin-top: auto;
  transition: var(--transition-fast);
}

#noticia-single
  .noticia__card-relacionada:hover
  #noticia-single
  .noticia__card-cta {
  transform: translateX(5px);
}

/* Responsividade */
@media (max-width: 991.98px) {
  #noticia-single .noticia__hero {
    min-height: 50vh;
    padding: 60px 0 40px;
  }

  #noticia-single .noticia__titulo {
    font-size: 2rem;
  }

  #noticia-single .noticia__subtitulo {
    font-size: 1.1rem;
  }

  #noticia-single .noticia__galeria {
    padding: 30px 20px;
  }
}

@media (max-width: 767.98px) {
  #noticia-single .noticia__hero {
    min-height: 40vh;
    padding: 40px 0 30px;
  }

  #noticia-single .noticia__titulo {
    font-size: 1.6rem;
  }

  #noticia-single .noticia__subtitulo {
    font-size: 1rem;
  }

  #noticia-single .noticia__texto {
    font-size: 1rem;
  }

  #noticia-single .noticia__galeria {
    padding: 25px 15px;
  }

  #noticia-single .noticia__galeria-titulo {
    font-size: 1.4rem;
  }

  #noticia-single .noticia__compartilhar {
    padding: 20px;
  }

  #noticia-single .noticia__share-btn {
    width: 45px;
    height: 45px;
    font-size: 1.3rem;
  }
}

/* ============================================== */
/* PÁGINA DESAFIOS                                */
/* ============================================== */

/* ============================================== */
/* Page Header                                    */
/* ============================================== */
#desafios-interno .desafios-page__header {
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-petroleo) 100%
  );
  padding: 100px 0 80px;
  position: relative;
  overflow: hidden;
}

#desafios-interno .desafios-page__header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="2" fill="rgba(255,255,255,0.1)"/></svg>');
  opacity: 0.3;
}

#desafios-interno .desafios-page__header-content {
  position: relative;
  z-index: 1;
}

#desafios-interno .desafios-page__title {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 0;
}

#desafios-interno .desafios-page__highlight {
  color: var(--azul-claro);
  position: relative;
}

#desafios-interno .desafios-page__subtitle {
  font-size: clamp(1rem, 2vw, 1.125rem);
  color: rgba(255, 255, 255, 0.9);
  max-width: 700px;
  margin: 0 auto;
  line-height: 1.6;
}

/* Estatísticas */
#desafios-interno .desafios-page__stats {
  margin-top: 3rem;
}

#desafios-interno .desafios-page__stat {
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 15px;
  padding: 1.5rem 2rem;
  text-align: center;
  display: flex;
  align-items: center;
  gap: 1rem;
  transition: var(--transition-medium);
}

#desafios-interno .desafios-page__stat:hover {
  background: rgba(255, 255, 255, 0.15);
  transform: translateY(-5px);
}

#desafios-interno .desafios-page__stat i {
  font-size: 2rem;
  color: var(--azul-claro);
}

#desafios-interno .desafios-page__stat-number {
  font-family: var(--font-heading);
  font-size: 2rem;
  font-weight: 700;
  color: #fff;
  display: block;
}

#desafios-interno .desafios-page__stat-label {
  font-size: 0.875rem;
  color: rgba(255, 255, 255, 0.8);
  text-transform: uppercase;
  letter-spacing: 1px;
  display: block;
}

#desafios-interno .desafios-page__stat--active {
  background: rgba(84, 172, 191, 0.2);
  border-color: var(--azul-claro);
}

/* ============================================== */
/* Filtros                                        */
/* ============================================== */
#desafios-interno .desafios-page__filters {
  padding: 40px 0;
  background: #f8f9fa;
}

#desafios-interno .desafios-page__filter-wrapper {
  background: #fff;
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
}

#desafios-interno .desafios-page__filter-label {
  display: block;
  font-weight: 600;
  color: var(--azul-principal);
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
}

#desafios-interno .desafios-page__filter-select,
#desafios-interno .desafios-page__search-input {
  border: 2px solid #e0e0e0;
  border-radius: 10px;
  padding: 0.75rem 1rem;
  transition: var(--transition-fast);
  font-size: 0.95rem;
}

#desafios-interno .desafios-page__filter-select:focus,
#desafios-interno .desafios-page__search-input:focus {
  border-color: var(--azul-principal);
  box-shadow: 0 0 0 0.2rem rgba(3, 158, 211, 0.15);
}

#desafios-interno .desafios-page__results-count {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  color: #fff;
  padding: 0.75rem 1rem;
  border-radius: 10px;
  font-weight: 600;
  height: 100%;
  margin-top: 1.5rem;
}

#desafios-interno .desafios-page__results-count i {
  font-size: 1.25rem;
}

/* ============================================== */
/* Cards de Desafios                              */
/* ============================================== */
#desafios-interno .desafios-page__list {
  padding: 60px 0;
  background: #f8f9fa;
}

#desafios-interno .desafios-page__card {
  background: #fff;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08);
  transition: var(--transition-medium);
  height: 100%;
  display: flex;
  flex-direction: column;
  position: relative;
}

#desafios-interno .desafios-page__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 35px rgba(0, 0, 0, 0.15);
}

/* Imagem do Card */
#desafios-interno .desafios-page__card-image-wrapper {
  position: relative;
  width: 100%;
  padding-top: 66.67%;
  /* Aspect ratio 3:2 */
  overflow: hidden;
}

#desafios-interno .desafios-page__card-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-medium);
}

#desafios-interno
  .desafios-page__card:hover
  #desafios-interno
  .desafios-page__card-image {
  transform: scale(1.1);
}

#desafios-interno .desafios-page__card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.4) 0%, transparent 50%);
  opacity: 0;
  transition: var(--transition-medium);
}

#desafios-interno
  .desafios-page__card:hover
  #desafios-interno
  .desafios-page__card-overlay {
  opacity: 1;
}

/* Conteúdo do Card */
#desafios-interno .desafios-page__card-content {
  padding: 1.5rem;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}

#desafios-interno .desafios-page__card-title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1rem;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

#desafios-interno .desafios-page__card-description {
  font-size: 0.95rem;
  color: #666;
  line-height: 1.6;
  margin-bottom: 1rem;
  flex-grow: 1;
}

#desafios-interno .desafios-page__card-info {
  display: flex;
  align-items: center;
  font-size: 0.875rem;
  color: var(--azul-petroleo);
  font-weight: 600;
  margin-bottom: 1rem;
  padding: 0.75rem;
  background: rgba(4, 41, 64, 0.05);
  border-radius: 8px;
}

#desafios-interno .desafios-page__card-info i {
  font-size: 1.1rem;
}

#desafios-interno .desafios-page__card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  color: #fff;
  padding: 0.875rem 1.5rem;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 600;
  transition: var(--transition-fast);
  text-align: center;
}

#desafios-interno .desafios-page__card-link:hover {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo),
    var(--azul-principal)
  );
  color: #fff;
  transform: translateX(5px);
}

#desafios-interno .desafios-page__card-link i {
  transition: var(--transition-fast);
}

#desafios-interno .desafios-page__card-link:hover i {
  transform: translateX(5px);
}

/* ============================================== */
/* Estado Vazio                                   */
/* ============================================== */
#desafios-interno .desafios-page__empty {
  text-align: center;
  padding: 80px 20px;
  background: #fff;
  border-radius: 20px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

#desafios-interno .desafios-page__empty i {
  font-size: 4rem;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
  display: block;
}

#desafios-interno .desafios-page__empty h3 {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1rem;
}

#desafios-interno .desafios-page__empty p {
  font-size: 1.125rem;
  color: #666;
  line-height: 1.6;
  max-width: 500px;
  margin: 0 auto;
}

#desafios-interno .desafios-page__empty-link {
  display: inline-block;
  color: var(--azul-petroleo);
  font-weight: 600;
  text-decoration: none;
  margin-top: 1rem;
  transition: var(--transition-fast);
}

#desafios-interno .desafios-page__empty-link:hover {
  color: var(--azul-principal);
  text-decoration: underline;
}

/* ============================================== */
/* Responsividade                                 */
/* ============================================== */
@media (max-width: 991.98px) {
  #desafios-interno .desafios-page__header {
    padding: 80px 0 60px;
  }

  #desafios-interno .desafios-page__stats {
    margin-top: 2rem;
  }

  #desafios-interno .desafios-page__stat {
    padding: 1rem 1.5rem;
  }

  #desafios-interno .desafios-page__filter-wrapper {
    padding: 1.5rem;
  }

  #desafios-interno .desafios-page__results-count {
    margin-top: 0;
  }
}

@media (max-width: 767.98px) {
  #desafios-interno .desafios-page__header {
    padding: 60px 0 40px;
  }

  #desafios-interno .desafios-page__title {
    font-size: 2rem;
  }

  #desafios-interno .desafios-page__subtitle {
    font-size: 1rem;
  }

  #desafios-interno .desafios-page__stat {
    flex-direction: column;
    gap: 0.5rem;
  }

  #desafios-interno .desafios-page__stat-number {
    font-size: 1.5rem;
  }

  #desafios-interno .desafios-page__filter-wrapper {
    padding: 1rem;
  }

  #desafios-interno .desafios-page__list {
    padding: 40px 0;
  }

  #desafios-interno .desafios-page__card-title {
    font-size: 1.125rem;
  }
}

/* ============================================== */
/* PÁGINA DESAFIO                                 */
/* ============================================== */

/* ============================================== */
/* Page Header                                    */
/* ============================================== */
#desafio-interno .desafio-page__header {
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-petroleo) 100%
  );
  padding: 120px 0 60px;
  position: relative;
  overflow: hidden;
}

#desafio-interno .desafio-page__header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="2" fill="rgba(255,255,255,0.1)"/></svg>');
  opacity: 0.3;
}

#desafio-interno .desafio-page__header-content {
  position: relative;
  z-index: 1;
}

#desafio-interno .desafio-page__badge {
  display: inline-block;
  background: var(--azul-claro);
  color: var(--azul-principal);
  padding: 0.5rem 1.5rem;
  border-radius: 50px;
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

#desafio-interno .desafio-page__title {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 0;
  line-height: 1.2;
}

#desafio-interno .desafio-page__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
}

#desafio-interno .desafio-page__meta-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.95rem;
}

#desafio-interno .desafio-page__meta-item i {
  font-size: 1.25rem;
  color: var(--azul-claro);
}

/* ============================================== */
/* Foto de Capa                                   */
/* ============================================== */
#desafio-interno .desafio-page__cover {
  padding: 60px 0;
  background: #f8f9fa;
}

#desafio-interno .desafio-page__cover-wrapper {
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
  position: relative;
  padding-top: 56.25%; /* Aspect ratio 16:9 */
}

#desafio-interno .desafio-page__cover-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-medium);
}

#desafio-interno .desafio-page__cover-wrapper:hover .desafio-page__cover-image {
  transform: scale(1.05);
}

#desafio-interno .desafio-page__cover-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.3) 100%);
  opacity: 0;
  transition: var(--transition-medium);
}

#desafio-interno
  .desafio-page__cover-wrapper:hover
  .desafio-page__cover-overlay {
  opacity: 1;
}

/* ============================================== */
/* Conteúdo Principal                             */
/* ============================================== */
#desafio-interno .desafio-page__content {
  padding: 80px 0;
  background: #fff;
}

#desafio-interno .desafio-page__section {
  margin-bottom: 4rem;
}

/* Card de Descrição */
#desafio-interno .desafio-page__description-card {
  background: #fff;
  border-radius: 20px;
  padding: 2.5rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 2rem;
}

#desafio-interno .desafio-page__section-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  color: #fff;
  border-radius: 12px;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

#desafio-interno .desafio-page__section-title {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
}

#desafio-interno .desafio-page__description-content {
  font-size: 1.05rem;
  line-height: 1.8;
  color: #333;
}

#desafio-interno .desafio-page__description-content p {
  margin-bottom: 1rem;
}

#desafio-interno .desafio-page__description-content ul,
#desafio-interno .desafio-page__description-content ol {
  margin-bottom: 1rem;
  padding-left: 2rem;
}

#desafio-interno .desafio-page__description-content li {
  margin-bottom: 0.5rem;
}

#desafio-interno .desafio-page__description-content img {
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  margin: 1.5rem 0;
}

/* ============================================== */
/* Galeria                                        */
/* ============================================== */
#desafio-interno .desafio-page__galeria-item {
  position: relative;
  display: block;
  border-radius: 10px;
  overflow: hidden;
  aspect-ratio: 1;
}

#desafio-interno .desafio-page__galeria-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-medium);
}

#desafio-interno .desafio-page__galeria-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(3, 158, 211, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: var(--transition-medium);
}

#desafio-interno .desafio-page__galeria-overlay i {
  font-size: 2rem;
  color: #fff;
}

#desafio-interno .desafio-page__galeria-item:hover img {
  transform: scale(1.1);
}

#desafio-interno
  .desafio-page__galeria-item:hover
  #desafio-interno
  .desafio-page__galeria-overlay {
  opacity: 1;
}

/* ============================================== */
/* Sidebar                                        */
/* ============================================== */
#desafio-interno .desafio-page__sidebar {
  position: sticky;
  top: 100px;
}

#desafio-interno .desafio-page__info-card,
#desafio-interno .desafio-page__document-card,
#desafio-interno .desafio-page__cta-card {
  background: #fff;
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 1.5rem;
}

#desafio-interno .desafio-page__info-title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
}

#desafio-interno .desafio-page__info-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid #e0e0e0;
}

#desafio-interno .desafio-page__info-item:last-child {
  border-bottom: none;
}

#desafio-interno .desafio-page__info-item i {
  font-size: 1.5rem;
  color: var(--azul-principal);
  flex-shrink: 0;
}

#desafio-interno .desafio-page__info-item > div {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

#desafio-interno .desafio-page__info-label {
  font-size: 0.875rem;
  color: #666;
  font-weight: 600;
}

#desafio-interno .desafio-page__info-value {
  font-size: 1rem;
  color: #333;
  font-weight: 600;
}

/* Documento */
#desafio-interno .desafio-page__document-link {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem;
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  color: #fff;
  border-radius: 10px;
  text-decoration: none;
  transition: var(--transition-medium);
}

#desafio-interno .desafio-page__document-link:hover {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo),
    var(--azul-principal)
  );
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(3, 158, 211, 0.3);
}

#desafio-interno .desafio-page__document-link i:first-child {
  font-size: 2rem;
}

#desafio-interno .desafio-page__document-link span {
  font-weight: 600;
}

/* CTA */
#desafio-interno .desafio-page__cta-card {
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  color: #fff;
}

#desafio-interno .desafio-page__cta-title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 1rem;
}

#desafio-interno .desafio-page__cta-text {
  font-size: 0.95rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
  color: rgba(255, 255, 255, 0.9);
}

#desafio-interno .desafio-page__cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  color: var(--azul-principal);
  padding: 0.875rem 1.5rem;
  border-radius: 50px;
  text-decoration: none;
  font-weight: 600;
  transition: var(--transition-fast);
  width: 100%;
}

#desafio-interno .desafio-page__cta-button:hover {
  background: var(--azul-claro);
  color: var(--azul-principal);
  transform: translateY(-2px);
}

/* Status Card (quando inscrições não estão disponíveis) */
#desafio-interno .desafio-page__status-card {
  background: #fff;
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 1.5rem;
  text-align: center;
  border: 2px solid #f8f9fa;
}

#desafio-interno .desafio-page__status-card i {
  font-size: 3rem;
  color: #6c757d;
  margin-bottom: 1rem;
  display: block;
}

#desafio-interno .desafio-page__status-card h3 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: #495057;
  margin-bottom: 0.5rem;
}

#desafio-interno .desafio-page__status-card p {
  color: #6c757d;
  font-size: 0.95rem;
  margin: 0;
}

/* Empty Card (quando não há material complementar) */
#desafio-interno .desafio-page__empty-card {
  background: #fff;
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 1.5rem;
  text-align: center;
  border: 2px dashed #e9ecef;
}

#desafio-interno .desafio-page__empty-card i {
  font-size: 2.5rem;
  color: #adb5bd;
  margin-bottom: 1rem;
  display: block;
}

#desafio-interno .desafio-page__empty-card span {
  color: #6c757d;
  font-size: 0.95rem;
  font-weight: 500;
}

/* Voltar Centralizado */
#desafio-interno .desafio-page__back-centered {
  text-align: center;
  margin-top: 4rem;
  padding: 2rem 0;
}

#desafio-interno .desafio-page__back-centered a {
  display: inline-flex;
  align-items: center;
  color: var(--azul-principal);
  font-weight: 600;
  text-decoration: none;
  transition: var(--transition-fast);
  padding: 1rem 2rem;
  border: 2px solid var(--azul-principal);
  border-radius: 50px;
  background: transparent;
}

#desafio-interno .desafio-page__back-centered a:hover {
  color: #fff;
  background: var(--azul-principal);
  transform: translateY(-2px);
}

/* ============================================== */
/* Responsividade                                 */
/* ============================================== */
@media (max-width: 991.98px) {
  #desafio-interno .desafio-page__header {
    padding: 100px 0 40px;
  }

  #desafio-interno .desafio-page__sidebar {
    position: static;
    margin-top: 3rem;
  }

  #desafio-interno .desafio-page__content {
    padding: 60px 0;
  }

  #desafio-interno .desafio-page__section {
    margin-bottom: 3rem;
  }
}

@media (max-width: 767.98px) {
  #desafio-interno .desafio-page__header {
    padding: 80px 0 30px;
  }

  #desafio-interno .desafio-page__title {
    font-size: 1.75rem;
  }

  #desafio-interno .desafio-page__meta {
    flex-direction: column;
    gap: 1rem;
  }

  #desafio-interno .desafio-page__cover {
    padding: 40px 0;
  }

  #desafio-interno .desafio-page__content {
    padding: 40px 0;
  }

  #desafio-interno .desafio-page__section-title {
    font-size: 1.5rem;
  }

  #desafio-interno .desafio-page__gallery {
    grid-template-columns: repeat(2, 1fr);
  }

  #desafio-interno .desafio-page__info-card,
  #desafio-interno .desafio-page__document-card,
  #desafio-interno .desafio-page__cta-card,
  #desafio-interno .desafio-page__status-card,
  #desafio-interno .desafio-page__empty-card {
    padding: 1.5rem;
  }
}

/* ============================================== */
/* PÁGINA INTERNA: Cursos - ConneCT               */
/* ============================================== */

#cursos-interno {
  background: linear-gradient(
    180deg,
    var(--azul-preto) 0%,
    var(--azul-petroleo) 15%,
    var(--branco-gelo) 15%,
    var(--branco-gelo) 100%
  );
}

/* Header da Página */
#cursos-interno .cursos-page__header {
  padding: 120px 0 80px;
  background: linear-gradient(
    135deg,
    var(--azul-preto) 0%,
    var(--azul-petroleo) 50%,
    var(--azul-principal) 100%
  );
  position: relative;
  overflow: hidden;
}

#cursos-interno .cursos-page__header::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    rgba(84, 172, 191, 0.15) 0%,
    transparent 70%
  );
  animation: float 8s ease-in-out infinite;
}

#cursos-interno .cursos-page__header::after {
  content: "";
  position: absolute;
  bottom: -30%;
  left: -5%;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(187, 232, 242, 0.1) 0%,
    transparent 70%
  );
  animation: float 10s ease-in-out infinite reverse;
}

@keyframes float {
  0%,
  100% {
    transform: translateY(0) rotate(0deg);
  }
  50% {
    transform: translateY(-30px) rotate(10deg);
  }
}

#cursos-interno .cursos-page__header-content {
  position: relative;
  z-index: 2;
}

/* Título */
#cursos-interno .cursos-page__title {
  font-family: var(--font-primary);
  font-size: 3rem;
  font-weight: 700;
  color: var(--branco-gelo);
  line-height: 1.2;
  margin-bottom: 0;
}

#cursos-interno .cursos-page__highlight {
  color: var(--azul-claro);
  position: relative;
  display: inline-block;
}

/* Subtítulo */
#cursos-interno .cursos-page__subtitle {
  font-size: 1.25rem;
  color: var(--azul-suave);
  line-height: 1.6;
  max-width: 700px;
  margin: 0 auto;
}

/* Estatísticas */
#cursos-interno .cursos-page__stats {
  margin-top: 3rem;
  position: relative;
  z-index: 2;
}

#cursos-interno .cursos-page__stat {
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(187, 232, 242, 0.2);
  border-radius: 15px;
  padding: 1.5rem;
  text-align: center;
  transition: var(--transition-medium);
}

#cursos-interno .cursos-page__stat:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(187, 232, 242, 0.4);
  transform: translateY(-5px);
  box-shadow: 0 8px 25px rgba(84, 172, 191, 0.2);
}

#cursos-interno .cursos-page__stat--active {
  background: linear-gradient(
    135deg,
    rgba(84, 172, 191, 0.15),
    rgba(187, 232, 242, 0.1)
  );
  border-color: var(--azul-claro);
}

#cursos-interno .cursos-page__stat-number {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-claro);
  line-height: 1;
  margin-bottom: 0.5rem;
}

#cursos-interno .cursos-page__stat-label {
  font-size: 0.95rem;
  color: var(--azul-suave);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 500;
}

/* Seção de Filtros */
#cursos-interno .cursos-page__filters {
  padding: 50px 0;
  background: var(--branco-gelo);
}

#cursos-interno .cursos-page__filter-wrapper {
  background: var(--branco-gelo);
  border: 1px solid rgba(4, 41, 64, 0.1);
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 8, 13, 0.05);
}

#cursos-interno .cursos-page__filter-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  margin-bottom: 0.5rem;
  display: block;
}

#cursos-interno .cursos-page__search-input,
#cursos-interno .cursos-page__filter-select {
  border: 2px solid rgba(84, 172, 191, 0.2);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  transition: var(--transition-fast);
  background: var(--branco-gelo);
}

#cursos-interno .cursos-page__search-input:focus,
#cursos-interno .cursos-page__filter-select:focus {
  border-color: var(--azul-principal);
  box-shadow: 0 0 0 0.2rem rgba(84, 172, 191, 0.15);
  background: var(--branco-gelo);
}

#cursos-interno .cursos-page__results-count {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  color: #fff;
  padding: 0.75rem 1rem;
  border-radius: 10px;
  font-weight: 600;
  height: 100%;
  margin-top: 1.5rem;
}

#cursos-interno .cursos-page__results-count i {
  font-size: 1.25rem;
}

/* Lista de Cursos */
#cursos-interno .cursos-page__list {
  padding: 50px 0 100px;
  background: var(--branco-gelo);
}

/* Card do Curso */
#cursos-interno .cursos-page__card {
  background: var(--branco-gelo);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 8, 13, 0.08);
  transition: var(--transition-medium);
  height: 100%;
  display: flex;
  flex-direction: column;
}

#cursos-interno .cursos-page__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(84, 172, 191, 0.25);
}

/* Imagem do Card */
#cursos-interno .cursos-page__card-image-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: var(--azul-petroleo);
}

#cursos-interno .cursos-page__card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-medium);
}

#cursos-interno
  .cursos-page__card:hover
  #cursos-interno
  .cursos-page__card-image {
  transform: scale(1.08);
}

#cursos-interno .cursos-page__card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 8, 13, 0.4) 100%);
  opacity: 0;
  transition: var(--transition-medium);
}

#cursos-interno
  .cursos-page__card:hover
  #cursos-interno
  .cursos-page__card-overlay {
  opacity: 1;
}

/* Conteúdo do Card */
#cursos-interno .cursos-page__card-content {
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  flex-grow: 1;
}

#cursos-interno .cursos-page__card-title {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  line-height: 1.3;
  margin-bottom: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 3.6rem;
}

#cursos-interno .cursos-page__card-description {
  font-size: 0.95rem;
  color: var(--cinza-texto);
  line-height: 1.6;
  margin-bottom: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Informações do Card */
#cursos-interno .cursos-page__card-info {
  display: flex;
  align-items: center;
  font-size: 0.9rem;
  color: var(--azul-petroleo);
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(84, 172, 191, 0.1);
}

#cursos-interno .cursos-page__card-info:last-of-type {
  border-bottom: none;
}

#cursos-interno .cursos-page__card-info i {
  color: var(--azul-principal);
  font-size: 1.1rem;
  flex-shrink: 0;
}

#cursos-interno .cursos-page__card-info span {
  flex-grow: 1;
}

/* Link do Card */
#cursos-interno .cursos-page__card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.875rem 1.5rem;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  color: var(--branco-gelo);
  font-weight: 600;
  font-size: 0.95rem;
  border-radius: 10px;
  text-decoration: none;
  transition: var(--transition-fast);
  margin-top: auto;
  box-shadow: 0 4px 15px rgba(84, 172, 191, 0.3);
}

#cursos-interno .cursos-page__card-link:hover {
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: var(--branco-gelo);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(84, 172, 191, 0.4);
}

#cursos-interno .cursos-page__card-link i {
  transition: var(--transition-fast);
}

#cursos-interno .cursos-page__card-link:hover i {
  transform: translateX(5px);
}

/* Empty State */
#cursos-interno .cursos-page__empty {
  text-align: center;
  padding: 100px 20px;
  background: var(--branco-gelo);
  border-radius: 20px;
  box-shadow: 0 4px 20px rgba(0, 8, 13, 0.05);
}

#cursos-interno .cursos-page__empty i {
  font-size: 5rem;
  color: var(--azul-claro);
  margin-bottom: 1.5rem;
  opacity: 0.7;
}

#cursos-interno .cursos-page__empty h3 {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#cursos-interno .cursos-page__empty p {
  font-size: 1.1rem;
  color: var(--cinza-texto);
  max-width: 500px;
  margin: 0 auto;
}

/* Responsividade */
@media (max-width: 1199.98px) {
  #cursos-interno .cursos-page__title {
    font-size: 2.5rem;
  }

  #cursos-interno .cursos-page__stat-number {
    font-size: 2rem;
  }
}

@media (max-width: 991.98px) {
  #cursos-interno .cursos-page__filter-wrapper {
    padding: 1.5rem;
  }

  #cursos-interno .cursos-page__results-count {
    margin-top: 1rem;
  }
}

@media (max-width: 767.98px) {
  #cursos-interno .cursos-page__header {
    padding: 80px 0 50px;
  }

  #cursos-interno .cursos-page__title {
    font-size: 1.85rem;
  }

  #cursos-interno .cursos-page__subtitle {
    font-size: 1rem;
  }

  #cursos-interno .cursos-page__stat {
    padding: 1.25rem;
  }

  #cursos-interno .cursos-page__stat-number {
    font-size: 1.75rem;
  }

  #cursos-interno .cursos-page__stat-label {
    font-size: 0.85rem;
  }

  #cursos-interno .cursos-page__filters {
    padding: 40px 0;
  }

  #cursos-interno .cursos-page__filter-wrapper {
    padding: 1.25rem;
  }

  #cursos-interno .cursos-page__list {
    padding: 40px 0 80px;
  }

  #cursos-interno .cursos-page__card-title {
    font-size: 1.25rem;
  }

  #cursos-interno .cursos-page__card-content {
    padding: 1.5rem;
  }

  #cursos-interno .cursos-page__empty {
    padding: 80px 20px;
  }

  #cursos-interno .cursos-page__empty i {
    font-size: 4rem;
  }

  #cursos-interno .cursos-page__empty h3 {
    font-size: 1.5rem;
  }
}

/* ============================================== */
/* PÁGINA INTERNA DE CURSO - ConneCT             */
/* ============================================== */

/* ============================================== */
/* Header da Página                               */
/* ============================================== */
#curso-interno .curso-page__header {
  background: linear-gradient(
    135deg,
    var(--azul-principal) 0%,
    var(--azul-petroleo) 100%
  );
  padding: 120px 0 60px;
  position: relative;
  overflow: hidden;
}

#curso-interno .curso-page__header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="2" fill="rgba(255,255,255,0.1)"/></svg>');
  opacity: 0.3;
}

#curso-interno .curso-page__header-content {
  position: relative;
  z-index: 1;
}

/* Breadcrumb */
#curso-interno .curso-page__breadcrumb {
  margin-bottom: 1.5rem;
}

#curso-interno .curso-page__breadcrumb-link {
  display: inline-flex;
  align-items: center;
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 500;
  transition: var(--transition-fast);
}

#curso-interno .curso-page__breadcrumb-link:hover {
  color: var(--azul-claro);
}

/* Badge */
#curso-interno .curso-page__badge {
  display: inline-block;
  background: var(--azul-claro);
  color: var(--azul-principal);
  padding: 0.5rem 1.5rem;
  border-radius: 50px;
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Título */
#curso-interno .curso-page__title {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 0;
  line-height: 1.2;
}

/* Meta Informações */
#curso-interno .curso-page__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  margin-top: 1.5rem;
}

#curso-interno .curso-page__meta-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.95rem;
}

#curso-interno .curso-page__meta-item i {
  font-size: 1.25rem;
  color: var(--azul-claro);
}

/* ============================================== */
/* Foto de Capa                                   */
/* ============================================== */
#curso-interno .curso-page__cover {
  padding: 60px 0;
  background: #f8f9fa;
}

#curso-interno .curso-page__cover-wrapper {
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
  position: relative;
  padding-top: 56.25%; /* Aspect ratio 16:9 */
}

#curso-interno .curso-page__cover-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-medium);
}

#curso-interno .curso-page__cover-wrapper:hover .curso-page__cover-image {
  transform: scale(1.05);
}

#curso-interno .curso-page__cover-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.3) 100%);
  opacity: 0;
  transition: var(--transition-medium);
}

#curso-interno .curso-page__cover-wrapper:hover .curso-page__cover-overlay {
  opacity: 1;
}

/* ============================================== */
/* Conteúdo Principal                             */
/* ============================================== */
#curso-interno .curso-page__content {
  padding: 80px 0;
  background: #fff;
}

/* Card de Descrição */
#curso-interno .curso-page__description-card {
  background: #fff;
  border-radius: 20px;
  padding: 2.5rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 2rem;
}

#curso-interno .curso-page__section-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  color: #fff;
  border-radius: 12px;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

#curso-interno .curso-page__section-title {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
}

#curso-interno .curso-page__description-content {
  font-size: 1.05rem;
  line-height: 1.8;
  color: #333;
}

#curso-interno .curso-page__description-content p {
  margin-bottom: 1rem;
}

#curso-interno .curso-page__description-content ul,
#curso-interno .curso-page__description-content ol {
  margin-bottom: 1rem;
  padding-left: 2rem;
}

#curso-interno .curso-page__description-content li {
  margin-bottom: 0.5rem;
}

#curso-interno .curso-page__description-content img {
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  margin: 1.5rem 0;
}

/* ============================================== */
/* Sidebar - Cards de Informação                  */
/* ============================================== */

/* Card de Informações */
#curso-interno .curso-page__info-card {
  background: #fff;
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 1.5rem;
}

#curso-interno .curso-page__info-header {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
}

#curso-interno .curso-page__info-header h3 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin: 0;
}

#curso-interno .curso-page__info-list {
  display: flex;
  flex-direction: column;
}

#curso-interno .curso-page__info-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid #e0e0e0;
}

#curso-interno .curso-page__info-item:last-child {
  border-bottom: none;
}

#curso-interno .curso-page__info-item i {
  font-size: 1.5rem;
  color: var(--azul-principal);
  flex-shrink: 0;
}

#curso-interno .curso-page__info-item > div {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

#curso-interno .curso-page__info-label {
  font-size: 0.875rem;
  color: #666;
  font-weight: 600;
}

#curso-interno .curso-page__info-value {
  font-size: 1rem;
  color: #333;
  font-weight: 600;
}

/* Badge de Status */
#curso-interno .curso-page__status-badge {
  display: inline-block;
  padding: 0.375rem 1rem;
  background: linear-gradient(135deg, #28a745, #20c997);
  color: #fff;
  border-radius: 50px;
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ============================================== */
/* Card de CTA - Inscrição                        */
/* ============================================== */
#curso-interno .curso-page__cta-card {
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  border-radius: 20px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(3, 158, 211, 0.3);
  margin-bottom: 1.5rem;
  text-align: center;
  color: #fff;
}

#curso-interno .curso-page__cta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(10px);
  border-radius: 50%;
  font-size: 1.75rem;
  color: #fff;
  margin-bottom: 1rem;
}

#curso-interno .curso-page__cta-title {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 1rem;
}

#curso-interno .curso-page__cta-text {
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: 1.5rem;
}

#curso-interno .curso-page__cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem 2rem;
  background: #fff;
  color: var(--azul-principal);
  border-radius: 50px;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.05rem;
  transition: var(--transition-fast);
  width: 100%;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
}

#curso-interno .curso-page__cta-btn:hover {
  background: var(--azul-claro);
  color: var(--azul-principal);
  transform: translateY(-3px);
  box-shadow: 0 6px 25px rgba(0, 0, 0, 0.2);
}

#curso-interno .curso-page__cta-btn i {
  transition: var(--transition-fast);
}

#curso-interno .curso-page__cta-btn:hover i {
  transform: translateX(5px);
}

/* Alerta de Vagas */
#curso-interno .curso-page__cta-alert {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  background: rgba(255, 193, 7, 0.2);
  border: 1px solid rgba(255, 193, 7, 0.5);
  border-radius: 10px;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
}

#curso-interno .curso-page__cta-alert--full {
  background: rgba(220, 53, 69, 0.2);
  border-color: rgba(220, 53, 69, 0.5);
}

/* ============================================== */
/* Botão Voltar Centralizado                      */
/* ============================================== */
#curso-interno .curso-page__back-centered {
  text-align: center;
  margin-top: 4rem;
  padding: 2rem 0;
}

#curso-interno .curso-page__back-centered a {
  display: inline-flex;
  align-items: center;
  color: var(--azul-principal);
  font-weight: 600;
  text-decoration: none;
  transition: var(--transition-fast);
  padding: 1rem 2rem;
  border: 2px solid var(--azul-principal);
  border-radius: 50px;
  background: transparent;
}

#curso-interno .curso-page__back-centered a:hover {
  color: #fff;
  background: var(--azul-principal);
  transform: translateY(-2px);
}

/* ============================================== */
/* Responsividade                                 */
/* ============================================== */
@media (max-width: 991.98px) {
  #curso-interno .curso-page__header {
    padding: 100px 0 40px;
  }

  #curso-interno .curso-page__content {
    padding: 60px 0;
  }

  #curso-interno .curso-page__description-card {
    padding: 2rem;
  }

  #curso-interno .curso-page__info-card,
  #curso-interno .curso-page__cta-card {
    padding: 1.75rem;
  }
}

@media (max-width: 767.98px) {
  #curso-interno .curso-page__header {
    padding: 80px 0 30px;
  }

  #curso-interno .curso-page__title {
    font-size: 1.75rem;
  }

  #curso-interno .curso-page__meta {
    flex-direction: column;
    gap: 1rem;
  }

  #curso-interno .curso-page__cover {
    padding: 40px 0;
  }

  #curso-interno .curso-page__content {
    padding: 40px 0;
  }

  #curso-interno .curso-page__section-title {
    font-size: 1.5rem;
  }

  #curso-interno .curso-page__description-card {
    padding: 1.5rem;
  }

  #curso-interno .curso-page__info-card,
  #curso-interno .curso-page__cta-card {
    padding: 1.5rem;
  }

  #curso-interno .curso-page__cta-title {
    font-size: 1.25rem;
  }
}

/* ============================================== */
/* PÁGINA INTERNA: Workshops - ConneCT            */
/* ============================================== */

#workshops-interno {
  background: linear-gradient(
    180deg,
    var(--azul-preto) 0%,
    var(--azul-petroleo) 15%,
    var(--branco-gelo) 15%,
    var(--branco-gelo) 100%
  );
}

/* Header da Página */
#workshops-interno .workshops-page__header {
  padding: 120px 0 80px;
  background: linear-gradient(
    135deg,
    var(--azul-suave) 0%,
    var(--azul-claro) 50%,
    var(--azul-principal) 100%
  );
  position: relative;
  overflow: hidden;
}

#workshops-interno .workshops-page__header::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    rgba(15, 92, 140, 0.2) 0%,
    transparent 70%
  );
  animation: float 8s ease-in-out infinite;
}

#workshops-interno .workshops-page__header::after {
  content: "";
  position: absolute;
  bottom: -30%;
  left: -5%;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(4, 41, 64, 0.15) 0%,
    transparent 70%
  );
  animation: float 10s ease-in-out infinite reverse;
}

@keyframes float {
  0%,
  100% {
    transform: translateY(0) rotate(0deg);
  }

  50% {
    transform: translateY(-30px) rotate(10deg);
  }
}

#workshops-interno .workshops-page__header-content {
  position: relative;
  z-index: 2;
}

/* Título */
#workshops-interno .workshops-page__title {
  font-family: var(--font-primary);
  font-size: 3rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  line-height: 1.2;
  margin-bottom: 0;
}

#workshops-interno .workshops-page__highlight {
  color: var(--azul-principal);
  position: relative;
  display: inline-block;
}

/* Subtítulo */
#workshops-interno .workshops-page__subtitle {
  font-size: 1.25rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  max-width: 700px;
  margin: 0 auto;
}

/* Estatísticas */
#workshops-interno .workshops-page__stats {
  margin-top: 3rem;
  position: relative;
  z-index: 2;
}

#workshops-interno .workshops-page__stat {
  background: rgba(4, 41, 64, 0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(15, 92, 140, 0.2);
  border-radius: 15px;
  padding: 1.5rem;
  text-align: center;
  transition: var(--transition-medium);
}

#workshops-interno .workshops-page__stat:hover {
  background: rgba(4, 41, 64, 0.02);
  border-color: rgba(15, 92, 140, 0.4);
  transform: translateY(-5px);
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.2);
}

#workshops-interno .workshops-page__stat--active {
  background: linear-gradient(
    135deg,
    rgba(15, 92, 140, 0.15),
    rgba(84, 172, 191, 0.1)
  );
  border-color: var(--azul-principal);
}

#workshops-interno .workshops-page__stat-number {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-principal);
  line-height: 1;
  margin-bottom: 0.5rem;
}

#workshops-interno .workshops-page__stat-label {
  font-size: 0.95rem;
  color: var(--azul-petroleo);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 500;
}

/* Seção de Filtros */
#workshops-interno .workshops-page__filters {
  padding: 50px 0;
  background: var(--branco-gelo);
}

#workshops-interno .workshops-page__filter-wrapper {
  background: var(--branco-gelo);
  border: 1px solid rgba(4, 41, 64, 0.1);
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 8, 13, 0.05);
}

#workshops-interno .workshops-page__filter-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  margin-bottom: 0.5rem;
  display: block;
}

#workshops-interno .workshops-page__search-input,
#workshops-interno .workshops-page__filter-select {
  border: 2px solid rgba(84, 172, 191, 0.2);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  transition: var(--transition-fast);
  background: var(--branco-gelo);
}

#workshops-interno .workshops-page__search-input:focus,
#workshops-interno .workshops-page__filter-select:focus {
  border-color: var(--azul-principal);
  box-shadow: 0 0 0 0.2rem rgba(84, 172, 191, 0.15);
  background: var(--branco-gelo);
}

#workshops-interno .workshops-page__results-count {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  color: #fff;
  padding: 0.75rem 1rem;
  border-radius: 10px;
  font-weight: 600;
  height: 100%;
  margin-top: 1.5rem;
}

#workshops-interno .workshops-page__results-count i {
  font-size: 1.25rem;
}

/* Lista de Workshops */
#workshops-interno .workshops-page__list {
  padding: 50px 0 100px;
  background: var(--branco-gelo);
}

/* Card do Workshop */
#workshops-interno .workshops-page__card {
  background: var(--branco-gelo);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 8, 13, 0.08);
  transition: var(--transition-medium);
  height: 100%;
  display: flex;
  flex-direction: column;
}

#workshops-interno .workshops-page__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(84, 172, 191, 0.25);
}

/* Imagem do Card */
#workshops-interno .workshops-page__card-image-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: var(--azul-petroleo);
}

#workshops-interno .workshops-page__card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-medium);
}

#workshops-interno
  .workshops-page__card:hover
  #workshops-interno
  .workshops-page__card-image {
  transform: scale(1.08);
}

#workshops-interno .workshops-page__card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 8, 13, 0.4) 100%);
  opacity: 0;
  transition: var(--transition-medium);
}

#workshops-interno
  .workshops-page__card:hover
  #workshops-interno
  .workshops-page__card-overlay {
  opacity: 1;
}

/* Conteúdo do Card */
#workshops-interno .workshops-page__card-content {
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  flex-grow: 1;
}

#workshops-interno .workshops-page__card-title {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  line-height: 1.3;
  margin-bottom: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 3.6rem;
}

#workshops-interno .workshops-page__card-description {
  font-size: 0.95rem;
  color: var(--cinza-texto);
  line-height: 1.6;
  margin-bottom: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Informações do Card */
#workshops-interno .workshops-page__card-info {
  display: flex;
  align-items: center;
  font-size: 0.9rem;
  color: var(--azul-petroleo);
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(84, 172, 191, 0.1);
}

#workshops-interno .workshops-page__card-info:last-of-type {
  border-bottom: none;
}

#workshops-interno .workshops-page__card-info i {
  color: var(--azul-principal);
  font-size: 1.1rem;
  flex-shrink: 0;
}

#workshops-interno .workshops-page__card-info span {
  flex-grow: 1;
}

/* Link do Card */
#workshops-interno .workshops-page__card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.875rem 1.5rem;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  color: var(--branco-gelo);
  font-weight: 600;
  font-size: 0.95rem;
  border-radius: 10px;
  text-decoration: none;
  transition: var(--transition-fast);
  margin-top: auto;
  box-shadow: 0 4px 15px rgba(84, 172, 191, 0.3);
}

#workshops-interno .workshops-page__card-link:hover {
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: var(--branco-gelo);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(84, 172, 191, 0.4);
}

#workshops-interno .workshops-page__card-link i {
  transition: var(--transition-fast);
}

#workshops-interno .workshops-page__card-link:hover i {
  transform: translateX(5px);
}

/* Empty State */
#workshops-interno .workshops-page__empty {
  text-align: center;
  padding: 100px 20px;
  background: var(--branco-gelo);
  border-radius: 20px;
  box-shadow: 0 4px 20px rgba(0, 8, 13, 0.05);
}

#workshops-interno .workshops-page__empty i {
  font-size: 5rem;
  color: var(--azul-claro);
  margin-bottom: 1.5rem;
  opacity: 0.7;
}

#workshops-interno .workshops-page__empty h3 {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#workshops-interno .workshops-page__empty p {
  font-size: 1.1rem;
  color: var(--cinza-texto);
  max-width: 500px;
  margin: 0 auto;
}

/* Responsividade */
@media (max-width: 1199.98px) {
  #workshops-interno .workshops-page__title {
    font-size: 2.5rem;
  }

  #workshops-interno .workshops-page__stat-number {
    font-size: 2rem;
  }
}

@media (max-width: 991.98px) {
  #workshops-interno .workshops-page__filter-wrapper {
    padding: 1.5rem;
  }

  #workshops-interno .workshops-page__results-count {
    margin-top: 1rem;
  }
}

@media (max-width: 767.98px) {
  #workshops-interno .workshops-page__header {
    padding: 80px 0 50px;
  }

  #workshops-interno .workshops-page__title {
    font-size: 1.85rem;
  }

  #workshops-interno .workshops-page__subtitle {
    font-size: 1rem;
  }

  #workshops-interno .workshops-page__stat {
    padding: 1.25rem;
  }

  #workshops-interno .workshops-page__stat-number {
    font-size: 1.75rem;
  }

  #workshops-interno .workshops-page__stat-label {
    font-size: 0.85rem;
  }

  #workshops-interno .workshops-page__filters {
    padding: 40px 0;
  }

  #workshops-interno .workshops-page__filter-wrapper {
    padding: 1.25rem;
  }

  #workshops-interno .workshops-page__list {
    padding: 40px 0 80px;
  }

  #workshops-interno .workshops-page__card-title {
    font-size: 1.25rem;
  }

  #workshops-interno .workshops-page__card-content {
    padding: 1.5rem;
  }

  #workshops-interno .workshops-page__empty {
    padding: 80px 20px;
  }

  #workshops-interno .workshops-page__empty i {
    font-size: 4rem;
  }

  #workshops-interno .workshops-page__empty h3 {
    font-size: 1.5rem;
  }
}

/* ============================================== */
/* PÁGINA INTERNA DE WORKSHOP - ConneCT          */
/* ============================================== */

/* ============================================== */
/* Header da Página                               */
/* ============================================== */
#workshop-interno .workshop-page__header {
  background: linear-gradient(
    135deg,
    var(--azul-claro) 0%,
    var(--azul-principal) 50%,
    var(--azul-petroleo) 100%
  );
  padding: 120px 0 60px;
  position: relative;
  overflow: hidden;
}

#workshop-interno .workshop-page__header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="2" fill="rgba(255,255,255,0.1)"/></svg>');
  opacity: 0.3;
}

#workshop-interno .workshop-page__header-content {
  position: relative;
  z-index: 1;
}

/* Breadcrumb */
#workshop-interno .workshop-page__breadcrumb {
  margin-bottom: 1.5rem;
}

#workshop-interno .workshop-page__breadcrumb-link {
  display: inline-flex;
  align-items: center;
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 500;
  transition: var(--transition-fast);
}

#workshop-interno .workshop-page__breadcrumb-link:hover {
  color: var(--azul-claro);
}

/* Badge */
#workshop-interno .workshop-page__badge {
  display: inline-block;
  background: var(--azul-claro);
  color: var(--azul-principal);
  padding: 0.5rem 1.5rem;
  border-radius: 50px;
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Título */
#workshop-interno .workshop-page__title {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 0;
  line-height: 1.2;
}

/* Meta Informações */
#workshop-interno .workshop-page__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  margin-top: 1.5rem;
}

#workshop-interno .workshop-page__meta-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.95rem;
}

#workshop-interno .workshop-page__meta-item i {
  font-size: 1.25rem;
  color: var(--azul-claro);
}

/* ============================================== */
/* Foto de Capa                                   */
/* ============================================== */
#workshop-interno .workshop-page__cover {
  padding: 60px 0;
  background: #f8f9fa;
}

#workshop-interno .workshop-page__cover-wrapper {
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
  position: relative;
  padding-top: 56.25%;
  /* Aspect ratio 16:9 */
}

#workshop-interno .workshop-page__cover-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-medium);
}

#workshop-interno
  .workshop-page__cover-wrapper:hover
  .workshop-page__cover-image {
  transform: scale(1.05);
}

#workshop-interno .workshop-page__cover-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.3) 100%);
  opacity: 0;
  transition: var(--transition-medium);
}

#workshop-interno
  .workshop-page__cover-wrapper:hover
  .workshop-page__cover-overlay {
  opacity: 1;
}

/* ============================================== */
/* Conteúdo Principal                             */
/* ============================================== */
#workshop-interno .workshop-page__content {
  padding: 80px 0;
  background: #fff;
}

/* Card de Descrição */
#workshop-interno .workshop-page__description-card {
  background: #fff;
  border-radius: 20px;
  padding: 2.5rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 2rem;
}

#workshop-interno .workshop-page__section-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  color: #fff;
  border-radius: 12px;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

#workshop-interno .workshop-page__section-title {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
}

#workshop-interno .workshop-page__description-content {
  font-size: 1.05rem;
  line-height: 1.8;
  color: #333;
}

#workshop-interno .workshop-page__description-content p {
  margin-bottom: 1rem;
}

#workshop-interno .workshop-page__description-content ul,
#workshop-interno .workshop-page__description-content ol {
  margin-bottom: 1rem;
  padding-left: 2rem;
}

#workshop-interno .workshop-page__description-content li {
  margin-bottom: 0.5rem;
}

#workshop-interno .workshop-page__description-content img {
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  margin: 1.5rem 0;
}

/* ============================================== */
/* Sidebar - Cards de Informação                  */
/* ============================================== */

/* Card de Informações */
#workshop-interno .workshop-page__info-card {
  background: #fff;
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 1.5rem;
}

#workshop-interno .workshop-page__info-header {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
}

#workshop-interno .workshop-page__info-header h3 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin: 0;
}

#workshop-interno .workshop-page__info-list {
  display: flex;
  flex-direction: column;
}

#workshop-interno .workshop-page__info-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid #e0e0e0;
}

#workshop-interno .workshop-page__info-item:last-child {
  border-bottom: none;
}

#workshop-interno .workshop-page__info-item i {
  font-size: 1.5rem;
  color: var(--azul-principal);
  flex-shrink: 0;
}

#workshop-interno .workshop-page__info-item > div {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

#workshop-interno .workshop-page__info-label {
  font-size: 0.875rem;
  color: #666;
  font-weight: 600;
}

#workshop-interno .workshop-page__info-value {
  font-size: 1rem;
  color: #333;
  font-weight: 600;
}

/* Badge de Status */
#workshop-interno .workshop-page__status-badge {
  display: inline-block;
  padding: 0.375rem 1rem;
  background: linear-gradient(135deg, #28a745, #20c997);
  color: #fff;
  border-radius: 50px;
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ============================================== */
/* Card de CTA - Inscrição                        */
/* ============================================== */
#workshop-interno .workshop-page__cta-card {
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  border-radius: 20px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(3, 158, 211, 0.3);
  margin-bottom: 1.5rem;
  text-align: center;
  color: #fff;
}

#workshop-interno .workshop-page__cta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(10px);
  border-radius: 50%;
  font-size: 1.75rem;
  color: #fff;
  margin-bottom: 1rem;
}

#workshop-interno .workshop-page__cta-title {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 1rem;
}

#workshop-interno .workshop-page__cta-text {
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: 1.5rem;
}

#workshop-interno .workshop-page__cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem 2rem;
  background: #fff;
  color: var(--azul-principal);
  border-radius: 50px;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.05rem;
  transition: var(--transition-fast);
  width: 100%;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
}

#workshop-interno .workshop-page__cta-btn:hover {
  background: var(--azul-claro);
  color: var(--azul-principal);
  transform: translateY(-3px);
  box-shadow: 0 6px 25px rgba(0, 0, 0, 0.2);
}

#workshop-interno .workshop-page__cta-btn i {
  transition: var(--transition-fast);
}

#workshop-interno .workshop-page__cta-btn:hover i {
  transform: translateX(5px);
}

/* Alerta de Vagas */
#workshop-interno .workshop-page__cta-alert {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  background: rgba(255, 193, 7, 0.2);
  border: 1px solid rgba(255, 193, 7, 0.5);
  border-radius: 10px;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
}

#workshop-interno .workshop-page__cta-alert--full {
  background: rgba(220, 53, 69, 0.2);
  border-color: rgba(220, 53, 69, 0.5);
}

/* ============================================== */
/* Botão Voltar Centralizado                      */
/* ============================================== */
#workshop-interno .workshop-page__back-centered {
  text-align: center;
  margin-top: 4rem;
  padding: 2rem 0;
}

#workshop-interno .workshop-page__back-centered a {
  display: inline-flex;
  align-items: center;
  color: var(--azul-principal);
  font-weight: 600;
  text-decoration: none;
  transition: var(--transition-fast);
  padding: 1rem 2rem;
  border: 2px solid var(--azul-principal);
  border-radius: 50px;
  background: transparent;
}

#workshop-interno .workshop-page__back-centered a:hover {
  color: #fff;
  background: var(--azul-principal);
  transform: translateY(-2px);
}

/* ============================================== */
/* Responsividade                                 */
/* ============================================== */
@media (max-width: 991.98px) {
  #workshop-interno .workshop-page__header {
    padding: 100px 0 40px;
  }

  #workshop-interno .workshop-page__content {
    padding: 60px 0;
  }

  #workshop-interno .workshop-page__description-card {
    padding: 2rem;
  }

  #workshop-interno .workshop-page__info-card,
  #workshop-interno .workshop-page__cta-card {
    padding: 1.75rem;
  }
}

@media (max-width: 767.98px) {
  #workshop-interno .workshop-page__header {
    padding: 80px 0 30px;
  }

  #workshop-interno .workshop-page__title {
    font-size: 1.75rem;
  }

  #workshop-interno .workshop-page__meta {
    flex-direction: column;
    gap: 1rem;
  }

  #workshop-interno .workshop-page__cover {
    padding: 40px 0;
  }

  #workshop-interno .workshop-page__content {
    padding: 40px 0;
  }

  #workshop-interno .workshop-page__section-title {
    font-size: 1.5rem;
  }

  #workshop-interno .workshop-page__description-card {
    padding: 1.5rem;
  }

  #workshop-interno .workshop-page__info-card,
  #workshop-interno .workshop-page__cta-card {
    padding: 1.5rem;
  }

  #workshop-interno .workshop-page__cta-title {
    font-size: 1.25rem;
  }
}

/* ============================================== */
/* PÁGINA INTERNA: Visitas Técnicas - ConneCT    */
/* ============================================== */

#visitas-interno {
  background: linear-gradient(
    180deg,
    var(--azul-preto) 0%,
    var(--azul-petroleo) 15%,
    var(--branco-gelo) 15%,
    var(--branco-gelo) 100%
  );
}

/* Header da Página */
#visitas-interno .visitas-page__header {
  padding: 120px 0 80px;
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 50%,
    var(--azul-claro) 100%
  );
  position: relative;
  overflow: hidden;
}

#visitas-interno .visitas-page__header::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    rgba(15, 92, 140, 0.2) 0%,
    transparent 70%
  );
  animation: float 8s ease-in-out infinite;
}

#visitas-interno .visitas-page__header::after {
  content: "";
  position: absolute;
  bottom: -30%;
  left: -5%;
  width: 400px;
  height: 400px;
  background: radial-gradient(
    circle,
    rgba(4, 41, 64, 0.15) 0%,
    transparent 70%
  );
  animation: float 10s ease-in-out infinite reverse;
}

@keyframes float {
  0%,
  100% {
    transform: translateY(0) rotate(0deg);
  }

  50% {
    transform: translateY(-30px) rotate(10deg);
  }
}

#visitas-interno .visitas-page__header-content {
  position: relative;
  z-index: 2;
}

/* Título */
#visitas-interno .visitas-page__title {
  font-family: var(--font-primary);
  font-size: 3rem;
  font-weight: 700;
  color: var(--branco-gelo);
  line-height: 1.2;
  margin-bottom: 0;
}

#visitas-interno .visitas-page__highlight {
  color: var(--azul-claro);
  position: relative;
  display: inline-block;
}

/* Subtítulo */
#visitas-interno .visitas-page__subtitle {
  font-size: 1.25rem;
  color: var(--branco-gelo);
  line-height: 1.6;
  max-width: 700px;
  margin: 0 auto;
}

/* Estatísticas */
#visitas-interno .visitas-page__stats {
  margin-top: 3rem;
  position: relative;
  z-index: 2;
}

#visitas-interno .visitas-page__stat {
  background: rgba(4, 41, 64, 0.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(15, 92, 140, 0.2);
  border-radius: 15px;
  padding: 1.5rem;
  text-align: center;
  transition: var(--transition-medium);
}

#visitas-interno .visitas-page__stat:hover {
  background: rgba(4, 41, 64, 0.08);
  border-color: rgba(15, 92, 140, 0.4);
  transform: translateY(-5px);
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.2);
}

#visitas-interno .visitas-page__stat--active {
  background: linear-gradient(
    135deg,
    rgba(15, 92, 140, 0.15),
    rgba(84, 172, 191, 0.1)
  );
  border-color: var(--azul-principal);
}

#visitas-interno .visitas-page__stat-number {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--branco-gelo);
  line-height: 1;
  margin-bottom: 0.5rem;
}

#visitas-interno .visitas-page__stat-label {
  font-size: 0.95rem;
  color: var(--branco-gelo);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 500;
}

/* Seção de Filtros */
#visitas-interno .visitas-page__filters {
  padding: 50px 0;
  background: var(--branco-gelo);
}

#visitas-interno .visitas-page__filter-wrapper {
  background: var(--branco-gelo);
  border: 1px solid rgba(4, 41, 64, 0.1);
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 8, 13, 0.05);
}

#visitas-interno .visitas-page__filter-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  margin-bottom: 0.5rem;
  display: block;
}

#visitas-interno .visitas-page__search-input,
#visitas-interno .visitas-page__filter-select {
  border: 2px solid rgba(84, 172, 191, 0.2);
  border-radius: 10px;
  padding: 0.75rem 1rem;
  font-size: 1rem;
  transition: var(--transition-fast);
  background: var(--branco-gelo);
}

#visitas-interno .visitas-page__search-input:focus,
#visitas-interno .visitas-page__filter-select:focus {
  border-color: var(--azul-principal);
  box-shadow: 0 0 0 0.2rem rgba(84, 172, 191, 0.15);
  background: var(--branco-gelo);
}

#visitas-interno .visitas-page__results-count {
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  color: #fff;
  padding: 0.75rem 1rem;
  border-radius: 10px;
  font-weight: 600;
  height: 100%;
  margin-top: 1.5rem;
}

#visitas-interno .visitas-page__results-count i {
  font-size: 1.25rem;
}

/* Lista de Visitas */
#visitas-interno .visitas-page__list {
  padding: 50px 0 100px;
  background: var(--branco-gelo);
}

/* Card da Visita */
#visitas-interno .visitas-page__card {
  background: var(--branco-gelo);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(0, 8, 13, 0.08);
  transition: var(--transition-medium);
  height: 100%;
  display: flex;
  flex-direction: column;
}

#visitas-interno .visitas-page__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 15px 40px rgba(84, 172, 191, 0.25);
}

/* Imagem do Card */
#visitas-interno .visitas-page__card-image-wrapper {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background: var(--azul-petroleo);
}

#visitas-interno .visitas-page__card-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-medium);
}

#visitas-interno
  .visitas-page__card:hover
  #visitas-interno
  .visitas-page__card-image {
  transform: scale(1.08);
}

#visitas-interno .visitas-page__card-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 8, 13, 0.4) 100%);
  opacity: 0;
  transition: var(--transition-medium);
}

#visitas-interno
  .visitas-page__card:hover
  #visitas-interno
  .visitas-page__card-overlay {
  opacity: 1;
}

/* Conteúdo do Card */
#visitas-interno .visitas-page__card-content {
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  flex-grow: 1;
}

#visitas-interno .visitas-page__card-title {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--azul-petroleo);
  line-height: 1.3;
  margin-bottom: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 3.6rem;
}

#visitas-interno .visitas-page__card-description {
  font-size: 0.95rem;
  color: var(--cinza-texto);
  line-height: 1.6;
  margin-bottom: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Informações do Card */
#visitas-interno .visitas-page__card-info {
  display: flex;
  align-items: center;
  font-size: 0.9rem;
  color: var(--azul-petroleo);
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(84, 172, 191, 0.1);
}

#visitas-interno .visitas-page__card-info:last-of-type {
  border-bottom: none;
}

#visitas-interno .visitas-page__card-info i {
  color: var(--azul-principal);
  font-size: 1.1rem;
  flex-shrink: 0;
}

#visitas-interno .visitas-page__card-info span {
  flex-grow: 1;
}

/* Link do Card */
#visitas-interno .visitas-page__card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.875rem 1.5rem;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  color: var(--branco-gelo);
  font-weight: 600;
  font-size: 0.95rem;
  border-radius: 10px;
  text-decoration: none;
  transition: var(--transition-fast);
  margin-top: auto;
  box-shadow: 0 4px 15px rgba(84, 172, 191, 0.3);
}

#visitas-interno .visitas-page__card-link:hover {
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: var(--branco-gelo);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(84, 172, 191, 0.4);
}

#visitas-interno .visitas-page__card-link i {
  transition: var(--transition-fast);
}

#visitas-interno .visitas-page__card-link:hover i {
  transform: translateX(5px);
}

/* Empty State */
#visitas-interno .visitas-page__empty {
  text-align: center;
  padding: 100px 20px;
  background: var(--branco-gelo);
  border-radius: 20px;
  box-shadow: 0 4px 20px rgba(0, 8, 13, 0.05);
}

#visitas-interno .visitas-page__empty i {
  font-size: 5rem;
  color: var(--azul-claro);
  margin-bottom: 1.5rem;
  opacity: 0.7;
}

#visitas-interno .visitas-page__empty h3 {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  color: var(--azul-petroleo);
  margin-bottom: 1rem;
}

#visitas-interno .visitas-page__empty p {
  font-size: 1.1rem;
  color: var(--cinza-texto);
  max-width: 500px;
  margin: 0 auto;
}

/* Responsividade */
@media (max-width: 1199.98px) {
  #visitas-interno .visitas-page__title {
    font-size: 2.5rem;
  }

  #visitas-interno .visitas-page__stat-number {
    font-size: 2rem;
  }
}

@media (max-width: 991.98px) {
  #visitas-interno .visitas-page__filter-wrapper {
    padding: 1.5rem;
  }

  #visitas-interno .visitas-page__results-count {
    margin-top: 1rem;
  }
}

@media (max-width: 767.98px) {
  #visitas-interno .visitas-page__header {
    padding: 80px 0 50px;
  }

  #visitas-interno .visitas-page__title {
    font-size: 1.85rem;
  }

  #visitas-interno .visitas-page__subtitle {
    font-size: 1rem;
  }

  #visitas-interno .visitas-page__badge {
    font-size: 0.75rem;
    padding: 0.4rem 1.2rem;
  }

  #visitas-interno .visitas-page__stat {
    padding: 1.25rem;
  }

  #visitas-interno .visitas-page__stat-number {
    font-size: 1.75rem;
  }

  #visitas-interno .visitas-page__stat-label {
    font-size: 0.85rem;
  }

  #visitas-interno .visitas-page__filters {
    padding: 40px 0;
  }

  #visitas-interno .visitas-page__filter-wrapper {
    padding: 1.25rem;
  }

  #visitas-interno .visitas-page__list {
    padding: 40px 0 80px;
  }

  #visitas-interno .visitas-page__card-title {
    font-size: 1.25rem;
  }

  #visitas-interno .visitas-page__card-content {
    padding: 1.5rem;
  }

  #visitas-interno .visitas-page__empty {
    padding: 80px 20px;
  }

  #visitas-interno .visitas-page__empty i {
    font-size: 4rem;
  }

  #visitas-interno .visitas-page__empty h3 {
    font-size: 1.5rem;
  }
}

/* ============================================== */
/* PÁGINA INTERNA DE VISITA TÉCNICA - ConneCT    */
/* ============================================== */

/* ============================================== */
/* Header da Página                               */
/* ============================================== */
#visita-interno .visita-page__header {
  background: linear-gradient(
    135deg,
    var(--azul-claro) 0%,
    var(--azul-principal) 50%,
    var(--azul-petroleo) 100%
  );
  padding: 120px 0 60px;
  position: relative;
  overflow: hidden;
}

#visita-interno .visita-page__header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: url('data:image/svg+xml,<svg width="100" height="100" xmlns="http://www.w3.org/2000/svg"><circle cx="50" cy="50" r="2" fill="rgba(255,255,255,0.1)"/></svg>');
  opacity: 0.3;
}

#visita-interno .visita-page__header-content {
  position: relative;
  z-index: 1;
}

/* Breadcrumb */
#visita-interno .visita-page__breadcrumb {
  margin-bottom: 1.5rem;
}

#visita-interno .visita-page__breadcrumb-link {
  display: inline-flex;
  align-items: center;
  color: rgba(255, 255, 255, 0.9);
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 500;
  transition: var(--transition-fast);
}

#visita-interno .visita-page__breadcrumb-link:hover {
  color: var(--azul-claro);
}

/* Badge */
#visita-interno .visita-page__badge {
  display: inline-block;
  background: var(--azul-claro);
  color: var(--azul-principal);
  padding: 0.5rem 1.5rem;
  border-radius: 50px;
  font-weight: 600;
  font-size: 0.875rem;
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Título */
#visita-interno .visita-page__title {
  font-family: var(--font-primary);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 0;
  line-height: 1.2;
}

/* Meta Informações */
#visita-interno .visita-page__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  margin-top: 1.5rem;
}

#visita-interno .visita-page__meta-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  color: rgba(255, 255, 255, 0.9);
  font-size: 0.95rem;
}

#visita-interno .visita-page__meta-item i {
  font-size: 1.25rem;
  color: var(--azul-claro);
}

/* ============================================== */
/* Foto de Capa                                   */
/* ============================================== */
#visita-interno .visita-page__cover {
  padding: 60px 0;
  background: #f8f9fa;
}

#visita-interno .visita-page__cover-wrapper {
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
  position: relative;
  padding-top: 56.25%;
  /* Aspect ratio 16:9 */
}

#visita-interno .visita-page__cover-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: var(--transition-medium);
}

#visita-interno .visita-page__cover-wrapper:hover .visita-page__cover-image {
  transform: scale(1.05);
}

#visita-interno .visita-page__cover-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.3) 100%);
  opacity: 0;
  transition: var(--transition-medium);
}

#visita-interno .visita-page__cover-wrapper:hover .visita-page__cover-overlay {
  opacity: 1;
}

/* ============================================== */
/* Conteúdo Principal                             */
/* ============================================== */
#visita-interno .visita-page__content {
  padding: 80px 0;
  background: #fff;
}

/* Card de Descrição */
#visita-interno .visita-page__description-card {
  background: #fff;
  border-radius: 20px;
  padding: 2.5rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 2rem;
}

#visita-interno .visita-page__section-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  color: #fff;
  border-radius: 12px;
  font-size: 1.5rem;
  margin-bottom: 1rem;
}

#visita-interno .visita-page__section-title {
  font-family: var(--font-heading);
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
}

#visita-interno .visita-page__description-content {
  font-size: 1.05rem;
  line-height: 1.8;
  color: #333;
}

#visita-interno .visita-page__description-content p {
  margin-bottom: 1rem;
}

#visita-interno .visita-page__description-content ul,
#visita-interno .visita-page__description-content ol {
  margin-bottom: 1rem;
  padding-left: 2rem;
}

#visita-interno .visita-page__description-content li {
  margin-bottom: 0.5rem;
}

#visita-interno .visita-page__description-content img {
  max-width: 100%;
  height: auto;
  border-radius: 10px;
  margin: 1.5rem 0;
}

/* ============================================== */
/* Sidebar - Cards de Informação                  */
/* ============================================== */

/* Card de Informações */
#visita-interno .visita-page__info-card {
  background: #fff;
  border-radius: 15px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
  margin-bottom: 1.5rem;
}

#visita-interno .visita-page__info-header {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin-bottom: 1.5rem;
}

#visita-interno .visita-page__info-header h3 {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--azul-principal);
  margin: 0;
}

#visita-interno .visita-page__info-list {
  display: flex;
  flex-direction: column;
}

#visita-interno .visita-page__info-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem 0;
  border-bottom: 1px solid #e0e0e0;
}

#visita-interno .visita-page__info-item:last-child {
  border-bottom: none;
}

#visita-interno .visita-page__info-item i {
  font-size: 1.5rem;
  color: var(--azul-principal);
  flex-shrink: 0;
}

#visita-interno .visita-page__info-item > div {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

#visita-interno .visita-page__info-label {
  font-size: 0.875rem;
  color: #666;
  font-weight: 600;
}

#visita-interno .visita-page__info-value {
  font-size: 1rem;
  color: #333;
  font-weight: 600;
}

/* Badge de Status */
#visita-interno .visita-page__status-badge {
  display: inline-block;
  padding: 0.375rem 1rem;
  background: linear-gradient(135deg, #28a745, #20c997);
  color: #fff;
  border-radius: 50px;
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* ============================================== */
/* Card de CTA - Inscrição                        */
/* ============================================== */
#visita-interno .visita-page__cta-card {
  background: linear-gradient(
    135deg,
    var(--azul-principal),
    var(--azul-petroleo)
  );
  border-radius: 20px;
  padding: 2rem;
  box-shadow: 0 4px 20px rgba(3, 158, 211, 0.3);
  margin-bottom: 1.5rem;
  text-align: center;
  color: #fff;
}

#visita-interno .visita-page__cta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 60px;
  height: 60px;
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(10px);
  border-radius: 50%;
  font-size: 1.75rem;
  color: #fff;
  margin-bottom: 1rem;
}

#visita-interno .visita-page__cta-title {
  font-family: var(--font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 1rem;
}

#visita-interno .visita-page__cta-text {
  font-size: 0.95rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: 1.5rem;
}

#visita-interno .visita-page__cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 1rem 2rem;
  background: #fff;
  color: var(--azul-principal);
  border-radius: 50px;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.05rem;
  transition: var(--transition-fast);
  width: 100%;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
}

#visita-interno .visita-page__cta-btn:hover {
  background: var(--azul-claro);
  color: var(--azul-principal);
  transform: translateY(-3px);
  box-shadow: 0 6px 25px rgba(0, 0, 0, 0.2);
}

#visita-interno .visita-page__cta-btn i {
  transition: var(--transition-fast);
}

#visita-interno .visita-page__cta-btn:hover i {
  transform: translateX(5px);
}

/* Alerta de Vagas */
#visita-interno .visita-page__cta-alert {
  margin-top: 1rem;
  padding: 0.75rem 1rem;
  background: rgba(255, 193, 7, 0.2);
  border: 1px solid rgba(255, 193, 7, 0.5);
  border-radius: 10px;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: center;
}

#visita-interno .visita-page__cta-alert--full {
  background: rgba(220, 53, 69, 0.2);
  border-color: rgba(220, 53, 69, 0.5);
}

/* ============================================== */
/* Botão Voltar Centralizado                      */
/* ============================================== */
#visita-interno .visita-page__back-centered {
  text-align: center;
  margin-top: 4rem;
  padding: 2rem 0;
}

#visita-interno .visita-page__back-centered a {
  display: inline-flex;
  align-items: center;
  color: var(--azul-principal);
  font-weight: 600;
  text-decoration: none;
  transition: var(--transition-fast);
  padding: 1rem 2rem;
  border: 2px solid var(--azul-principal);
  border-radius: 50px;
  background: transparent;
}

#visita-interno .visita-page__back-centered a:hover {
  color: #fff;
  background: var(--azul-principal);
  transform: translateY(-2px);
}

/* ============================================== */
/* Responsividade                                 */
/* ============================================== */
@media (max-width: 991.98px) {
  #visita-interno .visita-page__header {
    padding: 100px 0 40px;
  }

  #visita-interno .visita-page__content {
    padding: 60px 0;
  }

  #visita-interno .visita-page__description-card {
    padding: 2rem;
  }

  #visita-interno .visita-page__info-card,
  #visita-interno .visita-page__cta-card {
    padding: 1.75rem;
  }
}

@media (max-width: 767.98px) {
  #visita-interno .visita-page__header {
    padding: 80px 0 30px;
  }

  #visita-interno .visita-page__title {
    font-size: 1.75rem;
  }

  #visita-interno .visita-page__meta {
    flex-direction: column;
    gap: 1rem;
  }

  #visita-interno .visita-page__cover {
    padding: 40px 0;
  }

  #visita-interno .visita-page__content {
    padding: 40px 0;
  }

  #visita-interno .visita-page__section-title {
    font-size: 1.5rem;
  }

  #visita-interno .visita-page__description-card {
    padding: 1.5rem;
  }

  #visita-interno .visita-page__info-card,
  #visita-interno .visita-page__cta-card {
    padding: 1.5rem;
  }

  #visita-interno .visita-page__cta-title {
    font-size: 1.25rem;
  }
}

/* ============================================== */
/* PÁGINA: Contato - ConneCT                      */
/* ============================================== */

/* Hero Section */
#contato .contato__hero {
  background: linear-gradient(
    135deg,
    rgba(15, 92, 140, 0.05) 0%,
    rgba(84, 172, 191, 0.05) 100%
  );
  position: relative;
  overflow: hidden;
}

#contato .contato__hero::before {
  content: "";
  position: absolute;
  top: -50%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(
    circle,
    rgba(84, 172, 191, 0.1) 0%,
    transparent 70%
  );
  border-radius: 50%;
  z-index: 0;
}

#contato .contato__hero .container {
  position: relative;
  z-index: 1;
}

#contato .contato__hero-title {
  font-family: var(--font-primary);
  color: var(--azul-petroleo);
  line-height: 1.2;
}

#contato .contato__hero-highlight {
  color: var(--azul-principal);
  position: relative;
}

#contato .contato__hero-highlight::after {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 4px;
  background: linear-gradient(90deg, var(--azul-claro), var(--azul-principal));
  border-radius: 2px;
}

#contato .contato__hero-text {
  font-size: 1.125rem;
  line-height: 1.7;
}

/* Cards de Contato */
#contato .contato__card {
  border: 1px solid rgba(15, 92, 140, 0.1);
  transition: var(--transition-fast);
}

#contato .contato__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 10px 30px rgba(15, 92, 140, 0.15) !important;
  border-color: var(--azul-claro);
}

#contato .contato__card-icon-wrapper {
  width: 80px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  border-radius: 50%;
  box-shadow: 0 5px 20px rgba(15, 92, 140, 0.25);
  transition: var(--transition-fast);
}

#contato .contato__card:hover .contato__card-icon-wrapper {
  transform: rotate(360deg) scale(1.1);
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.35);
}

#contato .contato__card-icon {
  font-size: 2rem;
  color: white;
}

#contato .contato__card-title {
  color: var(--azul-petroleo);
}

#contato .contato__card-link {
  color: var(--azul-principal);
  text-decoration: none;
  font-weight: 500;
  transition: var(--transition-fast);
}

#contato .contato__card-link:hover {
  color: var(--azul-claro);
  transform: translateX(5px);
}

#contato .contato__social-links {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}

#contato .contato__social-link {
  display: inline-flex;
  align-items: center;
  padding: 0.75rem 1.5rem;
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  color: white;
  text-decoration: none;
  border-radius: 50px;
  font-weight: 600;
  transition: var(--transition-fast);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.2);
}

#contato .contato__social-link:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.35);
  color: white;
}

#contato .contato__social-link i {
  font-size: 1.5rem;
}

/* Formulário */
#contato .contato__form-wrapper {
  border: 1px solid rgba(15, 92, 140, 0.1);
}

#contato .contato__form-title {
  color: var(--azul-petroleo);
}

#contato .contato__form .form-control,
#contato .contato__form .form-select {
  border: 2px solid rgba(15, 92, 140, 0.2);
  transition: var(--transition-fast);
  height: 75px;
}

#contato .contato__form .form-control:focus,
#contato .contato__form .form-select:focus {
  border-color: var(--azul-principal);
  box-shadow: 0 0 0 0.25rem rgba(15, 92, 140, 0.15);
}

#contato .contato__form .form-floating > label {
  color: var(--azul-petroleo);
}

#contato .contato__form-btn {
  background: linear-gradient(135deg, var(--azul-claro), var(--azul-principal));
  color: white;
  border: none;
  font-weight: 600;
  letter-spacing: 0.5px;
  transition: var(--transition-fast);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.25);
}

#contato .contato__form-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(15, 92, 140, 0.35);
}

#contato .contato__form-btn:active {
  transform: translateY(-1px);
}

#contato .contato__form-btn i {
  transition: var(--transition-fast);
}

#contato .contato__form-btn:hover i {
  transform: translateX(5px);
}

/* Alertas */
.c-alert {
  display: none;
  padding: 1rem 1.5rem;
  border-radius: 0.5rem;
  margin-bottom: 1.5rem;
  align-items: center;
  font-weight: 500;
}

.c-alert--show {
  display: flex;
}

.c-alert--success {
  background-color: rgba(15, 92, 140, 0.1);
  border: 2px solid var(--azul-principal);
  color: var(--azul-petroleo);
}

.c-alert--error {
  background-color: rgba(220, 53, 69, 0.1);
  border: 2px solid #dc3545;
  color: #842029;
}

.c-alert i {
  font-size: 1.25rem;
}

/* Mapa */
#contato .contato__map-title {
  color: var(--azul-petroleo);
}

#contato .contato__map-wrapper {
  border: 3px solid var(--azul-claro);
}

#contato .contato__map-wrapper iframe {
  display: block;
}

/* Responsividade */
@media (max-width: 991.98px) {
  #contato .contato__hero-title {
    font-size: 2.5rem;
  }

  #contato .contato__card-icon-wrapper {
    width: 70px;
    height: 70px;
  }

  #contato .contato__card-icon {
    font-size: 1.75rem;
  }
}

@media (max-width: 767.98px) {
  #contato .contato__hero-title {
    font-size: 2rem;
  }

  #contato .contato__hero-text {
    font-size: 1rem;
  }

  #contato .contato__form-wrapper {
    padding: 1.5rem !important;
  }

  #contato .contato__map-wrapper iframe {
    height: 300px;
  }

  #contato .contato__social-link {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
  }

  #contato .contato__social-link i {
    font-size: 1.25rem;
  }
}

@media (max-width: 575.98px) {
  #contato .contato__hero {
    padding: 3rem 0 !important;
  }

  #contato .contato__hero-title {
    font-size: 1.75rem;
  }

  #contato .contato__card {
    padding: 1.5rem !important;
  }

  #contato .contato__form-btn {
    width: 100%;
  }
}

/* ============================================== */
/* PÁGINA: Cadastro - ConneCT                     */
/* ============================================== */

#cadastro {
  padding: 80px 0;
  background: linear-gradient(135deg, var(--branco-gelo) 0%, #ffffff 100%);
  position: relative;
  overflow: hidden;
}

/* Decoração de fundo */
#cadastro::before {
  content: "";
  position: absolute;
  top: -50px;
  right: -50px;
  width: 300px;
  height: 300px;
  background: linear-gradient(135deg, var(--azul-suave) 0%, transparent 70%);
  border-radius: 50%;
  opacity: 0.3;
  animation: float 6s ease-in-out infinite;
}

#cadastro::after {
  content: "";
  position: absolute;
  bottom: -100px;
  left: -100px;
  width: 400px;
  height: 400px;
  background: linear-gradient(135deg, var(--azul-claro) 0%, transparent 70%);
  border-radius: 50%;
  opacity: 0.2;
  animation: float-reverse 8s ease-in-out infinite;
}

#cadastro .container {
  position: relative;
  z-index: 2;
}

/* Hero Section */
#cadastro .cadastro__hero {
  margin-bottom: 3rem;
}

#cadastro .cadastro__hero-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-preto);
  margin-bottom: 1rem;
}

#cadastro .cadastro__hero-highlight {
  color: var(--azul-principal);
  position: relative;
  display: inline-block;
}

#cadastro .cadastro__hero-text {
  font-size: 1.125rem;
  color: var(--azul-petroleo);
  line-height: 1.8;
}

/* Form Card */
#cadastro .cadastro__form-card {
  background: white;
  border-radius: 15px;
  padding: 3rem;
  box-shadow: 0 10px 40px rgba(0, 8, 13, 0.1);
  transition: var(--transition-fast);
}

#cadastro .cadastro__form-card:hover {
  box-shadow: 0 15px 50px rgba(0, 8, 13, 0.15);
  transform: translateY(-5px);
}

/* Form Groups */
#cadastro .form-group {
  margin-bottom: 1.5rem;
}

#cadastro .form-group label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  font-size: 0.95rem;
}

#cadastro .form-group input,
#cadastro .form-group select {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 2px solid #e0e0e0;
  border-radius: 8px;
  font-size: 1rem;
  transition: var(--transition-fast);
  background-color: var(--branco-gelo);
}

#cadastro .form-group input:focus,
#cadastro .form-group select:focus {
  outline: none;
  border-color: var(--azul-principal);
  background-color: white;
  box-shadow: 0 0 0 3px rgba(15, 92, 140, 0.1);
}

/* Cards de Tipo de Usuário */
#cadastro .tipo-usuario-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 0.5rem;
}

#cadastro .tipo-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1rem 0.75rem;
  border: 2px solid #e0e0e0;
  border-radius: 12px;
  cursor: pointer;
  transition: var(--transition-fast);
  background-color: white;
  min-height: 80px;
  text-align: center;
}

#cadastro .tipo-card i {
  display: block;
  font-size: 1.5rem;
  color: var(--azul-petroleo);
  margin-bottom: 0.5rem;
  transition: var(--transition-fast);
}

#cadastro .tipo-card span {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  transition: var(--transition-fast);
  margin-top: 0.25rem;
}

#cadastro .tipo-card:hover {
  border-color: var(--azul-principal);
  background-color: var(--branco-gelo);
  transform: translateY(-3px);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.15);
}

#cadastro input[type="radio"]:checked + .tipo-card {
  border-color: var(--azul-principal);
  background-color: var(--azul-principal);
  box-shadow: 0 4px 20px rgba(15, 92, 140, 0.3);
}

#cadastro input[type="radio"]:checked + .tipo-card i,
#cadastro input[type="radio"]:checked + .tipo-card span {
  color: white;
}

/* Password Wrapper */
#cadastro .password-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

#cadastro .password-wrapper input {
  padding-right: 3rem;
}

#cadastro .toggle-password {
  position: absolute;
  right: 0.75rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  color: var(--azul-petroleo);
  font-size: 1.2rem;
  transition: var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

#cadastro .toggle-password:hover {
  color: var(--azul-principal);
}

#cadastro .toggle-password i {
  pointer-events: none;
}

/* Campos Dinâmicos */
#cadastro .campo-dinamico {
  display: none;
  animation: fadeIn 0.3s ease;
}

#cadastro .campo-dinamico.active {
  display: block;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(-10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Botões */
#cadastro .btn-cadastrar {
  width: 100%;
  padding: 1rem;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 1.1rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition-fast);
  position: relative;
  overflow: hidden;
}

#cadastro .btn-cadastrar::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.3),
    transparent
  );
  transition: var(--transition-medium);
}

#cadastro .btn-cadastrar:hover::before {
  left: 100%;
}

#cadastro .btn-cadastrar:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 25px rgba(15, 92, 140, 0.4);
}

#cadastro .btn-cadastrar:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

#cadastro .btn-cadastrar i {
  transition: var(--transition-fast);
}

/* Alertas */
#cadastro .alert {
  padding: 1rem 1.5rem;
  margin-bottom: 1.5rem;
  border-radius: 8px;
  display: none;
  animation: slideDown 0.3s ease;
}

@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#cadastro .alert-success {
  background: #d4edda;
  color: #155724;
  border: 2px solid #c3e6cb;
}

#cadastro .alert-error {
  background: #f8d7da;
  color: #721c24;
  border: 2px solid #f5c6cb;
}

/* Termo de Adesão */
#cadastro .termo-subtitulo {
  font-size: 0.92rem;
  color: var(--azul-petroleo);
  line-height: 1.6;
  margin-bottom: 1rem;
  font-style: italic;
}

#cadastro .termo-scroll-box {
  border: 2px solid #e0e0e0;
  border-radius: 8px;
  padding: 1rem 1.25rem;
  height: 220px;
  overflow-y: scroll;
  background-color: var(--branco-gelo);
  font-size: 0.875rem;
  color: #444;
  line-height: 1.65;
  scroll-behavior: smooth;
  transition: border-color 0.2s;
}

#cadastro .termo-scroll-box:focus {
  outline: none;
  border-color: var(--azul-principal);
}

#cadastro .termo-scroll-box p {
  margin-bottom: 0.75rem;
}

#cadastro .termo-scroll-box p:last-child {
  margin-bottom: 0;
}

#cadastro .termo-aceite {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-top: 0.85rem;
  padding: 0.75rem 1rem;
  background-color: #f0f7ff;
  border: 1px solid #c5dff0;
  border-radius: 8px;
}

#cadastro .termo-aceite input[type="checkbox"] {
  width: 18px;
  height: 18px;
  min-width: 18px;
  cursor: pointer;
  accent-color: var(--azul-principal);
}

#cadastro .termo-aceite label {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--azul-petroleo);
  cursor: pointer;
}

/* Links */
#cadastro .link-login {
  text-align: center;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid #e0e0e0;
}

#cadastro .link-login a {
  color: var(--azul-principal);
  text-decoration: none;
  font-weight: 500;
  transition: var(--transition-fast);
}

#cadastro .link-login a:hover {
  color: var(--azul-claro);
  text-decoration: underline;
}

/* Responsividade */
@media (max-width: 991.98px) {
  #cadastro .cadastro__hero-title {
    font-size: 2rem;
  }

  #cadastro .cadastro__form-card {
    padding: 2rem;
  }
}

@media (max-width: 767.98px) {
  #cadastro {
    padding: 50px 0;
  }

  #cadastro .cadastro__hero-title {
    font-size: 1.75rem;
  }

  #cadastro .cadastro__form-card {
    padding: 1.5rem;
  }

  #cadastro .form-group input,
  #cadastro .form-group select {
    font-size: 0.95rem;
  }

  #cadastro .tipo-card {
    min-height: 100px;
    padding: 1.25rem 1rem;
  }

  #cadastro .tipo-card i {
    font-size: 1.75rem;
  }

  #cadastro .toggle-password {
    font-size: 1.1rem;
  }
}

@media (max-width: 575.98px) {
  #cadastro .tipo-card {
    padding: 1rem 0.75rem;
  }

  #cadastro .tipo-card i {
    font-size: 1.5rem;
  }

  #cadastro .tipo-card span {
    font-size: 0.875rem;
  }
}

/* ============================================== */
/* PÁGINA: Recuperar Senha - ConneCT              */
/* ============================================== */

#recuperar-senha {
  padding: 80px 0;
  background: linear-gradient(135deg, var(--branco-gelo) 0%, #ffffff 100%);
  position: relative;
  overflow: hidden;
}

/* Decoração de fundo */
#recuperar-senha::before {
  content: "";
  position: absolute;
  top: -50px;
  right: -50px;
  width: 300px;
  height: 300px;
  background: linear-gradient(135deg, var(--azul-suave) 0%, transparent 70%);
  border-radius: 50%;
  opacity: 0.3;
  animation: float 6s ease-in-out infinite;
}

#recuperar-senha::after {
  content: "";
  position: absolute;
  bottom: -100px;
  left: -100px;
  width: 400px;
  height: 400px;
  background: linear-gradient(135deg, var(--azul-claro) 0%, transparent 70%);
  border-radius: 50%;
  opacity: 0.2;
  animation: float-reverse 8s ease-in-out infinite;
}

#recuperar-senha .container {
  position: relative;
  z-index: 2;
}

/* Hero Section */
#recuperar-senha .recuperacao__hero {
  margin-bottom: 3rem;
}

#recuperar-senha .recuperacao__hero-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--azul-preto);
  margin-bottom: 1rem;
}

#recuperar-senha .recuperacao__hero-highlight {
  color: var(--azul-principal);
  position: relative;
  display: inline-block;
}

#recuperar-senha .recuperacao__hero-text {
  font-size: 1.125rem;
  color: var(--azul-petroleo);
  line-height: 1.8;
}

/* Form Card */
#recuperar-senha .recuperacao__form-card {
  background: white;
  border-radius: 15px;
  padding: 3rem;
  box-shadow: 0 10px 40px rgba(0, 8, 13, 0.1);
  transition: var(--transition-fast);
}

#recuperar-senha .recuperacao__form-card:hover {
  box-shadow: 0 15px 50px rgba(0, 8, 13, 0.15);
  transform: translateY(-5px);
}

/* Form Groups */
#recuperar-senha .form-group {
  margin-bottom: 1.5rem;
}

#recuperar-senha .form-group label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  font-size: 0.95rem;
}

#recuperar-senha .form-group input,
#recuperar-senha .form-group select {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 2px solid #e0e0e0;
  border-radius: 8px;
  font-size: 1rem;
  transition: var(--transition-fast);
  background-color: var(--branco-gelo);
}

#recuperar-senha .form-group input:focus,
#recuperar-senha .form-group select:focus {
  outline: none;
  border-color: var(--azul-principal);
  background-color: white;
  box-shadow: 0 0 0 3px rgba(15, 92, 140, 0.1);
}

#recuperar-senha .form-group small {
  display: block;
  margin-top: 0.5rem;
  color: #666;
  font-size: 0.875rem;
}

/* Botões */
#recuperar-senha .btn-enviar,
#recuperar-senha .btn-redefinir {
  width: 100%;
  padding: 1rem;
  background: linear-gradient(135deg, var(--azul-principal), var(--azul-claro));
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 1.1rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition-fast);
  position: relative;
  overflow: hidden;
  margin-bottom: 0.5rem;
}

#recuperar-senha .btn-enviar::before,
#recuperar-senha .btn-redefinir::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.3),
    transparent
  );
  transition: var(--transition-medium);
}

#recuperar-senha .btn-enviar:hover::before,
#recuperar-senha .btn-redefinir:hover::before {
  left: 100%;
}

#recuperar-senha .btn-enviar:hover,
#recuperar-senha .btn-redefinir:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 25px rgba(15, 92, 140, 0.4);
}

#recuperar-senha .btn-enviar:disabled,
#recuperar-senha .btn-redefinir:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none;
}

#recuperar-senha .btn-voltar {
  width: 100%;
  padding: 1rem;
  background: #757575;
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition-fast);
  margin-top: 0.5rem;
}

#recuperar-senha .btn-voltar:hover {
  background: #616161;
  transform: translateY(-2px);
}

/* Alternância de Formulários */
#recuperar-senha #form-codigo {
  display: none;
  animation: fadeIn 0.3s ease;
}

/* Alertas */
#recuperar-senha .alert {
  padding: 1rem 1.5rem;
  margin-bottom: 1.5rem;
  border-radius: 8px;
  display: none;
  animation: slideDown 0.3s ease;
}

#recuperar-senha .alert-success {
  background: #d4edda;
  color: #155724;
  border: 2px solid #c3e6cb;
}

#recuperar-senha .alert-error {
  background: #f8d7da;
  color: #721c24;
  border: 2px solid #f5c6cb;
}

/* Links */
#recuperar-senha .link-voltar {
  text-align: center;
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid #e0e0e0;
}

#recuperar-senha .link-voltar a {
  color: var(--azul-principal);
  text-decoration: none;
  font-weight: 500;
  transition: var(--transition-fast);
}

#recuperar-senha .link-voltar a:hover {
  color: var(--azul-claro);
  text-decoration: underline;
}

/* Cards de Tipo de Usuário */
#recuperar-senha .tipo-usuario-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 0.5rem;
}

#recuperar-senha .tipo-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1rem 0.75rem;
  border: 2px solid #e0e0e0;
  border-radius: 12px;
  cursor: pointer;
  transition: var(--transition-fast);
  background-color: white;
  min-height: 80px;
  text-align: center;
}

#recuperar-senha .tipo-card i {
  display: block;
  font-size: 1.5rem;
  color: var(--azul-petroleo);
  margin-bottom: 0.5rem;
  transition: var(--transition-fast);
}

#recuperar-senha .tipo-card span {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  transition: var(--transition-fast);
  margin-top: 0.25rem;
}

#recuperar-senha .tipo-card:hover {
  border-color: var(--azul-principal);
  background-color: var(--branco-gelo);
  transform: translateY(-3px);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.15);
}

#recuperar-senha input[type="radio"]:checked + .tipo-card {
  border-color: var(--azul-principal);
  background-color: var(--azul-principal);
  box-shadow: 0 4px 20px rgba(15, 92, 140, 0.3);
}

#recuperar-senha input[type="radio"]:checked + .tipo-card i,
#recuperar-senha input[type="radio"]:checked + .tipo-card span {
  color: white;
}

/* Cards de Tipo de Usuário */
#recuperar-senha .tipo-usuario-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 0.5rem;
}

#recuperar-senha .tipo-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1rem 0.75rem;
  border: 2px solid #e0e0e0;
  border-radius: 12px;
  cursor: pointer;
  transition: var(--transition-fast);
  background-color: white;
  min-height: 80px;
  text-align: center;
}

#recuperar-senha .tipo-card i {
  display: block;
  font-size: 1.5rem;
  color: var(--azul-petroleo);
  margin-bottom: 0.5rem;
  transition: var(--transition-fast);
}

#recuperar-senha .tipo-card span {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--azul-petroleo);
  transition: var(--transition-fast);
  margin-top: 0.25rem;
}

#recuperar-senha .tipo-card:hover {
  border-color: var(--azul-principal);
  background-color: var(--branco-gelo);
  transform: translateY(-3px);
  box-shadow: 0 4px 15px rgba(15, 92, 140, 0.15);
}

#recuperar-senha input[type="radio"]:checked + .tipo-card {
  border-color: var(--azul-principal);
  background-color: var(--azul-principal);
  box-shadow: 0 4px 20px rgba(15, 92, 140, 0.3);
}

#recuperar-senha input[type="radio"]:checked + .tipo-card i,
#recuperar-senha input[type="radio"]:checked + .tipo-card span {
  color: white;
}

/* Password Wrapper */
#recuperar-senha .password-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

#recuperar-senha .password-wrapper input {
  padding-right: 3rem;
}

#recuperar-senha .toggle-password {
  position: absolute;
  right: 0.75rem;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem;
  color: var(--azul-petroleo);
  font-size: 1.2rem;
  transition: var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}

#recuperar-senha .toggle-password:hover {
  color: var(--azul-principal);
}

#recuperar-senha .toggle-password i {
  pointer-events: none;
}

/* Responsividade para os cards */
@media (max-width: 767.98px) {
  #recuperar-senha .tipo-card {
    min-height: 70px;
    padding: 0.75rem 0.5rem;
  }

  #recuperar-senha .tipo-card i {
    font-size: 1.25rem;
  }

  #recuperar-senha .tipo-card span {
    font-size: 0.8rem;
  }
}

@media (max-width: 575.98px) {
  #recuperar-senha .tipo-card {
    padding: 0.5rem 0.25rem;
  }

  #recuperar-senha .tipo-card i {
    font-size: 1rem;
  }

  #recuperar-senha .tipo-card span {
    font-size: 0.75rem;
  }
}

/* Responsividade para os cards */
@media (max-width: 767.98px) {
  #recuperar-senha .tipo-card {
    min-height: 70px;
    padding: 0.75rem 0.5rem;
  }

  #recuperar-senha .tipo-card i {
    font-size: 1.25rem;
  }

  #recuperar-senha .tipo-card span {
    font-size: 0.8rem;
  }
}

@media (max-width: 575.98px) {
  #recuperar-senha .tipo-card {
    padding: 0.5rem 0.25rem;
  }

  #recuperar-senha .tipo-card i {
    font-size: 1rem;
  }

  #recuperar-senha .tipo-card span {
    font-size: 0.75rem;
  }
}

/* Responsividade */
@media (max-width: 991.98px) {
  #recuperar-senha .recuperacao__hero-title {
    font-size: 2rem;
  }

  #recuperar-senha .recuperacao__form-card {
    padding: 2rem;
  }
}

@media (max-width: 767.98px) {
  #recuperar-senha {
    padding: 50px 0;
  }

  #recuperar-senha .recuperacao__hero-title {
    font-size: 1.75rem;
  }

  #recuperar-senha .recuperacao__form-card {
    padding: 1.5rem;
  }

  #recuperar-senha .form-group input,
  #recuperar-senha .form-group select {
    font-size: 0.95rem;
  }
}

/* ============================================
           PRIVACIDADE PAGE
        ============================================ */
#privacidade .privacidade__hero {
  background: linear-gradient(
    135deg,
    var(--azul-petroleo) 0%,
    var(--azul-principal) 100%
  );
  padding: 80px 0 60px;
  color: #fff;
}

#privacidade .privacidade__hero-title {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  color: #fff;
  margin-bottom: 1rem;
}

#privacidade .privacidade__hero-highlight {
  color: var(--azul-claro);
}

#privacidade .privacidade__hero-text {
  font-size: 1.1rem;
  color: rgba(255, 255, 255, 0.85);
  max-width: 640px;
  margin: 0 auto;
}

#privacidade .privacidade__content-section {
  padding: 70px 0;
  background: #fff;
}

#privacidade .privacidade__card {
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 4px 32px rgba(15, 92, 140, 0.08);
  padding: 48px;
}

@media (max-width: 767px) {
  #privacidade .privacidade__card {
    padding: 28px 20px;
  }
}

#privacidade .privacidade__section-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(15, 92, 140, 0.08);
  color: var(--azul-principal);
  font-family: var(--font-heading);
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 6px 16px;
  border-radius: 50px;
  margin-bottom: 20px;
}

#privacidade .privacidade__title {
  font-family: var(--font-heading);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 700;
  color: var(--azul-petroleo);
  margin-bottom: 1.5rem;
}

#privacidade .privacidade__title span {
  color: var(--azul-principal);
}

#privacidade .privacidade__text {
  font-family: var(--font-primary);
  font-size: 1rem;
  line-height: 1.9;
  color: #4a5568;
}

#privacidade .privacidade__divider {
  border: none;
  border-top: 2px solid rgba(15, 92, 140, 0.1);
  margin: 32px 0;
}

#privacidade .privacidade__update {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.85rem;
  color: #718096;
  margin-top: 8px;
}

#privacidade .privacidade__update i {
  color: var(--azul-claro);
}

#privacidade .privacidade__empty {
  text-align: center;
  padding: 60px 20px;
  color: #718096;
}

#privacidade .privacidade__empty i {
  font-size: 3rem;
  color: var(--azul-claro);
  display: block;
  margin-bottom: 16px;
}
