@import url('https://fonts.googleapis.com/css2?family=Calistoga&family=Chango&family=Chela+One&family=Courgette&family=Edu+AU+VIC+WA+NT+Hand:wght@400..700&family=Grand+Hotel&family=Great+Vibes&family=Leckerli+One&family=Pattaya&family=Playwrite+NO&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=REM:ital,wght@0,100..900;1,100..900&family=Raleway:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&family=Rufina:wght@400;700&family=Satisfy&family=Sevillana&family=Titan+One&display=swap');
:root {
    --primary-blue: #1e40af;
    --azul-escuro: #172754;
    --primary-red: #dc2626;
    --light-blue: #3b82f6;
    --light-red: #ef4444;
    --dark-blue: #1e3a8a;
    --gradient-bg: linear-gradient(135deg, var(--azul-escuro) 0%, var(--primary-red) 100%);
    --primary-blue: #bfcffe;     
    --terciaria-vermelho: #c60f19;    
    --secondary-color:#b7cdff;
    --neutral-azul: #f2f4ff;     
    --neutral-sand: #fef2e8;      
     --accent-sage: #B7C4B4;      
    --lilas-claro:#eee4f0;
    --cinza:#6f6f6f;
    --neutral-light: #dbe4fe;     
    --neutral-dark:#3f2942;     
    --background-gradient: linear-gradient(135deg, var(--neutral-light), var(--neutral-light));
}

body {
    font-family: 'Poppins', sans-serif;
    color: var(--light-color);
    background: var(--neutral-azul);
    overflow-x: hidden; /* Esta linha remove a barra de rolagem horizontal */
   
}

.py-5{
    background: var(--primary-color);
}


.text-center h2{
    margin-top: 30px;
    font-size: 2rem;
    color: #ffffff;
    font-family: "Poppins", 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    
}

.text-muted{
    color: #363636 !important;
    text-align: justify;
}

h2{
     font-family: "Poppins", 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 1.5rem;
    font-style: normal;
    font-weight: bold;
    color:var(--primary-color);
}

.text-h2 h2{
    color:#ffffff;
    font-family: "Poppins" system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
    font-size: 2rem;
    text-align: center;
    font-weight: bold;

}

.navbar {
    transition: background-color 0.3s ease;
    
}

.navbar.scrolled {
    background-color: #f2f4ff;
}

.nav-item .nav-link {
    position: relative;
    color: #0d0764 !important;
}

.nav-item .nav-link::after {
    content: '';
    position: absolute;
    width:0;
    height: 2px;
    bottom: 0;
    left: 0;
    background-color: #ff0000;
    transition: width 0.3s ease;
}

.nav-link:hover::after {
    width: 100%;
}


/* Estilização do botão toggle */
.navbar-toggler {
   border: none;
   background-color: transparent;
    position: relative;
    width: 40px;
    height: 40px;
    padding: 0;
  }

.navbar-toggler:focus {
    box-shadow: none;
  }

.navbar-toggler .navbar-toggler-icon {
    background-image: none !important;
    position: relative;
    height: 2px;
    width: 24px;
    background-color: var(--primary-blue);
    transition: all 0.3s ease;
    
  }

.navbar-toggler .navbar-toggler-icon::before,
.navbar-toggler .navbar-toggler-icon::after {
    content: "";
    position: absolute;
    height: 2px;
    width: 24px;
    background-color:var(--primary-blue);
    transition: all 0.3s ease;
    
  }

.navbar-toggler .navbar-toggler-icon::before {
    top: -5px;
   
  }

.navbar-toggler .navbar-toggler-icon::after {
    bottom: -5px;
    
  }

.navbar-toggler[aria-expanded="true"] .navbar-toggler-icon {
    background-color: transparent;
  }

.navbar-toggler[aria-expanded="true"] .navbar-toggler-icon::before {
    transform: translateY(8px) rotate(45deg);
    background-color: var(--primary-blue);
  }

.navbar-toggler[aria-expanded="true"] .navbar-toggler-icon::after {
    transform: translateY(-8px) rotate(-45deg);
    background-color: var(--primary-blue);
  }

      
.mobile-search {
    display: none;
}

h3, h4{
    margin-top: 20px;
    margin-left:10px;
    font-family: "Poppins", 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 1.5rem;
    font-style: normal;
    font-weight: bold;
    color:var(--primary-color);
}

.text-p {
  color: white;           /* Cor branca */
  text-decoration: none;  /* Sem riscado */
  cursor: pointer;        /* Cursor padrão de link */
}


/* Estado ao passar o mouse */
.text-p:hover {
  color: yellow;          /* Cor amarela ao passar o mouse */
}

/* Estado ao clicar */
.text-p:active {
  color: yellow;          /* Cor amarela ao clicar */
}




.social-media h5{
    margin-top: 20px;
    margin-left:10px;
    font-family: "Poppins", 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 1.5rem;
    font-style: normal;
    font-weight: bold;
    color:#ffffff;

}
.text-s h3{
    margin-top: 40px;
    margin-left:0px;
    font-family: "Poppins", 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 2rem;
    font-style: normal;
    color:#0d0764;

}

.appointment-btn{
    background-color:#e6e4ff;
    text-decoration: none;
    color: #0d0764;    
    text-transform: uppercase;
    padding: 12px 15px;
    font-size: 16px;
    font-weight: 600;
    border: 2px solid var(--azul-escuro);
    border-radius: 50px;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(15, 39, 146, 0.842);
    white-space: nowrap;
    
}

.appointment-btn:hover {
    background-color:#0d0764;
    color: var(--lilas-claro);
    text-transform: uppercase;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(5, 31, 145, 0.846);
    background: linear-gradient(135deg, #d80e0e 0%, #011a87 100%);
    color: white;
    text-decoration: none;
    
}

.appointment-btn:active {
    transform: translateY(0);
    
}

.carousel-caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding-bottom: 40px; /* Espaçamento base */
    text-align: center;
    z-index: 10;
    
}

.listaprod a{
       width: 30%;
       position: absolute;
       margin-top: 50px;
       margin-left: 400px;
       text-align: center;
    }

.btn-container {
        display: flex;
        justify-content: center;
        width: 100%;
    }
    

