/* ── Variables ── */
html.dark-mode {
    --bg-primary:     #0f1117;
    --bg-secondary:   #1a1d27;
    --bg-card:        #1e2130;
    --bg-elevated:    #252838;
    --text-primary:   #f0f2f8;
    --text-secondary: #9ba3c0;
    --text-muted:     #5c6585;
    --border-color:   #2a2f45;
    --border-light:   #1e2336;
    --accent-color:   #60a5fa;
    --primary-color:  #3b82f6;
    --shadow-sm:      0 1px 4px rgba(0,0,0,0.4);
    --shadow-md:      0 4px 16px rgba(0,0,0,0.5);
    --shadow-lg:      0 8px 32px rgba(0,0,0,0.6);
}

/* ── Body base ── */
html.dark-mode body {
    background-color: var(--bg-primary);
    color: var(--text-primary);
}

/* ============================================================
   BARRA DE INDICADORES ECONÓMICOS
   ============================================================ */
html.dark-mode .economic-indicators-bar {
    background: linear-gradient(135deg, #0d1526 0%, #111827 100%);
    border-bottom: 1px solid rgba(255,255,255,0.06);
}

html.dark-mode .indicator-label {
    opacity: 0.75;
}

html.dark-mode .indicator-value {
    color: #93c5fd;
}

html.dark-mode .indicator-date {
    color: rgba(255,255,255,0.4);
}

/* ============================================================
   NAVBAR
   ============================================================ */
html.dark-mode .navbar {
    background: rgba(15, 17, 23, 0.97);
    border-bottom: 1px solid var(--border-color);
    box-shadow: 0 2px 12px rgba(0,0,0,0.5);
}

html.dark-mode .navbar.scrolled {
    background: rgba(15, 17, 23, 0.99);
    box-shadow: 0 2px 20px rgba(0,0,0,0.7);
}

html.dark-mode .navbar-brand .logo {
    filter: brightness(0) invert(1);
    opacity: 0.92;
}

html.dark-mode .navbar-menu a {
    color: #c8d0e8;
}

html.dark-mode .navbar-menu a:hover,
html.dark-mode .navbar-menu a.active {
    color: #93c5fd;
}

html.dark-mode .navbar-menu a::after {
    background-color: #3b82f6;
}

html.dark-mode .navbar-tagline span {
    color: #6b7a9e;
}

html.dark-mode .navbar-tagline-brand {
    color: #93c5fd !important;
}

html.dark-mode .navbar-lang-text {
    color: #9ba3c0;
}

html.dark-mode .navbar-lang-text .lang-option {
    color: #5c6585;
}

html.dark-mode .navbar-lang-text .lang-option.active {
    color: #f0f2f8;
}

html.dark-mode .navbar-lang-text .lang-option:hover {
    color: #f59e0b;
}

html.dark-mode .navbar-lang-text .separator {
    color: #2a2f45;
}

html.dark-mode .navbar-indicator {
    background: rgba(59, 130, 246, 0.12);
    border: 1px solid rgba(59, 130, 246, 0.2);
    color: #93c5fd;
}

html.dark-mode .navbar-indicator i {
    color: #60a5fa;
}

html.dark-mode .navbar-uf-value {
    color: #93c5fd;
}

html.dark-mode .navbar-theme {
    color: #9ba3c0;
}

html.dark-mode .navbar-theme:hover {
    color: #f59e0b;
    background: rgba(245, 158, 11, 0.12);
}

html.dark-mode .navbar-toggle span {
    background: #c8d0e8;
}

html.dark-mode .dropdown-menu {
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-lg);
}

html.dark-mode .dropdown-menu a {
    color: var(--text-secondary);
}

html.dark-mode .dropdown-menu a:hover {
    background: var(--bg-secondary);
    color: var(--text-primary);
}

html.dark-mode .dropdown-mega {
    background: var(--bg-card);
    border-color: var(--border-color);
    box-shadow: 0 16px 48px rgba(0,0,0,0.6);
}

html.dark-mode .dropdown-container {
    background: var(--bg-card);
    border-bottom-color: var(--border-color);
}

html.dark-mode .dropdown-section h3 {
    color: #60a5fa;
}

html.dark-mode .dropdown-section ul li a {
    color: var(--text-secondary);
}

html.dark-mode .dropdown-section ul li a:hover {
    color: var(--text-primary);
}

html.dark-mode .dropdown-featured {
    background: var(--bg-secondary);
    border-color: var(--border-color);
}

html.dark-mode .featured-content h4 {
    color: var(--text-primary);
}

html.dark-mode .featured-content p {
    color: var(--text-secondary);
}

html.dark-mode .featured-content a {
    color: #60a5fa;
}

html.dark-mode .dropdown-footer {
    background: linear-gradient(to bottom, var(--bg-card), var(--bg-secondary));
}

html.dark-mode .dropdown-footer p {
    color: var(--text-secondary);
}

html.dark-mode .dropdown-footer .btn {
    background: transparent;
    color: #60a5fa;
    border-color: #3b82f6;
}

html.dark-mode .dropdown-footer .btn:hover {
    background: #3b82f6;
    color: white;
}

