@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;700&family=Open+Sans:wght@400;600;700&display=swap');

/* =========================
   TEMA CLARO (SOL) - CONTRASTE FUERTE
========================= */
:root{
  --bg: #ffffff;
  
  --surface: rgba(0, 0, 0, 0.03);
  --card: rgba(0, 0, 0, 0.04);
  --border: rgba(0, 0, 0, 0.15);
  
  /* TEXTO NEGRO FUERTE PARA MÁXIMO CONTRASTE */
  --text: #000000; 
  --muted: rgba(0, 0, 0, 0.75);
  
  /* Sol: botones azul cielo vibrantes */
  --primary: #0066cc;
  --primary-2: #0088ff;
  
  /* Marca / títulos (azul marino OSCURO) */
  --brand: #001133;
  --brand-2: #002255;
  
  /* Acentos VIBRANTES */
  --accent: #0d8c2d;  /* verde oscuro vibrante */
  --bolt: #e6b400;    /* amarillo dorado vibrante */
  
  --shadow: 0 10px 30px rgba(0,0,0,0.15);
  --radius: 18px;
  
  --container: 1200px;
  
  /* Gradientes reutilizables (Nosotros) */
  --gradient-blue-light: rgba(0, 80, 200, 0.15);
  --gradient-green-light: rgba(13, 140, 45, 0.12);
  --gradient-blue-dark: rgba(13,110,253,.20);
  --gradient-green-dark: rgba(34,197,94,.14);
}

/* Tema claro explícito */
html[data-theme="light"]{
  --bg: #ffffff;
  
  --surface: rgba(0, 0, 0, 0.03);
  --card: rgba(0, 0, 0, 0.04);
  --border: rgba(0, 0, 0, 0.15);
  
  /* TEXTO NEGRO FUERTE */
  --text: #000000;
  --muted: rgba(0, 0, 0, 0.75);
  
  --primary: #0066cc;
  --primary-2: #0088ff;
  
  --brand: #001133;
  --brand-2: #002255;
  
  --accent: #0d8c2d;
  --bolt: #e6b400;
  
  --shadow: 0 10px 30px rgba(0,0,0,0.15);
}

/* =========================
   TEMA OSCURO (LUNA)
========================= */
html[data-theme="dark"]{
  --bg: #0b1220;
  
  --surface: rgba(255,255,255,0.08);
  --card: rgba(255,255,255,0.06);
  --border: rgba(255,255,255,0.12);
  
  --text: rgba(255,255,255,0.92);
  --muted: rgba(255,255,255,0.72);
  
  --primary: #1e88ff;
  --primary-2: #00d4ff;
  
  --brand: #ffffff;
  --brand-2: rgba(255,255,255,0.85);
  
  --accent: #22c55e;
  --bolt: #fbbf24;
  
  --shadow: 0 10px 30px rgba(0,0,0,0.35);
}

/* =========================
   RESET / GLOBAL
========================= */
*{ margin:0; padding:0; box-sizing:border-box; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
html{ scroll-behavior:smooth; }

html, body{
  background: var(--bg);
  color: var(--text);
  transition: background-color 0.3s ease, color 0.3s ease;
}

body{
  font-family: "Plus Jakarta Sans", "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
  
  /* Fondo decorativo global (se adapta a tema) */
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(0,31,77,0.08), transparent 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(0,61,122,0.06), transparent 55%),
    radial-gradient(900px 600px at 50% 100%, rgba(0,0,0,0.02), transparent 60%),
    var(--bg);
}

html[data-theme="dark"] body{
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(25,143,227,0.18), transparent 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(0,61,122,0.18), transparent 55%),
    radial-gradient(900px 600px at 50% 100%, rgba(255,255,255,0.06), transparent 60%),
    var(--bg);
}

/* =========================
   CONTRASTE FORZADO EN MODO SOL - SOLUCIÓN COMPLETA
========================= */

/* 1. Fuerza texto negro en TODO el cuerpo en modo claro */
html[data-theme="light"] body,
html[data-theme="light"] .body-content,
html[data-theme="light"] main,
html[data-theme="light"] section,
html[data-theme="light"] div:not(.btn-primary):not(.btn-brand):not(.wa-float):not(.hero-card-icon):not(.card-icon):not(.theme-toggle *),
html[data-theme="light"] article {
  color: #000000 !important;
}

/* 2. Excepciones específicas para mantener colores especiales */
html[data-theme="light"] .btn-primary,
html[data-theme="light"] .btn-brand,
html[data-theme="light"] .wa-float {
  color: #ffffff !important;
}

/* 3. Elementos de texto específicos - TODOS NEGROS */
html[data-theme="light"] p,
html[data-theme="light"] span:not(.theme-toggle *),
html[data-theme="light"] li,
html[data-theme="light"] td,
html[data-theme="light"] th,
html[data-theme="light"] label,
html[data-theme="light"] strong,
html[data-theme="light"] em,
html[data-theme="light"] b,
html[data-theme="light"] i:not([class*="fa-"]),
html[data-theme="light"] small,
html[data-theme="light"] caption {
  color: #000000 !important;
}

/* 4. Títulos - azul oscuro para contraste */
html[data-theme="light"] h1,
html[data-theme="light"] h2,
html[data-theme="light"] h3,
html[data-theme="light"] h4,
html[data-theme="light"] h5,
html[data-theme="light"] h6 {
  color: var(--brand) !important;
}

/* 5. Enlaces */
html[data-theme="light"] a:not(.btn-primary):not(.btn-brand):not(.wa-float) {
  color: #000000 !important;
}

html[data-theme="light"] a:not(.btn-primary):not(.btn-brand):not(.wa-float):hover {
  color: var(--primary) !important;
}

/* 6. Cartas y contenedores - texto negro */
html[data-theme="light"] .card,
html[data-theme="light"] .card-glass,
html[data-theme="light"] .servicio-item,
html[data-theme="light"] .service-card,
html[data-theme="light"] .testimonio-card,
html[data-theme="light"] .faq-plomeria,
html[data-theme="light"] .contacto-plomeria {
  color: #000000 !important;
}

/* Texto dentro de cartas */
html[data-theme="light"] .card *:not(.btn-primary):not(.btn-brand):not(.card-icon),
html[data-theme="light"] .servicio-item *:not(.btn),
html[data-theme="light"] .service-card *:not(.btn) {
  color: #000000 !important;
}

/* 7. Específico para cartas de servicios de plomería */
html[data-theme="light"] .servicios-plomeria,
html[data-theme="light"] .servicios-lista,
html[data-theme="light"] .servicio-item p,
html[data-theme="light"] .servicio-item span,
html[data-theme="light"] .servicio-item div:not(.icon-container),
html[data-theme="light"] .servicio-item li {
  color: #000000 !important;
}

/* 8. Listas de servicios (tu problema específico) */
html[data-theme="light"] .servicios-lista .servicio-item,
html[data-theme="light"] .servicios-lista .servicio-item * {
  color: #000000 !important;
}

/* 9. Texto en formularios */
html[data-theme="light"] input,
html[data-theme="light"] textarea,
html[data-theme="light"] select,
html[data-theme="light"] .form-control,
html[data-theme="light"] .form-select {
  color: #000000 !important;
  background: rgba(255, 255, 255, 0.95) !important;
}

html[data-theme="light"] ::placeholder {
  color: rgba(0, 0, 0, 0.6) !important;
}

/* 10. Footer */
html[data-theme="light"] .site-footer,
html[data-theme="light"] .footer-text,
html[data-theme="light"] .footer-list,
html[data-theme="light"] .footer-bottom-inner,
html[data-theme="light"] .social-link {
  color: #000000 !important;
}

/* 11. Íconos Font Awesome - oscuros para contraste */
html[data-theme="light"] .fa,
html[data-theme="light"] .fas,
html[data-theme="light"] .far,
html[data-theme="light"] .fab,
html[data-theme="light"] .fal {
  color: var(--brand) !important;
}

/* Íconos específicos en servicios */
html[data-theme="light"] .servicio-item i,
html[data-theme="light"] .service-card i,
html[data-theme="light"] .value-item i,
html[data-theme="light"] .checklist i {
  color: #003366 !important;
}

/* 12. Navbar y menú - fondo claro, texto oscuro */
html[data-theme="light"] .navbar,
html[data-theme="light"] .navbar-glass,
html[data-theme="light"] .site-header,
html[data-theme="light"] .main-header {
  background: rgba(255, 255, 255, 0.98) !important;
  border-color: rgba(0, 0, 0, 0.15) !important;
}

html[data-theme="light"] .nav-link,
html[data-theme="light"] .navbar .nav-link,
html[data-theme="light"] .main-nav ul li a,
html[data-theme="light"] .hamburguesa {
  color: #000000 !important;
}

html[data-theme="light"] .nav-link:hover,
html[data-theme="light"] .navbar .nav-link:hover {
  color: var(--primary) !important;
}

/* 13. Menú desplegable */
html[data-theme="light"] .nav-menu,
html[data-theme="light"] .main-nav ul {
  background: rgba(255, 255, 255, 0.99) !important;
  border-color: rgba(0, 0, 0, 0.2) !important;
}

/* =========================
   BOTÓN TEMA LUNA/SOL
========================= */
.theme-toggle {
  position: relative;
  width: 60px;
  height: 30px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50px;
  cursor: pointer;
  display: flex;
  align-items: center;
  padding: 0 5px;
  transition: all 0.3s ease;
}

.theme-toggle::before {
  content: '';
  position: absolute;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, #fbbf24, #f59e0b);
  transition: transform 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: #000;
}

html[data-theme="dark"] .theme-toggle::before {
  transform: translateX(30px);
  background: linear-gradient(135deg, #103870, #0d3772);
}

.theme-toggle .sun-icon,
.theme-toggle .moon-icon {
  position: absolute;
  font-size: 14px;
  transition: opacity 0.3s ease;
}

.theme-toggle .sun-icon {
  left: 8px;
  color: #f59e0b;
  opacity: 1;
}

.theme-toggle .moon-icon {
  right: 8px;
  color: #074086;
  opacity: 0.5;
}

html[data-theme="dark"] .theme-toggle .sun-icon {
  opacity: 0.5;
}

html[data-theme="dark"] .theme-toggle .moon-icon {
  opacity: 1;
  color: #0b52af;
}

.container{
  width: min(92%, var(--container));
  margin: 0 auto;
}

/* Skip link */
.skip-link{
  position:absolute;
  left:-9999px;
  top:10px;
  padding:10px 14px;
  border-radius: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  z-index: 999;
}
.skip-link:focus{ left: 12px; }

/* =========================
   UI GLOBAL (glass/cards/forms/reveal/wa)
========================= */

/* Navbar glass (Bootstrap .navbar / o tu clase .navbar-glass) */
.navbar-glass{
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,.85);
}
html[data-theme="dark"] .navbar-glass{
  background: rgba(11,18,32,.65);
}

/* Links navbar (Bootstrap) */
.navbar .nav-link{
  color: var(--text);
  font-weight: 600;
}
.navbar .nav-link:hover,
.navbar .nav-link.active{
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 7px;
}

/* Botones */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 18px;
  border-radius: 999px;
  font-weight: 700;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .15s ease, filter .2s ease, background .2s ease, border .2s ease;
}
.btn-lg{ padding: 13px 20px; }

.btn-primary{
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  color: #ffffff !important;
  box-shadow: 0 16px 35px rgba(0,31,77,0.22);
}
html[data-theme="dark"] .btn-primary{ box-shadow: 0 16px 35px rgba(0,0,0,0.40); }
.btn-primary:hover{ transform: translateY(-1px); filter: brightness(0.95); }

.btn-ghost{
  background: transparent;
  border-color: var(--border);
  color: var(--text);
}
.btn-ghost:hover{ transform: translateY(-1px); background: var(--surface); }

