/* ============================================================
   Notaría de Teno — Estilos (paleta "Rosé Maule")
   Paleta femenina y elegante inspirada en Hormazábal:
   burdeo/rosa profundo + rose gold, sobre cremas cálidos.
   ============================================================ */

:root {
  --primary:         #8b3a5c;
  --primary-dark:    #6b2a45;
  --primary-light:   #f6ebf0;
  --accent:          #c9a07a;
  --accent-dark:     #a87a5e;
  --text-body:       #4a3a42;
  --text-heading:    #3a2530;
  --bg-section:      #faf5f7;
  --bg-section-dark: #2e1c25;
  --footer:          #1f1218;
  --border-soft:     #ead8de;
}

/* ----------------------- Base ----------------------- */
* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: 'Lato', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  color: var(--text-body);
  background: #fff;
  line-height: 1.7;
  font-size: 15px;
  font-weight: 400;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Playfair Display', 'Georgia', serif;
  color: var(--text-heading);
  font-weight: 600;
  letter-spacing: 0;
}

a { color: var(--primary); text-decoration: none; transition: color .2s; }
a:hover { color: var(--primary-dark); }

img { max-width: 100%; height: auto; display: block; }

/* ----------------------- Navbar ----------------------- */
.navbar-teno {
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(8px);
  border-bottom: 3px solid var(--primary);
  box-shadow: 0 2px 14px rgba(0,0,0,0.05);
  padding: .65rem 0;
  font-family: 'Lato', sans-serif;
}
.navbar-teno .navbar-brand {
  font-family: 'Playfair Display', 'Georgia', serif;
  font-weight: 700;
  color: var(--primary) !important;
  font-size: 1.35rem;
  letter-spacing: 0.3px;
}
.navbar-teno .navbar-brand .brand-accent { color: var(--accent-dark); }
.navbar-teno .nav-link {
  color: var(--text-heading) !important;
  font-weight: 500;
  font-size: .92rem;
  padding: .5rem .95rem !important;
  position: relative;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
/* Underline animado en hover/active del nav-link.
   Usamos ::before (no ::after) para no colisionar con el caret del dropdown
   que Bootstrap dibuja en .dropdown-toggle::after */
.navbar-teno .nav-link { position: relative; }
.navbar-teno .nav-link::before {
  content: '';
  position: absolute;
  bottom: 4px; left: 50%;
  width: 0; height: 2px;
  background: var(--accent);
  transition: width .25s, left .25s;
  pointer-events: none;
}
.navbar-teno .nav-link:hover::before,
.navbar-teno .nav-link.active::before {
  width: calc(100% - 1.9rem);
  left: .95rem;
}
/* En el dropdown-toggle eliminamos cualquier underline residual */
.navbar-teno .nav-link.dropdown-toggle::before,
.navbar-teno .nav-link.dropdown-toggle.show::before,
.navbar-teno .nav-link.dropdown-toggle:focus::before {
  width: 0 !important;
}
.navbar-teno .nav-link:hover { color: var(--primary) !important; }
.navbar-teno .dropdown-menu {
  border-radius: 0;
  border: none;
  border-top: 3px solid var(--accent);
  box-shadow: 0 8px 22px rgba(0,0,0,0.12);
  padding: .5rem 0;
  margin-top: 0;
}
/* Evita el flash del dropdown +Info antes de que Bootstrap JS hidrate */
.navbar-teno .dropdown-menu:not(.show) {
  display: none !important;
}
.navbar-teno .dropdown-item {
  color: var(--text-heading);
  font-size: .9rem;
  padding: .55rem 1.25rem;
  text-transform: none;
  letter-spacing: 0;
}
.navbar-teno .dropdown-item:hover {
  background: var(--primary-light);
  color: var(--primary-dark);
}

/* ----------------------- Hero ----------------------- */
.hero-teno {
  position: relative;
  min-height: 88vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  background-color: #2e1c25;
  overflow: hidden;
  padding: 8rem 1rem 4rem;
}
.hero-teno .hero-video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate(-50%, -50%);
  z-index: 0;
}
.hero-teno .hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(rgba(46, 28, 37, 0.70), rgba(46, 28, 37, 0.78));
  z-index: 1;
}
.hero-teno .hero-content { max-width: 820px; position: relative; z-index: 2; }
.hero-teno h1 {
  color: #fff;
  font-size: clamp(2.2rem, 5vw, 3.6rem);
  font-weight: 700;
  margin-bottom: 1.2rem;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
.hero-teno .hero-divider {
  width: 80px;
  height: 3px;
  background: var(--accent);
  margin: 1.5rem auto;
}
.hero-teno p.lead {
  font-size: 1.15rem;
  color: rgba(255,255,255,0.92);
  margin-bottom: 2rem;
  font-weight: 300;
}
.hero-teno .hero-cta { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

/* ----------------------- Botones ----------------------- */
.btn-accent, .btn-accent-solid {
  font-family: 'Lato', sans-serif;
  font-weight: 500;
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  padding: .85rem 2rem;
  border-radius: 50px;
  border: 2px solid var(--accent);
  transition: all .25s;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}
.btn-accent {
  background: transparent;
  color: #fff;
}
.btn-accent:hover {
  background: var(--accent);
  color: #fff;
  transform: translateY(-1px);
}
.btn-accent-solid {
  background: var(--accent);
  color: #fff;
}
.btn-accent-solid:hover {
  background: var(--accent-dark);
  border-color: var(--accent-dark);
  color: #fff;
}
.btn-primary-teno {
  background: var(--primary);
  color: #fff;
  border: 2px solid var(--primary);
  font-family: 'Lato', sans-serif;
  font-weight: 500;
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: .75rem 1.8rem;
  border-radius: 50px;
  transition: all .25s;
}
.btn-primary-teno:hover {
  background: var(--primary-dark);
  border-color: var(--primary-dark);
  color: #fff;
}

/* ----------------------- Secciones ----------------------- */
.section-padding { padding: 5.5rem 0; }
.bg-light-section { background: var(--bg-section); }
.bg-dark-section { background: var(--bg-section-dark); color: rgba(255,255,255,0.88); }
.bg-dark-section h2, .bg-dark-section h3, .bg-dark-section h4, .bg-dark-section h5 { color: #fff; }
.bg-dark-section p { color: rgba(255,255,255,0.78); }

.section-header { text-align: center; margin-bottom: 3.5rem; }
.section-header h2 {
  font-size: clamp(1.8rem, 3.2vw, 2.4rem);
  margin-bottom: .8rem;
}
.section-header .section-divider {
  width: 60px;
  height: 3px;
  background: var(--accent);
  margin: 1rem auto;
}
.section-header .subtitle {
  color: var(--text-body);
  font-size: 1.05rem;
  max-width: 720px;
  margin: 0 auto;
}
.bg-dark-section .section-header .subtitle { color: rgba(255,255,255,0.7); }

/* ----------------------- Tarjetas genéricas (servicios/info/links) ----------------------- */
.card-teno {
  background: #fff;
  border: 1px solid var(--border-soft);
  border-top: 3px solid var(--accent);
  border-radius: 4px;
  padding: 2rem 1.5rem;
  height: 100%;
  transition: transform .25s, box-shadow .25s;
  text-align: center;
}
.card-teno:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 28px rgba(139, 58, 92, 0.14);
  border-top-color: var(--primary);
}
.card-teno .card-icon {
  width: 64px; height: 64px;
  display: inline-flex;
  align-items: center; justify-content: center;
  background: var(--primary-light);
  color: var(--primary);
  border-radius: 50%;
  font-size: 1.5rem;
  margin-bottom: 1.2rem;
  transition: all .25s;
}
.card-teno:hover .card-icon {
  background: var(--primary);
  color: #fff;
}
.card-teno h5 {
  font-size: 1.05rem;
  margin-bottom: .8rem;
  color: var(--primary-dark);
}
.card-teno p {
  font-size: .92rem;
  color: var(--text-body);
  margin: 0;
}

/* ----------------------- Tarjetas Índices (con foto patrón Hormazábal simplificado) ----------------------- */
.index-card {
  position: relative;
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: #fff;
  padding: 2.5rem 1.5rem;
  border-radius: 6px;
  text-align: center;
  height: 100%;
  overflow: hidden;
  transition: transform .25s;
}
.index-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--accent);
}
.index-card:hover { transform: translateY(-4px); }
.index-card .index-icon {
  font-size: 2.3rem;
  color: var(--accent);
  margin-bottom: 1rem;
}
.index-card h5 {
  color: #fff;
  font-size: 1.15rem;
  margin-bottom: .8rem;
}
.index-card p {
  color: rgba(255,255,255,0.82);
  font-size: .9rem;
  margin-bottom: 1.4rem;
}
.index-card .btn-index {
  display: inline-block;
  padding: .55rem 1.4rem;
  background: transparent;
  border: 2px solid var(--accent);
  color: #fff;
  font-family: 'Lato', sans-serif;
  font-size: .8rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 1px;
  border-radius: 50px;
  transition: all .2s;
}
.index-card .btn-index:hover {
  background: var(--accent);
  color: var(--primary-dark);
}