/* ============================================================
   FOOTER
   ============================================================ */
html.dark-mode .footer {
    background: #080b12;
    border-top: 1px solid var(--border-color);
}

html.dark-mode .footer h3 {
    color: #f0f2f8;
}

html.dark-mode .footer-description {
    color: rgba(155, 163, 192, 0.8);
}

html.dark-mode .footer a {
    color: rgba(155, 163, 192, 0.75);
}

html.dark-mode .footer a:hover {
    color: #93c5fd;
}

html.dark-mode .footer ul li {
    color: rgba(155, 163, 192, 0.75);
}

html.dark-mode .footer-social a {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.08);
}

html.dark-mode .footer-social a:hover {
    background: var(--primary-color);
    border-color: var(--primary-color);
}

html.dark-mode .footer-bottom {
    border-top: 1px solid rgba(255,255,255,0.06);
    color: rgba(155, 163, 192, 0.5);
}

html.dark-mode .footer-bottom a {
    color: #f59e0b;
}

html.dark-mode .footer-bottom a:hover {
    color: #fbbf24;
}

/* ============================================================
   ÍCONO SOL / LUNA en el botón toggle
   ============================================================ */

/* Modo claro: mostrar luna (invita a activar dark) */
.navbar-theme .sun-icon  { display: flex; }
.navbar-theme .moon-icon { display: none; }

/* Modo oscuro: mostrar sol (invita a volver a claro) */
html.dark-mode .navbar-theme .sun-icon  { display: none; }
html.dark-mode .navbar-theme .moon-icon { display: flex; }

.navbar-theme {
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary, #6b7280);
    border-radius: 8px;
    transition: color 0.2s ease, background 0.2s ease, transform 0.3s ease;
    width: 36px;
    height: 36px;
}

.navbar-theme:hover {
    color: #f59e0b;
    background: rgba(245, 158, 11, 0.1);
}

/* ============================================================
   TRANSICIÓN SUAVE al cambiar tema
   ============================================================ */
body,
.navbar,
.footer,
.economic-indicators-bar {
    transition:
        background-color 0.3s ease,
        color 0.3s ease,
        border-color 0.3s ease;
}