/* Botón estilo soft (compatible con tus páginas) */
.btn-soft{
  border-radius: 999px;
  padding: .65rem 1rem;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.btn-soft:hover{
  transform: translateY(-1px);
  background: var(--card);
  border-color: rgba(0, 80, 200, 0.3);
}

/* Botón marca */
.btn-brand{
  border-radius: 999px;
  padding: .75rem 1.1rem;
  font-weight: 800;
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  color:#fff !important;
  box-shadow: var(--shadow);
  border: 1px solid transparent;
  transition: transform .2s ease, filter .2s ease;
}
.btn-brand:hover{ transform: translateY(-1px); filter: brightness(.97); }

/* Card glass reutilizable */
.card-glass{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  color: var(--text);
}

/* Icon pill */
.icon-pill{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(0, 80, 200, 0.15);
  border: 1px solid rgba(0, 80, 200, 0.3);
  color: var(--text);
}

html[data-theme="light"] .icon-pill {
  background: rgba(0, 31, 77, 0.15);
  border: 1px solid rgba(0, 31, 77, 0.3);
}

/* Inputs / selects (Bootstrap) */
.form-control,
.form-select{
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 14px;
  padding: .85rem .95rem;
}
html[data-theme="light"] .form-control,
html[data-theme="light"] .form-select{
  background: rgba(0, 0, 0, 0.03);
}
.form-control::placeholder{ color: var(--muted); }
html[data-theme="light"] .form-control::placeholder{ color: rgba(0, 0, 0, 0.6); }
.form-control:focus{
  border-color: var(--primary);
  box-shadow: 0 0 0 .2rem rgba(0, 102, 204, 0.25);
}

/* Reveal (tu JS lo usa) */
.reveal{
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.show{
  opacity: 1;
  transform: translateY(0);
}

/* WhatsApp flotante */
.wa-float{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 9999;
  border-radius: 999px;
  padding: .85rem 1rem;
  display: inline-flex;
  gap: .6rem;
  align-items:center;
  text-decoration:none;
  background: var(--primary);
  color:#ffffff !important;
  box-shadow: var(--shadow);
  transition: transform .2s ease, filter .2s ease;
}
.wa-float:hover{
  transform: translateY(-2px);
  filter: brightness(.96);
  color:#ffffff !important;
}

/* =========================
   HEADER / NAV (site-header)
========================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(255,255,255,0.95);
  border-bottom: 1px solid var(--border);
}
html[data-theme="dark"] .site-header{
  background: rgba(11,18,32,0.85);
  border-bottom: 1px solid rgba(255,255,255,0.10);
}

.header-container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;
  gap: 16px;
}

.brand{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 220px;
}
.brand-logo{
  width: 90px;
  height: 90px;
  border-radius: 50px;
  object-fit: cover;
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}
html[data-theme="dark"] .brand-logo{ box-shadow: 0 8px 20px rgba(0,0,0,0.45); }

.brand-name{
  font-family: 'Playfair Display', serif;
  letter-spacing: 0.3px;
  font-weight: 700;
  font-size: 1.35rem;
  color: var(--brand);
}

.nav{
  position: relative;
  display:flex;
  align-items:center;
  gap: 12px;
}

.nav-toggle{
  display:none;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  width: 44px;
  height: 44px;
  border-radius: 14px;
  cursor:pointer;
  transition: transform .15s ease, background .2s ease;
}
.nav-toggle:hover{ transform: translateY(-1px); background: rgba(0,0,0,0.06); }
html[data-theme="dark"] .nav-toggle:hover{ background: rgba(255,255,255,0.12); }

.nav-menu{
  display:flex;
  align-items:center;
  gap: 14px;
}

.nav-list{
  list-style:none;
  display:flex;
  align-items:center;
  gap: 10px;
}

.nav-link{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  font-weight: 600;
  color: var(--text);
  transition: background .2s ease, color .2s ease, transform .15s ease;
}
.nav-link:hover{
  background: var(--surface);
  color: var(--brand);
  transform: translateY(-1px);
}
.nav-link.is-active{
  background: rgba(0,31,77,0.15);
  color: var(--brand);
}
html[data-theme="dark"] .nav-link.is-active{
  background: rgba(25,143,227,0.16);
  color: var(--brand);
}

.nav-cta{
  display:flex;
  align-items:center;
  gap: 10px;
}

/* =========================
   HERO GLOBAL (para páginas normales)
========================= */
.hero{
  position: relative;
  padding: 86px 0 56px;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 22px;
  align-items:center;
}

.hero-content{ max-width: 820px; }

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--brand);
  margin-bottom: 18px;
}
html[data-theme="dark"] .hero-badge{ color: var(--text); }

.hero-title{
  font-family:'Playfair Display', serif;
  font-size: clamp(2rem, 4vw, 3.25rem);
  line-height: 1.08;
  margin-bottom: 14px;
  color: var(--brand);
}

.hero-subtitle{
  color: var(--text);
  font-size: 1.08rem;
  max-width: 680px;
  margin-bottom: 22px;
}

.hero-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 22px;
}

.hero-highlights{
  list-style:none;
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  color: var(--text);
}
.hero-highlights li{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
}

.hero-visual{ display:flex; justify-content:flex-end; }
.hero-card{
  width: min(420px, 100%);
  padding: 18px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  display:flex;
  gap: 14px;
  align-items:center;
}
.hero-card-icon{
  width: 54px;
  height: 54px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, rgba(0, 80, 200, 0.4), rgba(0, 120, 255, 0.25));
  border: 1px solid var(--border);
  font-size: 1.45rem;
  color: #000000;
}
.hero-card-title{ font-weight: 800; margin-bottom: 2px; color: var(--brand); }
.hero-card-desc{ color: var(--text); font-size: .98rem; }

/* =========================
   SECCIONES / TITULOS
========================= */
.section{ padding: 56px 0; }

.section-head{
  text-align:center;
  max-width: 820px;
  margin: 0 auto 28px;
}
.section-title{
  font-family:'Playfair Display', serif;
  font-size: clamp(1.55rem, 2.5vw, 2.15rem);
  margin-bottom: 8px;
  color: var(--brand);
}
.section-subtitle{ color: var(--text); }

.section-mini-title{
  font-family:'Playfair Display', serif;
  text-align:center;
  margin: 10px 0 14px;
  color: var(--brand);
}

/* =========================
   ABOUT
========================= */
.about-grid{ display:grid; gap: 16px; }

.about-card{
  margin: 0 auto;
  max-width: 920px;
  padding: 22px;
  border-radius: var(--radius);
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  text-align:center;
}
.about-text{
  color: var(--text);
  font-size: 1.05rem;
  margin-bottom: 14px;
}
.about-actions{
  display:flex;
  justify-content:center;
  gap: 12px;
  flex-wrap: wrap;
}

/* =========================
   CARDS / GRID
========================= */
.cards-grid{
  display:grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.card{
  padding: 18px;
  border-radius: var(--radius);
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: 0 10px 28px rgba(0,0,0,0.12);
  transition: transform .18s ease, background .2s ease, border .2s ease;
}
html[data-theme="dark"] .card{ box-shadow: 0 10px 28px rgba(0,0,0,0.35); }
.card:hover{
  transform: translateY(-4px);
  background: var(--surface);
}

.service-card{
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.card-icon{
  width: 54px;
  height: 54px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, rgba(0, 80, 200, 0.4), rgba(0, 120, 255, 0.25));
  border: 1px solid var(--border);
  margin: 0 auto 6px;
  font-size: 1.45rem;
  color: #000000;
}

.card-title{
  text-align:center;
  font-family:'Playfair Display', serif;
  font-size: 1.25rem;
  margin-bottom: 6px;
  color: var(--brand);
}

.card-text{
  text-align:center;
  color: var(--text);
  margin-bottom: 8px;
}

.card-link{
  display:flex;
  justify-content:center;
  gap: 8px;
  color: var(--brand);
  font-weight: 800;
}

/* =========================
   TESTIMONIOS + FORM - CON FONDO BLANCO EN MODO CLARO
========================= */
.testimonials-grid{ margin-bottom: 22px; }
.testimonial-card{ text-align:left; }
.testimonial-text{ color: var(--text); font-style: italic; margin-bottom: 10px; }
.testimonial-meta{ color: var(--text); font-weight: 800; }

.testimonial-form-wrap{
  max-width: 920px;
  margin: 18px auto 0;
  padding: 22px;
  border-radius: var(--radius);
  background: var(--card); /* Este es el color por defecto */
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

/* FONDO BLANCO EN MODO CLARO */
html[data-theme="light"] .testimonial-form-wrap,
body:not([data-theme="dark"]) .testimonial-form-wrap {
  background: #e7e5e5 !important; /* ← FONDO BLANCO */
  border: 1px solid rgba(0, 0, 0, 0.15) !important;
}

/* Mantener fondo oscuro en modo oscuro */
html[data-theme="dark"] .testimonial-form-wrap {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
}

/* Inputs blancos en modo claro */
html[data-theme="light"] .testimonial-form-wrap input,
html[data-theme="light"] .testimonial-form-wrap textarea {
  background: rgba(255, 255, 255, 0.486) !important;
  border: 1px solid rgba(0, 0, 0, 0.15) !important;
  color: #000000 !important;
}

html[data-theme="dark"] .testimonial-form-wrap input,
html[data-theme="dark"] .testimonial-form-wrap textarea {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
}

.form{ margin-top: 10px; }
.form-grid{
  display:grid;
  gap: 12px;
  grid-template-columns: 1fr;
  margin-bottom: 14px;
}

.field{ display:flex; flex-direction:column; gap: 8px; }
.field-label{ color: var(--text); font-weight: 600; font-size: .95rem; }
.field-full{ grid-column: 1 / -1; }

.input, .textarea, input, textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  outline: none;
}
input::placeholder, textarea::placeholder{ color: var(--muted); }
input:focus, textarea:focus{
  border-color: rgba(0, 80, 200, 0.8);
  box-shadow: 0 0 0 4px rgba(0, 80, 200, 0.15);
}
/* =========================
   FOOTER
========================= */
.site-footer{
  margin-top: 40px;
  border-top: 1px solid var(--border);
  background: var(--surface);
  backdrop-filter: blur(10px);
}

.footer-grid{
  display:grid;
  gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  padding: 34px 0 18px;
}

.footer-logo{
  width: 62px;
  height: 62px;
  border-radius: 18px;
  object-fit: cover;
  box-shadow: 0 12px 25px rgba(0,0,0,0.15);
  margin-bottom: 10px;
}
html[data-theme="dark"] .footer-logo{ box-shadow: 0 12px 25px rgba(0,0,0,0.45); }

.footer-title{
  font-family:'Playfair Display', serif;
  margin-bottom: 10px;
  color: var(--brand);
}

.footer-text{ color: var(--text); max-width: 340px; }

.footer-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap: 8px;
  color: var(--text);
}