.btn-saiba-mais {   
    margin-top: 30px;
    font-size: 16px;
    padding: 10px 20px;
    text-transform: uppercase;
    text-decoration: none;
    font-weight: bold;
    transition: all 0.3s ease;
    width: 20%;
    background-color: var(--azul-escuro);
    color: white;
    border-radius: 25px;
   
}

.btn-saiba-mais:hover {
    background-color:var(--secondary-color);
    color: var(--azul-escuro);
    padding: 10px 10px;
    border-radius: 25px;
    text-transform: uppercase;
    transition: all 0.3s ease;
    width: 20%;
}



.catalogo-p a{
    margin-top: -340px;
}

.top-bar {
    background-color: #0d0764;
    color: white;
    height: 70px;
    padding: 8px 0;
    font-size: 14px;
}



.carousel-item img {
    width: 100%;
    height: 60vh;
    object-fit: cover;
}

.logo {
    width: 30%;
   
}

.social-icon {
    color: white;
    margin: 0 5px;
    transition: color 0.3s ease;
}

.social-icon:hover {
    color:var(--primary-dark);
}

/*segurança*/

.hover-shadow {
    transition: all 0.3s ease;
    box-shadow: 0 4px 8px rgba(0,0,0,0.1);
}

.hover-shadow:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 16px rgba(0,0,0,0.2);
}