/* Hero */
html.dark-mode .faq-hero {
    background: linear-gradient(135deg, #060c1f 0%, #0d1a3a 45%, #0f2060 100%);
}

html.dark-mode .faq-hero-label {
    border-color: rgba(255,255,255,0.15);
    color: rgba(255,255,255,0.55);
}

html.dark-mode .faq-hero p {
    color: rgba(255,255,255,0.65);
}

/* Buscador */
html.dark-mode .faq-search {
    background: var(--bg-card);
    border-color: var(--border-color);
    color: var(--text-primary);
    box-shadow: 0 4px 20px rgba(0,0,0,0.4);
}

html.dark-mode .faq-search::placeholder {
    color: var(--text-muted);
}

html.dark-mode .faq-search:focus {
    border-color: var(--accent-color);
    box-shadow: 0 4px 24px rgba(59,130,246,0.2);
}

html.dark-mode .faq-search-icon {
    stroke: var(--text-muted);
}

/* Tabs de filtro */
html.dark-mode .faq-filtros {
    background: var(--bg-secondary);
    border-bottom-color: var(--border-color);
}

html.dark-mode .faq-tab {
    background: var(--bg-card);
    border-color: var(--border-color);
    color: var(--text-secondary);
}

html.dark-mode .faq-tab:hover {
    border-color: var(--accent-color);
    color: var(--accent-color);
    box-shadow: 0 4px 12px rgba(59,130,246,0.15);
}

html.dark-mode .faq-tab.active {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: #fff;
    box-shadow: 0 4px 16px rgba(59,130,246,0.35);
}

/* Área principal */
html.dark-mode .faq-main {
    background: var(--bg-primary);
}

/* Encabezado de sección */
html.dark-mode .faq-section-icon {
    background: linear-gradient(135deg, #1d4ed8, #3b82f6);
    box-shadow: 0 4px 14px rgba(59,130,246,0.3);
}

html.dark-mode .faq-section-title {
    color: #93c5fd;
}

html.dark-mode .faq-section-num {
    color: var(--accent-color);
}

/* Cards FAQ */
html.dark-mode .faq-item {
    background: var(--bg-card);
    border-color: var(--border-color);
}

html.dark-mode .faq-item:hover {
    border-color: #3b82f6;
    box-shadow: 0 4px 20px rgba(59,130,246,0.12);
}

html.dark-mode .faq-item.open {
    border-color: var(--accent-color);
    box-shadow: 0 6px 24px rgba(59,130,246,0.18);
}

/* Texto de pregunta */
html.dark-mode .faq-q-num {
    color: var(--accent-color);
}

html.dark-mode .faq-q-text {
    color: var(--text-primary);
}

html.dark-mode .faq-item.open .faq-q-text {
    color: #93c5fd;
}

/* Ícono +/x */
html.dark-mode .faq-icon-wrap {
    border-color: var(--border-color);
}

html.dark-mode .faq-icon-wrap svg {
    stroke: var(--text-secondary);
}

html.dark-mode .faq-item.open .faq-icon-wrap {
    background: var(--primary-color);
    border-color: var(--primary-color);
}

html.dark-mode .faq-item.open .faq-icon-wrap svg {
    stroke: white;
}

/* Respuesta */
html.dark-mode .faq-answer-inner {
    border-top-color: var(--border-color);
}

html.dark-mode .faq-answer-inner p {
    color: var(--text-secondary);
}

/* Highlight bar */
html.dark-mode .faq-answer-inner .highlight {
    background: rgba(59,130,246,0.08);
    border-left-color: var(--accent-color);
}

html.dark-mode .faq-answer-inner .highlight p {
    color: #93c5fd;
}

/* CTA banner */
html.dark-mode .faq-cta {
    background: linear-gradient(135deg, #0d1a3a 0%, #1a3575 100%);
    border: 1px solid rgba(59,130,246,0.2);
}

html.dark-mode .faq-cta h3 {
    color: #f0f2f8;
}

html.dark-mode .faq-cta p {
    color: rgba(255,255,255,0.65);
}

html.dark-mode .faq-cta .btn-white {
    background: var(--bg-elevated);
    color: #93c5fd;
    border: 1px solid rgba(59,130,246,0.3);
    box-shadow: 0 4px 20px rgba(0,0,0,0.3);
}

html.dark-mode .faq-cta .btn-white:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

html.dark-mode .faq-hero::after {
    background: linear-gradient(to bottom right, transparent 49.5%, var(--bg-primary) 50%);
}

/* ============================================================
   NOSOTROS PAGE — DARK MODE
   ============================================================ */

/* ── Hero ── */
html.dark-mode .nosotros-hero {
    background: linear-gradient(135deg, #060c1f 0%, #0d1a3a 45%, #0f2060 100%);
}

html.dark-mode .nosotros-hero-overlay {
    background: rgba(0, 0, 0, 0.3);
}

html.dark-mode .nosotros-hero h1 {
    color: var(--text-primary);
}

/* ── Tabs de navegación ── */
html.dark-mode .nosotros-tabs-section {
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
}

html.dark-mode .nosotros-tab {
    color: var(--text-secondary);
    border-color: var(--border-color);
}

html.dark-mode .nosotros-tab:hover {
    color: var(--accent-color);
    border-color: var(--accent-color);
}

html.dark-mode .nosotros-tab.active {
    color: var(--accent-color);
    border-color: var(--accent-color);
}

/* ── Sección ADN / Visión ── */
html.dark-mode .nosotros-vision {
    background: var(--bg-primary);
}

html.dark-mode .nosotros-vision h2 {
    color: var(--text-primary);
}

html.dark-mode .nosotros-vision p {
    color: var(--text-secondary);
}

/* Video thumbnail */
html.dark-mode .video-thumbnail {
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-lg);
}

/* ── Sección Impacto (Misión/Visión cards) ── */
html.dark-mode .nosotros-impacto {
    background: var(--bg-secondary);
}

html.dark-mode .nosotros-impacto .section-title {
    color: var(--text-primary);
}

html.dark-mode .impacto-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-md);
}

html.dark-mode .impacto-card:hover {
    border-color: #3b82f6;
    box-shadow: 0 8px 32px rgba(59,130,246,0.15);
}

html.dark-mode .impacto-contenido h3 {
    color: #93c5fd;
}

html.dark-mode .impacto-contenido p {
    color: var(--text-secondary);
}

/* ── Propuesta de Valor (sección oscura con overlay) ── */
html.dark-mode .nosotros-mision {
    background: linear-gradient(135deg, #060c1f 0%, #0d1535 100%);
}

html.dark-mode .mision-overlay {
    background: rgba(0, 0, 0, 0.45);
}

html.dark-mode .nosotros-mision h2 {
    color: var(--text-primary);
}

html.dark-mode .nosotros-mision p {
    color: rgba(255,255,255,0.7);
}

html.dark-mode .btn-white-outline {
    border-color: rgba(255,255,255,0.4);
    color: rgba(255,255,255,0.85);
}

html.dark-mode .btn-white-outline:hover {
    background: rgba(255,255,255,0.1);
    border-color: white;
    color: white;
}

/* ── Sello 360° ── */
html.dark-mode .nosotros-valores {
    background: var(--bg-primary);
}

html.dark-mode .valores-texto h2 {
    color: var(--text-primary);
}

html.dark-mode .valores-texto > p {
    color: var(--text-secondary);
}

html.dark-mode .valores-lista li {
    border-bottom-color: var(--border-color);
}

html.dark-mode .valores-lista li strong {
    color: #93c5fd;
}

html.dark-mode .valores-lista li span {
    color: var(--text-secondary);
}

html.dark-mode .valores-imagen img {
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-lg);
}

/* ── Compromiso de Transparencia ── */
html.dark-mode .nosotros-sostenibilidad {
    background: var(--bg-secondary);
}

html.dark-mode .sostenibilidad-contenido h2 {
    color: var(--text-primary);
}

html.dark-mode .sostenibilidad-contenido > p {
    color: var(--text-secondary);
}

html.dark-mode .compromiso-puntos h4 {
    color: #93c5fd !important;
}

html.dark-mode .compromiso-puntos p {
    color: var(--text-secondary);
}

html.dark-mode .sostenibilidad-imagen img {
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-lg);
}