.footer-social{
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.social-link{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  color: var(--text);
  padding: 10px 12px;
  border-radius: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
}
.social-link:hover{
  background: var(--card);
  color: var(--brand);
}
html[data-theme="dark"] .social-link:hover{
  background: rgba(255,255,255,0.10);
  color: var(--brand);
}

.footer-cta{ margin-top: 12px; }

.footer-bottom{
  border-top: 1px solid var(--border);
  padding: 14px 0;
}
.footer-bottom-inner{
  text-align:center;
  color: var(--text);
  font-size: .92rem;
}

/* =========================
   RESPONSIVE NAV
========================= */
@media (max-width: 900px){
  .nav-toggle{ display:inline-grid; place-items:center; }

  .nav-menu{
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    display: none;
    padding: 12px;
    border-radius: 18px;
    background: rgba(255,255,255,0.98);
    border: 1px solid var(--border);
    backdrop-filter: blur(10px);
    box-shadow: var(--shadow);
  }
  html[data-theme="dark"] .nav-menu{
    background: rgba(11,18,32,0.95);
    border: 1px solid rgba(255,255,255,0.12);
  }

  .nav-menu.is-open{ display:block; }

  .nav-list{
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 0;
    margin-bottom: 10px;
  }

  .nav-link{
    justify-content: space-between;
    border-radius: 16px;
    padding: 12px 14px;
  }

  .nav-cta{
    display:grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .hero-grid{ grid-template-columns: 1fr; }
  .hero-visual{ justify-content:center; }
}

/* =========================================================
   COMPATIBILIDAD: main-header / main-nav (estilo viejo)
========================================================= */
.main-header{
  background-color: var(--bg);
  color: var(--text);
  padding: 0.7rem 1rem;
  position: sticky;
  top: 0;
  z-index: 10;
  border-bottom: 1px solid var(--border);
}
.logo{ color: var(--text); }
.main-nav a{ color: var(--text); }

.hamburguesa{
  display: none;
  background: none;
  border: none;
  color: var(--text);
  font-size: 1.8rem;
  cursor: pointer;
}
@media (max-width: 768px) {
  .main-nav ul{
    display: none;
    flex-direction: column;
    background-color: var(--bg);
    position: absolute;
    top: 60px;
    right: 0;
    width: 200px;
    padding: 1rem;
    border-radius: 0 0 0 8px;
    border: 1px solid var(--border);
  }
  .main-nav.nav-visible ul{ display: flex; }
  .hamburguesa{ display: block; }
}

/* Gotas */
.gotas{
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  overflow: hidden;
  z-index: 1;
}
.gota{
  position: absolute;
  top: -50px;
  background: rgba(0, 140, 255, 0.5);
  border-radius: 50% / 70%;
  filter: drop-shadow(0 0 5px #0080ffaa);
  animation-name: caer;
  animation-timing-function: linear;
  animation-fill-mode: forwards;
}
@keyframes caer{
  0%{ transform: translateY(0) scaleX(1) scaleY(1); opacity: 0.8; }
  50%{ transform: translateY(50vh) scaleX(1.1) scaleY(0.9); opacity: 0.9; }
  100%{ transform: translateY(100vh) scaleX(1) scaleY(1); opacity: 0; }
}

/* =========================================================
   PLOMERÍA (conectado al tema global)
========================================================= */
.plomeria-section{
  padding: 2rem 1rem;
  background: var(--surface);
  text-align: center;
  position: relative;
  z-index: 2;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.plomeria-section h2{ margin-bottom: 1rem; color: var(--brand); }
.plomeria-intro{
  max-width: 600px;
  margin: 0 auto 2rem auto;
  color: var(--text);
  font-size: 1.1rem;
}
.gallery{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}
.gallery img,
.gallery video{
  max-width: 300px;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}
html[data-theme="dark"] .gallery img,
html[data-theme="dark"] .gallery video{
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.6);
}

.servicios-plomeria{
  background: transparent;
  padding: 2rem 1rem;
  text-align: center;
}
.servicios-plomeria h3{ margin-bottom: 1.5rem; color: var(--brand); }

.servicios-lista{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem;
}

.servicio-item{
  max-width: 220px;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1rem;
  color: var(--text);
  background: var(--card);
  transition: background-color 0.3s, color 0.3s, transform .15s ease;
  cursor: default;
}
.servicio-item:hover{
  background-color: var(--surface);
  transform: translateY(-2px);
}
.servicio-item i{
  font-size: 2.5rem;
  margin-bottom: 0.7rem;
  color: var(--primary);
}

/* FAQ */
.faq-plomeria{
  padding: 2rem 1rem;
  background: var(--card);
  max-width: 800px;
  margin: 0 auto 2rem auto;
  border-radius: 8px;
  color: var(--text);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.faq-plomeria h3{ text-align: center; margin-bottom: 1rem; color: var(--brand); }
.faq-item{
  margin-bottom: 1rem;
  cursor: pointer;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.5rem;
}
.faq-question{
  font-weight: 700;
  position: relative;
  padding-right: 1.5rem;
}
.faq-question::after{
  content: "+";
  position: absolute;
  right: 0;
  top: 0;
  font-size: 1.5rem;
  color: var(--text);
}
.faq-item.active .faq-question::after{ content: "-"; }
.faq-answer{ display: none; margin-top: 0.5rem; color: var(--text); }
.faq-item.active .faq-answer{ display: block; }

/* Testimonios */
.testimonios-plomeria{
  background: var(--card);
  padding: 2rem 1rem;
  max-width: 900px;
  margin: 0 auto 2rem auto;
  border-radius: 8px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.testimonios-plomeria h3{
  text-align: center;
  margin-bottom: 1.5rem;
  color: var(--brand);
}
.testimonio-card{
  background: var(--surface);
  padding: 1rem 1.5rem;
  margin-bottom: 1rem;
  border-left: 6px solid rgba(0, 31, 77, 0.65);
  border-radius: 4px;
}
html[data-theme="dark"] .testimonio-card{
  border-left: 6px solid rgba(30, 58, 138, 0.65);
}
.testimonio-card h4{
  margin-top: 0.8rem;
  text-align: right;
  font-weight: 700;
  color: var(--text);
}

/* Contacto */
.contacto-plomeria{
  padding: 2rem 1rem;
  background: var(--card);
  max-width: 600px;
  margin: 0 auto 2rem auto;
  border-radius: 8px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.contacto-plomeria h3{
  text-align: center;
  margin-bottom: 1rem;
  color: var(--brand);
}
.contacto-plomeria input,
.contacto-plomeria textarea{
  padding: 0.7rem 1rem;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text);
}
.contacto-plomeria button{
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  color: #000000 !important;
  border: none;
  padding: 0.8rem 1.2rem;
  border-radius: 6px;
  cursor: pointer;
}
.contacto-plomeria button:hover{ filter: brightness(0.95); }

@media (max-width: 768px){
  .servicios-lista,
  .gallery{
    flex-direction: column;
    align-items: center;
  }
}

/* Star rating */
.star-rating{
  display: flex;
  gap: 5px;
  justify-content: center;
  font-size: 2rem;
  cursor: pointer;
}
html[data-theme="light"] .star-rating{
  color: #003366;
}
html[data-theme="dark"] .star-rating{
  color: #64748b;
}
.star-rating .star.checked{ color: #facc15; }

/* =========================================================
   PISCINAS — CONECTADO A SOL/LUNA (encapsulado)
========================================================= */
.piscinas{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(56,189,248,.18), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(37,99,235,.14), transparent 55%),
    var(--bg);
  color: var(--text);
}
html[data-theme="dark"] .piscinas{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(56,189,248,.22), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(37,99,235,.18), transparent 55%),
    var(--bg);
}

/* Hero de piscinas */
.piscinas .hero{
  padding: 8rem 0 4rem;
  min-height: 78vh;
  display: grid;
  align-items: center;
}
.piscinas .hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, rgba(11,18,32,.35), rgba(11,18,32,.85)),
    url("imagenes/piscinas-hero.jpg");
  background-size: cover;
  background-position: center;
  z-index: -2;
  filter: saturate(1.05);
}
html[data-theme="light"] .piscinas .hero::before{
  background:
    linear-gradient(to bottom, rgba(255,255,255,.20), rgba(11,18,32,.35)),
    url("imagenes/piscinas-hero.jpg");
  background-size: cover;
  background-position: center;
}
.piscinas .hero::after{
  content: "";
  position: absolute;
  inset: -2px;
  background: radial-gradient(900px 450px at 25% 20%, rgba(56,189,248,.22), transparent 55%);
  z-index: -1;
  pointer-events: none;
}

/* Galería piscinas */
.gallery-grid{ margin-top: .25rem; }
.gallery-tile{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: 0 16px 44px rgba(0,0,0,.18);
  min-height: 210px;
}
html[data-theme="dark"] .gallery-tile{
  box-shadow: 0 16px 44px rgba(0,0,0,.42);
}
.gallery-tile img{
  width: 100%;
  height: 240px;
  object-fit: cover;
  display:block;
  transform: scale(1.01);
  transition: transform .3s ease, filter .3s ease;
  filter: saturate(1.05) contrast(1.03);
}
.gallery-tile:hover img{
  transform: scale(1.08);
  filter: saturate(1.12) contrast(1.06);
}

/* =========================================================
   NOSOTROS — CONECTADO A SOL/LUNA (encapsulado)
========================================================= */
.nosotros{
  background:
    radial-gradient(1200px 600px at 10% 0%, var(--gradient-blue-light), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, var(--gradient-green-light), transparent 55%),
    var(--bg);
  color: var(--text);
}
html[data-theme="dark"] .nosotros{
  background:
    radial-gradient(1200px 600px at 10% 0%, var(--gradient-blue-dark), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, var(--gradient-green-dark), transparent 55%),
    var(--bg);
}

.nosotros .hero{
  padding: 8rem 0 4rem;
  min-height: 72vh;
  display: grid;
  align-items: center;
}
.nosotros .hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(11,18,32,.30), rgba(11,18,32,.88)),
    url("imagenes/sobre-hero.jpg");
  background-size: cover;
  background-position: center;
  z-index:-2;
  filter: saturate(1.05);
}
html[data-theme="light"] .nosotros .hero::before{
  background:
    linear-gradient(to bottom, rgba(255,255,255,.18), rgba(11,18,32,.38)),
    url("imagenes/sobre-hero.jpg");
  background-size: cover;
  background-position: center;
}
.nosotros .hero::after{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(900px 450px at 25% 18%, rgba(13,110,253,.22), transparent 55%);
  z-index:-1;
  pointer-events:none;
}

.badge-glow{
  display:inline-flex;
  gap:.5rem;
  align-items:center;
  padding:.45rem .75rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  font-weight: 700;
  box-shadow: var(--shadow);
}

.nosotros .stat{
  padding: 1.1rem 1.2rem;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface);
}
.nosotros .stat .num{
  font-weight: 900;
  font-size: 1.6rem;
  letter-spacing: -0.02em;
  color: var(--brand);
}
.nosotros .stat .lbl{ color: var(--text); font-weight: 600; }

.value-item{
  display:flex;
  gap:.9rem;
  align-items:flex-start;
  padding: 1rem;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface);
}
.value-item i{
  color: var(--accent);
  margin-top: .25rem;
}

.cta-band{
  background: linear-gradient(135deg, rgba(13,110,253,.14), rgba(34,197,94,.10));
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 2.2rem;
  box-shadow: var(--shadow);
}
html[data-theme="dark"] .cta-band{
  background: linear-gradient(135deg, rgba(13,110,253,.20), rgba(34,197,94,.14));
}

/* =========================================================
   ELECTRICIDAD — CONECTADO A SOL/LUNA (encapsulado)
========================================================= */
.electricidad{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(13,110,253,.14), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(34,197,94,.10), transparent 55%),
    var(--bg);
  color: var(--text);
}
html[data-theme="dark"] .electricidad{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(13,110,253,.22), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(34,197,94,.18), transparent 55%),
    var(--bg);
}

/* Botón extra "rayo" */
.btn-bolt{
  border-radius: 999px;
  padding: .75rem 1.1rem;
  font-weight: 900;
  background: color-mix(in srgb, var(--bolt) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--bolt) 30%, transparent);
  color: var(--text);
  transition: transform .2s ease, filter .2s ease, background .2s ease;
}
.btn-bolt:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
  background: color-mix(in srgb, var(--bolt) 22%, transparent);
}

/* HERO Electricidad */
.electricidad .hero{
  padding: 8rem 0 4rem;
  min-height: 78vh;
  display:grid;
  align-items:center;
}
.electricidad .hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(11,18,32,.35), rgba(11,18,32,.82)),
    url("imagenes/electricidad-hero.jpg");
  background-size: cover;
  background-position: center;
  filter: saturate(1.05);
  z-index:-2;
}
html[data-theme="light"] .electricidad .hero::before{
  background:
    linear-gradient(to bottom, rgba(255, 255, 255, 0.712), rgba(11,18,32,.38)),
    url("imagenes/electricidad-hero.jpg");
  background-size: cover;
  background-position: center;
}

.electricidad .hero::after{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(900px 450px at 20% 15%, rgba(251,191,36,.24), transparent 55%);
  z-index:-1;
  pointer-events:none;
}

.electricidad .badge-glow{
  display:inline-flex;
  gap:.5rem;
  align-items:center;
  padding:.45rem .75rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  font-weight: 800;
  box-shadow: var(--shadow);
}

/* Checklist */
.checklist{
  list-style: none;
  padding-left: 0;
  margin: 0;
  display: grid;
  gap: .75rem;
}
.checklist li{
  display:flex;
  gap:.7rem;
  align-items:flex-start;
  color: var(--text);
}
.pagina-electricidad .checklist i{
  color: var(--accent);
  margin-top: .15rem;
}

/* Icon-pill con "rayo" */
.electricidad .icon-pill{
  background: color-mix(in srgb, var(--bolt) 16%, transparent);
  border: 1px solid color-mix(in srgb, var(--bolt) 28%, transparent);
}

/* Fotos en "¿Qué ofrecemos?" (Electricidad) */
.pagina-electricidad .service-card{ overflow:hidden; }

.service-media{
  border-radius: 60px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: 0 12px 35px rgba(0,0,0,.18);
  margin-bottom: 12px;
}
html[data-theme="dark"] .service-media{
  box-shadow: 0 12px 35px rgba(0,0,0,.40);
}
.service-media img{
  width: 100%;
  height: 165px;
  object-fit: cover;
  display: block;
  transform: scale(1.01);
  transition: transform .25s ease, filter .25s ease;
  filter: contrast(1.02) saturate(1.05);
}
.service-card:hover .service-media img{
  transform: scale(1.07);
  filter: contrast(1.06) saturate(1.12);
}

/* Galería (Electricidad) */
.electricidad .gallery-grid{ margin-top: .25rem; }

.electricidad .gallery-tile{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: 0 16px 44px rgba(0,0,0,.18);
  min-height: 210px;
}
html[data-theme="dark"] .electricidad .gallery-tile{
  box-shadow: 0 16px 44px rgba(0,0,0,.45);
}
.electricidad .gallery-tile img{
  width: 100%;
  height: 240px;
  object-fit: cover;
  display:block;
  transform: scale(1.01);
  transition: transform .3s ease, filter .3s ease;
  filter: saturate(1.05) contrast(1.03);
}
.electricidad .gallery-tile:hover img{
  transform: scale(1.08);
  filter: saturate(1.12) contrast(1.06);
}
.electricidad .gallery-tile::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(0,0,0,.28), rgba(0,0,0,0));
  pointer-events:none;
}

/* Logo chispa */
.logo-electricidad{
  font-size: 2rem;
  font-weight: bold;
  color: var(--bolt);
  background: color-mix(in srgb, var(--text) 12%, transparent);
  display: inline-block;
  padding: 0.5rem 1rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  text-shadow: 0 10px 30px rgba(0,0,0,.25);
  animation: chispa 1.5s infinite alternate;
}
.logo-electricidad i{
  margin-right: 0.5rem;
  color: color-mix(in srgb, var(--bolt) 90%, #fff);
}
@keyframes chispa{
  0% { text-shadow: 0 0 8px rgba(251, 190, 36, 0.808); }
  100% { text-shadow: 0 0 22px rgba(251,191,36,.75); }
}

/* =========================================================
   REFRIGERACIÓN — CONECTADO A SOL/LUNA (encapsulado)
========================================================= */
.refrigeracion{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(56,189,248,.18), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(34,197,94,.14), transparent 55%),
    var(--bg);
  color: var(--text);
}