#quem-somos {
            padding: 60px 0;
            animation: slideInUp 0.8s ease-out;
        }

        @keyframes slideInUp {
            from {
                opacity: 0;
                transform: translateY(50px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }
.text-h3 h3 {
            font-size: 2.5rem;
            font-weight: 700;
            line-height: 1.4;
            margin-bottom: 25px;
            animation: fadeInLeft 0.8s ease-out;
        }

        /* Estilização do título com cores alternadas */
.text-h3 h3 .black-text {
            color: #000000;
        }

.text-h3 h3 .blue-text {
            color: #003366;
            font-weight: 800;
        }

.text-h3 p {
            font-size: 1rem;
            line-height: 1.8;
            margin-bottom: 20px;
            color: #666666;
            animation: fadeInLeft 1s ease-out 0.2s both;
        }

.text-h3 strong {
            font-size: 1.1rem;
            color: #003366;
            display: block;
            margin-top: 20px;
            margin-bottom: 15px;
            animation: fadeInLeft 1.2s ease-out 0.4s both;
        }

        @keyframes fadeInLeft {
            from {
                opacity: 0;
                transform: translateX(-30px);
            }
            to {
                opacity: 1;
                transform: translateX(0);
            }
        }
.text-s{
            font-size: 1.1rem;
            color: #003366;
            display: block;
            margin-top: 20px;
            margin-bottom: 15px;
            animation: fadeInLeft 1.2s ease-out 0.4s both;
        }

        @keyframes fadeInLeft {
            from {
                opacity: 0;
                transform: translateX(-30px);
            }
            to {
                opacity: 1;
                transform: translateX(0);
            }
        }


.image-gallery {
            animation: fadeInRight 0.8s ease-out 0.3s both;
        }

.main-image {
            position: relative;
            display: inline-block;
            width: 100%;
        }

.main-image img {
            width: 100%;
            height: auto;
            display: block;
            border-radius: 12px;
            transition: all 0.4s ease;
            position: relative;
            z-index: 2;
        }

  
        /* Detalhe de suspensão no lado direito */
.main-image::after {
            content: '';
            position: absolute;
            top: -5px;
            right: 0px;
            width: 100%;
            height: 15px;
            background: #003366;
            border-radius: 10px 10px 0 0;
            box-shadow: 0 -5px 15px rgba(0, 51, 102, 0.3);
            z-index: 1;
        }
        

.image-text-overlay{
            position: absolute;
            bottom:-20px;
            left: 0;
            right: 0;
            background: linear-gradient(180deg, rgba(0, 51, 102, 0) 0%, rgba(0, 51, 102, 0.95) 60%, #003366 100%);
            color: white;
            padding: 40px 25px 25px;
            border-radius: 0 0 12px 12px;
            z-index: 3;
            font-weight: 700;
            font-size: 1rem;
            line-height: 1.6;
            text-align: center;
            animation: fadeInUp 0.8s ease-out 0.6s both;
        }

        @keyframes fadeInUp {
            from {
                opacity: 0;
                transform: translateY(20px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

        /* Efeito de suspensão - correntes decorativas */
.main-image {
            position: relative;
            margin-top: 50px;
        }

.main-image::before {
            position: absolute;
            top: -60px;
            right: 40px;
            color: #003366;
            font-size: 20px;
            letter-spacing: 8px;
            z-index: 3;
        }

.main-image img:hover {
            transform: translateY(-8px);
            box-shadow: 0 20px 50px rgba(0, 0, 0, 0.15);
        }

        /* Efeito de sombra elevado */
.hover-shadow {
            box-shadow: 0 10px 30px rgba(0, 51, 102, 0.2);
        }
@media (max-width: 768px) {
            .text-h3 h3 {
                font-size: 1.8rem;
            }
                                
            .main-image::after {
              height: 100px;
              right: 20px;
            }

            .main-image::before {
                right: 25px;
            }
            .image-text-overlay strong{
                font-size: 0.8rem;
            }
            .nav-item .appointment-btn{
             background-color: #f2f4ff;
             color: #0d0764;    
             text-transform: uppercase;
             padding: 5px 5px;
             font-size: 15px;
             font-weight: 200;
             border-radius: 50px;
             cursor: pointer;
             transition: all 0.3s ease;
             box-shadow: 0 4px 15px rgba(15, 39, 146, 0.842);
            white-space: nowrap;
            margin-top: 0px;
            margin-bottom: 20px;
    
          }
          .col-lg-6 .appointment-btn{
             background-color: #f2f4ff;
             color: #0d0764;    
             text-transform: uppercase;
             padding: 12px 15px;
             font-size: 16px;
             font-weight: 400;
             border-radius: 50px;
             cursor: pointer;
             transition: all 0.3s ease;
             box-shadow: 0 4px 15px rgba(15, 39, 146, 0.842);
            white-space: nowrap;
            margin-top: 0px;
    
          }
            
        }

        @keyframes fadeInRight {
            from {
                opacity: 0;
                transform: translateX(30px);
            }
            to {
                opacity: 1;
                transform: translateX(0);
            }
        }

.header {
    background: var(--gradient-bg);
    color: white;
    padding: 2rem 0;
    box-shadow: 0 4px 20px rgba(0,0,0,0.1);
        }

.header h1 {
    font-size: 2.5rem;
    font-weight: 700;
    margin: 0;
    text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
    }

.header p {
    font-size: 1.2rem;
    margin: 0.5rem 0 0 0;
    opacity: 0.9;
    }


.btn-primary {
    background: var(--gradient-bg);
    border: none;
    border-radius: 25px;
    padding: 0.8rem 2rem;
    font-weight: 600;
    transition: all 0.3s ease;
    position: relative;
    overflow: hidden;
    }

.btn-primary:hover {
            transform: translateY(-2px);
            box-shadow: 0 8px 25px rgba(30, 64, 175, 0.4);
        }



.btn-outline-primary {
            border: 2px solid var(--primary-blue);
            color: var(--primary-blue);
            background: transparent;
            border-radius: 25px;
            padding: 0.8rem 2rem;
            font-weight: 600;
            transition: all 0.3s ease;
        }

.btn-outline-primary:hover {
            background: var(--primary-blue);
            color: white;
            transform: translateY(-2px);
        }

.pulse {
            animation: pulse 2s infinite;
        }

        @keyframes pulse {
            0% {
                transform: scale(1);
                box-shadow: 0 0 0 0 rgba(1, 11, 199, 0.933);
            }
            70% {
                transform: scale(1.05);
                box-shadow: 0 0 0 10px rgb(45, 8, 255);
            }
            100% {
                transform: scale(1);
                box-shadow: 0 0 0 0 rgba(11, 121, 255, 0.876);
            }
        }


.whatsapp-btn {
    background: linear-gradient(135deg, #25d366, #128c7e);
    color: white;
    border: none;
    transition: all 0.3s ease;
}

.whatsapp-btn:hover {
    background: linear-gradient(135deg, #128c7e, #25d366);
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(37, 211, 102, 0.3);
}


.toast-error .toast-header,
.toast-error .toast-body {
    background-color: #dc3545 !important;
    color: white !important;
}

.simple-card img {
    height: 250px;
    object-fit: cover;
    border-radius: 15px 15px 0 0;
        }

.modal-header {
    background: var(--gradient-bg);
    color: white;
    border-radius: 15px 15px 0 0;
    }

.modal-content {
    border-radius: 15px;
    border: none;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
    }

.pdf-viewer {
            width: 100%;
            height: 600px;
            border: none;
            border-radius: 10px;
        }

@media (max-width: 768px) {
            .header h1 {
                font-size: 2rem;
            }
            
            .nav-tabs .nav-link {
                padding: 0.8rem 1rem;
                font-size: 1rem;
            }
            
            .carousel-item img {
                height: 250px;
            }
           
          }

.loading-spinner {
            display: none;
            justify-content: center;
            align-items: center;
            height: 200px;
        }

.spinner-border {
            color: var(--primary-blue);
        }

/* Acessibilidade */
.sr-only {
            position: absolute;
            width: 1px;
            height: 1px;
            padding: 0;
            margin: -1px;
            overflow: hidden;
            clip: rect(0, 0, 0, 0);
            white-space: nowrap;
            border: 0;
        }

.btn:focus,
.nav-link:focus {
            outline: 3px solid var(--light-blue);
            outline-offset: 2px;
        }

        /* Animações suaves */
.fade-in {
            animation: fadeIn 0.5s ease-in;
        }

@keyframes fadeIn {
            from { opacity: 0; transform: translateY(20px); }
            to { opacity: 1; transform: translateY(0); }
        }

.btn-group > .btn {
      border-radius: 50px !important;
      padding: 0.5rem 1.75rem;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 1px;
      transition: all 0.3s ease;
    }
.btn-group > .btn.active, 
.btn-group > .btn:hover {
      background: var(--gradient-bg);  
      color: white !important;
      box-shadow: 0 8px 15px rgba(13, 110, 253, 0.3);
      border-color: #0d6efd !important;
    }
.product-card {
      background: white;
      border-radius: 12px;
      box-shadow: 0 8px 20px rgb(0 0 0 / 0.08);
      transition: transform 0.3s ease, box-shadow 0.3s ease;
      will-change: transform;
      display: flex;
      flex-direction: column;
      outline-offset: 4px;
    }
.product-card:hover,
.product-card:focus-within {
      transform: translateY(-6px);
      box-shadow: 0 12px 30px rgb(0 0 0 / 0.15);
      z-index: 10;
    }


.product-card img {
      border-top-left-radius: 9px;
      border-top-right-radius: 9px;
      object-fit: cover;
      height: 100%;
      width: 100%;
      transition: transform 0.3s ease;
        }
    
.product-card:hover img,
.product-card:focus-within img {
      transform: scale(1.05);
    }
.card-body {
      flex-grow: 1;
      display: flex;
      flex-direction: column;
      padding: 1.25rem 1.5rem;
    }
.card-title {
      font-size: 1.25rem;
      margin-bottom: 0.5rem;
      color: #343a40;
      font-weight: 700;
    }
.card-text {
      flex-grow: 1;
      font-size: 0.95rem;
      color: #6c757d;
      margin-bottom: 1rem;
      line-height: 1.4;
    }
.btn-group-actions {
      display: flex;
      gap: 1rem;
      margin-top: auto;
    }
.btn-comprar, .btn-ficha {
      flex: 1;
      font-weight: 600;
      border-radius: 20px;
      font-size: 0.95rem;
      display: flex;
      margin: 5px;
      padding: 10px;
      align-items: center;
      justify-content: center;
      gap: 0.5rem;
      transition: all 0.3s ease;
      box-shadow: 0 4px 10px rgb(0 0 0 / 0.1);
    }
.btn-comprar {
      background: var(--gradient-bg);  
      border: none;
      color: #fff;
      padding-left: 10px;
      padding-right: 10px;

    }
.btn-comprar:hover, 
.btn-comprar:focus {
      background: var(--azul-escuro);
      box-shadow: 0 6px 15px rgba(125, 149, 230, 0.839);
      outline: none;
    }
.btn-ficha {
      background: #fff;
      border: 2px solid #270df0;
      font-family: 'Gill Sans', 'Gill Sans MT', Calibri, 'Trebuchet MS', sans-serif;
      font-size: 1rem;
      color: #1a0579;
      padding-left: 10px;
      padding-right: 10px;
    }


    
.btn-ficha:hover, 
.btn-ficha:focus {
      background: var(--azul-escuro);
      color:#fff;
      box-shadow: 0 6px 15px rgb(13 202 240 / 0.4);
      outline: none;
    }

.btn-comprar svg,
.btn-ficha svg {
      width: 18px;
      height: 18px;
      color: #0d0764;
      fill: currentColor;
    }


.blink {
     animation: blink-animation 1.5s infinite;
      border-radius: 50px;
      padding: 0.6rem 2rem;
      font-weight: 700;
      text-transform: uppercase;
      letter-spacing: 1.5px;
      box-shadow: 0 8px 20px rgba(13, 110, 253, 0.3);
      transition: box-shadow 0.3s ease;
    }
.blink:hover, .blink:focus {
      box-shadow: 0 12px 30px rgba(13, 110, 253, 0.6);
      outline: none;
    }
    @keyframes blink-animation {
      0%, 100% { opacity: 1; }
      50% { opacity: 0.4; }
    }
    /* Modal custom */
.modal-content {
      border-radius: 16px;
      box-shadow: 0 16px 40px rgb(0 0 0 / 0.25);
      font-size: 1rem;
      color: #212529;
    }
.modal-header {
      border-bottom: none;
      padding-bottom: 0.5rem;
    }
.modal-title {
      font-weight: 800;
      font-size: 1.5rem;
      color: #ffffff;
      text-transform: uppercase;
      letter-spacing: 1.2px;
    }
.modal-body ul {
      padding-left: 1.25rem;
    }
.modal-footer {
      border-top: none;
      justify-content: center;
      padding-top: 0.5rem;
    }
.btn-close {
    filter: drop-shadow(0 2px 2px rgba(0,0,0,0.08));
    }

/*video segurança */

.seguranca-section {
    margin-top: 80px;
    background: linear-gradient(135deg, #0d0764 0%, #1a237e 100%);
    position: relative;
    overflow: hidden;
   
    
}

.seguranca{
    margin-bottom: 150px;
}

.seguranca-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0) 70%);
}

.glass-effect {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-radius: 15px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.37);
    
}

.security-card {
    padding: 2rem;
    height: 100%;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.security-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 12px 40px 0 rgba(31, 38, 135, 0.5);
}

.security-card h4 {
    color: white;
    font-size: 1.25rem;
    margin-bottom: 1rem;
}

.security-card p {
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: 0;
    font-size: 0.95rem;
}

.icon-wrapper {
    color: #fff;
    font-size: 2rem;
}

.icon-wrapper i {
    opacity: 0.9;
}

.intro-text p {
    font-size: 1.1rem;
    line-height: 1.6;
}

/*video*/
#video-section {
            padding: 60px 20px;
            background: linear-gradient(135deg, #07113f 0%, #2458e9 100%);
            min-height: 600px;
            display: flex;
            align-items: center;
            justify-content: center;
        }

.container {
            max-width: 1000px;
            width: 100%;
            margin: 0 auto;
        }

h2 {
    text-align: center;
    color: white;
    font-size: 2.5rem;
            margin-bottom: 50px;
            font-weight: 700;
            text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.2);
        }
.video-container {
            display: flex;
            justify-content: center;
            align-items: center;
        }

.video-wrapper {
            position: relative;
            width: 100%;
            max-width: 900px;
            aspect-ratio: 16 / 9;
            border-radius: 12px;
            overflow: hidden;
            box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
            transition: transform 0.3s ease, box-shadow 0.3s ease;
        }

.video-wrapper:hover {
            transform: translateY(-5px);
            box-shadow: 0 15px 50px rgba(0, 0, 0, 0.4);
        }

.video-wrapper iframe {
            width: 100%;
            height: 100%;
            border: none;
            display: block;
        }

@media (max-width: 768px) {
            h2 {
                font-size: 1.8rem;
                margin-bottom: 30px;
            }

            #video-section {
                padding: 40px 15px;
                min-height: auto;
            }

            .video-wrapper {
                min-height: 250px;
            }
        }

@media (max-width: 480px) {
            h2 {
                font-size: 1.4rem;
                margin-bottom: 20px;
            }

            #video-section {
                padding: 30px 10px;
            }
        }
    

/*testemunho*/


.testimonial-carousel {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
}

.py-5 h2 {
    text-align: center;
    margin-bottom: 30px;
    color: #0d0764;
    font-size: 2rem;
    font-weight: 700;
}

.testimonial-card {
    background: #0d0764;
    border-radius: 15px;
    padding: 25px;
    width: 350px;
    height: 200px;
    margin: 0 auto;
    color: white;
    box-shadow: 0 4px 15px rgba(13, 7, 100, 0.2);
    position: relative;
    overflow: hidden;
}

.profile-header {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
}

.profile-img {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    overflow: hidden;
    margin-right: 15px;
    border: 2px solid rgba(255, 255, 255, 0.2);
}

.profile-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.profile-info h5 {
    margin: 0;
    font-size: 14px;
    color: white;
}

.rating {
    color: #FFD700;
    font-size: 12px;
    margin-top: 3px;
}

.testimonial-text {
    font-size: 13px;
    line-height: 1.4;
    margin-bottom: 10px;
    opacity: 0.9;
}

.review-date {
    font-size: 11px;
    opacity: 0.7;
    position: absolute;
    bottom: 15px;
    left: 25px;
}

.carousel-control-prev,
.carousel-control-next {
    width: 40px;
    height: 40px;
    background:var(--primary-blue);
    border-radius: 50%;
    top: 50%;
    transform: translateY(-50%);
    opacity: 1;
}

.carousel-control-prev {
    left: 30px;
}

.carousel-control-next {
    right: 30px;
}

.carousel-control-prev i,
.carousel-control-next i {
    color: #0d0764;
    font-size: 18px;
}

.carousel-indicators {
    bottom: -40px;
}

.carousel-indicators button {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #0d0764;
    opacity: 0.5;
    margin: 0 5px;
}

.carousel-indicators button.active {
    opacity: 1;
}

.footer {
    position: relative;
    background: url('../img/fachada.jpg') center/cover no-repeat;
    padding: 80px 0 0;
    color: white;
}

.footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(13, 7, 100, 0.9);
    z-index: 1;
}

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

.glass-effect {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-radius: 15px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 25px;
    box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.37);
}

