/* ===== SOURCE: responsive-fixes.css ===== */
/* Correções gerais de responsividade */
@media (max-width: 991px) {
  .container {
    padding: 0 20px;
  }

  h1 {
    font-size: 2.2rem;
  }

  h2 {
    font-size: 1.8rem;
  }

  .section {
    padding: 60px 0;
  }
}

@media (max-width: 768px) {
  /* Ajustes para o hero */
  .hero {
    min-height: auto;
    padding-top: 120px;
    padding-bottom: 60px;
  }

  .hero-content {
    flex-direction: column;
    gap: 40px;
  }

  .hero-text-content {
    order: 1;
    text-align: center;
  }

  .hero-img-container {
    order: 2;
    max-width: 100%;
    margin: 0 auto;
  }

  .hero-stats {
    justify-content: center;
  }

  .hero-btns {
    justify-content: center;
  }

  /* Ajustes para outras seções */
  .steps-container,
  .services-grid,
  .differentials-grid,
  .results-cards {
    grid-template-columns: 1fr;
  }

  .about-content {
    grid-template-columns: 1fr;
  }

  .about-text {
    margin-left: 0;
    padding-left: 0;
  }

  .about-img {
    margin: 0 auto;
    max-width: 80%;
  }

  /* Ajustes para o portfólio */
  .portfolio-gallery {
    height: 400px;
  }

  /* Ajustes para visualização de dados */
  .data-viz-container {
    padding: 20px;
  }

  .data-chart {
    height: 300px;
  }
}

@media (max-width: 576px) {
  h1 {
    font-size: 1.8rem;
  }

  h2 {
    font-size: 1.5rem;
  }

  .hero-stat {
    min-width: 100px;
    padding: 10px;
  }

  .hero-stat-number {
    font-size: 1.5rem;
  }

  .hero-stat-text {
    font-size: 0.75rem;
  }

  .btn-primary,
  .btn-secondary {
    padding: 12px 25px;
    font-size: 0.9rem;
  }

  .portfolio-gallery {
    height: 300px;
  }

  .portfolio-controls {
    flex-direction: column;
    gap: 15px;
  }

  .portfolio-nav-btn {
    width: 40px;
    height: 40px;
  }

  .data-chart {
    height: 250px;
  }
}


/* ===== SOURCE: mobile-menu-fix.css ===== */
/* Correções para o menu mobile */
@media (max-width: 991px) {

  /* Esconder links de navegação no desktop */
  .nav-links {
    display: none;
  }

  /* Mostrar botão de toggle do menu */
  .mobile-menu-toggle {
    display: block !important;
    background: transparent;
    border: none;
    color: var(--text-primary);
    font-size: 1.5rem;
    cursor: pointer;
    padding: 5px;
    margin-left: auto;
  }

  /* Ajustes para o menu mobile */
  .mobile-menu {
    position: fixed;
    top: var(--navbar-height);
    right: -100%;
    width: 100%;
    max-width: 300px;
    height: calc(100vh - var(--navbar-height));
    background: rgba(5, 8, 15, 0.95);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    z-index: 1001;
    transition: right 0.3s ease;
    padding: 20px;
    box-shadow: -5px 0 25px rgba(0, 0, 0, 0.5);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
  }

  .mobile-menu.active {
    right: 0;
  }

  /* Ajustes para o botão de contato no navbar */
  .btn-contact {
    display: none;
  }

  /* Garantir que o logo não seja muito grande */
  .logo {
    font-size: 1.5rem;
  }
}

/* Ajustes para dispositivos muito pequenos */
@media (max-width: 576px) {
  .navbar .container {
    padding: 0 15px;
  }

  .logo {
    font-size: 1.3rem;
  }

  .mobile-menu {
    max-width: 100%;
  }
}

/* Ajustes para o tema claro */
[data-theme="light"] .mobile-menu {
  background: rgba(240, 248, 255, 0.95);
}

/* Melhorar a visibilidade dos links no menu mobile */
.mobile-nav-link {
  display: block;
  padding: 15px 0;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--text-primary);
  border-bottom: 1px solid rgba(240, 248, 255, 0.1);
  transition: all 0.3s ease;
}

.mobile-nav-link:hover {
  color: var(--accent);
  padding-left: 10px;
}

/* Botão de contato no menu mobile */
.mobile-cta {
  margin-top: auto;
  width: 100%;
}

