/**
 * CTR Bienes Raíces - Estilos Página Proyectos
 */

.proyectos-page {
    padding: 8rem 2rem 4rem;
}

/* ===== FILTROS ===== */
.filtros-section {
    padding: var(--spacing-sm) 2rem;
    background-color: var(--color-white);
    box-shadow: var(--shadow-sm);
    position: relative;
    z-index: 100;
    transition: all 0.3s ease;
}

.proyectos-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
    gap: 2rem;
    margin-top: 3rem;
}

.proyecto-card {
    background: white;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
    transition: transform 0.3s ease;
    cursor: pointer;
}

.proyecto-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

/* ===== BOTÓN TOGGLE FILTROS ===== */
.btn-toggle-filtros {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    width: 100%;
    max-width: 300px;
    margin: 0 auto 1rem;
    padding: 0.75rem 1.5rem;
    background-color: var(--color-primary);
    color: var(--color-white);
    border: none;
    border-radius: 8px;
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: 0 2px 8px rgba(0, 61, 255, 0.3);
}

.btn-toggle-filtros:hover {
    background-color: var(--color-primary-dark);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 61, 255, 0.4);
}

.btn-toggle-filtros:active {
    transform: translateY(0);
}

.filtros-icon {
    font-size: 1rem;
    transition: transform 0.3s ease;
    display: inline-block;
}

/* Estilos globales para descripciones */
.proyecto-detail-description {
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    word-break: break-word !important;
    white-space: normal !important;
    max-width: 100% !important;
    width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
}

.proyecto-detail-description * {
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
    word-break: break-word !important;
    white-space: normal !important;
    max-width: 100% !important;
}

/* Asegurar que el contenedor padre también se ajuste */
.detalle-proyecto .container > div[style*="grid-template-columns: 2fr 1fr"] {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
}

.detalle-proyecto .container > div[style*="grid-template-columns: 2fr 1fr"] > div:first-child {
    min-width: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    overflow-x: hidden !important;
}

.detalle-proyecto .container {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
}

/* Estilos específicos para filtros de proyectos */
.filtros-section .filtros-avanzados {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)) !important;
    gap: 0.75rem !important;
    margin-top: var(--spacing-sm) !important;
    max-height: 2000px !important;
    opacity: 1 !important;
    transition: max-height 0.4s ease, opacity 0.3s ease, margin-top 0.3s ease !important;
    overflow: hidden !important;
}

.filtros-section .filtros-avanzados.filtros-ocultos {
    display: none !important;
    max-height: 0 !important;
    opacity: 0 !important;
    margin-top: 0 !important;
    overflow: hidden !important;
}

/* En móvil, ocultar filtros por defecto */
@media (max-width: 768px) {
    .filtros-section .filtros-avanzados {
        display: none !important;
    }
    
    .filtros-section .filtros-avanzados.filtros-visible-forced {
        display: grid !important;
    }
}

/* En PC, mostrar filtros por defecto */
@media (min-width: 769px) {
    .filtros-section .filtros-avanzados:not(.filtros-ocultos) {
        display: grid !important;
    }
}

.filtros-section .filtros-container {
    max-width: 1400px !important;
    margin: 0 auto !important;
}

.filtros-section .filtro-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 0.35rem !important;
}

.filtros-section .filtro-group label {
    font-family: var(--font-body) !important;
    font-weight: 500 !important;
    font-size: 0.9rem !important;
    color: var(--color-gray-dark) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
}

.filtros-section .filtro-group select,
.filtros-section .filtro-group input {
    padding: 0.6rem 0.75rem !important;
    border: 2px solid var(--color-gray-light) !important;
    border-radius: 4px !important;
    font-family: var(--font-body) !important;
    font-size: 0.95rem !important;
    transition: border-color var(--transition-fast) !important;
}

.filtros-section .filtro-group select:focus,
.filtros-section .filtro-group input:focus {
    outline: none !important;
    border-color: var(--color-primary) !important;
}

.filtros-section .filtros-acciones {
    display: flex !important;
    gap: var(--spacing-sm) !important;
    align-items: flex-end !important;
    grid-column: 1 / -1 !important;
}