.contact-card h4,
.quick-links h4,
.map-container h4 {
    color: white;
    margin-bottom: 20px;
    font-size: 1.5rem;
}

.contact-item {
    display: flex;
    align-items: center;
    margin-bottom: 15px;
}

.contact-item i {
    width: 25px;
    color: rgba(255, 255, 255, 0.8);
}

.contact-item a,
.contact-item span {
    color: white;
    text-decoration: none;
    margin-left: 10px;
}

.social-icons {
    display: flex;
    gap: 15px;
}

.social-icon {
    color: white;
    font-size: 24px;
    transition: transform 0.3s ease;
}

.social-icon:hover {
    transform: scale(1.1);
    color: #f2f4ff;
}

.qr-image {
    width: 30%;
    border-radius: 10px;
    border: 2px solid rgba(255, 255, 255, 0.2);
}

.quick-links ul {
    list-style: none;
    padding: 0;
}

.quick-links ul li {
    margin-bottom: 10px;
}

.quick-links ul li a {
    color: white;
    text-decoration: none;
    transition: padding-left 0.3s ease;
}

.quick-links ul li a:hover {
    padding-left: 10px;
    color: #f2f4ff;
}

.map-container iframe {
    border-radius: 10px;
    margin-bottom: 10px;
}

.address {
    color: white;
    margin: 0;
}