html.dark-mode .btn-primary-outline {
    border-color: #3b82f6;
    color: #93c5fd;
}

html.dark-mode .btn-primary-outline:hover {
    background: #3b82f6;
    color: white;
}

/* ── CTA Final ── */
html.dark-mode .nosotros-cta-final {
    background: linear-gradient(135deg, #060c1f 0%, #1a3575 100%);
    border-top: 1px solid rgba(59,130,246,0.2);
}

html.dark-mode .nosotros-cta-final h2 {
    color: var(--text-primary);
}

html.dark-mode .nosotros-cta-final .btn-white {
    background: var(--bg-elevated);
    color: #93c5fd;
    border: 1px solid rgba(59,130,246,0.3);
}

html.dark-mode .nosotros-cta-final .btn-white:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

/* ============================================================
   HOME PAGE — DARK MODE
   ============================================================ */

/* ── Hero Slider ── */
html.dark-mode .hss-overlay {
    background: linear-gradient(to bottom, rgba(0,0,0,0.5), rgba(0,0,0,0.7));
}

html.dark-mode .hero-label {
    background: rgba(59,130,246,0.2);
    border-color: rgba(59,130,246,0.4);
    color: #93c5fd;
}

html.dark-mode .hss-btn {
    background: rgba(15,17,23,0.7);
    border: 1px solid var(--border-color);
    color: var(--text-primary);
}

html.dark-mode .hss-btn:hover {
    background: var(--primary-color);
    border-color: var(--primary-color);
}

html.dark-mode .hss-dot {
    background: rgba(255,255,255,0.3);
}

html.dark-mode .hss-dot.active {
    background: var(--accent-color);
}

/* ── Servicios ── */
html.dark-mode .servicios {
    background: var(--bg-primary);
}

html.dark-mode .servicios .section-header h2 {
    color: var(--text-primary);
}

html.dark-mode .servicios .section-header p {
    color: var(--text-secondary);
}

html.dark-mode .servicio-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}

html.dark-mode .servicio-card:hover {
    border-color: #3b82f6;
    box-shadow: 0 8px 32px rgba(59,130,246,0.15);
}

html.dark-mode .servicio-card-preview h3 {
    color: var(--text-primary);
}

html.dark-mode .servicio-preview-text {
    color: var(--text-secondary);
}

html.dark-mode .btn-link.servicio-toggle {
    color: var(--accent-color);
}

html.dark-mode .servicio-card-expanded {
    background: var(--bg-elevated);
    border-top: 1px solid var(--border-color);
}

html.dark-mode .servicio-expanded-content h4 {
    color: #93c5fd;
}

html.dark-mode .servicio-intro {
    color: var(--text-secondary);
}

html.dark-mode .servicio-subsection {
    border-bottom-color: var(--border-color);
}

html.dark-mode .servicio-subsection h5 {
    color: var(--text-primary);
}

html.dark-mode .servicio-subsection p,
html.dark-mode .servicio-subsection ul li {
    color: var(--text-secondary);
}

html.dark-mode .servicio-benefits li::before {
    color: var(--accent-color);
}

html.dark-mode .servicio-highlight {
    background: rgba(59,130,246,0.08);
    border-left-color: var(--accent-color);
    color: #93c5fd;
}

html.dark-mode .servicio-note {
    background: rgba(245,158,11,0.08);
    border-left-color: #f59e0b;
    color: #fcd34d;
}

/* ── FAQ Home ── */
html.dark-mode .faq-home {
    background: var(--bg-secondary);
}

html.dark-mode .faq-home-label {
    color: var(--accent-color);
}

html.dark-mode .faq-home-header h2 {
    color: var(--text-primary);
}

html.dark-mode .faq-home-header p {
    color: var(--text-secondary);
}

html.dark-mode .faq-home-item {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
}

html.dark-mode .faq-home-item:hover {
    border-color: #3b82f6;
    box-shadow: 0 4px 16px rgba(59,130,246,0.1);
}

html.dark-mode .faq-home-num {
    color: var(--accent-color);
}

html.dark-mode .faq-home-q-text {
    color: var(--text-primary);
}

html.dark-mode .faq-home-chevron {
    stroke: var(--text-secondary);
}

html.dark-mode .faq-home-a-inner {
    border-top: 1px solid var(--border-color);
}

html.dark-mode .faq-home-a-inner p {
    color: var(--text-secondary);
}

html.dark-mode .faq-home-a-inner strong {
    color: #93c5fd;
}

html.dark-mode .faq-home-cta p {
    color: var(--text-secondary);
}

html.dark-mode .faq-home-cta a {
    color: var(--accent-color);
}

html.dark-mode .faq-home-cta a:hover {
    color: #bfdbfe;
}

