/* ═══════════════════════════════════════════════════════
   ROESAN AGROPECUARIA — Custom Styles v2.0
   ═══════════════════════════════════════════════════════ */

/* ─── CSS VARIABLES ────────────────────────────────────── */
:root {
    --color-primary:    #4A5C2F;
    --color-primary-light: #5A7A35; /* Ajustado para contraste AA 4.92:1 sobre blanco */
    --color-secondary:  #C8A96E;
    --color-bg:         #F5F0E8;
    --color-bg-alt:     #FDFAF4;
    --color-dark:       #3D2B1F;
    --color-light:      #FDFAF4;
    --color-text:       #3D2B1F;
    --color-text-light: #6B5D52;
    --font-heading:     "Playfair Display", Georgia, serif;
    --font-body:        "Lato", sans-serif;
    --radius:           6px;
    --radius-lg:        12px;
    --shadow:           0 4px 20px rgba(61, 43, 31, 0.08);
    --shadow-hover:     0 8px 30px rgba(61, 43, 31, 0.15);
    --transition:       all 0.3s ease;
    --container:        1140px;
    --section-gap:      clamp(60px, 8vw, 100px);
}

/* ─── BASE ─────────────────────────────────────────────── */
body {
    background-color: var(--color-bg);
    font-family: var(--font-body);
    color: var(--color-dark);
    line-height: 1.7;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    line-height: 1.2;
    color: var(--color-dark);
}

/* ─── SKIP LINK ────────────────────────────────────────── */
.skip-link {
    position: absolute;
    top: -40px;
    left: 0;
    background: var(--color-primary);
    color: var(--color-light);
    padding: 8px 16px;
    z-index: 10000;
    transition: top 0.2s ease;
    text-decoration: none;
    font-size: 14px;
    border-radius: 0 0 var(--radius) 0;
}
.skip-link:focus {
    top: 0;
    outline: 2px solid var(--color-secondary);
}

/* ─── ECO BADGE ────────────────────────────────────────── */
.roesan-eco-badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--color-primary);
    color: var(--color-light);
    padding: 8px 18px;
    border-radius: 24px;
    font-size: 0.85em;
    font-family: var(--font-body);
    font-weight: 400;
    letter-spacing: 0.3px;
    transition: var(--transition);
}
.roesan-eco-badge:hover {
    background: var(--color-primary-light);
    transform: translateY(-1px);
}

/* ─── CONTACTO ADDRESS ─────────────────────────────────── */
.roesan-contacto {
    font-style: normal;
    line-height: 1.8;
}
.roesan-contacto a {
    color: var(--color-primary);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: var(--transition);
}
.roesan-contacto a:hover {
    border-bottom-color: var(--color-primary);
}

/* ─── PHONE LINK ───────────────────────────────────────── */
.roesan-phone {
    font-weight: 700;
    color: var(--color-primary);
    text-decoration: none;
}
.roesan-phone:hover {
    color: var(--color-primary-light);
}

/* ─── HORARIO ──────────────────────────────────────────── */
.roesan-horario {
    font-size: 0.95em;
    color: var(--color-text-light);
}

/* ─── CF7 FORMULARIOS ──────────────────────────────────── */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea,
.wpcf7 select {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid #d4cdc4;
    border-radius: var(--radius);
    font-family: var(--font-body);
    font-size: 1em;
    margin-bottom: 16px;
    background: var(--color-light);
    color: var(--color-dark);
    transition: var(--transition);
}
.wpcf7 input:focus,
.wpcf7 textarea:focus,
.wpcf7 select:focus {
    border-color: var(--color-primary);
    outline: 2px solid var(--color-primary);
    outline-offset: 2px;
    box-shadow: 0 0 0 3px rgba(74, 92, 47, 0.15);
}
.wpcf7 label {
    display: block;
    font-weight: 700;
    margin-bottom: 4px;
    color: var(--color-dark);
    font-size: 0.95em;
}
.wpcf7 input[type="submit"] {
    background: var(--color-primary);
    color: var(--color-light);
    border: none;
    padding: 14px 36px;
    border-radius: var(--radius);
    cursor: pointer;
    font-size: 1em;
    font-weight: 700;
    letter-spacing: 0.5px;
    transition: var(--transition);
}
.wpcf7 input[type="submit"]:hover {
    background: var(--color-primary-light);
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}
.wpcf7 .wpcf7-acceptance label {
    font-size: 0.9em;
    color: var(--color-text-light);
}

