/* ============================================
   LOGYSER — CONTACTO.CSS
   Estilos específicos de contacto.html
   ============================================ */

/* ==========================================
   1. GRID PRINCIPAL DE CONTACTO
   ========================================== */
.contacto-section {
    padding-block: var(--space-24);
    background: var(--color-white);
}

.contacto__grid {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: var(--space-12);
    align-items: start;
}

/* ==========================================
   2. PANEL DE INFORMACIÓN
   ========================================== */
.contacto__info {}

.contacto__info-intro {
    font-size: var(--text-base);
    color: var(--color-text-muted);
    line-height: var(--leading-loose);
    margin-bottom: var(--space-8);
}

/* Lista vertical de datos de contacto */
.contacto__cards {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    margin-bottom: var(--space-5);
}

.contacto-card {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    padding: var(--space-4) var(--space-5);
    background: var(--color-bg);
    border-radius: var(--radius-lg);
    border: 1px solid var(--color-border);
    transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

.contacto-card:hover {
    transform: translateX(4px);
    box-shadow: var(--shadow-md);
    border-color: var(--color-primary);
}

.contacto-card__icon {
    flex-shrink: 0;
    width: 42px;
    height: 42px;
    background: var(--color-primary);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.contacto-card__icon svg {
    width: 20px;
    height: 20px;
}

.contacto-card__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.contacto-card__label {
    font-family: var(--font-mono);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--color-primary);
    font-weight: var(--weight-medium);
}

.contacto-card__value {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--color-text);
    line-height: var(--leading-snug);
}

.contacto-card__value a {
    color: inherit;
    transition: color var(--transition-fast);
}

.contacto-card__value a:hover {
    color: var(--color-primary);
}

.contacto-card__sub {
    font-size: var(--text-xs);
    color: var(--color-text-light);
}

/* Horarios — franja integrada, misma familia visual que las cards */
.contacto__horarios {
    background: var(--color-dark);
    border-radius: var(--radius-lg);
    padding: var(--space-5) var(--space-6);
    color: var(--color-white);
    border: 1px solid rgba(255, 255, 255, 0.06);
}

.contacto__horarios-title {
    font-family: var(--font-display);
    font-size: var(--text-sm);
    font-weight: var(--weight-bold);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-primary);
    margin-bottom: var(--space-4);
}

.contacto__horario-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-block: var(--space-2);
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    font-size: var(--text-sm);
}

.contacto__horario-row:last-of-type {
    border-bottom: none;
}

.contacto__horario-dia {
    color: rgba(255, 255, 255, 0.65);
}

.contacto__horario-hora {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--color-primary);
    font-weight: var(--weight-medium);
}

.contacto__horario-cobertura {
    margin-top: var(--space-4);
    padding-top: var(--space-3);
    border-top: 1px solid rgba(255, 255, 255, 0.07);
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--text-xs);
    color: rgba(255, 255, 255, 0.5);
}

.contacto__horario-cobertura::before {
    content: '';
    display: block;
    width: 8px;
    height: 8px;
    border-radius: var(--radius-full);
    background: #4CAF50;
    flex-shrink: 0;
    animation: pulse-green 2s infinite;
}

@keyframes pulse-green {

    0%,
    100% {
        opacity: 1;
    }

    50% {
        opacity: 0.4;
    }
}

@media (max-width: 540px) {
    .contacto__cards {
        grid-template-columns: 1fr;
    }
}

/* ==========================================
   3. FORMULARIO DE CONTACTO
   ========================================== */
.contacto__form-box {
    background: var(--color-bg);
    border-radius: var(--radius-xl);
    padding: var(--space-10);
    border: 1px solid var(--color-border);
    box-shadow: var(--shadow-lg);
}

.contacto__form-title {
    font-size: var(--text-2xl);
    font-weight: var(--weight-black);
    color: var(--color-text);
    margin-bottom: var(--space-2);
    text-transform: uppercase;
}

.contacto__form-subtitle {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-8);
    line-height: var(--leading-snug);
}

@media (max-width: 960px) {
    .contacto__grid {
        grid-template-columns: 1fr;
        gap: var(--space-10);
    }
}