/* ----------------------- Nosotros (Quiénes Somos) ----------------------- */
.nosotros-img {
  border-radius: 6px;
  overflow: hidden;
  border-bottom: 4px solid var(--accent);
  box-shadow: 0 12px 30px rgba(0,0,0,0.25);
}
.nosotros-img-placeholder {
  min-height: 340px;
  background: linear-gradient(135deg, #6b2a45, #2e1c25);
}
.stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 2.5rem;
}
.stat-card {
  background: rgba(255,255,255,0.05);
  border-left: 3px solid var(--accent);
  padding: 1.2rem 1rem;
  text-align: center;
}
.stat-card .stat-num {
  font-family: 'Lato', sans-serif;
  font-weight: 700;
  font-size: 1.8rem;
  color: var(--accent);
  display: block;
}
.stat-card .stat-label {
  font-size: .82rem;
  color: rgba(255,255,255,0.75);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* ----------------------- +Info cards ----------------------- */
.info-card {
  background: #fff;
  border: 1px solid var(--border-soft);
  border-radius: 4px;
  padding: 1.8rem 1.4rem;
  height: 100%;
  text-align: center;
  transition: transform .25s, box-shadow .25s;
  position: relative;
}
.info-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(139, 58, 92, 0.12);
}
.info-card .info-icon {
  color: var(--accent-dark);
  font-size: 1.7rem;
  margin-bottom: .9rem;
}
.info-card h6 {
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--primary-dark);
  margin-bottom: .7rem;
  font-weight: 600;
}
.info-card p {
  margin: 0;
  font-size: .9rem;
  color: var(--text-body);
}
.info-card .por-definir {
  color: #9a5a78;
  font-style: italic;
  font-size: .85rem;
  background: #fbeaf1;
  padding: 2px 8px;
  border-radius: 3px;
  display: inline-block;
}