/* ── CTA Section ── */
html.dark-mode .cta {
    background: linear-gradient(135deg, #060c1f 0%, #1a3575 100%);
    border-top: 1px solid rgba(59,130,246,0.2);
    border-bottom: 1px solid rgba(59,130,246,0.2);
}

html.dark-mode .cta h2 {
    color: var(--text-primary);
}

html.dark-mode .cta p {
    color: rgba(255,255,255,0.7);
}

html.dark-mode .cta .btn-white {
    background: var(--bg-elevated);
    color: #93c5fd;
    border: 1px solid rgba(59,130,246,0.3);
}

html.dark-mode .cta .btn-white:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

/* ── Indicadores Económicos ── */
html.dark-mode .indicadores-economicos {
    background: var(--bg-primary);
    border-top: 1px solid var(--border-color);
}

html.dark-mode .indicador-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}

html.dark-mode .indicador-card:hover {
    border-color: #3b82f6;
    box-shadow: 0 4px 20px rgba(59,130,246,0.12);
}

html.dark-mode .indicador-icon {
    background: rgba(59,130,246,0.12);
    color: #93c5fd;
    border: 1px solid rgba(59,130,246,0.2);
}

html.dark-mode .indicador-label {
    color: var(--text-muted);
}

html.dark-mode .indicador-valor {
    color: var(--text-primary);
}

/* ============================================================
   PROPIEDADES PAGE — DARK MODE
   ============================================================ */

/* ── Hero ── */
html.dark-mode .propiedades-hero {
    background: linear-gradient(135deg, #060c1f 0%, #0d1a3a 45%, #0f2060 100%);
}

html.dark-mode .propiedades-hero h1 {
    color: var(--text-primary);
}

html.dark-mode .propiedades-hero .service-lead {
    color: rgba(255,255,255,0.7);
}

/* ── Buscador ── */
html.dark-mode .propiedades-search {
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
}

html.dark-mode .search-form-advanced {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-md);
}

html.dark-mode .search-field label {
    color: var(--text-muted);
}

html.dark-mode .search-field input,
html.dark-mode .search-field select,
html.dark-mode .search-field-inline input,
html.dark-mode .search-field-inline select {
    background: var(--bg-secondary);
    border-color: var(--border-color);
    color: var(--text-primary);
}

html.dark-mode .search-field input:focus,
html.dark-mode .search-field select:focus,
html.dark-mode .search-field-inline input:focus,
html.dark-mode .search-field-inline select:focus {
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(59,130,246,0.15);
}

html.dark-mode .search-field-inline label {
    color: var(--text-muted);
}

html.dark-mode .search-advanced {
    border-top: 1px solid var(--border-color);
}

html.dark-mode .btn-toggle-advanced {
    background: var(--bg-elevated);
    border-color: var(--border-color);
    color: var(--text-secondary);
}

html.dark-mode .btn-toggle-advanced:hover,
html.dark-mode .btn-toggle-advanced.active {
    background: rgba(59,130,246,0.1);
    border-color: var(--accent-color);
    color: var(--accent-color);
}

/* ── Resultados ── */
html.dark-mode .propiedades-results {
    background: var(--bg-primary);
}

html.dark-mode .results-info .results-count {
    color: var(--text-muted);
}

html.dark-mode .results-sort label {
    color: var(--text-muted);
}

html.dark-mode .results-sort select {
    background: var(--bg-card);
    border-color: var(--border-color);
    color: var(--text-primary);
}

/* ── Cards de Propiedades ── */
html.dark-mode .propiedad-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}

html.dark-mode .propiedad-card:hover {
    border-color: #3b82f6;
    box-shadow: 0 8px 32px rgba(59,130,246,0.15);
}

html.dark-mode .propiedad-title {
    color: var(--text-primary);
}

html.dark-mode .propiedad-location {
    color: var(--text-secondary);
}

html.dark-mode .propiedad-location svg {
    stroke: var(--text-muted);
}

html.dark-mode .propiedad-details {
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
}

html.dark-mode .detail-value {
    color: var(--text-primary);
}

html.dark-mode .detail-label {
    color: var(--text-muted);
}

html.dark-mode .propiedad-footer {
    background: var(--bg-elevated);
}

html.dark-mode .price-label {
    color: var(--text-muted);
}

html.dark-mode .price-value {
    color: #93c5fd;
    font-weight: 700;
}

html.dark-mode .image-count {
    background: rgba(0,0,0,0.6);
    color: rgba(255,255,255,0.85);
}

/* Badges tipo listado */
html.dark-mode .propiedad-badge {
    backdrop-filter: blur(4px);
}

/* Sin resultados */
html.dark-mode .no-results {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
}

html.dark-mode .no-results h3 {
    color: var(--text-primary);
}

html.dark-mode .no-results p {
    color: var(--text-secondary);
}

/* Paginación */
html.dark-mode .pagination-info {
    color: var(--text-muted);
}

/* ── CTA Propiedades ── */
html.dark-mode .propiedades-cta {
    background: linear-gradient(135deg, #060c1f 0%, #1a3575 100%);
    border-top: 1px solid rgba(59,130,246,0.2);
}

html.dark-mode .propiedades-cta h2 {
    color: var(--text-primary);
}

html.dark-mode .propiedades-cta p {
    color: rgba(255,255,255,0.7);
}

html.dark-mode .propiedades-cta .btn-white {
    background: var(--bg-elevated);
    color: #93c5fd;
    border: 1px solid rgba(59,130,246,0.3);
}

html.dark-mode .propiedades-cta .btn-white:hover {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
}

/* ============================================================
   PROPIEDAD DETALLE — DARK MODE
   ============================================================ */

/* ── Hero / Breadcrumb ── */
html.dark-mode .propiedad-detalle-hero {
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border-color);
}