/* Navbar glass para refrigeración */
.refrigeracion .navbar-glass{
  background: rgba(11,18,32,.45);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
}
.refrigeracion .navbar .nav-link{
  color: rgba(255,255,255,.82);
  font-weight: 600;
}
.refrigeracion .navbar .nav-link:hover{ color:#fff; }
.refrigeracion .navbar .nav-link.active{
  color:#ffffff5b;
  text-decoration: underline;
  text-underline-offset: 7px;
}

/* Botones refrigeración */
.refrigeracion .btn-soft{
  border-radius: 999px;
  padding: .65rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0);
  background: rgba(255,255,255,.06);
  color:#ffffff60;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.refrigeracion .btn-soft:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.22);
  color:#ffffff1c;
}

.refrigeracion .btn-brand{
  border-radius: 999px;
  padding: .75rem 1.1rem;
  font-weight: 800;
  box-shadow: 0 14px 34px rgba(56,189,248,.18);
}

/* HERO refrigeración */
.refrigeracion .hero{
  position: relative;
  padding: 8rem 0 4rem;
  min-height: 78vh;
  display: grid;
  align-items: center;
}
.refrigeracion .hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(11,18,32,.35), rgba(11,18,32,.85)),
    url("imagenes/refrigeracion-hero.jpg");
  background-size: cover;
  background-position: center;
  z-index:-2;
  filter: saturate(1.05);
}
.refrigeracion .hero::after{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(900px 450px at 25% 20%, rgba(56,189,248,.22), transparent 55%);
  z-index:-1;
  pointer-events:none;
}

.refrigeracion .badge-glow{
  display:inline-flex;
  gap:.5rem;
  align-items:center;
  padding:.45rem .75rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.92);
  font-weight: 700;
  box-shadow: var(--shadow);
}

.refrigeracion .hero h1{
  font-size: clamp(2rem, 4vw, 3.25rem);
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1.05;
}
.refrigeracion .lead-muted{ color: var(--text); }

/* Secciones refrigeración */
.refrigeracion .section{ padding: 4rem 0; }

.refrigeracion .card-glass{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.refrigeracion .icon-pill{
  width: 46px; height: 46px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(56,189,248,.14);
  border: 1px solid rgba(56,189,248,.30);
  color: rgba(0, 0, 0, 0.95);
}

/* Lista bonita refrigeración */
.refrigeracion .list-clean li{
  margin-bottom: .65rem;
  color: var(--text);
}
.refrigeracion .list-clean i{
  color: rgba(2, 63, 88, 0.95);
  margin-right: .55rem;
}

/* CTA banda refrigeración */
.refrigeracion .cta-band{
  background: linear-gradient(135deg, rgba(56,189,248,.16), rgba(34,197,94,.10));
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  padding: 2.2rem;
  box-shadow: var(--shadow);
}

/* Footer refrigeración */
.refrigeracion footer{
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.15);
}
.refrigeracion .footer-link{
  color: var(--text);
  text-decoration: none;
}
.refrigeracion .footer-link:hover{ color:#000000; }

/* Imágenes grandes en "¿Qué ofrecemos?" refrigeración */
.refrigeracion .service-card{ overflow: hidden; }

.refrigeracion .service-media{
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  box-shadow: 0 12px 35px rgba(0,0,0,.28);
  margin-bottom: 14px;
}
html[data-theme="dark"] .refrigeracion .service-media{
  box-shadow: 0 12px 35px rgba(0,0,0,.48);
}
.refrigeracion .service-media img{
  width: 100%;
  height: 240px;           /* tamaño grande */
  object-fit: cover;
  display: block;
  transform: scale(1.01);
  transition: transform .28s ease, filter .28s ease;
  filter: contrast(1.03) saturate(1.10);
}

.refrigeracion .service-card:hover .service-media img{
  transform: scale(1.08);
  filter: contrast(1.06) saturate(1.18);
}

/* Imágenes en "¿Por qué elegirnos?" (GRID 2x2) refrigeración */
.refrigeracion .why-media{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.refrigeracion .why-img{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.575);
  box-shadow: 0 16px 44px rgba(0,0,0,.35);
  background: rgba(255,255,255,.04);
}

.refrigeracion .why-img img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
  transition: transform .35s ease, filter .35s ease;
  filter: saturate(1.05) contrast(1.04);
}

.refrigeracion .why-img:hover img{
  transform: scale(1.08);
  filter: saturate(1.15) contrast(1.08);
}

@media (max-width: 991px){
  .refrigeracion .why-media{ grid-template-columns: 1fr; }
  .refrigeracion .why-img img{ height: 250px; }
  .refrigeracion .service-media img{ height: 250px; }
}
@media (max-width: 768px){
  .refrigeracion .section{ padding: 2.5rem 1rem; }   
  .refrigeracion .navbar{
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  } 
  .refrigeracion .nav-links{
    flex-direction: column; 
    width: 100%;
    align-items: flex-start;
  }
  .refrigeracion .nav-links a{ width: 100%; }
  .refrigeracion .hero{
    padding: 6rem 0 3rem;
    min-height: 65vh;
  }
  .refrigeracion .hero h1{ font-size: clamp(1.75rem, 6vw, 2.75rem); }
}

/* =========================================================
   NAVBAR GENERAL (conectado al tema global)
========================================================= */
.navbar{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--shadow);
}
.navbar .logo{
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--brand);
  text-decoration: none;
}
.main-nav ul{
  display: flex;
  gap: 1.8rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.main-nav ul li a{
  color: var(--text);
  text-decoration: none;
  font-weight: 600;
  transition: color 0.3s;
}
.main-nav ul li a:hover{ color: var(--primary); }
.hamburguesa{
  display: none;
  font-size: 1.8rem;
  color: var(--text);
  cursor: pointer;
}
@media (max-width: 768px){
  .main-nav ul{
    display: none;
    flex-direction: column;
    gap: 1.2rem;
    background: var(--bg);
    position: absolute;
    top: 60px;
    right: 2rem;
    padding: 1rem 1.5rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    box-shadow: var(--shadow);
  }
  .main-nav ul.show{ display: flex; }
  .hamburguesa{ display: block; }
}

/* =========================
   ANIMACIONES
========================= */
@keyframes floatUp{
  0%{ transform: translateY(0) scaleX(1) scaleY(1); opacity: 1; }       
  100%{ transform: translateY(-20px) scaleX(1.05) scaleY(0.95); opacity: 0; }
}

.burbuja{
  position: absolute;
  bottom: -40px;
  width: 30px;
  height: 30px;
  background: rgba(0, 128, 255, 0.2);
  border-radius: 50%;
  animation-duration: 6s;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
  animation-name: floatUp;
}
.burbuja:nth-child(1){
  left: 10%;
  animation-delay: 0s;
}
.burbuja:nth-child(2){
  left: 30%;
  width: 20px;
  height: 20px;
  animation-delay: 2s;
}
.burbuja:nth-child(3){
  left: 50%;
  width: 25px;
  height: 25px;
  animation-delay: 4s;
}
.burbuja:nth-child(4){
  left: 70%;
  width: 15px;
  height: 15px;
  animation-delay: 1s;
}

/* =========================
   SOLUCIÓN NUCLEAR PARA TEXTO BLANCO EN MODO CLARO
   Esto asegura que TODO el texto sea negro en modo claro
========================= */
html[data-theme="light"] {
  /* Fuerza color negro en todos los elementos de texto */
  color-scheme: light;
}

/* Regla global para forzar texto negro en modo claro */
html[data-theme="light"] * {
  color: #000000 !important;
}

/* Excepciones necesarias */
html[data-theme="light"] .btn-primary,
html[data-theme="light"] .btn-brand,
html[data-theme="light"] .wa-float,
html[data-theme="light"] .hero-card-icon,
html[data-theme="light"] .card-icon,
html[data-theme="light"] .theme-toggle *,
html[data-theme="light"] .star.checked,
html[data-theme="light"] [style*="color: white"],
html[data-theme="light"] [style*="color: #bl"],
html[data-theme="light"] [style*="color: #ffffff"] {
  color: inherit !important;
}

/* Botones mantienen su color de texto */
html[data-theme="light"] .btn-primary,
html[data-theme="light"] .btn-brand {
  color: #000000 !important;
}

/* Íconos especiales */
html[data-theme="light"] .fa,
html[data-theme="light"] .fas,
html[data-theme="light"] .far,
html[data-theme="light"] .fab {
  color: var(--brand) !important;
}

/* Títulos - azul oscuro para destacar */
html[data-theme="light"] h1,
html[data-theme="light"] h2,
html[data-theme="light"] h3,
html[data-theme="light"] h4,
html[data-theme="light"] h5,
html[data-theme="light"] h6,
html[data-theme="light"] .brand-name,
html[data-theme="light"] .section-title,
html[data-theme="light"] .card-title,
html[data-theme="light"] .hero-title {
  color: var(--brand) !important;
}

/* Enlaces */
html[data-theme="light"] a:not(.btn):hover {
  color: var(--primary) !important;
}

/* Placeholders */
html[data-theme="light"] ::placeholder {
  color: rgba(0, 0, 0, 0.5) !important;
}

/* Inputs y textareas */
html[data-theme="light"] input,
html[data-theme="light"] textarea,
html[data-theme="light"] select {
  color: #000000 !important;
  background-color: rgba(0, 0, 0, 0.9) !important;
}

/* Asegurar que elementos con colores inline se mantengan */
html[data-theme="light"] [class*="text-white"],
html[data-theme="light"] [class*="text-light"],
html[data-theme="light"] [style*="color:white"],
html[data-theme="light"] [style*="color:#fff"],
html[data-theme="light"] [style*="color:#ffffff"] {
  color: #000000 !important;
}

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;700&family=Open+Sans:wght@400;600;700&display=swap');

/* =========================================================
   styles.css (UNIFICADO / COMPLETO) - CONTRASTE MEJORADO
   - TEMA CLARO (SOL) = :root + (opcional) html[data-theme="light"]
   - TEMA OSCURO (LUNA) = html[data-theme="dark"]
   ========================================================= */

/* =========================
   TEMA CLARO (SOL) - CONTRASTE FUERTE
========================= */
:root{
  --bg: #ffffff;
  
  --surface: rgba(0, 0, 0, 0.03);
  --card: rgba(0, 0, 0, 0.04);
  --border: rgba(0, 0, 0, 0.15);
  
  /* TEXTO NEGRO FUERTE PARA MÁXIMO CONTRASTE */
  --text: #000000; 
  --muted: rgba(0, 0, 0, 0.75);
  
  /* Sol: botones azul cielo vibrantes */
  --primary: #0066cc;
  --primary-2: #0088ff;
  
  /* Marca / títulos (azul marino OSCURO) */
  --brand: #001133;
  --brand-2: #002255;
  
  /* Acentos VIBRANTES */
  --accent: #0d8c2d;  /* verde oscuro vibrante */
  --bolt: #e6b400;    /* amarillo dorado vibrante */
  
  --shadow: 0 10px 30px rgba(0,0,0,0.15);
  --radius: 18px;
  
  --container: 1200px;
  
  /* Gradientes reutilizables (Nosotros) */
  --gradient-blue-light: rgba(0, 80, 200, 0.15);
  --gradient-green-light: rgba(13, 140, 45, 0.12);
  --gradient-blue-dark: rgba(13,110,253,.20);
  --gradient-green-dark: rgba(34,197,94,.14);
}

/* Tema claro explícito */
html[data-theme="light"]{
  --bg: #ffffff;
  
  --surface: rgba(0, 0, 0, 0.03);
  --card: rgba(0, 0, 0, 0.04);
  --border: rgba(0, 0, 0, 0.15);
  
  /* TEXTO NEGRO FUERTE */
  --text: #000000;
  --muted: rgba(0, 0, 0, 0.75);
  
  --primary: #0066cc;
  --primary-2: #0088ff;
  
  --brand: #001133;
  --brand-2: #002255;
  
  --accent: #0d8c2d;
  --bolt: #e6b400;
  
  --shadow: 0 10px 30px rgba(0,0,0,0.15);
}

/* =========================
   TEMA OSCURO (LUNA)
========================= */
html[data-theme="dark"]{
  --bg: #0b1220;
  
  --surface: rgba(255,255,255,0.08);
  --card: rgba(255,255,255,0.06);
  --border: rgba(255,255,255,0.12);
  
  --text: rgba(255,255,255,0.92);
  --muted: rgba(255,255,255,0.72);
  
  --primary: #1e88ff;
  --primary-2: #00d4ff;
  
  --brand: #ffffff;
  --brand-2: rgba(255,255,255,0.85);
  
  --accent: #22c55e;
  --bolt: #fbbf24;
  
  --shadow: 0 10px 30px rgba(0,0,0,0.35);
}

/* =========================
   RESET / GLOBAL
========================= */
*{ margin:0; padding:0; box-sizing:border-box; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
html{ scroll-behavior:smooth; }

html, body{
  background: var(--bg);
  color: var(--text);
  transition: background-color 0.3s ease, color 0.3s ease;
}

body{
  font-family: "Plus Jakarta Sans", "Open Sans", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
  
  /* Fondo decorativo global (se adapta a tema) */
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(0,31,77,0.08), transparent 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(0,61,122,0.06), transparent 55%),
    radial-gradient(900px 600px at 50% 100%, rgba(0,0,0,0.02), transparent 60%),
    var(--bg);
}

html[data-theme="dark"] body{
  background:
    radial-gradient(1200px 600px at 20% 10%, rgba(25,143,227,0.18), transparent 60%),
    radial-gradient(900px 500px at 80% 20%, rgba(0,61,122,0.18), transparent 55%),
    radial-gradient(900px 600px at 50% 100%, rgba(255,255,255,0.06), transparent 60%),
    var(--bg);
}

/* =========================
   CONTRASTE FORZADO EN MODO SOL - SOLUCIÓN COMPLETA
========================= */

/* 1. Fuerza texto negro en TODO el cuerpo en modo claro */
html[data-theme="light"] body,
html[data-theme="light"] .body-content,
html[data-theme="light"] main,
html[data-theme="light"] section,
html[data-theme="light"] div:not(.btn-primary):not(.btn-brand):not(.wa-float):not(.hero-card-icon):not(.card-icon):not(.theme-toggle *),
html[data-theme="light"] article {
  color: #000000 !important;
}

/* 2. Excepciones específicas para mantener colores especiales */
html[data-theme="light"] .btn-primary,
html[data-theme="light"] .btn-brand,
html[data-theme="light"] .wa-float {
  color: #ffffff !important;
}

/* 3. Elementos de texto específicos - TODOS NEGROS */
html[data-theme="light"] p,
html[data-theme="light"] span:not(.theme-toggle *),
html[data-theme="light"] li,
html[data-theme="light"] td,
html[data-theme="light"] th,
html[data-theme="light"] label,
html[data-theme="light"] strong,
html[data-theme="light"] em,
html[data-theme="light"] b,
html[data-theme="light"] i:not([class*="fa-"]),
html[data-theme="light"] small,
html[data-theme="light"] caption {
  color: #000000 !important;
}

/* 4. Títulos - azul oscuro para contraste */
html[data-theme="light"] h1,
html[data-theme="light"] h2,
html[data-theme="light"] h3,
html[data-theme="light"] h4,
html[data-theme="light"] h5,
html[data-theme="light"] h6 {
  color: var(--brand) !important;
}

/* 5. Enlaces */
html[data-theme="light"] a:not(.btn-primary):not(.btn-brand):not(.wa-float) {
  color: #000000 !important;
}

html[data-theme="light"] a:not(.btn-primary):not(.btn-brand):not(.wa-float):hover {
  color: var(--primary) !important;
}

/* 6. Cartas y contenedores - texto negro */
html[data-theme="light"] .card,
html[data-theme="light"] .card-glass,
html[data-theme="light"] .servicio-item,
html[data-theme="light"] .service-card,
html[data-theme="light"] .testimonio-card,
html[data-theme="light"] .faq-plomeria,
html[data-theme="light"] .contacto-plomeria {
  color: #000000 !important;
}

/* Texto dentro de cartas */
html[data-theme="light"] .card *:not(.btn-primary):not(.btn-brand):not(.card-icon),
html[data-theme="light"] .servicio-item *:not(.btn),
html[data-theme="light"] .service-card *:not(.btn) {
  color: #000000 !important;
}

/* 7. Específico para cartas de servicios de plomería */
html[data-theme="light"] .servicios-plomeria,
html[data-theme="light"] .servicios-lista,
html[data-theme="light"] .servicio-item p,
html[data-theme="light"] .servicio-item span,
html[data-theme="light"] .servicio-item div:not(.icon-container),
html[data-theme="light"] .servicio-item li {
  color: #000000 !important;
}

/* 8. Listas de servicios (tu problema específico) */
html[data-theme="light"] .servicios-lista .servicio-item,
html[data-theme="light"] .servicios-lista .servicio-item * {
  color: #000000 !important;
}

/* 9. Texto en formularios */
html[data-theme="light"] input,
html[data-theme="light"] textarea,
html[data-theme="light"] select,
html[data-theme="light"] .form-control,
html[data-theme="light"] .form-select {
  color: #000000 !important;
  background: rgba(255, 255, 255, 0.95) !important;
}

html[data-theme="light"] ::placeholder {
  color: rgba(0, 0, 0, 0.6) !important;
}

/* 10. Footer */
html[data-theme="light"] .site-footer,
html[data-theme="light"] .footer-text,
html[data-theme="light"] .footer-list,
html[data-theme="light"] .footer-bottom-inner,
html[data-theme="light"] .social-link {
  color: #000000 !important;
}

/* 11. Íconos Font Awesome - oscuros para contraste */
html[data-theme="light"] .fa,
html[data-theme="light"] .fas,
html[data-theme="light"] .far,
html[data-theme="light"] .fab,
html[data-theme="light"] .fal {
  color: var(--brand) !important;
}

/* Íconos específicos en servicios */
html[data-theme="light"] .servicio-item i,
html[data-theme="light"] .service-card i,
html[data-theme="light"] .value-item i,
html[data-theme="light"] .checklist i {
  color: #003366 !important;
}

/* 12. Navbar y menú - fondo claro, texto oscuro */
html[data-theme="light"] .navbar,
html[data-theme="light"] .navbar-glass,
html[data-theme="light"] .site-header,
html[data-theme="light"] .main-header {
  background: rgba(255, 255, 255, 0.98) !important;
  border-color: rgba(0, 0, 0, 0.15) !important;
}

html[data-theme="light"] .nav-link,
html[data-theme="light"] .navbar .nav-link,
html[data-theme="light"] .main-nav ul li a,
html[data-theme="light"] .hamburguesa {
  color: #000000 !important;
}

html[data-theme="light"] .nav-link:hover,
html[data-theme="light"] .navbar .nav-link:hover {
  color: var(--primary) !important;
}

/* 13. Menú desplegable */
html[data-theme="light"] .nav-menu,
html[data-theme="light"] .main-nav ul {
  background: rgba(255, 255, 255, 0.99) !important;
  border-color: rgba(0, 0, 0, 0.2) !important;
}

/* =========================
   BOTÓN TEMA LUNA/SOL
========================= */
.theme-toggle {
  position: relative;
  width: 60px;
  height: 30px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50px;
  cursor: pointer;
  display: flex;
  align-items: center;
  padding: 0 5px;
  transition: all 0.3s ease;
}

.theme-toggle::before {
  content: '';
  position: absolute;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, #fbbf24, #f59e0b);
  transition: transform 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  color: #000;
}

html[data-theme="dark"] .theme-toggle::before {
  transform: translateX(30px);
  background: linear-gradient(135deg, #103870, #0d3772);
}

.theme-toggle .sun-icon,
.theme-toggle .moon-icon {
  position: absolute;
  font-size: 14px;
  transition: opacity 0.3s ease;
}

.theme-toggle .sun-icon {
  left: 8px;
  color: #f59e0b;
  opacity: 1;
}

.theme-toggle .moon-icon {
  right: 8px;
  color: #074086;
  opacity: 0.5;
}

html[data-theme="dark"] .theme-toggle .sun-icon {
  opacity: 0.5;
}

html[data-theme="dark"] .theme-toggle .moon-icon {
  opacity: 1;
  color: #0b52af;
}

.container{
  width: min(92%, var(--container));
  margin: 0 auto;
}

/* Skip link */
.skip-link{
  position:absolute;
  left:-9999px;
  top:10px;
  padding:10px 14px;
  border-radius: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  z-index: 999;
}
.skip-link:focus{ left: 12px; }

/* =========================
   UI GLOBAL (glass/cards/forms/reveal/wa)
========================= */

/* Navbar glass (Bootstrap .navbar / o tu clase .navbar-glass) */
.navbar-glass{
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,.85);
}
html[data-theme="dark"] .navbar-glass{
  background: rgba(11,18,32,.65);
}

/* Links navbar (Bootstrap) */
.navbar .nav-link{
  color: var(--text);
  font-weight: 600;
}
.navbar .nav-link:hover,
.navbar .nav-link.active{
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 7px;
}

/* Botones */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  padding: 12px 18px;
  border-radius: 999px;
  font-weight: 700;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .15s ease, filter .2s ease, background .2s ease, border .2s ease;
}
.btn-lg{ padding: 13px 20px; }