/* Ajustes para o botão de fechar o menu mobile */
.mobile-menu-close {
  background: transparent;
  border: none;
  color: var(--text-primary);
  font-size: 1.5rem;
  cursor: pointer;
  padding: 5px;
  position: absolute;
  top: 15px;
  right: 15px;
}

/* ===== SOURCE: mobile-global-fix.css ===== */
/* =============================================
   MOBILE GLOBAL FIX — Minimal & Targeted
   Último CSS carregado — tem prioridade natural
   ============================================= */

/* Prevenir scroll horizontal */
html,
body {
    overflow-x: hidden;
    width: 100%;
}

/* Touch devices — desativar cursor custom */
@media (hover: none) and (pointer: coarse) {

    .custom-cursor,
    .custom-cursor-follower {
        display: none !important;
    }

    body {
        cursor: auto !important;
    }
}

/* ==============================
   TABLET e MOBILE (até 991px)
   ============================== */
@media (max-width: 991px) {

    /* Hero: empilhar texto + code em coluna */
    .hero-content {
        flex-direction: column;
        gap: 30px;
    }

    .hero-text-content {
        flex: 1 1 100%;
        order: 1;
        text-align: center;
    }

    .hero-img-container {
        flex: 1 1 100%;
        order: 2;
        max-width: 100%;
        perspective: none;
    }

    .hero-img-container img {
        transform: none;
    }

    /* Limitar bg elements que vazam */
    .hero-bg-1 {
        width: 300px;
        height: 300px;
        left: -50px;
        top: -100px;
    }

    .hero-bg-2 {
        width: 200px;
        height: 200px;
        right: -30px;
    }

    .hero-bg-3 {
        width: 150px;
        height: 150px;
    }

    /* Stats em wrap */
    .hero-stats {
        flex-wrap: wrap;
        justify-content: center;
    }

    /* Botões em wrap */
    .hero-btns {
        flex-wrap: wrap;
        justify-content: center;
    }

    /* Hero badge */
    .hero-badge {
        right: 10px;
    }

    /* About: coluna única */
    .about-content {
        grid-template-columns: 1fr;
    }

    .about-img {
        max-width: 100%;
    }

    /* Grids em coluna */
    .services-grid,
    .differentials-grid,
    .results-cards,
    .steps-container {
        grid-template-columns: 1fr;
    }

    /* Floating badges do terminal — podem vazar */
    .floating-badges {
        display: none;
    }

    /* Footer */
    .footer-content {
        grid-template-columns: 1fr;
    }

    /* Fix para o CTA do menu mobile não sobrepor o Chatwoot */
    .mobile-cta {
        margin-bottom: 90px !important;
        display: block;
        /* Garantir que margin funcione */
        width: fit-content;
        margin-left: auto;
        margin-right: auto;
    }

    .mobile-nav {
        padding-bottom: 40px;
    }
}

/* ==============================
   MOBILE PEQUENO (até 576px)
   ============================== */
@media (max-width: 576px) {
    .hero {
        padding-top: 100px;
        padding-bottom: 40px;
    }

    .hero h1,
    .creative-text {
        font-size: 1.5rem;
        line-height: 1.3;
    }

    .hero-subtitle {
        font-size: 0.9rem;
    }

    .hero-stat {
        min-width: 80px;
        padding: 8px;
    }

    .hero-stat-number {
        font-size: 1.3rem;
    }

    .hero-stat-text {
        font-size: 0.7rem;
    }

    /* Code animation menor */
    .code-animation-container,
    .code-window {
        max-width: 100%;
    }

    .code-content {
        font-size: 0.7rem;
        padding: 15px;
    }

    /* Terminal menor */
    .terminal-body {
        font-size: 0.7rem;
        padding: 12px;
        min-height: 200px;
    }

    /* About badge */
    .about-experience-badge {
        position: relative;
        right: auto;
        bottom: auto;
        margin-top: 15px;
        text-align: center;
    }
}

/* ==============================
   TELAS MUITO PEQUENAS (até 375px)
   ============================== */
@media (max-width: 375px) {

    .hero h1,
    .creative-text {
        font-size: 1.25rem;
    }

    .hero-stats {
        gap: 5px;
    }

    .hero-stat {
        min-width: 70px;
    }

    .logo a {
        font-size: 0.8rem;
    }
}