html.dark-mode .service-breadcrumb a {
    color: var(--text-secondary);
}

html.dark-mode .service-breadcrumb a:hover {
    color: var(--accent-color);
}

html.dark-mode .service-breadcrumb span {
    color: var(--text-muted);
}

/* ── Galería ── */
html.dark-mode .propiedad-gallery {
    background: var(--bg-primary);
}

html.dark-mode .gallery-primary {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-md);
}

html.dark-mode .gallery-nav {
    background: rgba(15,17,23,0.75);
    border: 1px solid rgba(255,255,255,0.1);
    color: var(--text-primary);
}

html.dark-mode .gallery-nav:hover {
    background: var(--primary-color);
    border-color: var(--primary-color);
}

html.dark-mode .thumbnail {
    border: 2px solid var(--border-color);
    background: var(--bg-card);
}

html.dark-mode .thumbnail.active {
    border-color: var(--accent-color);
}

html.dark-mode .thumbnail:hover {
    border-color: #3b82f6;
}

html.dark-mode .thumbnail-overlay {
    background: rgba(0,0,0,0.65);
    color: white;
}

/* ── Sección de contenido principal ── */
html.dark-mode .propiedad-content-section {
    background: var(--bg-primary);
}

/* ── Header info (título + precio) ── */
html.dark-mode .propiedad-header-info {
    border-bottom: 1px solid var(--border-color);
}

html.dark-mode .propiedad-title {
    color: var(--text-primary);
}

html.dark-mode .propiedad-location {
    color: var(--text-secondary);
}

html.dark-mode .propiedad-location svg {
    stroke: var(--text-muted);
}

html.dark-mode .propiedad-price-box {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}

html.dark-mode .propiedad-price-box .price-label {
    color: var(--text-muted);
}

html.dark-mode .propiedad-price-box .price-value {
    color: #93c5fd;
}

html.dark-mode .propiedad-price-box .price-secondary {
    color: var(--text-secondary);
}

/* ── Features / Características ── */
html.dark-mode .propiedad-features {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 12px;
}

html.dark-mode .feature-item {
    border-right-color: var(--border-color);
}

html.dark-mode .feature-item svg {
    stroke: var(--accent-color);
}

html.dark-mode .feature-value {
    color: var(--text-primary);
}

html.dark-mode .feature-label {
    color: var(--text-muted);
}

/* ── Secciones internas (Descripción, Detalles, etc.) ── */
html.dark-mode .propiedad-section {
    border-top: 1px solid var(--border-color);
}

html.dark-mode .propiedad-section h2 {
    color: var(--text-primary);
}

html.dark-mode .propiedad-description {
    color: var(--text-secondary);
    line-height: 1.8;
}

/* Características grid */
html.dark-mode .caracteristicas-grid {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
}

html.dark-mode .caracteristica-item {
    color: var(--text-secondary);
    border-bottom-color: var(--border-color);
}

html.dark-mode .caracteristica-item svg {
    stroke: #10b981;
}

/* Detalles grid */
html.dark-mode .detalles-grid {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
    border-radius: 10px;
}

html.dark-mode .detalle-row {
    border-bottom-color: var(--border-color);
}

html.dark-mode .detalle-label {
    color: var(--text-muted);
}

html.dark-mode .detalle-value {
    color: var(--text-primary);
}

/* ── Sidebar ── */
html.dark-mode .propiedad-sidebar .contact-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-md);
}

html.dark-mode .contact-card h3 {
    color: var(--text-primary);
}

html.dark-mode .contact-card .contact-subtitle {
    color: var(--text-secondary);
}

html.dark-mode .contact-form .form-group label {
    color: var(--text-secondary);
}

html.dark-mode .contact-form input,
html.dark-mode .contact-form textarea {
    background: var(--bg-secondary);
    border-color: var(--border-color);
    color: var(--text-primary);
}

html.dark-mode .contact-form input:focus,
html.dark-mode .contact-form textarea:focus {
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(59,130,246,0.15);
}

html.dark-mode .contact-form input::placeholder,
html.dark-mode .contact-form textarea::placeholder {
    color: var(--text-muted);
}

/* Mensaje de éxito del formulario */
html.dark-mode #contactoPropiedadForm h4 {
    color: #93c5fd !important;
}

html.dark-mode #contactoPropiedadForm p {
    color: var(--text-secondary) !important;
}

/* ── Share card ── */
html.dark-mode .share-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: var(--shadow-sm);
}

html.dark-mode .share-card h4 {
    color: var(--text-secondary);
}

html.dark-mode .share-btn {
    background: var(--bg-elevated);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
}

html.dark-mode .share-btn:hover {
    background: var(--primary-color);
    border-color: var(--primary-color);
    color: white;
}