.btn-primary{
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  color: #ffffff !important;
  box-shadow: 0 16px 35px rgba(0,31,77,0.22);
}
html[data-theme="dark"] .btn-primary{ box-shadow: 0 16px 35px rgba(0,0,0,0.40); }
.btn-primary:hover{ transform: translateY(-1px); filter: brightness(0.95); }

.btn-ghost{
  background: transparent;
  border-color: var(--border);
  color: var(--text);
}
.btn-ghost:hover{ transform: translateY(-1px); background: var(--surface); }

/* Botón estilo soft (compatible con tus páginas) */
.btn-soft{
  border-radius: 999px;
  padding: .65rem 1rem;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.btn-soft:hover{
  transform: translateY(-1px);
  background: var(--card);
  border-color: rgba(0, 80, 200, 0.3);
}

/* Botón marca */
.btn-brand{
  border-radius: 999px;
  padding: .75rem 1.1rem;
  font-weight: 800;
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  color:#fff !important;
  box-shadow: var(--shadow);
  border: 1px solid transparent;
  transition: transform .2s ease, filter .2s ease;
}
.btn-brand:hover{ transform: translateY(-1px); filter: brightness(.97); }

/* Card glass reutilizable */
.card-glass{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  color: var(--text);
}

/* Icon pill */
.icon-pill{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  background: rgba(0, 80, 200, 0.15);
  border: 1px solid rgba(0, 80, 200, 0.3);
  color: var(--text);
}

html[data-theme="light"] .icon-pill {
  background: rgba(0, 31, 77, 0.15);
  border: 1px solid rgba(0, 31, 77, 0.3);
}

/* Inputs / selects (Bootstrap) */
.form-control,
.form-select{
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  border-radius: 14px;
  padding: .85rem .95rem;
}
html[data-theme="light"] .form-control,
html[data-theme="light"] .form-select{
  background: rgba(0, 0, 0, 0.03);
}
.form-control::placeholder{ color: var(--muted); }
html[data-theme="light"] .form-control::placeholder{ color: rgba(0, 0, 0, 0.6); }
.form-control:focus{
  border-color: var(--primary);
  box-shadow: 0 0 0 .2rem rgba(0, 102, 204, 0.25);
}

/* Reveal (tu JS lo usa) */
.reveal{
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.show{
  opacity: 1;
  transform: translateY(0);
}

/* WhatsApp flotante */
.wa-float{
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 9999;
  border-radius: 999px;
  padding: .85rem 1rem;
  display: inline-flex;
  gap: .6rem;
  align-items:center;
  text-decoration:none;
  background: var(--primary);
  color:#ffffff !important;
  box-shadow: var(--shadow);
  transition: transform .2s ease, filter .2s ease;
}
.wa-float:hover{
  transform: translateY(-2px);
  filter: brightness(.96);
  color:#ffffff !important;
}

/* =========================
   HEADER / NAV (site-header)
========================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(10px);
  background: rgba(255,255,255,0.95);
  border-bottom: 1px solid var(--border);
}
html[data-theme="dark"] .site-header{
  background: rgba(11,18,32,0.85);
  border-bottom: 1px solid rgba(255,255,255,0.10);
}

.header-container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;
  gap: 16px;
}

.brand{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 220px;
}
.brand-logo{
  width: 90px;
  height: 90px;
  border-radius: 50px;
  object-fit: cover;
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}
html[data-theme="dark"] .brand-logo{ box-shadow: 0 8px 20px rgba(0,0,0,0.45); }

.brand-name{
  font-family: 'Playfair Display', serif;
  letter-spacing: 0.3px;
  font-weight: 700;
  font-size: 1.35rem;
  color: var(--brand);
}

.nav{
  position: relative;
  display:flex;
  align-items:center;
  gap: 12px;
}

.nav-toggle{
  display:none;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
  width: 44px;
  height: 44px;
  border-radius: 14px;
  cursor:pointer;
  transition: transform .15s ease, background .2s ease;
}
.nav-toggle:hover{ transform: translateY(-1px); background: rgba(0,0,0,0.06); }
html[data-theme="dark"] .nav-toggle:hover{ background: rgba(255,255,255,0.12); }

.nav-menu{
  display:flex;
  align-items:center;
  gap: 14px;
}

.nav-list{
  list-style:none;
  display:flex;
  align-items:center;
  gap: 10px;
}

.nav-link{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  font-weight: 600;
  color: var(--text);
  transition: background .2s ease, color .2s ease, transform .15s ease;
}
.nav-link:hover{
  background: var(--surface);
  color: var(--brand);
  transform: translateY(-1px);
}
.nav-link.is-active{
  background: rgba(0,31,77,0.15);
  color: var(--brand);
}
html[data-theme="dark"] .nav-link.is-active{
  background: rgba(25,143,227,0.16);
  color: var(--brand);
}

.nav-cta{
  display:flex;
  align-items:center;
  gap: 10px;
}

/* =========================
   HERO GLOBAL (para páginas normales)
========================= */
.hero{
  position: relative;
  padding: 86px 0 56px;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: 22px;
  align-items:center;
}

.hero-content{ max-width: 820px; }

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--brand);
  margin-bottom: 18px;
}
html[data-theme="dark"] .hero-badge{ color: var(--text); }

