/* ===================================
   MeM Business Center — Custom CSS
   Astra Child Theme v1.2
   =================================== */

/* ─── Variables ─── */
:root {
    --mem-red: #cc0000;
    --mem-red-dark: #a00000;
}

/* ─── Header: título → MeM Business Center ─── */
.site-title a,
.site-title,
.ast-site-name-wrap .site-title a { color: var(--mem-red) !important; }

/* ─── Borde rojo bajo header ─── */
#masthead, .ast-header-break-point #masthead { border-bottom: 3px solid var(--mem-red); }

/* ─── Navegación ─── */
.main-header-menu .menu-item a,
.main-navigation ul li a {
    font-weight: 600 !important;
    letter-spacing: .4px;
}
.main-header-menu .menu-item a:hover,
.main-header-menu .current-menu-item > a { color: var(--mem-red) !important; }

/* ─── Botones CTA ─── */
.ast-button-wrap .ast-custom-button,
.wp-block-button__link,
.elementor-button,
.elementor-widget-button .elementor-button,
input[type="submit"], button[type="submit"] {
    background: var(--mem-red) !important;
    border-color: var(--mem-red) !important;
    transition: background .2s;
}
.elementor-button:hover,
.wp-block-button__link:hover { background: var(--mem-red-dark) !important; }

/* ─── Formularios ─── */
input[type="text"], input[type="email"], input[type="tel"],
input[type="url"], textarea, select {
    border: 2px solid #e0e0e0 !important;
    border-radius: 6px !important;
    padding: 10px 14px !important;
    transition: border-color .2s !important;
}
input[type="text"]:focus, input[type="email"]:focus,
input[type="tel"]:focus, textarea:focus {
    border-color: var(--mem-red) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(204,0,0,.1) !important;
}
.wpforms-submit { background: var(--mem-red) !important; border: none !important; border-radius: 6px !important; padding: 13px 36px !important; font-size: 16px !important; font-weight: 700 !important; }
.wpforms-submit:hover { background: var(--mem-red-dark) !important; }
.wpforms-field-label { font-weight: 600 !important; color: #333 !important; }

/* ─── Tabla de precios ─── */
.mem-pricing-wrap {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 28px; margin: 40px 0 50px;
}
.mem-card {
    border: 2px solid #e8e8e8; border-radius: 14px;
    padding: 36px 28px; text-align: center;
    transition: border-color .25s, box-shadow .25s;
    background: #fff;
}
.mem-card:hover { border-color: var(--mem-red); box-shadow: 0 8px 32px rgba(204,0,0,.13); }
.mem-card.featured {
    border-color: var(--mem-red); background: #fff5f5;
    position: relative;
}
.mem-card.featured::before {
    content: "Mas popular";
    position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
    background: var(--mem-red); color: #fff; border-radius: 20px;
    padding: 4px 18px; font-size: 12px; font-weight: 700; letter-spacing: .5px;
}
.mem-card h3 { color: var(--mem-red); font-size: 1.15em; margin: 0 0 12px; text-transform: uppercase; letter-spacing: 1px; }
.mem-price { font-size: 2.5em; font-weight: 900; color: #111; line-height: 1; margin: 12px 0 4px; }
.mem-price sup { font-size: .45em; vertical-align: top; margin-top: 8px; }
.mem-price sub { font-size: .38em; color: #666; font-weight: 400; }
.mem-desc { color: #777; font-size: .88em; margin: 0 0 18px; }
.mem-card ul { list-style: none; padding: 0; margin: 0 0 24px; text-align: left; }
.mem-card ul li { padding: 7px 0; border-bottom: 1px solid #f0f0f0; font-size: .92em; }
.mem-card ul li::before { content: "\2713 "; color: var(--mem-red); font-weight: 700; }
.mem-btn-reservar {
    display: inline-block; background: var(--mem-red); color: #fff !important;
    padding: 12px 28px; border-radius: 7px; text-decoration: none !important;
    font-weight: 700; font-size: .94em; transition: background .2s;
}
.mem-btn-reservar:hover { background: var(--mem-red-dark) !important; }

/* ─── WhatsApp flotante ─── */
#mem-wa-float {
    position: fixed; bottom: 26px; right: 26px; z-index: 99999;
    display: flex; align-items: center; gap: 10px;
    background: #25D366; color: #fff !important;
    border-radius: 50px; padding: 13px 22px 13px 16px;
    text-decoration: none !important; font-weight: 700;
    font-family: Arial, sans-serif; font-size: 15px;
    box-shadow: 0 4px 20px rgba(0,0,0,.28);
    transition: transform .2s, box-shadow .2s;
}
#mem-wa-float:hover {
    transform: translateY(-3px) scale(1.03);
    box-shadow: 0 8px 28px rgba(0,0,0,.32);
    color: #fff !important; text-decoration: none !important;
}
@media (max-width: 600px) {
    #mem-wa-float span { display: none; }
    #mem-wa-float { padding: 14px; border-radius: 50%; bottom: 20px; right: 16px; }
}

/* ─── Footer ─── */
#colophon, .site-footer { border-top: 3px solid var(--mem-red); }








/* ─── Header: logo izquierda, título+tagline centrados ─── */

/* Contenedor real del flex (ast-container dentro del above-header) */
.site-above-header-wrap.ast-builder-grid-row-container {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100% !important;
}

/* Sección izquierda: crece para llenar espacio */
.site-header-above-section-left.site-header-section-left,
.site-header-above-section-left {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    position: static !important;
}

/* Sección derecha (social): tamaño natural al extremo derecho */
.site-header-above-section-right {
    flex: 0 0 auto !important;
    position: static !important;
    transform: none !important;
}

/* Identidad: flex row logo + título */
.site-branding.ast-site-identity {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    width: 100% !important;
    position: static !important;
    padding: 0 !important;
    min-height: 0 !important;
}

/* Logo: tamaño natural a la izquierda */
.site-header .site-logo-img {
    flex: 0 0 auto !important;
    position: static !important;
    transform: none !important;
    line-height: 0 !important;
}

/* Título+tagline: crece, texto centrado */
.ast-site-title-wrap {
    flex: 1 1 auto !important;
    text-align: center !important;
    position: static !important;
    transform: none !important;
    min-width: 0 !important;
}
.site-header .site-title,
.site-header .site-title a,
.site-header .site-description {
    text-align: center !important;
    display: block !important;
}

/* Logo: altura = suma de ambas líneas (~65px), ancho proporcional */
.site-header .custom-logo-link img,
.custom-logo-link img,
.custom-logo {
    height: 65px !important;
    width: auto !important;
    max-width: none !important;
    max-height: none !important;
}