/* ── Fix contenedor principal blanco ── */
html.dark-mode .propiedad-main,
html.dark-mode .propiedad-layout,
html.dark-mode .propiedad-header-info {
    background: transparent;
}

/* Tarjeta blanca que envuelve todo el contenido */
html.dark-mode .propiedad-content-section .container > *,
html.dark-mode .propiedad-layout {
    background: transparent;
}

/* El wrapper blanco general de la sección */
html.dark-mode .propiedad-content-section {
    background: var(--bg-primary);
}

/* ── Fix feature items (las 4 tarjetas de superficie, habitaciones, etc.) ── */
html.dark-mode .feature-item {
    background: var(--bg-secondary);
    border: 1px solid var(--border-color);
}

html.dark-mode .feature-value {
    color: var(--text-primary);
    font-weight: 700;
}

html.dark-mode .feature-label {
    color: var(--text-muted);
}

/* ── Fix la tarjeta blanca exterior que envuelve título + precio ── */
html.dark-mode .propiedad-detalle-hero,
html.dark-mode .propiedad-header-info {
    background: var(--bg-card);
}

/* Si hay un card/wrapper blanco general de la vista */
html.dark-mode .propiedad-card-wrapper,
html.dark-mode .propiedad-detail-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
}

/* ── Fix Características ── */
html.dark-mode .caracteristicas-grid {
    background: transparent;
    border: none;
}

html.dark-mode .caracteristica-item {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    color: var(--text-secondary);
    border-radius: 8px;
}

html.dark-mode .caracteristica-item:hover {
    border-color: #3b82f6;
    color: var(--text-primary);
}

html.dark-mode .caracteristica-item svg {
    stroke: #10b981;
}

/* ── Fix Detalles ── */
html.dark-mode .detalles-grid {
    background: transparent;
    border: none;
}

html.dark-mode .detalle-row {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    margin-bottom: 6px;
}

html.dark-mode .detalle-label {
    color: var(--text-primary);
    font-weight: 600;
}

html.dark-mode .detalle-value {
    color: var(--text-secondary);
}

/* ============================================================
   MODAL CONTACTO GENERAL (.contacto-modal) — DARK MODE
   ============================================================ */

html.dark-mode .contacto-modal-content {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: 0 32px 80px rgba(0,0,0,0.7);
}

html.dark-mode .contacto-modal-close {
    background: var(--bg-elevated);
    border-color: var(--border-color);
    color: var(--text-secondary);
}

html.dark-mode .contacto-modal-close:hover {
    background: rgba(220,38,38,0.15);
    border-color: #f87171;
    color: #f87171;
}

html.dark-mode .contacto-modal-header {
    border-bottom-color: var(--border-color);
}

html.dark-mode .contacto-modal-header h3 {
    color: #93c5fd;
}

html.dark-mode .contacto-modal-header p {
    color: var(--text-secondary);
}

html.dark-mode .contacto-modal-icon {
    background: rgba(59,130,246,0.15);
    border: 1px solid rgba(59,130,246,0.25);
}

html.dark-mode .contacto-modal-icon svg {
    stroke: #60a5fa;
}

html.dark-mode .form-group-modal label {
    color: var(--text-secondary);
}

html.dark-mode .form-group-modal input,
html.dark-mode .form-group-modal textarea,
html.dark-mode .form-group-modal select {
    background: var(--bg-secondary);
    border-color: var(--border-color);
    color: var(--text-primary);
}

html.dark-mode .form-group-modal input::placeholder,
html.dark-mode .form-group-modal textarea::placeholder {
    color: var(--text-muted);
}

html.dark-mode .form-group-modal input:focus,
html.dark-mode .form-group-modal textarea:focus,
html.dark-mode .form-group-modal select:focus {
    border-color: var(--accent-color);
    box-shadow: 0 0 0 3px rgba(59,130,246,0.15);
    background: var(--bg-card);
}

html.dark-mode .contacto-modal-footer {
    border-top-color: var(--border-color);
    background: var(--bg-card);
}

html.dark-mode .btn-modal-secondary {
    background: var(--bg-elevated);
    border-color: var(--border-color);
    color: var(--text-secondary);
}

html.dark-mode .btn-modal-secondary:hover {
    border-color: var(--accent-color);
    color: var(--accent-color);
    background: rgba(59,130,246,0.08);
}

/* Mensaje de éxito */
html.dark-mode .form-success-message {
    background: var(--bg-card);
}

html.dark-mode .form-success-message h3 {
    color: #93c5fd;
}

html.dark-mode .form-success-message p {
    color: var(--text-secondary);
}

/* ============================================================
   MODAL CARRUSEL DE SERVICIOS (.sim-wrapper) — DARK MODE
   ============================================================ */

html.dark-mode .sim-panel {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    box-shadow: 0 32px 100px rgba(0,0,0,0.7);
}

html.dark-mode .sim-close {
    background: var(--bg-elevated);
    border-color: var(--border-color);
    color: var(--text-secondary);
}

html.dark-mode .sim-close:hover {
    background: rgba(220,38,38,0.15);
    border-color: #f87171;
    color: #f87171;
}

/* Slide 1 — Info servicio */
html.dark-mode .sim-header {
    border-bottom-color: var(--border-color);
}

