.elementor-1102 .elementor-element.elementor-element-141b14c{--display:flex;}/* Start custom CSS for html, class: .elementor-element-f22a006 *//* --- DISEÑO PENAL PREMIUM --- */

/* Hero con efecto de profundidad */
.hero-legal-premium {
    background: linear-gradient(rgba(27, 38, 59, 0.9), rgba(27, 38, 59, 0.95)), 
                url('https://images.unsplash.com/photo-1589829545856-d10d557cf95f?auto=format&fit=crop&w=1350&q=80');
    background-size: cover;
    background-position: center;
    color: white;
    padding: 120px 0;
    text-align: center;
}

.hero-legal-premium h1 span { color: var(--oro-viejo); }

.hero-badges {
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 30px;
}

.hero-badges span {
    border: 1px solid var(--oro-viejo);
    padding: 8px 20px;
    font-size: 0.8rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* Tarjetas de Confianza (01, 02, 03) */
.premium-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0; /* Unificadas */
    margin-top: -60px; /* Sube sobre el hero */
    box-shadow: 0 20px 40px rgba(0,0,0,0.1);
}

.premium-card {
    background: white;
    padding: 50px 30px;
    border-right: 1px solid var(--gris-piedra);
}

.card-icon {
    font-family: 'Lora', serif;
    font-size: 3rem;
    color: var(--gris-piedra);
    opacity: 0.5;
    margin-bottom: 20px;
}

/* Filas de Servicios Alternadas */
.service-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    margin-bottom: 100px;
    text-align: left;
}

.service-row.reverse { direction: rtl; }
.service-row.reverse .service-text { direction: ltr; }

.visual-box {
    background: var(--azul-medianoche);
    height: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--oro-viejo);
    font-size: 5rem;
    font-family: 'Lora', serif;
    border-bottom: 8px solid var(--oro-viejo);
}

.check-list {
    list-style: none;
    padding: 0;
    margin-top: 25px;
}

.check-list li::before {
    content: '✓';
    color: var(--oro-viejo);
    margin-right: 10px;
    font-weight: bold;
}

/* CTA Emergencia */
.cta-box-premium {
    background: var(--azul-medianoche);
    padding: 60px;
    border: 1px solid var(--oro-viejo);
    color: white;
    width: 100%;
}

.btn-emergency {
    background: #922b21;
    color: white !important;
    padding: 20px 40px;
    display: inline-block;
    margin-top: 30px;
    font-weight: 700;
    text-decoration: none;
    letter-spacing: 1px;
    transition: var(--transicion);
}

.btn-emergency:hover { background: #b03a2e; transform: scale(1.05); }

/* Móvil */
@media (max-width: 900px) {
    .premium-grid, .service-row { grid-template-columns: 1fr; }
    .hero-badges { flex-direction: column; }
}

/* --- MEJORAS VISUALES HERENCIAS --- */

/* Fondos alternos para romper el blanco */
.service-intro-alt {
    background-color: var(--blanco-hueso) !important;
    width: 100%;
}

/* Grid de beneficios con iconos */
.benefits-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 30px;
    margin-top: -30px;
}

.benefit-item {
    background: white;
    padding: 30px;
    border-top: 3px solid var(--oro-viejo);
    box-shadow: 0 10px 30px rgba(0,0,0,0.05);
    text-align: center;
}

.benefit-icon { font-size: 2.5rem; margin-bottom: 15px; }

/* Acordeón de FAQ */
.faq-container {
    max-width: 800px;
    margin: 40px auto 0;
    text-align: left;
}

.faq-item {
    background: white;
    margin-bottom: 15px;
    border: 1px solid var(--gris-piedra);
    padding: 20px;
}

.faq-item summary {
    font-weight: 700;
    cursor: pointer;
    color: var(--azul-medianoche);
    list-style: none;
    position: relative;
    padding-right: 30px;
}

.faq-item summary::after {
    content: '+';
    position: absolute;
    right: 0;
    color: var(--oro-viejo);
    font-size: 1.5rem;
}

.faq-item[open] summary::after { content: '-'; }

.faq-item p {
    margin-top: 15px;
    font-size: 0.95rem;
    color: var(--azul-cobalto);
}

/* FORZAR 3 COLUMNAS EN PÁGINA DE HERENCIAS */
@media (min-width: 1024px) {
    div.bufete-wrapper .benefits-grid {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 30px !important;
        width: 100% !important;
    }
}

/* Mejora de las tarjetas para que no parezcan "solo texto" */
.benefit-item {
    border: 1px solid var(--gris-piedra) !important;
    border-top: 4px solid var(--oro-viejo) !important;
    padding: 45px 30px !important;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: var(--transicion);
}

.benefit-item:hover {
    box-shadow: 0 15px 35px rgba(27, 38, 59, 0.1) !important;
    transform: translateY(-5px);
}

.benefit-icon {
    background: var(--blanco-hueso);
    width: 70px;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    margin-bottom: 20px;
    font-size: 2rem;
}

/* ============================================================
   COLUMNAS (HERENCIAS)
   ============================================================ */

/* Forzado de 3 columnas (Valores) */
@media (min-width: 1024px) {
    .premium-grid-row {
        display: grid !important;
        grid-template-columns: 1fr 1fr 1fr !important;
        gap: 30px !important;
        width: 100% !important;
        margin-top: -60px;
    }
}

/* Forzado de 4 columnas (Especialidades) */
@media (min-width: 1024px) {
    .stats-grid-4 {
        display: grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 20px !important;
        width: 100% !important;
    }
}

/* Estilo de tarjetas para evitar el efecto de "fila única" */
.premium-card {
    background: white !important;
    padding: 40px !important;
    border-right: 1px solid var(--gris-piedra) !important;
    height: 100% !important;
    display: flex;
    flex-direction: column;
}

.premium-card:last-child { border-right: none !important; }

/* Responsive móvil: volver a una columna */
@media (max-width: 768px) {
    .premium-grid-row, .stats-grid-4 {
        grid-template-columns: 1fr !important;
        margin-top: 0 !important;
    }
    .premium-card { border-right: none !important; border-bottom: 1px solid var(--gris-piedra); }
}/* End custom CSS */