/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Jun 10 2026 | 05:47:30 */
/* ============================================================
   1. BOTONES Y HOVERS CORPORATIVOS
   ============================================================ */
li.boton-contacto a {
  background-color: #019AA8;
  color: #ffffff !important;
  padding: 2px 10px;
  border-radius: 2px;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.2;
  text-transform: none;
  transition: background-color 0.3s ease;
  display: inline-block;
  height: auto;
}

li.boton-contacto a:hover {
  background-color: #017b87;
  text-decoration: none;
}

.price-btn {
  background-color: #007c8c;
  color: #fff;
  padding: 0.4rem 1rem;
  font-weight: 600;
  display: inline-block;
  border-radius: 999px;
  text-align: center;
  transition: all 0.3s ease;
}

.price-btn:hover {
  background-color: #000;
  color: #fff;
}

.card-hover {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  border-radius: 10px;
}

.card-hover:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 20px rgba(0,0,0,0.12);
}

.tarjeta-hover a {
  display: inline-block;
  padding: 6px 14px;
  border-radius: 8px;
  background-color: transparent;
  color: #019aa8;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.3s ease;
}

.tarjeta-hover a:hover {
  background-color: #000;
  color: #fff !important;
}

.btn-continuar, .btn-ver-precio {
  transition: background-color 0.3s ease;
}
.btn-continuar { background-color: #019AA8; }
.btn-continuar:hover { background-color: #000000; }
.btn-ver-precio { background-color: #019AA8; }
.btn-ver-precio:hover { background-color: #000000; }

/* ============================================================
   2. HERO SECTION COMPONENT (Para páginas específicas)
   ============================================================ */
.hero-section {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 40px 20px;
  background-color: #f8f8f8;
  gap: 40px;
}

.hero-text { max-width: 50%; }
.hero-text h1 { font-size: 28px; font-weight: bold; margin-bottom: 20px; }
.hero-text p { font-size: 18px; margin-bottom: 20px; }
.hero-text ul { list-style: none; padding: 0; margin-bottom: 20px; }
.hero-text ul li::before { content: "✓ "; color: #019aa8; margin-right: 4px; }

.cta-btn {
  background-color: #019aa8;
  color: #fff;
  padding: 10px 20px;
  text-decoration: none;
  border-radius: 5px;
  display: inline-block;
}
.cta-btn:hover { background-color: #017b87; }
.hero-image img { max-width: 350px; width: 100%; border-radius: 12px; }

@media (max-width: 768px) {
  .hero-section { flex-direction: column; text-align: center; }
  .hero-text, .hero-image img { max-width: 100%; }
}

/* ============================================================
   3. OCULTAR TÍTULOS DE PÁGINAS Y CONFIGURACIONES H1
   ============================================================ */
.page-id-223 h1.entry-title, .page-id-1333 h1.entry-title,
.page-id-1731 h1.entry-title, .page-id-1733 h1.entry-title,
.page-id-1735 h1.entry-title, .page-id-1737 h1.entry-title,
.page-id-1739 h1.entry-title, .page-id-1741 h1.entry-title,
.page-id-1743 h1.entry-title, .page-id-1755 h1.entry-title,
.page-id-1757 h1.entry-title, .page-id-1759 h1.entry-title,
.page-id-1761 h1.entry-title, .page-id-1752 h1.entry-title,
.page-id-1767 h1.entry-title, .page-id-1769 h1.entry-title,
.page-id-1771 h1.entry-title, .page-id-1773 h1.entry-title,
.page-id-1775 h1.entry-title, .page-id-1785 h1.entry-title,
.page-id-1787 h1.entry-title, .page-id-1789 h1.entry-title,
.page-id-1791 h1.entry-title, .page-id-1793 h1.entry-title,
.page-id-1795 h1.entry-title, .page-id-1335 h1.entry-title,
.single-post .entry-header .entry-title {
    display: none !important;
}
h1 { text-transform: none !important; }

/* Control de imagen en el primer post */
.gb-post-template img.imagen-solo-primer-post { display: none !important; }
.gb-post-template:first-child img.imagen-solo-primer-post { display: block !important; }

/* ============================================================
   4. FORMULARIOS (WPFORMS & CHECKBOXES)
   ============================================================ */
input[type=checkbox] {
    appearance: none; background-color: #fff; margin: 0; font: inherit; color: currentColor;
    width: 1.15em; height: 1.15em; border: 0.1em solid #cbd5e1; border-radius: 0.25em;
    transform: translateY(-0.075em); display: grid; place-content: center; cursor: pointer;
}
.modal-backdrop { background-color: rgba(0, 0, 0, 0.5); }

div.wpforms-container-full .wpforms-form button[type=submit] {
    background-color: #0097a7 !important;
    border: 1px solid #0097a7 !important;
    color: white !important;
    width: 100%;
    padding: 15px;
    font-size: 18px;
    font-weight: bold;
    border-radius: 5px;
    text-transform: uppercase;
    margin-top: 10px;
    cursor: pointer;
    transition: all 0.3s ease;
}
div.wpforms-container-full .wpforms-form button[type=submit]:hover {
    background-color: #007c8a !important;
    border-color: #007c8a !important;
}
div.wpforms-container-full { margin-bottom: 0px !important; }
div.wpforms-container-full .wpforms-form .wpforms-field-label {
    font-size: 13px !important; font-weight: 700 !important; margin-bottom: 4px !important;
}
div.wpforms-container-full .wpforms-form input[type=text],
div.wpforms-container-full .wpforms-form input[type=number],
div.wpforms-container-full .wpforms-form input[type=email] {
    font-size: 13px !important; padding: 6px 10px !important; height: 35px !important;
}
div.wpforms-container-full .wpforms-form .wpforms-field { padding: 5px 0 !important; margin-bottom: 0px !important; }

div.wpforms-container-full ul, div.wpforms-container-full li { list-style: none !important; margin-left: 0 !important; padding-left: 0 !important; }
div.wpforms-container-full .wpforms-form li::before,
div.wpforms-container-full .wpforms-form label::before,
div.wpforms-container-full .wpforms-form input[type=checkbox]::before {
    display: none !important; content: none !important; border: none !important; background: none !important;
}
div.wpforms-container-full .wpforms-form input[type=checkbox] {
    -webkit-appearance: checkbox !important; -moz-appearance: checkbox !important; appearance: checkbox !important;
    border: 1px solid #555 !important; background-color: #fff !important; width: 18px !important; height: 18px !important; border-radius: 3px !important;
    display: inline-block !important; visibility: visible !important; opacity: 1 !important; accent-color: #008C99 !important;
    margin-right: 10px !important; vertical-align: middle !important; position: relative !important; top: -2px !important; box-shadow: none !important;
}

/* ============================================================
   5. ESTRUCTURA DEL MENÚ PRINCIPAL (CORREGIDO ERROR INTERMITENTE)
   ============================================================ */
/* Evitamos el fondo blanco inicial indeseado en la cabecera */
.site-header {
  z-index: 1000;
  position: relative;
  background-color: transparent !important;
}

/* Forzar que los hovers no rompan transparencias */
.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li:focus > a,
.main-navigation .main-nav ul li.sfHover > a,
.main-navigation .main-nav ul li[class*="current-menu-"] > a {
    background-color: transparent !important;
}

.main-navigation {
    background: none !important;
}

/* --- VERSIÓN ORDENADOR (Desktop) --- */
@media (min-width: 769px) {
    .inside-header, .inside-navigation {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important; 
        flex-wrap: nowrap !important;
    }

    /* Forzamos tamaño de 50px al logo normal y al que aparece en el scroll fijo */
    .site-logo img,
    .navigation-stick .navigation-branding img,
    .navigation-stick .site-logo img {
        height: 50px !important;
        width: auto !important;
        margin: 5px 0 !important;
    }
    
    /* Evitamos la duplicidad ocultando el logo estático cuando se activa el menú pegajoso */
    .navigation-stick .site-logo:not(.navigation-branding) {
        display: none !important;
    }

    .main-navigation {
        margin-left: 30px !important; 
        margin-right: auto !important;
    }
    .main-navigation .main-nav {
        margin-left: 40px;
    }
}

/* --- VERSIÓN MÓVIL MENÚ LATERAL (Off-Canvas) --- */
#generate-slideout-menu.main-navigation.off-canvas-active,
#generate-slideout-menu.do-overlay .outside-menu,
.slideout-navigation {
    background-color: #f2f2f2 !important;
    background: #f2f2f2 !important;
}

.slideout-navigation.main-navigation .main-nav ul li a,
.slideout-navigation button.slideout-exit {
    color: #000000 !important;
    font-weight: 600 !important;
}

.slideout-navigation.main-navigation .main-nav ul li a:hover {
    color: #019AA8 !important;
    background-color: transparent !important;
}

.slideout-navigation.main-navigation .main-nav ul li a {
    line-height: 1.2 !important;
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    margin-bottom: 0px !important;
}

/* Separador del menú móvil */
.menu-separator a {
    font-size: 0 !important;
    border-top: 1px solid #cbd5e1 !important;
    display: block !important;
    height: 1px !important;
    margin: 12px 15px 12px 15px !important;
    padding: 0 !important;
    pointer-events: none !important;
}
.menu-separator + li { margin-top: 0 !important; }

/* Cabecera Móvil Fija */
@media (max-width: 768px) {
    #mobile-header .inside-navigation {
        height: 70px !important;
    }

    #mobile-header .site-logo img,
    #mobile-header .mobile-header-logo img,
    #mobile-header .navigation-branding img {
        width: 110px !important;
        max-width: 110px !important;
        height: auto !important;
        margin-left: 18px !important;
        margin-top: 10px !important;
    }

    #mobile-header .menu-toggle {
        margin-right: 2px !important;
        background: transparent !important;
    }

    .mobile-menu, .menu-toggle .mobile-menu {
        display: none !important;
        font-size: 0 !important;
    }
}

/* Seguridad global de colores de marcas */
img.custom-logo, .site-logo img, .navigation-branding img {
    filter: none !important;
}