html.dark-mode .sim-title {
    color: #93c5fd;
}

html.dark-mode .sim-subtitle {
    color: var(--text-muted);
}

html.dark-mode .sim-body > p {
    color: var(--text-secondary);
}

html.dark-mode .sim-section-title {
    color: #60a5fa;
    border-bottom-color: rgba(59,130,246,0.15);
}

html.dark-mode .sim-body ul li {
    color: var(--text-secondary);
}

html.dark-mode .sim-body ul li strong {
    color: #93c5fd;
}

html.dark-mode .sim-highlight {
    background: rgba(59,130,246,0.08);
    border-left-color: var(--accent-color);
}

html.dark-mode .sim-highlight p {
    color: #93c5fd;
}

html.dark-mode .sim-pill {
    background: rgba(59,130,246,0.1);
    border-color: rgba(59,130,246,0.25);
    color: #93c5fd;
}

html.dark-mode .sim-note {
    background: rgba(16,185,129,0.08);
    border-color: rgba(16,185,129,0.25);
    color: #6ee7b7;
}

html.dark-mode .sim-footer {
    border-top-color: var(--border-color);
    background: var(--bg-card);
}

/* Slide 2 — Formulario */
html.dark-mode .sim-form-body {
    background: var(--bg-card);
}

html.dark-mode .sim-field label {
    color: var(--text-secondary);
}

html.dark-mode .sim-field label span {
    color: #60a5fa;
}

html.dark-mode .sim-field input,
html.dark-mode .sim-field textarea,
html.dark-mode .sim-field select {
    background: var(--bg-secondary);
    border-color: var(--border-color);
    color: var(--text-primary);
}

html.dark-mode .sim-field input::placeholder,
html.dark-mode .sim-field textarea::placeholder {
    color: var(--text-muted);
}

html.dark-mode .sim-field input:focus,
html.dark-mode .sim-field textarea:focus,
html.dark-mode .sim-field select:focus {
    border-color: var(--accent-color);
    background: var(--bg-card);
    box-shadow: 0 0 0 3px rgba(59,130,246,0.15);
}

html.dark-mode .sim-field input.sim-error,
html.dark-mode .sim-field textarea.sim-error,
html.dark-mode .sim-field select.sim-error {
    border-color: #f87171;
    background: rgba(220,38,38,0.05);
}

html.dark-mode .sim-btn-back {
    background: var(--bg-elevated);
    border-color: var(--border-color);
    color: var(--text-secondary);
}

html.dark-mode .sim-btn-back:hover {
    border-color: var(--accent-color);
    color: var(--accent-color);
    background: rgba(59,130,246,0.08);
}

/* Slide 3 — Éxito */
html.dark-mode .sim-success-title {
    color: #93c5fd;
}

html.dark-mode .sim-success-msg {
    color: var(--text-secondary);
}

html.dark-mode .hero-label {
    background: transparent !important;
    background-color: transparent !important;
    border: none !important;
    box-shadow: none !important;
    color: #93c5fd !important;
    text-shadow: 0 1px 4px rgba(0,0,0,0.6);
    padding-left: 0 !important;
    padding-right: 0 !important;
}

@media (max-width: 768px) {
    html.dark-mode .navbar {
        background: rgba(15, 17, 23, 0.97) !important;
        background-color: rgba(15, 17, 23, 0.97) !important;
        border-bottom: 1px solid var(--border-color) !important;
    }

    html.dark-mode .navbar .container {
        background: transparent !important;
    }

    /* Logo: invertir a blanco en dark mode mobile */
    html.dark-mode .navbar-brand .logo {
        filter: brightness(0) invert(1) !important;
        opacity: 0.92 !important;
    }

    /* Hamburguesa: líneas blancas */
    html.dark-mode .navbar-toggle span,
    html.dark-mode #navbar-toggle span {
        background: #c8d0e8 !important;
    }

    /* Drawer lateral en dark mode */
    html.dark-mode .navbar-menu,
    html.dark-mode #navbar-menu {
        background: var(--bg-elevated, #252838) !important;
    }

    /* Items del drawer */
    html.dark-mode #navbar-menu li {
        border-bottom-color: var(--border-color, #2a2f45) !important;
    }

    html.dark-mode #navbar-menu li a {
        color: var(--text-primary, #f0f2f8) !important;
    }

    html.dark-mode #navbar-menu li a:hover,
    html.dark-mode #navbar-menu li a.active {
        color: var(--accent-color, #60a5fa) !important;
        background: rgba(59, 130, 246, 0.12) !important;
        border-left-color: var(--accent-color, #60a5fa) !important;
    }

    /* Idioma y tema */
    html.dark-mode .navbar-lang-text .lang-option {
        color: var(--text-muted, #5c6585) !important;
    }

    html.dark-mode .navbar-lang-text .lang-option.active {
        color: var(--text-primary, #f0f2f8) !important;
    }

    html.dark-mode .navbar-lang-text .separator {
        color: var(--border-color, #2a2f45) !important;
    }

    html.dark-mode .navbar-theme {
        color: var(--text-secondary, #9ba3c0) !important;
    }
}