/* ─── ELEMENTOR OVERRIDES ──────────────────────────────── */

/* Secciones con separador decorativo */
.roesan-divider-section .elementor-divider-separator {
    border-color: var(--color-secondary) !important;
    width: 60px;
}

/* Cards con hover */
.roesan-card {
    background: var(--color-light);
    border-radius: var(--radius-lg);
    padding: 30px;
    transition: var(--transition);
    box-shadow: var(--shadow);
}
.roesan-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-hover);
}

/* Stats bar counters */
.roesan-stat .elementor-counter-number-wrapper {
    font-family: var(--font-heading);
    font-size: 3em;
    font-weight: 700;
    color: var(--color-secondary);
}
.roesan-stat .elementor-counter-title {
    font-family: var(--font-body);
    font-size: 0.95em;
    color: var(--color-light);
    opacity: 0.85;
    margin-top: 8px;
}

/* CTA Buttons enhanced */
.roesan-btn-primary .elementor-button {
    background: var(--color-primary) !important;
    border-radius: var(--radius) !important;
    padding: 14px 32px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px;
    transition: var(--transition) !important;
}
.roesan-btn-primary .elementor-button:hover {
    background: var(--color-primary-light) !important;
    transform: translateY(-2px);
    box-shadow: var(--shadow);
}
.roesan-btn-outline .elementor-button {
    background: transparent !important;
    border: 2px solid var(--color-primary) !important;
    color: var(--color-primary) !important;
    border-radius: var(--radius) !important;
}
.roesan-btn-outline .elementor-button:hover {
    background: var(--color-primary) !important;
    color: var(--color-light) !important;
}

/* Process steps line */
.roesan-process .elementor-icon-box-icon {
    background: var(--color-primary);
    color: var(--color-light);
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 15px;
}

/* Gallery hover */
.roesan-gallery .e-gallery-item {
    border-radius: var(--radius-lg);
    overflow: hidden;
}

/* Testimonial quote */
.roesan-quote blockquote {
    border-left: 4px solid var(--color-secondary);
    padding-left: 20px;
    font-style: italic;
    font-size: 1.1em;
    color: var(--color-text-light);
}

/* Icon box enhanced */
.roesan-icon-box .elementor-icon {
    color: var(--color-primary);
    transition: var(--transition);
}
.roesan-icon-box:hover .elementor-icon {
    color: var(--color-primary-light);
    transform: scale(1.1);
}

/* ─── ACCESSIBILITY FOCUS STYLES ──────────────────────── */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[tabindex]:focus-visible {
    outline: 3px solid var(--color-primary);
    outline-offset: 2px;
}

.elementor-button:focus-visible {
    outline: 3px solid var(--color-secondary);
    outline-offset: 2px;
}

/* Ensure icon-boxes have adequate spacing */
.elementor-icon-box-wrapper {
    gap: 15px;
}

/* Better link visibility */
.elementor-widget-text-editor a {
    color: var(--color-primary);
    text-decoration: underline;
    text-underline-offset: 2px;
}
.elementor-widget-text-editor a:hover {
    color: var(--color-primary-light);
}

/* Counter section white text on dark bg */
.elementor-section[style*="background-color"] .elementor-counter-title,
.elementor-section .elementor-counter-title {
    margin-top: 8px;
}

/* ─── RESPONSIVE ───────────────────────────────────────── */
@media (max-width: 767px) {
    .roesan-eco-badge {
        font-size: 0.78em;
        padding: 6px 14px;
    }
    /* Ensure sections don't have excessive padding on mobile */
    .elementor-section {
        padding-left: 15px !important;
        padding-right: 15px !important;
    }
    /* Stack icon-boxes vertically */
    .elementor-icon-box-wrapper {
        text-align: center;
    }
}