.hero-title{
  font-family:'Playfair Display', serif;
  font-size: clamp(2rem, 4vw, 3.25rem);
  line-height: 1.08;
  margin-bottom: 14px;
  color: var(--brand);
}

.hero-subtitle{
  color: var(--text);
  font-size: 1.08rem;
  max-width: 680px;
  margin-bottom: 22px;
}

.hero-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 22px;
}

.hero-highlights{
  list-style:none;
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  color: var(--text);
}
.hero-highlights li{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
}

.hero-visual{ display:flex; justify-content:flex-end; }
.hero-card{
  width: min(420px, 100%);
  padding: 18px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  display:flex;
  gap: 14px;
  align-items:center;
}
.hero-card-icon{
  width: 54px;
  height: 54px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, rgba(0, 80, 200, 0.4), rgba(0, 120, 255, 0.25));
  border: 1px solid var(--border);
  font-size: 1.45rem;
  color: #000000;
}
.hero-card-title{ font-weight: 800; margin-bottom: 2px; color: var(--brand); }
.hero-card-desc{ color: var(--text); font-size: .98rem; }

/* =========================
   SECCIONES / TITULOS
========================= */
.section{ padding: 56px 0; }

.section-head{
  text-align:center;
  max-width: 820px;
  margin: 0 auto 28px;
}
.section-title{
  font-family:'Playfair Display', serif;
  font-size: clamp(1.55rem, 2.5vw, 2.15rem);
  margin-bottom: 8px;
  color: var(--brand);
}
.section-subtitle{ color: var(--text); }

.section-mini-title{
  font-family:'Playfair Display', serif;
  text-align:center;
  margin: 10px 0 14px;
  color: var(--brand);
}

/* =========================
   ABOUT
========================= */
.about-grid{ display:grid; gap: 16px; }

.about-card{
  margin: 0 auto;
  max-width: 920px;
  padding: 22px;
  border-radius: var(--radius);
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  text-align:center;
}
.about-text{
  color: var(--text);
  font-size: 1.05rem;
  margin-bottom: 14px;
}
.about-actions{
  display:flex;
  justify-content:center;
  gap: 12px;
  flex-wrap: wrap;
}

/* =========================
   CARDS / GRID
========================= */
.cards-grid{
  display:grid;
  gap: 16px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.card{
  padding: 18px;
  border-radius: var(--radius);
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: 0 10px 28px rgba(0,0,0,0.12);
  transition: transform .18s ease, background .2s ease, border .2s ease;
}
html[data-theme="dark"] .card{ box-shadow: 0 10px 28px rgba(0,0,0,0.35); }
.card:hover{
  transform: translateY(-4px);
  background: var(--surface);
}

.service-card{
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.card-icon{
  width: 54px;
  height: 54px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: linear-gradient(135deg, rgba(0, 80, 200, 0.4), rgba(0, 120, 255, 0.25));
  border: 1px solid var(--border);
  margin: 0 auto 6px;
  font-size: 1.45rem;
  color: #000000;
}

.card-title{
  text-align:center;
  font-family:'Playfair Display', serif;
  font-size: 1.25rem;
  margin-bottom: 6px;
  color: var(--brand);
}

.card-text{
  text-align:center;
  color: var(--text);
  margin-bottom: 8px;
}

.card-link{
  display:flex;
  justify-content:center;
  gap: 8px;
  color: var(--brand);
  font-weight: 800;
}

/* =========================
   TESTIMONIOS + FORM - CON FONDO BLANCO EN MODO CLARO
========================= */
.testimonials-grid{ margin-bottom: 22px; }
.testimonial-card{ text-align:left; }
.testimonial-text{ color: var(--text); font-style: italic; margin-bottom: 10px; }
.testimonial-meta{ color: var(--text); font-weight: 800; }

.testimonial-form-wrap{
  max-width: 920px;
  margin: 18px auto 0;
  padding: 22px;
  border-radius: var(--radius);
  background: var(--card); /* Este es el color por defecto */
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}

/* FONDO BLANCO EN MODO CLARO */
html[data-theme="light"] .testimonial-form-wrap,
body:not([data-theme="dark"]) .testimonial-form-wrap {
  background: #e7e5e5 !important; /* ← FONDO BLANCO */
  border: 1px solid rgba(0, 0, 0, 0.15) !important;
}

/* Mantener fondo oscuro en modo oscuro */
html[data-theme="dark"] .testimonial-form-wrap {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
}

/* Inputs blancos en modo claro */
html[data-theme="light"] .testimonial-form-wrap input,
html[data-theme="light"] .testimonial-form-wrap textarea {
  background: rgba(255, 255, 255, 0.486) !important;
  border: 1px solid rgba(0, 0, 0, 0.15) !important;
  color: #000000 !important;
}

html[data-theme="dark"] .testimonial-form-wrap input,
html[data-theme="dark"] .testimonial-form-wrap textarea {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
}

.form{ margin-top: 10px; }
.form-grid{
  display:grid;
  gap: 12px;
  grid-template-columns: 1fr;
  margin-bottom: 14px;
}

.field{ display:flex; flex-direction:column; gap: 8px; }
.field-label{ color: var(--text); font-weight: 600; font-size: .95rem; }
.field-full{ grid-column: 1 / -1; }

.input, .textarea, input, textarea{
  width: 100%;
  padding: 12px 12px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  outline: none;
}
input::placeholder, textarea::placeholder{ color: var(--muted); }
input:focus, textarea:focus{
  border-color: rgba(0, 80, 200, 0.8);
  box-shadow: 0 0 0 4px rgba(0, 80, 200, 0.15);
}
/* =========================
   FOOTER
========================= */
.site-footer{
  margin-top: 40px;
  border-top: 1px solid var(--border);
  background: var(--surface);
  backdrop-filter: blur(10px);
}

.footer-grid{
  display:grid;
  gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  padding: 34px 0 18px;
}

.footer-logo{
  width: 62px;
  height: 62px;
  border-radius: 18px;
  object-fit: cover;
  box-shadow: 0 12px 25px rgba(0,0,0,0.15);
  margin-bottom: 10px;
}
html[data-theme="dark"] .footer-logo{ box-shadow: 0 12px 25px rgba(0,0,0,0.45); }

.footer-title{
  font-family:'Playfair Display', serif;
  margin-bottom: 10px;
  color: var(--brand);
}

.footer-text{ color: var(--text); max-width: 340px; }

.footer-list{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap: 8px;
  color: var(--text);
}

.footer-social{
  display:flex;
  flex-direction:column;
  gap: 10px;
}

.social-link{
  display:inline-flex;
  align-items:center;
  gap: 10px;
  color: var(--text);
  padding: 10px 12px;
  border-radius: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
}
.social-link:hover{
  background: var(--card);
  color: var(--brand);
}
html[data-theme="dark"] .social-link:hover{
  background: rgba(255,255,255,0.10);
  color: var(--brand);
}

.footer-cta{ margin-top: 12px; }

.footer-bottom{
  border-top: 1px solid var(--border);
  padding: 14px 0;
}
.footer-bottom-inner{
  text-align:center;
  color: var(--text);
  font-size: .92rem;
}

/* =========================
   RESPONSIVE NAV
========================= */
@media (max-width: 900px){
  .nav-toggle{ display:inline-grid; place-items:center; }

  .nav-menu{
    position: absolute;
    top: calc(100% + 10px);
    left: 0;
    right: 0;
    display: none;
    padding: 12px;
    border-radius: 18px;
    background: rgba(255,255,255,0.98);
    border: 1px solid var(--border);
    backdrop-filter: blur(10px);
    box-shadow: var(--shadow);
  }
  html[data-theme="dark"] .nav-menu{
    background: rgba(11,18,32,0.95);
    border: 1px solid rgba(255,255,255,0.12);
  }

  .nav-menu.is-open{ display:block; }

  .nav-list{
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 0;
    margin-bottom: 10px;
  }

  .nav-link{
    justify-content: space-between;
    border-radius: 16px;
    padding: 12px 14px;
  }

  .nav-cta{
    display:grid;
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .hero-grid{ grid-template-columns: 1fr; }
  .hero-visual{ justify-content:center; }
}

/* =========================================================
   COMPATIBILIDAD: main-header / main-nav (estilo viejo)
========================================================= */
.main-header{
  background-color: var(--bg);
  color: var(--text);
  padding: 0.7rem 1rem;
  position: sticky;
  top: 0;
  z-index: 10;
  border-bottom: 1px solid var(--border);
}
.logo{ color: var(--text); }
.main-nav a{ color: var(--text); }

.hamburguesa{
  display: none;
  background: none;
  border: none;
  color: var(--text);
  font-size: 1.8rem;
  cursor: pointer;
}
@media (max-width: 768px) {
  .main-nav ul{
    display: none;
    flex-direction: column;
    background-color: var(--bg);
    position: absolute;
    top: 60px;
    right: 0;
    width: 200px;
    padding: 1rem;
    border-radius: 0 0 0 8px;
    border: 1px solid var(--border);
  }
  .main-nav.nav-visible ul{ display: flex; }
  .hamburguesa{ display: block; }
}

/* Gotas */
.gotas{
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  pointer-events: none;
  overflow: hidden;
  z-index: 1;
}
.gota{
  position: absolute;
  top: -50px;
  background: rgba(0, 140, 255, 0.5);
  border-radius: 50% / 70%;
  filter: drop-shadow(0 0 5px #0080ffaa);
  animation-name: caer;
  animation-timing-function: linear;
  animation-fill-mode: forwards;
}
@keyframes caer{
  0%{ transform: translateY(0) scaleX(1) scaleY(1); opacity: 0.8; }
  50%{ transform: translateY(50vh) scaleX(1.1) scaleY(0.9); opacity: 0.9; }
  100%{ transform: translateY(100vh) scaleX(1) scaleY(1); opacity: 0; }
}

/* =========================================================
   PLOMERÍA (conectado al tema global)
========================================================= */
.plomeria-section{
  padding: 2rem 1rem;
  background: var(--surface);
  text-align: center;
  position: relative;
  z-index: 2;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.plomeria-section h2{ margin-bottom: 1rem; color: var(--brand); }
.plomeria-intro{
  max-width: 600px;
  margin: 0 auto 2rem auto;
  color: var(--text);
  font-size: 1.1rem;
}
.gallery{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}
.gallery img,
.gallery video{
  max-width: 300px;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25);
}
html[data-theme="dark"] .gallery img,
html[data-theme="dark"] .gallery video{
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.6);
}

.servicios-plomeria{
  background: transparent;
  padding: 2rem 1rem;
  text-align: center;
}
.servicios-plomeria h3{ margin-bottom: 1.5rem; color: var(--brand); }

.servicios-lista{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem;
}

.servicio-item{
  max-width: 220px;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 1rem;
  color: var(--text);
  background: var(--card);
  transition: background-color 0.3s, color 0.3s, transform .15s ease;
  cursor: default;
}
.servicio-item:hover{
  background-color: var(--surface);
  transform: translateY(-2px);
}
.servicio-item i{
  font-size: 2.5rem;
  margin-bottom: 0.7rem;
  color: var(--primary);
}

/* FAQ */
.faq-plomeria{
  padding: 2rem 1rem;
  background: var(--card);
  max-width: 800px;
  margin: 0 auto 2rem auto;
  border-radius: 8px;
  color: var(--text);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.faq-plomeria h3{ text-align: center; margin-bottom: 1rem; color: var(--brand); }
.faq-item{
  margin-bottom: 1rem;
  cursor: pointer;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.5rem;
}
.faq-question{
  font-weight: 700;
  position: relative;
  padding-right: 1.5rem;
}
.faq-question::after{
  content: "+";
  position: absolute;
  right: 0;
  top: 0;
  font-size: 1.5rem;
  color: var(--text);
}
.faq-item.active .faq-question::after{ content: "-"; }
.faq-answer{ display: none; margin-top: 0.5rem; color: var(--text); }
.faq-item.active .faq-answer{ display: block; }

/* Testimonios */
.testimonios-plomeria{
  background: var(--card);
  padding: 2rem 1rem;
  max-width: 900px;
  margin: 0 auto 2rem auto;
  border-radius: 8px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.testimonios-plomeria h3{
  text-align: center;
  margin-bottom: 1.5rem;
  color: var(--brand);
}
.testimonio-card{
  background: var(--surface);
  padding: 1rem 1.5rem;
  margin-bottom: 1rem;
  border-left: 6px solid rgba(0, 31, 77, 0.65);
  border-radius: 4px;
}
html[data-theme="dark"] .testimonio-card{
  border-left: 6px solid rgba(30, 58, 138, 0.65);
}
.testimonio-card h4{
  margin-top: 0.8rem;
  text-align: right;
  font-weight: 700;
  color: var(--text);
}

/* Contacto */
.contacto-plomeria{
  padding: 2rem 1rem;
  background: var(--card);
  max-width: 600px;
  margin: 0 auto 2rem auto;
  border-radius: 8px;
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.contacto-plomeria h3{
  text-align: center;
  margin-bottom: 1rem;
  color: var(--brand);
}
.contacto-plomeria input,
.contacto-plomeria textarea{
  padding: 0.7rem 1rem;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  background: var(--surface);
  color: var(--text);
}
.contacto-plomeria button{
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  color: #000000 !important;
  border: none;
  padding: 0.8rem 1.2rem;
  border-radius: 6px;
  cursor: pointer;
}
.contacto-plomeria button:hover{ filter: brightness(0.95); }

@media (max-width: 768px){
  .servicios-lista,
  .gallery{
    flex-direction: column;
    align-items: center;
  }
}

/* Star rating */
.star-rating{
  display: flex;
  gap: 5px;
  justify-content: center;
  font-size: 2rem;
  cursor: pointer;
}
html[data-theme="light"] .star-rating{
  color: #003366;
}
html[data-theme="dark"] .star-rating{
  color: #64748b;
}
.star-rating .star.checked{ color: #facc15; }

/* =========================================================
   PISCINAS — CONECTADO A SOL/LUNA (encapsulado)
========================================================= */
.piscinas{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(56,189,248,.18), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(37,99,235,.14), transparent 55%),
    var(--bg);
  color: var(--text);
}
html[data-theme="dark"] .piscinas{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(56,189,248,.22), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(37,99,235,.18), transparent 55%),
    var(--bg);
}

/* Hero de piscinas */
.piscinas .hero{
  padding: 8rem 0 4rem;
  min-height: 78vh;
  display: grid;
  align-items: center;
}
.piscinas .hero::before{
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, rgba(11,18,32,.35), rgba(11,18,32,.85)),
    url("imagenes/piscinas-hero.jpg");
  background-size: cover;
  background-position: center;
  z-index: -2;
  filter: saturate(1.05);
}
html[data-theme="light"] .piscinas .hero::before{
  background:
    linear-gradient(to bottom, rgba(255,255,255,.20), rgba(11,18,32,.35)),
    url("imagenes/piscinas-hero.jpg");
  background-size: cover;
  background-position: center;
}
.piscinas .hero::after{
  content: "";
  position: absolute;
  inset: -2px;
  background: radial-gradient(900px 450px at 25% 20%, rgba(56,189,248,.22), transparent 55%);
  z-index: -1;
  pointer-events: none;
}

/* Galería piscinas */
.gallery-grid{ margin-top: .25rem; }
.gallery-tile{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: 0 16px 44px rgba(0,0,0,.18);
  min-height: 210px;
}
html[data-theme="dark"] .gallery-tile{
  box-shadow: 0 16px 44px rgba(0,0,0,.42);
}
.gallery-tile img{
  width: 100%;
  height: 240px;
  object-fit: cover;
  display:block;
  transform: scale(1.01);
  transition: transform .3s ease, filter .3s ease;
  filter: saturate(1.05) contrast(1.03);
}
.gallery-tile:hover img{
  transform: scale(1.08);
  filter: saturate(1.12) contrast(1.06);
}

/* =========================================================
   NOSOTROS — CONECTADO A SOL/LUNA (encapsulado)
========================================================= */
.nosotros{
  background:
    radial-gradient(1200px 600px at 10% 0%, var(--gradient-blue-light), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, var(--gradient-green-light), transparent 55%),
    var(--bg);
  color: var(--text);
}
html[data-theme="dark"] .nosotros{
  background:
    radial-gradient(1200px 600px at 10% 0%, var(--gradient-blue-dark), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, var(--gradient-green-dark), transparent 55%),
    var(--bg);
}

.nosotros .hero{
  padding: 8rem 0 4rem;
  min-height: 72vh;
  display: grid;
  align-items: center;
}
.nosotros .hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(11,18,32,.30), rgba(11,18,32,.88)),
    url("imagenes/sobre-hero.jpg");
  background-size: cover;
  background-position: center;
  z-index:-2;
  filter: saturate(1.05);
}
html[data-theme="light"] .nosotros .hero::before{
  background:
    linear-gradient(to bottom, rgba(255,255,255,.18), rgba(11,18,32,.38)),
    url("imagenes/sobre-hero.jpg");
  background-size: cover;
  background-position: center;
}
.nosotros .hero::after{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(900px 450px at 25% 18%, rgba(13,110,253,.22), transparent 55%);
  z-index:-1;
  pointer-events:none;
}

.badge-glow{
  display:inline-flex;
  gap:.5rem;
  align-items:center;
  padding:.45rem .75rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  font-weight: 700;
  box-shadow: var(--shadow);
}

.nosotros .stat{
  padding: 1.1rem 1.2rem;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface);
}
.nosotros .stat .num{
  font-weight: 900;
  font-size: 1.6rem;
  letter-spacing: -0.02em;
  color: var(--brand);
}
.nosotros .stat .lbl{ color: var(--text); font-weight: 600; }

.value-item{
  display:flex;
  gap:.9rem;
  align-items:flex-start;
  padding: 1rem;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface);
}
.value-item i{
  color: var(--accent);
  margin-top: .25rem;
}