.copyright-bar {
    background: rgba(0, 0, 0, 0.5);
    padding: 15px 0;
    margin-top: 50px;
    text-align: center;
    position: relative;
    z-index: 2;
}

.whatsapp-float {
            position: fixed;
            bottom: 25px;
            right: 25px;
            z-index: 9999; /* Z-index muito alto para ficar sempre por cima */
            transition: all 0.3s ease;
            border-radius: 50%;
            box-shadow: 0 4px 20px rgba(76, 175, 80, 0.4);
            animation: pulse 2s infinite;
        }

.whatsapp-float:hover {
            transform: scale(1.1);
            box-shadow: 0 6px 25px rgba(76, 175, 80, 0.6);
        }

.whatsapp-float svg {
            display: block;
            transition: transform 0.3s ease;
        }

.whatsapp-float:hover svg {
            transform: rotate(5deg);
        }

        /* Animação de pulse para chamar atenção */
        @keyframes pulse {
            0% {
                box-shadow: 0 4px 20px rgba(76, 175, 80, 0.4);
            }
            50% {
                box-shadow: 0 4px 20px rgba(76, 175, 80, 0.8);
            }
            100% {
                box-shadow: 0 4px 20px rgba(76, 175, 80, 0.4);
            }
        }

        /* Responsividade */
@media (max-width: 768px) {
            .whatsapp-float {
                bottom: 20px;
                right: 20px;
            }
            
            .whatsapp-float svg {
                width: 45px;
                height: 45px;
            }
            
            .glass-effect {
                padding: 20px;
            }
            .certificate-img {
                width: 85%;
                height: 85%;
                object-fit: cover;
        }

        }

        /* Iframe responsivo */
.iframe {
    border-radius: 10px;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
        }
@media (max-width: 1200px) {
    .carousel-caption {
        padding-bottom: 10px;
    }
    .btn-container {
        display: flex;
        justify-content: center;
        width: 65%;
    }
    .btn-saiba-mais {
        font-size: 10px;
        padding: 6px 0px;
        width: 65%;
    }
}


@media (max-width: 991px) {
    .logo {
        margin-left: 10px;
    }

    .carousel-caption {
        padding-bottom: 30px;
    }
    .footer {
        padding: 50px 0 0;
    }
    
    .glass-effect {
        margin-bottom: 20px;
    }
    .mobile-search {
        display: block;
        margin: 10px 0;
    }
    
    .mobile-search input {
        background-color: #f8f9fa;
        border: 1px solid #dee2e6;
    }
    .image-gallery {
        margin-top: 2rem;
    }
    
    .main-image {
        text-align: center;
        
        
    }
    
.main-image img {
        width: 600px;
        border-radius: 10px;
        height: auto;
}
.security-card {
        padding: 1.5rem;
    }
    
.intro-text p {
        font-size: 1rem;
    }
.carousel-item img {
        width: 100% !important;
        height: 100%; /* Permite que a altura se ajuste proporcionalmente */
        object-fit: cover; /* Garante que a imagem cubra a área, mantendo a proporção */
      }
    
#mainCarousel .carousel-caption {
           display: none; /* Oculta a legenda em celulares, se necessário */
      }
    
.carousel-caption {
        position: absolute;
        bottom: 0px;
        left: 0;
        right: 0;
        text-align: center;
        display: block !important;
    }
    
    
.btn-saiba-mais {
        font-size: 14px;
        padding: 8px 16px;
   
           
    }     

.row.g-4 {
        margin-left: -10px;
        margin-right: -10px;
    }
    
.col-md-6 {
        padding-left: 10px;
        padding-right: 10px;
    }
.video-wrapper {
        width: 90%;
        margin:10px;
    }
    

.testimonial-carousel {
          padding: 20px 20px;
        
    }

.carousel-control-prev {
        left: -20px;
    }

.carousel-control-next {
        right: -20px;
    }
.text-s h3{
        margin-top: -30px;
        margin-left:0px;
        font-family: "Poppins", 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        font-size: 1.5rem;
        font-style: normal;
        color:#0d0764;
    
    }
.testimonial-text {
        margin-top: 40px;
        font-size: 15px;
        line-height: 1.2;
               
    }
.testimonial-card {
        background: #0d0764;
        border-radius: 15px;
        width: 90%;
        height: auto;
        margin: 0 auto;
        color: white;
        box-shadow: 0 4px 15px rgba(13, 7, 100, 0.2);
        position: relative;
        overflow: hidden;
    }
.video-placeholder {
        position: absolute;
        top: 0;
        left: 0;
        width: 90%;
        height: 100%;
        object-fit: cover;
    }
.card-title{
       margin-top:30px ;
    }
.listaprod a{
        display: none;
       
     }
 

}