.btn-filtrar {
    padding: 0.75rem 2rem;
    background-color: var(--color-primary);
    color: var(--color-white);
    border: none;
    border-radius: 4px;
    font-family: var(--font-body);
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.btn-filtrar:hover {
    background-color: var(--color-primary-dark);
    transform: translateY(-2px);
}

.btn-limpiar {
    padding: 0.75rem 2rem;
    background-color: transparent;
    color: var(--color-gray-medium);
    border: 2px solid var(--color-gray-light);
    border-radius: 4px;
    font-family: var(--font-body);
    font-weight: 500;
    cursor: pointer;
    transition: all var(--transition-fast);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.btn-limpiar:hover {
    border-color: var(--color-gray-medium);
    color: var(--color-gray-dark);
}

@media (max-width: 768px) {
    .proyectos-grid {
        grid-template-columns: 1fr;
    }
    
    .btn-toggle-filtros {
        max-width: 100%;
        font-size: 0.85rem;
        padding: 0.625rem 1.25rem;
    }
    
    .filtros-section .filtros-avanzados {
        grid-template-columns: 1fr !important;
    }
    
    .filtros-section .filtros-acciones {
        flex-direction: column !important;
        width: 100% !important;
    }
    
    .filtros-section .btn-filtrar,
    .filtros-section .btn-limpiar {
        width: 100% !important;
    }
    
    /* Descripciones responsive en móvil */
    .proyecto-detail-description {
        font-size: 1rem !important;
        line-height: 1.6 !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        word-break: break-word !important;
        padding: 0 !important;
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box !important;
        overflow-x: hidden !important;
        white-space: normal !important;
        display: block !important;
    }
    
    .proyecto-detail-description * {
        max-width: 100% !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        word-break: break-word !important;
        white-space: normal !important;
    }
    
    .detalle-proyecto .container {
        padding: 2rem 1rem !important;
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box !important;
        overflow-x: hidden !important;
    }
    
    .detalle-proyecto .container > div:first-child {
        gap: 2rem !important;
        margin-bottom: 2rem !important;
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }
    
    .detalle-proyecto .container > div:first-child > div:first-child {
        max-width: 100% !important;
        width: 100% !important;
        box-sizing: border-box !important;
        overflow-x: hidden !important;
    }
    
    .proyecto-video-description {
        font-size: 0.95rem !important;
        line-height: 1.6 !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        word-break: break-word !important;
        max-width: 100% !important;
    }
}

/* ===== MODO OSCURO ===== */
[data-theme="dark"] .proyectos-page {
    background-color: var(--bg-primary);
}

[data-theme="dark"] .propiedades-header {
    background: linear-gradient(135deg, #002a7f 0%, #003dff 50%, #4d80ff 100%);
}

[data-theme="dark"] .filtros-section {
    background-color: var(--bg-secondary);
    border-bottom: 1px solid rgba(0, 61, 255, 0.2);
}

[data-theme="dark"] .btn-toggle-filtros {
    background-color: var(--color-primary);
    box-shadow: 0 2px 8px rgba(0, 61, 255, 0.4);
}

[data-theme="dark"] .btn-toggle-filtros:hover {
    background-color: var(--color-primary-dark);
    box-shadow: 0 4px 12px rgba(0, 61, 255, 0.5);
}

[data-theme="dark"] .filtros-section .filtro-group label {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .filtro-group label {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .filtro-group select,
[data-theme="dark"] .filtro-group input {
    background-color: var(--bg-primary);
    border-color: rgba(0, 61, 255, 0.3);
    color: var(--text-primary);
}

[data-theme="dark"] .filtro-group select:focus,
[data-theme="dark"] .filtro-group input:focus {
    border-color: var(--color-primary);
    background-color: var(--bg-primary);
}

[data-theme="dark"] .filtro-group select option {
    background-color: var(--bg-primary);
    color: var(--text-primary);
}

[data-theme="dark"] .btn-limpiar {
    background-color: transparent;
    color: var(--text-secondary);
    border-color: rgba(0, 61, 255, 0.3);
}

[data-theme="dark"] .btn-limpiar:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background-color: rgba(0, 61, 255, 0.1);
}

[data-theme="dark"] .propiedades-section {
    background-color: var(--bg-primary);
}

[data-theme="dark"] .propiedades-stats {
    background-color: var(--bg-secondary);
    border: 1px solid rgba(0, 61, 255, 0.2);
}

[data-theme="dark"] .propiedades-stats p {
    color: var(--text-primary);
}

[data-theme="dark"] .propiedades-stats strong {
    color: var(--color-primary);
}

[data-theme="dark"] .proyecto-card {
    background: var(--bg-secondary) !important;
    border: 1px solid rgba(0, 61, 255, 0.2) !important;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.5) !important;
}

[data-theme="dark"] .proyecto-card:hover {
    box-shadow: 0 8px 32px rgba(0, 61, 255, 0.4) !important;
    border-color: var(--color-primary) !important;
}

[data-theme="dark"] .proyecto-card-content h3 {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .proyecto-card-content p {
    color: var(--text-secondary) !important;
}

[data-theme="dark"] .proyecto-card-content p svg {
    fill: var(--text-secondary);
}

[data-theme="dark"] .proyecto-card-content > div {
    color: var(--color-primary) !important;
}

[data-theme="dark"] .sin-resultados {
    background-color: var(--bg-secondary);
    border: 1px solid rgba(0, 61, 255, 0.2);
}

[data-theme="dark"] .sin-resultados svg {
    fill: var(--text-light);
}

[data-theme="dark"] .sin-resultados h3 {
    color: var(--text-primary);
}

[data-theme="dark"] .sin-resultados p {
    color: var(--text-secondary);
}

/* ===== MODO OSCURO - DETALLE PROYECTO ===== */
[data-theme="dark"] .detalle-proyecto {
    background-color: var(--bg-primary) !important;
}

/* Títulos */
[data-theme="dark"] .proyecto-detail-title {
    color: var(--text-primary) !important;
}

[data-theme="dark"] .proyecto-video-title {
    color: var(--text-primary) !important;
}

/* Descripción del proyecto */
[data-theme="dark"] .proyecto-detail-description,
[data-theme="dark"] .proyecto-detail-description[style*="color: var(--color-gray-medium)"] {
    color: var(--text-secondary) !important;
}

/* Contenedor de información (sidebar) */
[data-theme="dark"] .proyecto-info-box,
[data-theme="dark"] .proyecto-info-box[style*="background-color"] {
    background-color: var(--bg-secondary) !important;
    border: 1px solid rgba(0, 61, 255, 0.2) !important;
}

/* Labels dentro del contenedor de información */
[data-theme="dark"] .proyecto-info-label,
[data-theme="dark"] .proyecto-info-label[style*="color: var(--color-gray-medium)"] {
    color: var(--text-secondary) !important;
}

/* Textos dentro del contenedor de información */
[data-theme="dark"] .proyecto-info-text,
[data-theme="dark"] .proyecto-info-text[style*="color: var(--color-gray-dark)"] {
    color: var(--text-primary) !important;
}

/* Precio - mantener color primario pero asegurar visibilidad */
[data-theme="dark"] .proyecto-info-box p[style*="color: var(--color-primary)"] {
    color: var(--color-primary) !important;
}

/* Características */
[data-theme="dark"] .proyecto-caracteristica-box,
[data-theme="dark"] .proyecto-caracteristica-box[style*="background-color"] {
    background-color: var(--bg-secondary) !important;
    border: 1px solid rgba(0, 61, 255, 0.2) !important;
}

[data-theme="dark"] .proyecto-caracteristica-text,
[data-theme="dark"] .proyecto-caracteristica-text[style*="color: var(--color-gray-medium)"] {
    color: var(--text-secondary) !important;
}

/* Descripción de videos adicionales */
[data-theme="dark"] .proyecto-video-description {
    color: var(--text-secondary) !important;
}

/* Galería */
[data-theme="dark"] .detalle-proyecto .galeria-proyecto {
    background-color: transparent;
}