.cta-band{
  background: linear-gradient(135deg, rgba(13,110,253,.14), rgba(34,197,94,.10));
  border: 1px solid var(--border);
  border-radius: 22px;
  padding: 2.2rem;
  box-shadow: var(--shadow);
}
html[data-theme="dark"] .cta-band{
  background: linear-gradient(135deg, rgba(13,110,253,.20), rgba(34,197,94,.14));
}

/* =========================================================
   ELECTRICIDAD — CONECTADO A SOL/LUNA (encapsulado)
========================================================= */
.electricidad{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(13,110,253,.14), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(34,197,94,.10), transparent 55%),
    var(--bg);
  color: var(--text);
}
html[data-theme="dark"] .electricidad{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(13,110,253,.22), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(34,197,94,.18), transparent 55%),
    var(--bg);
}

/* Botón extra "rayo" */
.btn-bolt{
  border-radius: 999px;
  padding: .75rem 1.1rem;
  font-weight: 900;
  background: color-mix(in srgb, var(--bolt) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--bolt) 30%, transparent);
  color: var(--text);
  transition: transform .2s ease, filter .2s ease, background .2s ease;
}
.btn-bolt:hover{
  transform: translateY(-1px);
  filter: brightness(1.02);
  background: color-mix(in srgb, var(--bolt) 22%, transparent);
}

/* HERO Electricidad */
.electricidad .hero{
  padding: 8rem 0 4rem;
  min-height: 78vh;
  display:grid;
  align-items:center;
}
.electricidad .hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(11,18,32,.35), rgba(11,18,32,.82)),
    url("imagenes/electricidad-hero.jpg");
  background-size: cover;
  background-position: center;
  filter: saturate(1.05);
  z-index:-2;
}
html[data-theme="light"] .electricidad .hero::before{
  background:
    linear-gradient(to bottom, rgba(255, 255, 255, 0.712), rgba(11,18,32,.38)),
    url("imagenes/electricidad-hero.jpg");
  background-size: cover;
  background-position: center;
}

.electricidad .hero::after{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(900px 450px at 20% 15%, rgba(251,191,36,.24), transparent 55%);
  z-index:-1;
  pointer-events:none;
}

.electricidad .badge-glow{
  display:inline-flex;
  gap:.5rem;
  align-items:center;
  padding:.45rem .75rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  font-weight: 800;
  box-shadow: var(--shadow);
}

/* Checklist */
.checklist{
  list-style: none;
  padding-left: 0;
  margin: 0;
  display: grid;
  gap: .75rem;
}
.checklist li{
  display:flex;
  gap:.7rem;
  align-items:flex-start;
  color: var(--text);
}
.pagina-electricidad .checklist i{
  color: var(--accent);
  margin-top: .15rem;
}

/* Icon-pill con "rayo" */
.electricidad .icon-pill{
  background: color-mix(in srgb, var(--bolt) 16%, transparent);
  border: 1px solid color-mix(in srgb, var(--bolt) 28%, transparent);
}

/* Fotos en "¿Qué ofrecemos?" (Electricidad) */
.pagina-electricidad .service-card{ overflow:hidden; }

.service-media{
  border-radius: 60px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: 0 12px 35px rgba(0,0,0,.18);
  margin-bottom: 12px;
}
html[data-theme="dark"] .service-media{
  box-shadow: 0 12px 35px rgba(0,0,0,.40);
}
.service-media img{
  width: 100%;
  height: 165px;
  object-fit: cover;
  display: block;
  transform: scale(1.01);
  transition: transform .25s ease, filter .25s ease;
  filter: contrast(1.02) saturate(1.05);
}
.service-card:hover .service-media img{
  transform: scale(1.07);
  filter: contrast(1.06) saturate(1.12);
}

/* Galería (Electricidad) */
.electricidad .gallery-grid{ margin-top: .25rem; }

.electricidad .gallery-tile{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: 0 16px 44px rgba(0,0,0,.18);
  min-height: 210px;
}
html[data-theme="dark"] .electricidad .gallery-tile{
  box-shadow: 0 16px 44px rgba(0,0,0,.45);
}
.electricidad .gallery-tile img{
  width: 100%;
  height: 240px;
  object-fit: cover;
  display:block;
  transform: scale(1.01);
  transition: transform .3s ease, filter .3s ease;
  filter: saturate(1.05) contrast(1.03);
}
.electricidad .gallery-tile:hover img{
  transform: scale(1.08);
  filter: saturate(1.12) contrast(1.06);
}
.electricidad .gallery-tile::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(0,0,0,.28), rgba(0,0,0,0));
  pointer-events:none;
}

/* Logo chispa */
.logo-electricidad{
  font-size: 2rem;
  font-weight: bold;
  color: var(--bolt);
  background: color-mix(in srgb, var(--text) 12%, transparent);
  display: inline-block;
  padding: 0.5rem 1rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  text-shadow: 0 10px 30px rgba(0,0,0,.25);
  animation: chispa 1.5s infinite alternate;
}
.logo-electricidad i{
  margin-right: 0.5rem;
  color: color-mix(in srgb, var(--bolt) 90%, #fff);
}
@keyframes chispa{
  0% { text-shadow: 0 0 8px rgba(251, 190, 36, 0.808); }
  100% { text-shadow: 0 0 22px rgba(251,191,36,.75); }
}

/* =========================================================
   REFRIGERACIÓN — CONECTADO A SOL/LUNA (encapsulado)
========================================================= */
.refrigeracion{
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(56,189,248,.18), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(34,197,94,.14), transparent 55%),
    var(--bg);
  color: var(--text);
}

/* Navbar glass para refrigeración */
.refrigeracion .navbar-glass{
  background: rgba(11,18,32,.45);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
}
.refrigeracion .navbar .nav-link{
  color: rgba(255,255,255,.82);
  font-weight: 600;
}
.refrigeracion .navbar .nav-link:hover{ color:#fff; }
.refrigeracion .navbar .nav-link.active{
  color:#ffffff5b;
  text-decoration: underline;
  text-underline-offset: 7px;
}

/* Botones refrigeración */
.refrigeracion .btn-soft{
  border-radius: 999px;
  padding: .65rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0);
  background: rgba(255,255,255,.06);
  color:#ffffff60;
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.refrigeracion .btn-soft:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.22);
  color:#ffffff1c;
}

.refrigeracion .btn-brand{
  border-radius: 999px;
  padding: .75rem 1.1rem;
  font-weight: 800;
  box-shadow: 0 14px 34px rgba(56,189,248,.18);
}

/* HERO refrigeración */
.refrigeracion .hero{
  position: relative;
  padding: 8rem 0 4rem;
  min-height: 78vh;
  display: grid;
  align-items: center;
}
.refrigeracion .hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(to bottom, rgba(11,18,32,.35), rgba(11,18,32,.85)),
    url("imagenes/refrigeracion-hero.jpg");
  background-size: cover;
  background-position: center;
  z-index:-2;
  filter: saturate(1.05);
}
.refrigeracion .hero::after{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(900px 450px at 25% 20%, rgba(56,189,248,.22), transparent 55%);
  z-index:-1;
  pointer-events:none;
}

.refrigeracion .badge-glow{
  display:inline-flex;
  gap:.5rem;
  align-items:center;
  padding:.45rem .75rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: rgba(255,255,255,.92);
  font-weight: 700;
  box-shadow: var(--shadow);
}

.refrigeracion .hero h1{
  font-size: clamp(2rem, 4vw, 3.25rem);
  font-weight: 900;
  letter-spacing: -0.02em;
  line-height: 1.05;
}
.refrigeracion .lead-muted{ color: var(--text); }

/* Secciones refrigeración */
.refrigeracion .section{ padding: 4rem 0; }