@media(max-width: 768px){    
     .logo {
        margin-left: 15px;
    }
     .carousel-item img {
        width: 100% !important;
        height: 100%; /* Permite que a altura se ajuste proporcionalmente */
        max-height: 700px; /* Defina uma altura máxima para celulares */
        object-fit: cover; /* Garante que a imagem cubra a área, mantendo a proporção */
      }
    
      #mainCarousel .carousel-caption {
        display: none; /* Oculta a legenda em celulares, se necessário */
      }
    
    .carousel-caption {
        position: absolute;
        bottom: 0px;
        left: 0;
        right: 0;
        text-align: center;
        display: block !important;
    }   
        
    .carousel-caption {
        padding-bottom: 5px;
    }
    .btn-saiba-mais {
        font-size: 13px;
        padding: 7px 14px;   
        width: 35%;
           
    }     

    .btn-saiba-mais:hover {
     background-color: #f2f4ff;
    color: var(--primary-color);
    padding: 20px 0px;
    margin: 20 20px;
    border-radius: 25px;
    text-transform: uppercase;
    transition: all 0.3s ease;
    width: 35%;   
    
    }

    .row.g-4 {
        margin-left: -10px;
        margin-right: -10px;
    }
    
    .col-md-6 {
        padding-left: 10px;
        padding-right: 10px;
    }
    .video-wrapper {
        width: 90%;
        margin:10px;
    }
    
    .certificates-container {
        gap: 20px;
    }
    
    .testimonial-carousel {
          padding: 20px 20px;
        
    }

    .carousel-control-prev {
        left: -20px;
    }

    .carousel-control-next {
        right: -20px;
    }
    .text-s h3{
        margin-top: -30px;
        margin-left:0px;
        font-family: "Poppins", 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        font-size: 1.5rem;
        font-style: normal;
        color:#0d0764;
    
    }
    .testimonial-text {
        margin-top: 40px;
        font-size: 15px;
        line-height: 1.2;
               
    }
    .testimonial-card {
        background: #0d0764;
        border-radius: 15px;
        width: 90%;
        height: auto;
        margin: 0 auto;
        color: white;
        box-shadow: 0 4px 15px rgba(13, 7, 100, 0.2);
        position: relative;
        overflow: hidden;
    }
    .video-placeholder {
        position: absolute;
        top: 0;
        left: 0;
        width: 90%;
        height: 100%;
        object-fit: cover;
    }
    .card-title{
        margin-top:30px ;
    }
    .listaprod a{
        display: none;
       
     }    
 
    
}


@media (max-width: 480px) {
    .footer {
        padding: 50px 0 0;
    }
    
    .glass-effect {
        margin-bottom: 20px;
    }
    .mobile-search {
        display: block;
        margin: 10px 0;
    }
    
    .mobile-search input {
        background-color: #f8f9fa;
        border: 1px solid #dee2e6;
    }
    .image-gallery {
        margin-top: 2rem;
    }
    
    .main-image {
        text-align: center;
        
    }
    
    .main-image img {
        max-width: 100%;
        border-radius: 10px;
        height: auto;
    }
    .security-card {
        padding: 1.5rem;
    }
    
    .intro-text p {
        font-size: 1rem;
    }
    .carousel-item img {
        width: 100% !important;
        height: 100%; /* Permite que a altura se ajuste proporcionalmente */
        max-height: 700px; /* Defina uma altura máxima para celulares */
        object-fit: cover; /* Garante que a imagem cubra a área, mantendo a proporção */
      }
    
      #mainCarousel .carousel-caption {
        display: none; /* Oculta a legenda em celulares, se necessário */
      }
    
    .carousel-caption {
        position: absolute;
        bottom: 0px;
        left: 0;
        right: 0;
        text-align: center;
        display: block !important;
    }
    
   .row.g-4 {
        margin-left: -10px;
        margin-right: -10px;
    }
    
    .col-md-6 {
        padding-left: 10px;
        padding-right: 10px;
    }
    .video-wrapper {
        width: 90%;
        margin:10px;
    }
    
    .certificates-container {
        gap: 10px;
    }
    
    .certificate-card {
        width: 150px;
        height: 150px;
    }
    .testimonial-carousel {
          padding: 20px 20px;
        
    }

    .carousel-control-prev {
        left: -20px;
    }

    .carousel-control-next {
        right: -20px;
    }
    .text-s h3{
        margin-top: -30px;
        margin-left:0px;
        font-family: "Poppins", 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
        font-size: 1.5rem;
        font-style: normal;
        color:#0d0764;
    
    }
    .testimonial-text {
        margin-top: 40px;
        font-size: 15px;
        line-height: 1.2;
               
    }
    .testimonial-card {
        background: #0d0764;
        border-radius: 15px;
        width: 90%;
        height: auto;
        margin: 0 auto;
        color: white;
        box-shadow: 0 4px 15px rgba(13, 7, 100, 0.2);
        position: relative;
        overflow: hidden;
    }
    .video-placeholder {
        position: absolute;
        top: 0;
        left: 0;
        width: 90%;
        height: 100%;
        object-fit: cover;
    }
    .card-title{
        margin-top:30px ;
    }
    .listaprod a{
        display: none;
    } 
    .certificates-container {
        flex-direction: column;
        align-items: center;
    }
    
    .certificate-card {
        width: 180px;
        height: 180px;
    }
    .testimonial-card {
        width: 90%;
        height: 350px;
    }

    .testimonial-text {
        font-size: 15px;
        margin-bottom: 10px;
    }
    .appointment-btn{
             padding: 5px 5px;
             margin-left: 50px;
             font-size: 15px;
             font-weight: 200;
             font-weight: bold;
             margin-top: 10px;
             margin-bottom: 0px
    
            }
   
}


.filter-section {
            background: var(--secondary-color);
            padding: 2rem 0;
            box-shadow: 0 2px 8px rgba(0,0,0,0.05);
            position: relative;
            top: 0;
            z-index: 100;
        }

.filter-btn {
            border: 2px solid var(--azul-escuro);
            color: var(--azul-escuro);
            background: white;
            padding: 0.75rem 1.5rem;
            margin: 0.5rem;
            border-radius: 50px;
            font-weight: 500;
            transition: all 0.3s ease;
            position: relative;
            overflow: hidden;
        }

.filter-btn:hover {
            background: var(--gradient-bg);
            color: white;
            transform: translateY(-2px);
            box-shadow: 0 4px 12px rgba(52, 152, 219, 0.3);
        }

.filter-btn.active {
            background: var(--gradient-bg);
            color: white;
            box-shadow: 0 4px 12px rgba(52, 152, 219, 0.4);
        }

.filter-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, height 0.6s;
        }

.filter-btn:active::before {
            width: 300px;
            height: 300px;
        }