.info-card-link {
  display: block;
  background: linear-gradient(135deg, #fff 0%, var(--primary-light) 100%);
  border: 1px solid var(--border-soft);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  padding: 1.6rem;
  text-decoration: none;
  color: var(--text-heading);
  height: 100%;
  transition: all .25s;
}
.info-card-link:hover {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary-dark);
  transform: translateY(-3px);
  box-shadow: 0 10px 28px rgba(139, 58, 92, 0.22);
}
.info-card-link:hover h5, .info-card-link:hover p, .info-card-link:hover i { color: #fff; }
.info-card-link .link-icon {
  font-size: 1.5rem;
  color: var(--primary);
  margin-bottom: .7rem;
  transition: color .25s;
}
.info-card-link h5 {
  font-size: 1.05rem;
  margin-bottom: .5rem;
}
.info-card-link p {
  font-size: .88rem;
  margin: 0;
  color: var(--text-body);
}

/* ----------------------- Turnos ----------------------- */
.turno-card {
  background: #fff;
  border: 1px solid var(--border-soft);
  border-top: 3px solid var(--accent);
  border-radius: 4px;
  padding: 1.3rem .8rem;
  text-align: center;
  transition: transform .25s;
}
.turno-card:hover { transform: translateY(-3px); box-shadow: 0 8px 18px rgba(0,0,0,0.07); }
.turno-card .turno-dia {
  font-family: 'Lato', sans-serif;
  font-weight: 700;
  font-size: 2rem;
  color: var(--primary);
  line-height: 1;
}
.turno-card .turno-mes {
  font-family: 'Lato', sans-serif;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-size: .8rem;
  color: var(--accent-dark);
  margin-top: .3rem;
  font-weight: 600;
}
.turno-card .turno-ano { color: var(--text-body); font-size: .82rem; margin-top: .2rem; }

/* ----------------------- Contacto (form) ----------------------- */
.contacto-form .form-label {
  font-family: 'Lato', sans-serif;
  font-size: .85rem;
  font-weight: 500;
  color: rgba(255,255,255,0.85);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: .3rem;
}
.contacto-form .req { color: #f1a8a8; margin-left: 3px; }
.contacto-form .form-control, .contacto-form .form-select {
  background: rgba(255,255,255,0.95);
  border: 1px solid transparent;
  border-radius: 3px;
  font-size: .95rem;
  padding: .65rem .85rem;
}
.contacto-form .form-control:focus, .contacto-form .form-select:focus {
  background: #fff;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(201, 160, 122, 0.25);
}
.contacto-form .invalid-feedback { display: block; min-height: 1em; color: #ffd2d2; font-size: .82rem; }
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important; height: 1px !important;
  opacity: 0 !important;
  overflow: hidden !important;
}

.contacto-info-block {
  color: rgba(255,255,255,0.9);
}
.contacto-info-block h4 {
  font-size: 1.1rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 1.5rem;
}
.contacto-info-block ul { list-style: none; padding: 0; margin: 0; }
.contacto-info-block li { display: flex; gap: 1rem; margin-bottom: 1.1rem; align-items: flex-start; }
.contacto-info-block li i {
  color: var(--accent);
  font-size: 1.2rem;
  margin-top: 3px;
  width: 22px;
  flex-shrink: 0;
}
.contacto-info-block li strong { color: #fff; display: block; font-size: .9rem; margin-bottom: 2px; }
.contacto-info-block li span { font-size: .9rem; color: rgba(255,255,255,0.75); }

/* ----------------------- Mapa ----------------------- */
.mapa-wrapper {
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,0.1);
  border-bottom: 4px solid var(--accent);
}
.mapa-wrapper iframe { display: block; width: 100%; height: 420px; border: 0; }

/* ----------------------- Links de interés ----------------------- */
.link-card {
  display: flex;
  align-items: center;
  gap: 1rem;
  background: #fff;
  border: 1px solid var(--border-soft);
  border-left: 3px solid var(--accent);
  padding: 1rem 1.2rem;
  border-radius: 4px;
  transition: all .25s;
  height: 100%;
  text-decoration: none;
  color: var(--text-heading);
}
.link-card:hover {
  background: var(--primary);
  color: #fff;
  border-left-color: var(--accent-dark);
  transform: translateX(4px);
}
.link-card:hover h6, .link-card:hover span, .link-card:hover .link-arrow { color: #fff; }
.link-card .link-favicon {
  width: 32px; height: 32px;
  flex-shrink: 0;
  background: var(--primary-light);
  border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  color: var(--primary);
  font-size: 1rem;
}
.link-card .link-body { flex: 1; min-width: 0; }
.link-card h6 {
  font-size: .92rem;
  margin: 0 0 .15rem;
  color: var(--primary-dark);
}
.link-card span {
  font-size: .78rem;
  color: var(--text-body);
}
.link-card .link-arrow {
  color: var(--accent-dark);
  font-size: 1rem;
}

/* ----------------------- Footer ----------------------- */
.footer-teno {
  background: var(--footer);
  color: rgba(255,255,255,0.7);
  padding: 2.5rem 0 1.5rem;
  font-size: .88rem;
  border-top: 3px solid var(--accent);
}
.footer-teno .footer-brand {
  font-family: 'Lato', sans-serif;
  font-weight: 600;
  color: #fff;
  font-size: 1rem;
  margin-bottom: .4rem;
}
.footer-teno a { color: var(--accent); }
.footer-teno a:hover { color: #fff; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  margin-top: 1.6rem;
  padding-top: 1.2rem;
  font-size: .82rem;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: .8rem;
}

/* ----------------------- Botón back-to-top ----------------------- */
#btnTop {
  position: fixed;
  bottom: 22px; right: 22px;
  width: 44px; height: 44px;
  background: var(--primary);
  color: #fff;
  border-radius: 50%;
  border: 2px solid var(--accent);
  display: none;
  align-items: center; justify-content: center;
  cursor: pointer;
  z-index: 999;
  transition: all .2s;
  box-shadow: 0 4px 14px rgba(0,0,0,0.2);
}
#btnTop:hover { background: var(--primary-dark); transform: translateY(-2px); }
#btnTop.show { display: inline-flex; }

/* ----------------------- Pages internas (aranceles/declaración/faq) ----------------------- */
.page-header-teno {
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: #fff;
  padding: 7rem 0 3rem;
  position: relative;
}
.page-header-teno::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 4px;
  background: var(--accent);
}
.page-header-teno h1 { color: #fff; font-size: 2.1rem; margin-bottom: .3rem; }
.page-header-teno .breadcrumb-teno {
  font-size: .85rem;
  color: rgba(255,255,255,0.7);
}
.page-header-teno .breadcrumb-teno a { color: rgba(255,255,255,0.9); }

.page-body-teno { padding: 3.5rem 0 5rem; }
.page-body-teno h2 {
  color: var(--primary-dark);
  font-size: 1.5rem;
  margin: 2rem 0 1rem;
  padding-bottom: .4rem;
  border-bottom: 2px solid var(--accent);
  display: inline-block;
}
.page-body-teno h3 { color: var(--primary); font-size: 1.15rem; margin-top: 1.6rem; }

/* FAQ accordion */
.faq-item {
  background: #fff;
  border: 1px solid var(--border-soft);
  border-left: 3px solid var(--accent);
  border-radius: 4px;
  margin-bottom: .8rem;
  overflow: hidden;
}
.faq-item summary {
  padding: 1rem 1.2rem;
  cursor: pointer;
  font-family: 'Lato', sans-serif;
  font-weight: 500;
  color: var(--primary-dark);
  list-style: none;
  position: relative;
  padding-right: 2.5rem;
}
.faq-item summary::after {
  content: '+';
  position: absolute;
  right: 1.2rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.4rem;
  color: var(--accent-dark);
  font-weight: 300;
}
.faq-item[open] summary::after { content: '−'; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item .faq-body {
  padding: 0 1.2rem 1.1rem;
  font-size: .95rem;
}

/* Banner Próximamente (índices) */
.proximamente-banner {
  background: linear-gradient(135deg, #fdeef3 0%, #f6dde6 100%);
  border: 1px solid var(--accent);
  border-left: 4px solid var(--primary);
  padding: 1.2rem 1.4rem;
  border-radius: 4px;
  color: #6b2a45;
  margin-bottom: 2rem;
}
.proximamente-banner i { color: var(--primary); margin-right: .5rem; }
.proximamente-banner strong { color: #4a1c30; }

/* ----------------------- Responsive ----------------------- */
@media (max-width: 992px) {
  .hero-teno { min-height: 75vh; }
  .stats-row { grid-template-columns: repeat(3, 1fr); }
  .section-padding { padding: 4rem 0; }
}
@media (max-width: 768px) {
  .stats-row { grid-template-columns: 1fr; }
  .hero-teno h1 { font-size: 1.9rem; }
  .footer-bottom { flex-direction: column; text-align: center; }
}

/* ============================================================
   ÍNDICES — BUSCADORES (repertorios / escrituras / vehículos)
   Agregar al FINAL de css/styles.css
   Paleta Rosé Maule · compatible con Bootstrap 5.3
   ============================================================ */

/* Respetar el atributo hidden por encima de cualquier display */
[hidden]{display:none !important}

/* Campos con formato automático */
.campo-mayusc{text-transform:uppercase}
.campo-numeros,.campo-rut{font-variant-numeric:tabular-nums}

/* ---------- Botonera del formulario ---------- */
.form-actions-teno{
  display:flex;gap:.8rem;justify-content:flex-end;
  flex-wrap:wrap;margin-top:1.2rem;
}
@media(max-width:520px){
  .form-actions-teno{flex-direction:column-reverse}
  .form-actions-teno .btn-primary-teno,
  .form-actions-teno .btn-outline-teno{width:100%;justify-content:center}
}

/* Botón outline (Limpiar) en paleta Quiroz */
.btn-outline-teno{
  background:transparent;
  color:var(--primary);
  border:2px solid var(--primary);
  font-family:'Lato',sans-serif;
  font-weight:500;font-size:.85rem;
  text-transform:uppercase;letter-spacing:1px;
  padding:.75rem 1.8rem;border-radius:50px;
  transition:all .25s;cursor:pointer;
  display:inline-flex;align-items:center;gap:.5rem;
}
.btn-outline-teno:hover{
  background:var(--primary);color:#fff;
}

/* ---------- Loader ---------- */
.loader-box{
  text-align:center;padding:2.5rem 1rem;
  margin:1.5rem auto 0;max-width:720px;
}
.loader-box p{
  color:var(--primary-dark);margin-top:1rem;
  font-style:italic;font-size:.95rem;
}
.spinner-teno{
  width:44px;height:44px;margin:0 auto;
  border:4px solid var(--primary-light);
  border-top-color:var(--primary);
  border-radius:50%;
  animation:spin-teno .8s linear infinite;
}
@keyframes spin-teno{to{transform:rotate(360deg)}}

/* ---------- Mensaje (sin resultados / info) ---------- */
.mensaje-box{
  display:flex;align-items:center;gap:1rem;
  background:#fbeaf1;
  border-left:4px solid var(--primary);
  color:var(--primary-dark);
  padding:1.1rem 1.3rem;border-radius:4px;
  margin:1.5rem auto 0;max-width:920px;
}
.mensaje-box i{font-size:1.5rem;color:var(--primary)}
.mensaje-box p{margin:0;font-size:.95rem}

/* ---------- Tarjeta de resultados ---------- */
.results-card{
  background:#fff;
  border:1px solid var(--border-soft);
  border-top:3px solid var(--accent);
  border-radius:6px;overflow:hidden;
  margin:1.8rem auto 0;
  box-shadow:0 6px 22px rgba(139,58,92,.08);
}
.results-header{
  padding:1rem 1.3rem;
  background:var(--primary-light);
  border-bottom:1px solid var(--border-soft);
  font-family:'Lato',sans-serif;font-weight:600;
  color:var(--primary-dark);font-size:.95rem;
}

/* ---------- Scroll horizontal + vertical, cabecera fija ---------- */
.table-scroll{
  overflow-x:auto;overflow-y:auto;
  max-height:65vh;
  -webkit-overflow-scrolling:touch;
}
.table-scroll table{
  width:100%;border-collapse:collapse;
  font-family:'Lato',sans-serif;font-size:.9rem;
  min-width:720px;            /* fuerza scroll horizontal en móvil */
  margin:0;
}
.table-scroll thead th{
  position:sticky;top:0;z-index:5;   /* cabecera fija al hacer scroll */
  background:var(--primary);color:#fff;
  text-align:left;padding:.8rem .9rem;
  font-weight:600;font-size:.78rem;
  text-transform:uppercase;letter-spacing:.5px;
  white-space:nowrap;
  border-bottom:2px solid var(--accent);
}
.table-scroll tbody td{
  padding:.7rem .9rem;
  border-bottom:1px solid var(--border-soft);
  color:var(--text-body);vertical-align:middle;
}
.table-scroll tbody tr:nth-child(even){background:var(--bg-section)}
.table-scroll tbody tr:hover{background:var(--primary-light)}
.table-scroll tbody tr:last-child td{border-bottom:none}

/* Scrollbar estilizado */
.table-scroll::-webkit-scrollbar{width:10px;height:10px}
.table-scroll::-webkit-scrollbar-track{background:var(--bg-section)}
.table-scroll::-webkit-scrollbar-thumb{
  background:var(--accent);border-radius:5px;
  border:2px solid var(--bg-section);
}
.table-scroll::-webkit-scrollbar-thumb:hover{background:var(--accent-dark)}

/* Ajuste responsivo */
@media (max-width:600px){
  .results-header{padding:.85rem 1rem;font-size:.88rem}
  .table-scroll table{font-size:.84rem}
  .table-scroll thead th,
  .table-scroll tbody td{padding:.6rem .65rem}
}