.refrigeracion .card-glass{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.refrigeracion .icon-pill{
  width: 46px; height: 46px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(56,189,248,.14);
  border: 1px solid rgba(56,189,248,.30);
  color: rgba(0, 0, 0, 0.95);
}

/* Lista bonita refrigeración */
.refrigeracion .list-clean li{
  margin-bottom: .65rem;
  color: var(--text);
}
.refrigeracion .list-clean i{
  color: rgba(2, 63, 88, 0.95);
  margin-right: .55rem;
}

/* CTA banda refrigeración */
.refrigeracion .cta-band{
  background: linear-gradient(135deg, rgba(56,189,248,.16), rgba(34,197,94,.10));
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  padding: 2.2rem;
  box-shadow: var(--shadow);
}

/* Footer refrigeración */
.refrigeracion footer{
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.15);
}
.refrigeracion .footer-link{
  color: var(--text);
  text-decoration: none;
}
.refrigeracion .footer-link:hover{ color:#000000; }

/* Imágenes grandes en "¿Qué ofrecemos?" refrigeración */
.refrigeracion .service-card{ overflow: hidden; }

.refrigeracion .service-media{
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  box-shadow: 0 12px 35px rgba(0,0,0,.28);
  margin-bottom: 14px;
}
html[data-theme="dark"] .refrigeracion .service-media{
  box-shadow: 0 12px 35px rgba(0,0,0,.48);
}
.refrigeracion .service-media img{
  width: 100%;
  height: 240px;           /* tamaño grande */
  object-fit: cover;
  display: block;
  transform: scale(1.01);
  transition: transform .28s ease, filter .28s ease;
  filter: contrast(1.03) saturate(1.10);
}

.refrigeracion .service-card:hover .service-media img{
  transform: scale(1.08);
  filter: contrast(1.06) saturate(1.18);
}

/* Imágenes en "¿Por qué elegirnos?" (GRID 2x2) refrigeración */
.refrigeracion .why-media{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
}

.refrigeracion .why-img{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.575);
  box-shadow: 0 16px 44px rgba(0,0,0,.35);
  background: rgba(255,255,255,.04);
}

.refrigeracion .why-img img{
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
  transition: transform .35s ease, filter .35s ease;
  filter: saturate(1.05) contrast(1.04);
}

.refrigeracion .why-img:hover img{
  transform: scale(1.08);
  filter: saturate(1.15) contrast(1.08);
}

@media (max-width: 991px){
  .refrigeracion .why-media{ grid-template-columns: 1fr; }
  .refrigeracion .why-img img{ height: 250px; }
  .refrigeracion .service-media img{ height: 250px; }
}
@media (max-width: 768px){
  .refrigeracion .section{ padding: 2.5rem 1rem; }   
  .refrigeracion .navbar{
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  } 
  .refrigeracion .nav-links{
    flex-direction: column; 
    width: 100%;
    align-items: flex-start;
  }
  .refrigeracion .nav-links a{ width: 100%; }
  .refrigeracion .hero{
    padding: 6rem 0 3rem;
    min-height: 65vh;
  }
  .refrigeracion .hero h1{ font-size: clamp(1.75rem, 6vw, 2.75rem); }
}

/* =========================================================
   NAVBAR GENERAL (conectado al tema global)
========================================================= */
.navbar{
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 2rem;
  background: var(--bg);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 1000;
  box-shadow: var(--shadow);
}
.navbar .logo{
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--brand);
  text-decoration: none;
}
.main-nav ul{
  display: flex;
  gap: 1.8rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.main-nav ul li a{
  color: var(--text);
  text-decoration: none;
  font-weight: 600;
  transition: color 0.3s;
}
.main-nav ul li a:hover{ color: var(--primary); }
.hamburguesa{
  display: none;
  font-size: 1.8rem;
  color: var(--text);
  cursor: pointer;
}
@media (max-width: 768px){
  .main-nav ul{
    display: none;
    flex-direction: column;
    gap: 1.2rem;
    background: var(--bg);
    position: absolute;
    top: 60px;
    right: 2rem;
    padding: 1rem 1.5rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    box-shadow: var(--shadow);
  }
  .main-nav ul.show{ display: flex; }
  .hamburguesa{ display: block; }
}

/* =========================
   ANIMACIONES
========================= */
@keyframes floatUp{
  0%{ transform: translateY(0) scaleX(1) scaleY(1); opacity: 1; }       
  100%{ transform: translateY(-20px) scaleX(1.05) scaleY(0.95); opacity: 0; }
}

.burbuja{
  position: absolute;
  bottom: -40px;
  width: 30px;
  height: 30px;
  background: rgba(0, 128, 255, 0.2);
  border-radius: 50%;
  animation-duration: 6s;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
  animation-name: floatUp;
}
.burbuja:nth-child(1){
  left: 10%;
  animation-delay: 0s;
}
.burbuja:nth-child(2){
  left: 30%;
  width: 20px;
  height: 20px;
  animation-delay: 2s;
}
.burbuja:nth-child(3){
  left: 50%;
  width: 25px;
  height: 25px;
  animation-delay: 4s;
}
.burbuja:nth-child(4){
  left: 70%;
  width: 15px;
  height: 15px;
  animation-delay: 1s;
}

/* =========================
   SOLUCIÓN NUCLEAR PARA TEXTO BLANCO EN MODO CLARO
   Esto asegura que TODO el texto sea negro en modo claro
========================= */
html[data-theme="light"] {
  /* Fuerza color negro en todos los elementos de texto */
  color-scheme: light;
}

/* Regla global para forzar texto negro en modo claro */
html[data-theme="light"] * {
  color: #000000 !important;
}

/* Excepciones necesarias */
html[data-theme="light"] .btn-primary,
html[data-theme="light"] .btn-brand,
html[data-theme="light"] .wa-float,
html[data-theme="light"] .hero-card-icon,
html[data-theme="light"] .card-icon,
html[data-theme="light"] .theme-toggle *,
html[data-theme="light"] .star.checked,
html[data-theme="light"] [style*="color: white"],
html[data-theme="light"] [style*="color: #bl"],
html[data-theme="light"] [style*="color: #ffffff"] {
  color: inherit !important;
}

/* Botones mantienen su color de texto */
html[data-theme="light"] .btn-primary,
html[data-theme="light"] .btn-brand {
  color: #000000 !important;
}

/* Íconos especiales */
html[data-theme="light"] .fa,
html[data-theme="light"] .fas,
html[data-theme="light"] .far,
html[data-theme="light"] .fab {
  color: var(--brand) !important;
}

/* Títulos - azul oscuro para destacar */
html[data-theme="light"] h1,
html[data-theme="light"] h2,
html[data-theme="light"] h3,
html[data-theme="light"] h4,
html[data-theme="light"] h5,
html[data-theme="light"] h6,
html[data-theme="light"] .brand-name,
html[data-theme="light"] .section-title,
html[data-theme="light"] .card-title,
html[data-theme="light"] .hero-title {
  color: var(--brand) !important;
}

/* Enlaces */
html[data-theme="light"] a:not(.btn):hover {
  color: var(--primary) !important;
}

/* Placeholders */
html[data-theme="light"] ::placeholder {
  color: rgba(0, 0, 0, 0.5) !important;
}

/* Inputs y textareas */
html[data-theme="light"] input,
html[data-theme="light"] textarea,
html[data-theme="light"] select {
  color: #000000 !important;
  background-color: rgba(0, 0, 0, 0.9) !important;
}

/* Asegurar que elementos con colores inline se mantengan */
html[data-theme="light"] [class*="text-white"],
html[data-theme="light"] [class*="text-light"],
html[data-theme="light"] [style*="color:white"],
html[data-theme="light"] [style*="color:#fff"],
html[data-theme="light"] [style*="color:#ffffff"] {
  color: #000000 !important;
}

/* =========================================================
   COMENTARIOS — 100% SINCRONIZADO CON SOL/LUNA (ENCAPSULADO REAL)
   Requisito: <body class="pagina-comentarios">
   - No toca otras páginas
   - Inputs/textarea en SOL = gris (NO negro)
========================================================= */

.pagina-comentarios{
  background: var(--bg);
  color: var(--text);

  /* Variables LOCALES para esta página */
  --c-card: var(--card);
  --c-surface: var(--surface);
  --c-border: var(--border);
  --c-text: var(--text);
  --c-muted: var(--muted);
  --c-shadow: var(--shadow);
  --c-radius: var(--radius, 18px);

  /* Defaults SOL (si tu SOL es :root por defecto) */
  --c-input-bg: rgba(179, 185, 196, 0.08);    /* gris */
  --c-input-text: rgba(11,18,32,0.92);  /* texto oscuro */
  --c-placeholder: rgba(11,18,32,0.45);
}

/* SOL explícito */
html[data-theme="light"] .comentarios{
  --c-input-bg: rgba(11,18,32,0.08);
  --c-input-text: rgba(11,18,32,0.92);
  --c-placeholder: rgba(11,18,32,0.45);
}

/* LUNA */
html[data-theme="dark"] .pagina-comentarios{
  --c-input-bg: var(--surface);
  --c-input-text: var(--text);
  --c-placeholder: color-mix(in srgb, var(--muted) 85%, transparent);
}

/* Contenedor */
.pagina-comentarios .comments-wrap{
  max-width: var(--container, 1100px);
  margin: 0 auto;
  padding: 24px 18px 60px;
}

/* Top bar */
.pagina-comentarios .topbar{
  display:flex;
  align-items:center;
  gap:12px;
  margin: 6px 0 10px;
}

/* Back */
.pagina-comentarios .btn-back{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--c-border);
  background: transparent;
  color: var(--c-text);
  font-weight:700;
  text-decoration:none;
}
.pagina-comentarios .btn-back:hover{ background: var(--c-surface); }

/* Header */
.pagina-comentarios .page-head{ margin: 10px 0 16px; }
.pagina-comentarios .page-head h1{ margin:0 0 8px; line-height:1.06; }
.pagina-comentarios .subtitle{ margin:0; color:var(--c-muted); }

/* Layout */
.pagina-comentarios .comments-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items:start;
  margin-top: 18px;
}
@media (max-width: 980px){
  .pagina-comentarios .comments-grid{ grid-template-columns: 1fr; }
}

/* Panel/Card */
.pagina-comentarios .panel,
.pagina-comentarios .card{
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--c-radius);
  box-shadow: var(--c-shadow);
}
.pagina-comentarios .panel{ padding:16px; }
.pagina-comentarios .form-panel{ padding:16px; }

/* Headers internos */
.pagina-comentarios .panel-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  padding-bottom:10px;
  border-bottom:1px solid var(--c-border);
  margin-bottom:12px;
}
.pagina-comentarios .panel-head h2{ margin:0; color:var(--c-text); }
.pagina-comentarios .hint{ margin:0; color:var(--c-muted); font-size:13px; }

.pagina-comentarios .form-title{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}
.pagina-comentarios .form-title h3{ margin:0; color:var(--c-text); }
.pagina-comentarios .form-title .wa{ margin:0; color:var(--c-muted); font-size:13px; }

/* ✅ WhatsApp label: se ve bien en SOL y LUNA (solo aquí) */
html[data-theme="light"] .pagina-comentarios .form-title .wa{
  color: rgba(226, 236, 255, 0.65);
  font-weight: 700;
}
html[data-theme="dark"] .pagina-comentarios .form-title .wa{
  color: rgba(255,255,255,0.72);
  font-weight: 700;
}

/* Empty */
.pagina-comentarios .empty{
  margin:0;
  padding: 14px 12px;
  border: 1px dashed var(--c-border);
  border-radius: 14px;
  background: var(--c-surface);
  color: var(--c-muted);
}

/* Campos */
.pagina-comentarios .field{ margin:12px 0; }
.pagina-comentarios .label{
  display:block;
  font-weight:800;
  margin:0 0 8px;
  color:var(--c-text);
}

/* INPUTS — SOLO en comentarios */
.pagina-comentarios .input[type="text"],
.pagina-comentarios .input[type="email"],
.pagina-comentarios .textarea{
  width:100%;
  border-radius:14px;
  border:1px solid var(--c-border);
  padding:12px 14px;
  font-size:15px;
  outline:none;

  background: var(--c-input-bg);
  color: var(--c-input-text);
}

.pagina-comentarios .textarea{ min-height:150px; resize:vertical; }

.pagina-comentarios .input::placeholder,
.pagina-comentarios .textarea::placeholder{
  color: var(--c-placeholder);
}

/* Focus */
.pagina-comentarios .input:focus,
.pagina-comentarios .textarea:focus{
  border-color: color-mix(in srgb, var(--brand) 60%, var(--c-border));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--brand) 18%, transparent);
}

/* Botones — SOLO en comentarios (NO toca el .btn-primary global) */
.pagina-comentarios .actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:14px;
}

.pagina-comentarios .btn-primary,
.pagina-comentarios .btn-ghost{
  border-radius:999px;
  padding:11px 16px;
  font-weight:800;
  border:1px solid var(--c-border);
  cursor:pointer;
}

.pagina-comentarios .btn-primary{
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  border-color: transparent;
  color:#000000;
}

.pagina-comentarios .btn-ghost{
  background: transparent;
  color: var(--c-text);
}
.pagina-comentarios .btn-ghost:hover{ background: var(--c-surface); }
/* =========================================
   FIX SOLAMENTE DE COLOR (NEGRO → GRIS)
   SOLO inputs/textarea en pagina comentarios
   NO afecta diseño
========================================= */
html[data-theme="light"] .pagina-comentarios input,
html[data-theme="light"] .pagina-comentarios textarea,
html[data-theme="light"] .pagina-comentarios select {
  background-color: #e5e7eb !important; /* gris claro */
  color: #111827 !important;            /* gris oscuro */
}