.filter-section h2 {
            text-align: center;
            margin-bottom: 1rem;
            color: var(--azul-escuro);
            font-weight: 700;
        }

.products-grid {
            padding: 3rem 0;
            border-radius: 12px;
            box-shadow: 0 8px 20px rgb(0 0 0 / 0.08);
           
        }

.product-card {
           background: #fff;
           border: 1px solid var(--cinza);
           border-radius: 12px;  
            overflow: hidden;           
            box-shadow: var(--card-shadow);
            transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
            margin-bottom: 2rem;
            height: 100%;
            display: flex;
            flex-direction: column;
        }

.product-card:hover {
            transform: translateY(-8px);
            box-shadow: var(--card-shadow-hover);
        }

.product-image-wrapper {
            position: relative;
            overflow: hidden;
            border-top-left-radius: 9px;
            border-top-right-radius: 9px;
            box-shadow: 0 8px 20px rgb(0 0 0 / 0.08);           
            background: #f0f0f0;
            height: auto;
        }

.icon-btn {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    border: none;
    background: linear-gradient(135deg, #232323 0%, #ffffff 100%);
    color: white;
    font-size: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    animation: slideInIcon 0.4s ease-out;
}



.icon-btn:hover {
    background: linear-gradient(135deg, #08018c 0%, #e10606 100%);
    transform: scale(1.1);
    box-shadow: 0 6px 16px rgba(255, 107, 107, 0.4);
}

.icon-btn:active {
    transform: scale(0.95);
}

/* Ícones Bootstrap */
.icon-btn i {
    font-size: 20px;
}

/* Animação de entrada dos ícones */
@keyframes slideInIcon {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}


.product-image-wrapper img {
            width: 100%;
            height: 300px;
            object-fit: cover;
            transition: transform 0.5s ease;
        }

.product-card:hover .product-image-wrapper img {
            transform: scale(1.1);
        }

.image-overlay {
            position: absolute;
            top: 10px;
            right: 10px;
            display: flex;
            gap: 8px;
            opacity: 0;
            transition: opacity 0.3s ease;
        }

.product-card:hover .image-overlay {
            opacity: 1;
        }


.carousel-control-prev,
.carousel-control-next {
           width: 35px;
            height: 35px;
            background: rgba(0,0,0,0.5);
            border-radius: 50%;
            top: 50%;
            transform: translateY(-50%);
        }

.carousel-indicators {
            margin-bottom: 10px;
        }

.product-content {
            padding: 1.5rem;
            flex: 1;
            display: flex;
            flex-direction: column;
        }

.product-title {
            font-size: 1.3rem;
            font-weight: 600;
            color: var(--primary-color);
            margin-bottom: 0.75rem;
            min-height: 60px;
        }

.product-description {
            color: #666;
            font-size: 0.95rem;
            line-height: 1.6;
            margin-bottom: 1.5rem;
            flex: 1;
            display: -webkit-box;
            -webkit-line-clamp: 3;
            -webkit-box-orient: vertical;
            overflow: hidden;
            margin-bottom: 30px;
        }

.product-actions {
            display: flex;
            gap: 10px;
        }


.modal-content {
            border-radius: 12px;
            border: none;
        }

.modal-header {
            background: linear-gradient(135deg, var(--primary-color), var(--secondary-color));
            color: white;
            border-radius: 12px 12px 0 0;
        }

.specs-table {
            margin-top: 1rem;
        }

.specs-table th {
            background: var(--light-bg);
            font-weight: 600;
            width: 40%;
        }

.zoom-modal .modal-dialog {
            max-width: 90vw;
        }

.zoom-modal img {
            width: 100%;
            height: auto;
            max-height: 85vh;
            object-fit: contain;
        }

@media (max-width: 768px) {
            header h1 {
                font-size: 1.8rem;
            }

            .filter-btn {
                padding: 0.6rem 1rem;
                font-size: 0.9rem;
            }

            .product-title {
                font-size: 1.1rem;
                min-height: auto;
            }
            .appointment-btn{
             padding: 5px 5px;
             margin-left: 50px;
             font-size: 15px;
             font-weight: 200;
             font-weight: bold;
            margin-top: 0px;
    
            }
            
        }

.fade-in {
            animation: fadeIn 0.5s ease-in;
        }

        @keyframes fadeIn {
            from {
                opacity: 0;
                transform: translateY(20px);
            }
            to {
                opacity: 1;
                transform: translateY(0);
            }
        }

.loading {
            text-align: center;
            padding: 3rem;
            font-size: 1.2rem;
            color: var(--secondary-color);
        }

/* SEÇÃO CERTIFICADOS */

.certificates-title {
    text-align: center;
    font-size: 2.5rem;
    font-weight: bold;
    color: var(--azul-escuro);
    margin-bottom: 3rem;
    position: relative;
    display: inline-block;
    width: 100%;
}

.certificates-title::after {
    content: '';
    position: absolute;
    bottom: -15px;
    left: 50%;
    transform: translateX(-50%);
    width: 150px;
    height: 3px;
    background: linear-gradient(90deg, #ff0000cd, #0056b3);
    border-radius: 2px;
}

/* CONTAINER DOS CERTIFICADOS */
.main-content {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    margin-top: 30px;
    
    
}

/* CARD DO CERTIFICADO */
.certificate-card {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    aspect-ratio: 1 / 1; /* Define proporção quadrada */
    object-fit: contain; /* Muda de 'cover' para 'contain' */
    background-color: transparent;    
   
}

.certificate-card:hover {
    transform: translateY(-5px);
    
}

.certificate-card img {
    width: 100%;
    height: auto;
    object-fit: cover; /* Mantém proporção sem distorcer */
    display: block;
}

.certificate-card-imetro img {
    width: 60%;
    height: auto;
    object-fit: cover; /* Mantém proporção sem distorcer */
    display: block;
   
}


/* RESPONSIVIDADE PARA TABLETS */
@media (max-width: 992px) {
    .main-content {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .certificates-title {
        font-size: 2rem;
    }
}

/* RESPONSIVIDADE PARA CELULAR */
@media (max-width: 768px) {
    .main-content {
        grid-template-columns: 1fr;
        gap: 0.5rem;
        margin-bottom: 30px;
    }
    
    .certificates-title {
        font-size: 1.5rem;
        margin-bottom: 2rem;
    }
    
    .certificates-title::after {
        bottom: -10px;
        width: 100px;
        height: 2px;
    }
}

/* AJUSTES EXTRAS */
.container-custom {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 15px;
}

#certificates {
    padding: 1rem 0;
    background-color: #f8f9fa;
}

/* BALÕES COM EFEITO VIDRO */
.glass-balloon {
            position: absolute;
            background: rgba(255, 255, 255, 0.25);
            backdrop-filter: blur(10px);
            border: 1px solid rgba(255, 255, 255, 0.4);
            border-radius: 15px;
            padding: 20px;
            color: rgb(50, 49, 49);
            font-size: 0.9rem;
            line-height: 1.5;
            box-shadow: 0 8px 32px rgba(13, 7, 100, 0.1);
            animation: float 3s ease-in-out infinite;
            z-index: 10;
        }
.glass-balloon::before {
            content: '';
            position: absolute;
            width: 45px;
            height: 25px;
            background: rgba(255, 255, 255, 0.25);
            border: 1px solid rgba(255, 255, 255, 0.4);
            border-radius: 50%;
            bottom: -25px;
            left: 20px;
        }

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

.balloon-cat {
            bottom: 20px;
            left: 15px;
            width: 260px;
            font-weight: 600;
            text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
        }

.balloon-cct {
            bottom: 10px;
            right: 10px;
            width: 260px;
            font-weight: 600;
            text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
        }

     
.faq-section {
            margin-top: 60px;
            background: var(--azul-escuro);
             
        }

.faq-container {
            max-width: 600px;
            margin: 0 auto;
           
        }

.faq-item {
            background: #fff;
            backdrop-filter: blur(10px);
            border: 1px solid rgba(255, 255, 255, 0.3);
            border-radius: 10px;
            margin-bottom: 15px;
            overflow: hidden;
            box-shadow: 0 8px 32px 0 rgba(31, 38, 135, 0.37);
            transition: all 0.3s ease;
        }

.faq-item:hover {
            box-shadow: 0 12px 40px 0 rgba(31, 38, 135, 0.5);
        }

.faq-question {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 20px;
            cursor: pointer;
            user-select: none;
            color: rgb(3, 10, 71);
            font-weight: 600;
            font-size: 1.05rem;
            transition: background 0.3s ease;
        }

.faq-question:hover {
            background: rgba(255, 255, 255, 0.1);
        }
.section-title h4{
    padding-top: 50px;
    align-items: center;
    font-family: 'Lucida Sans', 'Lucida Sans Regular', 'Lucida Grande', 'Lucida Sans Unicode', Geneva, Verdana, sans-serif;
    font-size: 1.5rem;
    color: #fff;
    text-align: center;


}
.faq-arrow {
            font-size: 1.2rem;
            color: #d20505;
            transition: transform 0.3s ease;
            min-width: 30px;
            text-align: right;
        }

.faq-arrow.active {
            transform: rotate(180deg);
        }

.faq-answer {
            max-height: 0;
            overflow: hidden;
            transition: max-height 0.3s ease, padding 0.3s ease;
            padding: 0 20px;
            background: #fff;
        }

.faq-answer.active {
            max-height: 500px;
            padding: 0 20px 20px 20px;
        }

.faq-answer-text {
            margin-top: 20px;
            color: rgba(7, 10, 161, 0.95);
            line-height: 1.8;
            padding: 15px;
            border-left: 3px solid #0c0351;
            border-radius: 5px;
        }

@media (max-width: 768px) {            
            .faq-container {
                max-width: 90%;
            }
        }

 
        /* RESPONSIVO */
@media (max-width: 1024px) {
            .main-content {
                grid-template-columns: 1fr 1fr;
                gap: 30px;
            }

            
        }

@media (max-width: 768px) {
            .main-content {
                grid-template-columns: 1fr;
                gap: 10px;
            }

           
            .certificates-title {
                font-size: 2rem;
            }

            .certificate-card {
                height: 100%;
                width: 95%;
                margin-top: -50px;
                margin-bottom: -70px;
            }

            .glass-balloon {
                font-size: 0.85rem;
                padding: 15px;
            }
                       
        }

#mainCarousel .carousel-control-prev,
#mainCarousel .carousel-control-next {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 45px;
    height: 45px;
    background: rgba(0, 0, 0, 0.35);
    border-radius: 50%;
    z-index: 10 !important;
}

/* posição lateral */
#mainCarousel .carousel-control-prev {
    left: 10px !important;
}

#mainCarousel .carousel-control-next {
    right: 10px !important;
}