@media (max-width: 540px) {
    .contacto__form-box {
        padding: var(--space-6);
    }
}

/* ==========================================
   4. SEDES — franja horizontal de datos
   ========================================== */
.sedes-section {
    padding-block: var(--space-16);
    background: var(--color-dark);
}

.sedes-section .section-label {
    color: var(--color-primary);
}

.sedes-section .section-title {
    color: var(--color-white);
}

.sedes-strip {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-xl);
    overflow: hidden;
    margin-top: var(--space-10);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.sedes-strip__item {
    background: rgba(255, 255, 255, 0.03);
    padding: var(--space-8) var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    transition: background var(--transition-base);
}

.sedes-strip__item:hover {
    background: rgba(255, 255, 255, 0.07);
}

.sedes-strip__icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-md);
    background: rgba(242, 92, 0, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
    flex-shrink: 0;
}

.sedes-strip__icon svg {
    width: 20px;
    height: 20px;
}

.sedes-strip__label {
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: rgba(255, 255, 255, 0.4);
}

.sedes-strip__value {
    font-size: var(--text-base);
    font-weight: var(--weight-semibold);
    color: var(--color-white);
    line-height: var(--leading-snug);
}

.sedes-strip__value a {
    color: inherit;
    transition: color var(--transition-fast);
}

.sedes-strip__value a:hover {
    color: var(--color-primary);
}

.sedes-strip__sub {
    font-size: var(--text-xs);
    color: rgba(255, 255, 255, 0.4);
    line-height: var(--leading-snug);
}

@media (max-width: 900px) {
    .sedes-strip {
        grid-template-columns: 1fr 1fr;
    }
}

@media (max-width: 540px) {
    .sedes-strip {
        grid-template-columns: 1fr;
    }
}

/* ==========================================
   5. CANAL DE DENUNCIAS
   ========================================== */
.denuncias-section {
    padding-block: var(--space-20);
    background: var(--color-dark);
}

.denuncias__grid {
    display: grid;
    grid-template-columns: 1fr 360px;
    gap: var(--space-16);
    align-items: center;
}

.denuncias__label {
    display: inline-flex;
    align-items: center;
    gap: var(--space-2);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin-bottom: var(--space-4);
}

.denuncias__label::before {
    content: '';
    display: block;
    width: 8px;
    height: 8px;
    border-radius: var(--radius-full);
    background: var(--color-primary);
}

.denuncias__title {
    font-size: var(--text-3xl);
    font-weight: var(--weight-black);
    color: var(--color-white);
    margin-bottom: var(--space-4);
    text-transform: uppercase;
}

.denuncias__text {
    font-size: var(--text-base);
    color: rgba(255, 255, 255, 0.65);
    line-height: var(--leading-loose);
    max-width: 560px;
    margin-bottom: var(--space-8);
}

.denuncias__features {
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
}

.denuncias__feature {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    font-size: var(--text-sm);
    color: rgba(255, 255, 255, 0.7);
}

.denuncias__feature-icon {
    width: 28px;
    height: 28px;
    flex-shrink: 0;
    background: rgba(242, 92, 0, 0.15);
    border-radius: var(--radius-full);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-primary);
}

.denuncias__feature-icon svg {
    width: 14px;
    height: 14px;
}

.denuncias__qr-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-4);
    flex-shrink: 0;
}

.denuncias__qr {
    width: 340px;
    height: auto;
    border-radius: var(--radius-xl);
    border: 3px solid rgba(255, 255, 255, 0.12);
    object-fit: cover;
    display: block;
    box-shadow: 0 20px 48px rgba(0, 0, 0, 0.35);
}

.denuncias__qr-label {
    font-size: var(--text-xs);
    color: rgba(255, 255, 255, 0.4);
    text-align: center;
    font-family: var(--font-mono);
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

@media (max-width: 960px) {
    .denuncias__qr {
        width: 260px;
    }
}

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

    .denuncias__qr-wrap {
        flex-direction: row;
        align-items: center;
        gap: var(--space-6);
    }

    .denuncias__qr {
        width: 200px;
    }
}