/* ícones */
#mainCarousel .carousel-control-prev-icon,
#mainCarousel .carousel-control-next-icon {
    width: 22px;
    height: 22px;
}
/* Garante que em tablets e celulares também fiquem visíveis */
@media (max-width: 991px) {
    .carousel-control-prev {
        left: 5px !important;
        display: flex !important;
    }

    .carousel-control-next {
        right: 5px !important;
        display: flex !important;
    }

    .carousel-control-prev,
    .carousel-control-next {
        width: 35px;
        height: 35px;
        opacity: 1 !important;
        background: rgba(15, 69, 205, 0.986);
    }
}

@media (max-width: 768px) {
    .carousel-control-prev {
        left: 5px !important;
        display: flex !important;
    }

    .carousel-control-next {
        right: 5px !important;
        display: flex !important;
    }

    .carousel-control-prev,
    .carousel-control-next {
        width: 35px;
        height: 35px;
        opacity: 1 !important;
        background: rgba(75, 55, 255, 0.7);
    }

    .carousel-control-prev-icon,
    .carousel-control-next-icon {
        width: 18px;
        height: 18px;
    }
    .certificate-card-imetro img {
    width: 60%;
    height: auto;
    margin-left: 30px;
   
    }

}

@media (max-width: 480px) {
    .carousel-control-prev {
        left: 5px !important;
        display: flex !important;
    }

    .carousel-control-next {
        right: 5px !important;
        display: flex !important;
    }

    .carousel-control-prev,
    .carousel-control-next {
        width: 32px;
        height: 32px;
        opacity: 1 !important;
        background: rgba(75, 55, 255, 0.7);
    }

    .carousel-control-prev-icon,
    .carousel-control-next-icon {
        width: 16px;
        height: 16px;
    }
    .certificate-card-imetro img {
    width: 60%;
    height: auto;
    margin-left: 30px;
   
    }
}
