/* =========================================================
   FusterLab  CSS consolidado
   ========================================================= */

/* --------- Variables y base --------- */
:root{
  --accent:#6B4426;     /* marrón FusterLab */
  --accent-2:#C49A6C;   /* marrón claro */
  --text:#1f2937;       /* gris oscuro */
  --muted:#6b7280;      /* gris medio */
  --bg:#ffffff;         /* fondo */
  --line:#e5e7eb;       /* líneas sutiles */
}
*{ box-sizing:border-box }
html{ scroll-behavior:smooth }
body{
  margin:0; font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  color:var(--text); background:var(--bg);
}
img{ max-width:100%; display:block; height:auto }
.container{ width:min(1140px,100%); margin:0 auto; padding:0 20px }
a{ color:var(--accent); text-decoration:none }
.small{ font-size:.925rem; color:var(--muted) }

/* --------- Botones --------- */
.btn{
  display:inline-block; padding:12px 18px; border-radius:12px;
  border:1px solid var(--accent); color:#fff; background:var(--accent);
  transition:.15s ease;
}
.btn:hover{ transform:translateY(-1px); background:var(--accent-2); border-color:var(--accent-2) }
.btn.ghost{ background:transparent; color:var(--accent) }

/* =========================================================
   HEADER + NAV
   ========================================================= */
header.site{
  position:sticky; top:0; z-index:50;
  background:#fff; border-bottom:1px solid var(--line);
}
.navbar{
  display:flex; align-items:center; justify-content:space-between;
  gap:32px; padding:10px 0; position:relative;
}
.brand{ display:flex; align-items:center; gap:12px }
.brand img{ height:80px; width:auto }

/* Nav común */
nav.primary ul{
  display:flex; align-items:center; gap:22px; margin:0; padding:0; list-style:none;
}
nav.primary a{
  position:relative; padding:8px 6px; border-radius:0; color:var(--text);
  transition:color .18s ease;
}
nav.primary a:hover{ color:var(--accent) }

/* Desktop: subrayado + color activo */
@media (min-width:901px){
  nav.primary a::before{
    content:""; position:absolute; left:0; right:0; bottom:-6px; height:2px;
    background:var(--accent); transform:scaleX(0); transform-origin:left;
    transition:transform .18s ease;
  }
  nav.primary a:hover::before{ transform:scaleX(1) }
  nav.primary a.is-active::before{ transform:scaleX(1) }
  nav.primary a.is-active{ color:var(--accent) }
}

/* Header sobre hero (transparente) / scrolleado (sólido) */
header.site.on-hero{ background:transparent; border-bottom-color:transparent }
header.site.on-hero nav.primary a{ color:#fff }
header.site.on-hero nav.primary a::before{ background:rgba(255,255,255,.95) }
header.site.scrolled{
  background:#fff; border-bottom:1px solid var(--line);
  box-shadow:0 6px 24px rgba(0,0,0,.06);
}

/* RRSS (solo desktop) */
.social{ display:flex; gap:8px }
.social a{
  width:34px; height:34px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid var(--accent); color:var(--accent);
  transition:background .15s ease, color .15s ease;
}
.social a:hover{ background:var(--accent); color:#fff }

/* Hamburguesa (3 rayas) */
.hamburger{
  display:none; width:44px; height:44px; border:1px solid var(--line); border-radius:10px;
  background:#fff; color:inherit; cursor:pointer;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:5px;
}
.hamburger span{
  width:22px; height:2px; background:currentColor; border-radius:2px;
  transition:transform .2s ease, opacity .2s ease;
}
header.site.on-hero .hamburger{ background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.5); color:#fff }
header.site.on-hero .hamburger span{ background:#fff }
body.nav-open .hamburger span:nth-child(1){ transform:translateY(7px) rotate(45deg) }
body.nav-open .hamburger span:nth-child(2){ opacity:0 }
body.nav-open .hamburger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg) }

/* Desktop por defecto */
@media (min-width:901px){
  header.site .hamburger{ display:none !important }
  header.site nav.primary ul{ display:flex !important; position:static !important; box-shadow:none !important }
}

/* Mobile: dropdown anclado a la derecha bajo hamburguesa */
@media (max-width:900px){
  .social{ display:none !important }     /* ocultar RRSS en móvil */
  .navbar{ position:relative }
  nav.primary{ position:absolute; top:8px; right:14px }
  .hamburger{ display:flex !important; position:static; margin:0 }
  body.nav-open{ overflow:hidden }

  nav.primary ul{
    position:absolute !important; top:calc(100% + 8px); right:0; left:auto !important;
    width:220px; margin:0; padding:6px 0; z-index:100;
    display:none; flex-direction:column; gap:0;
    background:#fff; border:1px solid var(--line); border-radius:10px;
    box-shadow:0 12px 28px rgba(0,0,0,.14);
  }
  body.nav-open nav.primary ul{ display:flex !important }

  nav.primary li{ border-bottom:1px solid var(--line) }
  nav.primary li:last-child{ border-bottom:0 }

  nav.primary a::before, nav.primary a::after{ content:none !important }
  nav.primary a{
    display:block; padding:12px 16px; font-size:1.05rem; border-radius:8px; color:var(--text);
  }
  nav.primary a:hover{ background:rgba(107,68,38,.08); color:var(--accent) }
  nav.primary a.is-active{ color:var(--accent); font-weight:600 }

  body.nav-open header.site.on-hero nav.primary ul{
    background:rgba(17,17,17,.92); border-color:rgba(255,255,255,.15); backdrop-filter:blur(8px)
  }
  body.nav-open header.site.on-hero nav.primary a{ color:#fff }
  body.nav-open header.site.on-hero nav.primary a:hover{ background:rgba(255,255,255,.08); color:#fff }
}

/* =========================================================
   HERO / SLIDER
   ========================================================= */
.hero{ position:relative }
.slider{ position:relative; overflow:hidden }
.slide{ position:relative; min-height:420px; height:60vh; max-height:700px }
.slide img.bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:brightness(.72) }
.slide::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(0,0,0,.30),rgba(0,0,0,.30)) }

.caption{ position:absolute; inset:auto 0 12%; z-index:2 }
.caption .inner{
  width:min(980px,100%); margin:0 auto; padding:0 20px;
  color:#fff; text-shadow:0 4px 12px rgba(0,0,0,.6);
}
.caption h1{ margin:0 0 6px; font-size:clamp(1.8rem,4vw,3rem) }
.caption p{ margin:0 0 14px; color:#f3f4f6 }

.slider-controls{ position:absolute; inset:auto 0 16px; display:flex; justify-content:center; gap:6px; z-index:3 }
.dot{ width:10px; height:10px; border-radius:999px; background:#fff; opacity:.5; border:1px solid rgba(0,0,0,.15); cursor:pointer }
.dot.active{ opacity:1; background:var(--accent) }

/* Flechas */
.slider .arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  z-index:3; width:40px; height:40px; border-radius:50%;
  border:1px solid rgba(255,255,255,.7); color:#fff; background:rgba(0,0,0,.25);
  display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .15s ease, transform .15s ease;
}
.slider .arrow:hover{ background:rgba(0,0,0,.45); transform:translateY(-50%) scale(1.03) }
.slider .arrow.prev{ left:12px }
.slider .arrow.next{ right:12px }

/* Fallback si no carga JS */
.slider .slide{ display:none }
.slider .slide:first-of-type{ display:block }

/* Sombra clara y contundente en los textos */
.caption .inner{
  text-shadow:
    0 12px 36px rgba(0,0,0,.65),
    0  4px 14px rgba(0,0,0,.55),
    0  2px  4px rgba(0,0,0,.45);
}

/* Título con más peso */
.caption h1{
  text-shadow:
    0 14px 40px rgba(0,0,0,.70),
    0  5px 18px rgba(0,0,0,.60);
}

/* Botón más separado del fondo */
.caption .btn{
  box-shadow: 0 10px 26px rgba(0,0,0,.25);
}

/* En móvil, subimos un poco el velo para asegurar lectura */
@media (max-width: 900px){
  .slide img.bg{ filter: brightness(.80); }
  .slide::after{
    background: linear-gradient(
      180deg,
      rgba(0,0,0,.28),
      rgba(0,0,0,.32)
    );
  }
}

/* =========================================================
   SECCIONES / GRID / CARDS / CONTACTO
   ========================================================= */
.section{ padding:72px 0; border-top:1px solid var(--line) }
.section .lead{ color:var(--muted); max-width:760px }

.grid{ display:grid; gap:24px; grid-template-columns:repeat(12,1fr) }
.col-4{ grid-column:span 4 } .col-6{ grid-column:span 6 } .col-12{ grid-column:span 12 }
@media (max-width:900px){ .col-4,.col-6{ grid-column:span 12 } }

.card{ border:1px solid var(--line); border-radius:16px; background:#fff; overflow:hidden; display:flex; flex-direction:column }
.card .thumb{ aspect-ratio:3/2; overflow:hidden }
.card .thumb img{ width:100%; height:100%; object-fit:cover }
.card .body{ padding:16px }

.kpis{ display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:16px }
.kpi{ border:1px solid var(--line); border-radius:12px; padding:14px; text-align:center }
.kpi strong{ display:block; font-size:1.6rem }

.contact{ display:grid; grid-template-columns:1.2fr .8fr; gap:24px }
@media (max-width:900px){ .contact{ grid-template-columns:1fr } }
form label{ display:block; font-weight:600; margin:6px 0 4px }
form input, form textarea{
  width:100%; padding:12px; border:1px solid var(--line); border-radius:10px; background:#fff; font:inherit;
}
form input:focus,form textarea:focus{
  border-color:var(--accent); outline:none; box-shadow:0 0 0 3px rgba(107,68,38,.12)
}
form .actions{ margin-top:12px; display:flex; gap:12px; flex-wrap:wrap }

/* =========================================================
   BOTÓN VOLVER ARRIBA
   ========================================================= */
.to-top{
  position:fixed; right:16px; bottom:calc(16px + env(safe-area-inset-bottom,0));
  width:44px; height:44px; display:inline-flex; align-items:center; justify-content:center;
  border-radius:999px; border:1px solid var(--line);
  background:#fff; color:var(--accent); box-shadow:0 8px 24px rgba(0,0,0,.12);
  opacity:0; pointer-events:none; transform:translateY(8px);
  transition:opacity .22s ease, transform .22s ease, background .15s ease, color .15s ease;
  z-index:80;
}
.to-top:hover{ background:var(--accent); color:#fff }
.to-top.show{ opacity:1; pointer-events:auto; transform:translateY(0) }
@media (prefers-reduced-motion:reduce){ .to-top{ transition:none } }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{
  background:#111; color:#eee; padding:24px 20px 12px; font-size:.95rem;
}
.footer-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; max-width:1200px; margin:0 auto; flex-wrap:wrap;
}
.footer-logo img{ height:34px; width:auto; filter:brightness(0) invert(1) }

/* Enlaces legales (desktop) */
.footer-legal .legal-links{
  list-style:none; margin:0; padding:0; display:flex; gap:16px; flex-wrap:wrap;
}
.footer-legal .legal-links a{ color:#ccc; transition:color .2s }
.footer-legal .legal-links a:hover{ color:var(--accent) }

/* RRSS footer */
.footer-social{ display:flex; gap:14px }
.footer-social a{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:50%;
  background:rgba(255,255,255,.08); color:#fff; transition:background .2s, color .2s;
}
.footer-social a:hover{ background:var(--accent); color:#fff }

/* Línea inferior */
.footer-bottom{
  text-align:center; margin-top:16px; padding-top:10px;
  border-top:1px solid rgba(255,255,255,.08); font-size:.85rem; color:#999;
}

/* Footer móvil compacto */
@media (max-width:700px){
  .site-footer{ padding:16px 14px 10px }
  .footer-inner{
    flex-direction:column; align-items:center; justify-content:center;
    gap:10px; text-align:center;
  }
  .footer-logo img{ height:28px }
  .footer-social{ order:3 }
  .footer-legal{ order:2 }
  .footer-legal .legal-links{ justify-content:center; gap:12px }
  /* Legales como botones planos (para modal) */
  .footer-legal .legal-links a{ display:none }
  .legal-links .legal-link{
    all:unset; cursor:pointer; color:#bbb; font:inherit; padding:0 2px;
  }
  .legal-links .legal-link:hover{ color:var(--accent) }
  .legal-links .legal-link + .legal-link::before{ content:""; color:#666; margin:0 6px 0 2px }
}

/* =========================================================
   MODAL LEGAL
   ========================================================= */
.modal{ position:fixed; inset:0; z-index:120; display:none }
.modal.is-open{ display:block }
.modal__overlay{
  position:absolute; inset:0; background:rgba(0,0,0,.45);
  opacity:0; transition:opacity .22s ease;
}
.modal.is-open .modal__overlay{ opacity:1 }
.modal__dialog{
  position:relative; width:min(760px,92vw); max-height:86vh; overflow:auto;
  margin:6vh auto 0; background:#fff; border-radius:14px; box-shadow:0 20px 60px rgba(0,0,0,.25);
  transform:translateY(10px); opacity:0; transition:transform .22s ease, opacity .22s ease;
}
.modal.is-open .modal__dialog{ transform:translateY(0); opacity:1 }
.modal__header{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:16px 18px; border-bottom:1px solid var(--line);
}
.modal__body{ padding:16px 18px; color:var(--text) }
.modal__body h4{ margin:0 0 10px }
.modal__footer{ padding:14px 18px; border-top:1px solid var(--line); display:flex; justify-content:flex-end }
.modal__close{
  font-size:24px; line-height:1; background:#fff; border:1px solid var(--line);
  width:36px; height:36px; border-radius:10px; cursor:pointer;
}
@media (prefers-reduced-motion:reduce){
  .modal__overlay, .modal__dialog{ transition:none !important; transform:none !important; opacity:1 !important }
}

/* ==== Legales: estilo discreto tipo enlace (sin underline) ==== */
.footer-legal .legal-links{
  list-style:none; margin:0; padding:0;
  display:flex; gap:14px; flex-wrap:wrap; align-items:center;
}

.footer-legal .legal-links a{ display:none; } /* por si quedan <a>, ocultar */
.footer-legal .legal-links .legal-link{
  all: unset;                 /* limpia estilos de <button> */
  cursor: pointer;
  color: #9aa0a6;             /* gris suave */
  font: inherit;
  font-size: .92rem;          /* un pelín más pequeño */
  line-height: 1.2;
  padding: 0 2px;
  transition: color .18s ease;
}

/* Hover/focus solo cambia color */
.footer-legal .legal-links .legal-link:hover,
.footer-legal .legal-links .legal-link:focus-visible{
  color: var(--accent);
}

/* Separadores puntito, muy tenues */
.footer-legal .legal-links .legal-link + .legal-link{
  position: relative;
}
.footer-legal .legal-links .legal-link + .legal-link::before{
  content: "";
  color: #666;
  opacity: .45;
  margin: 0 6px 0 2px;
}

/* En móvil mantenemos el mismo look y centramos */
@media (max-width:700px){
  .footer-legal .legal-links{
    justify-content: center;
    gap: 10px;
  }
  .footer-legal .legal-links .legal-link{
    font-size: .9rem;
    color: #a3a7ad;
  }
}

/* Mapa en tarjeta de contacto */
.map-embed{
  border:1px solid var(--line);
  border-radius:12px;
  overflow:hidden;
  background:#f3f4f6;
  /* proporción responsive; cambia si prefieres otra */
  aspect-ratio: 4 / 3;
}
.map-embed iframe{
  width:100%; height:100%; border:0; display:block;
}
@media (max-width:900px){
  .map-embed{ aspect-ratio: 3 / 2; }
}

/* ===== Bloque de cabecera de sección ===== */
.section h2 {
  text-align: center;
  font-size: clamp(2rem, 4vw, 2.6rem); /* adaptable */
  font-weight: 700;
  margin: 0 0 14px;
  color: var(--text);
  position: relative;
}

.section h2::after {
  content: "";
  display: block;
  width: 60px;
  height: 3px;
  background: var(--accent);
  margin: 12px auto 0;   /* centrado bajo el título */
  border-radius: 2px;
}

.section .lead {
  text-align: center;
  margin: 0 auto 40px;
  font-size: 1.08rem;
  color: var(--muted);
  max-width: 720px;
  line-height: 1.6;
}

/* ===== Subtítulo genérico (centrado) ===== */
.section .lead {
  text-align: center;
  margin: 0 auto 40px;
  font-size: 1.08rem;
  color: var(--muted);
  max-width: 720px;
  line-height: 1.6;
}

/* ===== Subtítulo especial en la sección "Nosotros" ===== */
#nosotros .lead {
  text-align: left;
  max-width: 100%;
  margin: 20px 0 40px;
  padding: 18px 22px;
  background: #f9f9f9;
  border-left: 4px solid var(--accent);
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}
#contacto .lead {
  text-align: left;
  max-width: 100%;
  margin: 20px 0 40px;
  padding: 18px 22px;
  background: #f9f9f9;
  border-left: 4px solid var(--accent);
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,.04);
}

/* ===== Navbar: menú centrado SIEMPRE en desktop ===== */
@media (min-width: 901px){
  .navbar{
    position: relative;         /* genera un contexto para centrar el nav */
    display: flex;
    align-items: center;        /* centra vertical */
    gap: 32px;
    padding: 0;
    min-height: 80px;           /* alto mínimo = alto del logo */
  }

  /* Logo grande */
  .brand img{ height:80px; width:auto; display:block; }

  /* Menú centrado respecto al contenedor, no respecto al logo */
  nav.primary{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);  /* centro exacto */
  }
  nav.primary ul{
    display:flex;
    align-items:center;         /* alinea los enlaces verticalmente */
    gap:22px; margin:0; padding:0; list-style:none;
  }
  /* Evita desnivel por line-height en los enlaces */
  nav.primary a{ line-height: 1; padding:8px 6px; }

  /* Deja logo pegado a la izquierda y RRSS pegadas a la derecha */
  .brand{ margin-right:auto; }
  .social{ margin-left:auto; display:flex; align-items:center; gap:8px; }
}

@media (max-width: 900px){
  header.site .navbar .brand{
    margin-left: 8px !important;    /* alternativa al padding */
  }
}

@media (min-width: 901px){
  header.site .navbar{
    padding-top: 18px;
    padding-bottom: 18px;
  }
}

/* === Mobile: centrar verticalmente la hamburguesa respecto al logo === */
@media (max-width: 900px){
  .navbar{ position: relative; } /* contexto para el posicionamiento */
  nav.primary{
    position: absolute !important;
    top: 50% !important;
    right: 14px !important;
    left: auto !important;
    transform: translateY(-50%) !important; /* centro exacto */
  }
  /* Asegura que el botón ocupa su caja centrada */
  nav.primary .hamburger{
    display: flex !important;
    align-items: center;
    justify-content: center;
    height: 44px; width: 44px;
  }
}

/* ===== Aviso cookies ===== */
.cookie-banner {
  position: fixed;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  width: min(95%, 480px);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 8px 20px rgba(0,0,0,.12);
  padding: 14px 16px;
  display: none;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: .9rem;
  z-index: 200;
}
.cookie-banner p {
  margin: 0;
  flex: 1;
  color: var(--text);
}
.cookie-banner a {
  color: var(--accent);
  text-decoration: underline;
}
.cookie-banner button {
  flex-shrink: 0;
}



/* Alturas más flexibles */
.slide{
  /* en desktop ya tienes height:60vh; max-height:700px */
  min-height: 420px;
}
@media (max-width: 900px){
  .slide{
    height: 58vh;            /* ocupa mejor alto útil */
    min-height: 360px;       /* evita quedar muy pequeño */
    max-height: 520px;
  }
  /* Fondo más oscuro para mayor contraste del texto */
  .slide::after{
    background: linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.45));
  }
  /* Títulos y subtítulos más compactos */
  .caption{ inset: auto 0 10%; }
  .caption .inner{ padding: 0 16px; text-shadow: 0 3px 10px rgba(0,0,0,.6); }
  .caption h1{ font-size: clamp(1.5rem, 5.5vw, 2rem); margin-bottom: 8px; }
  .caption p{ font-size: .98rem; margin-bottom: 12px; }
  .caption .btn{ padding: 11px 14px; border-radius: 10px; }
}

/* Encuadre por defecto */
.slide img.bg{ object-position: center center; }

/* Ejemplos por slide (opcional):
   añade en el HTML la clase .pos-top o .pos-bottom a la img de ese slide */
.slide img.bg.pos-top{ object-position: center 25%; }
.slide img.bg.pos-bottom{ object-position: center 75%; }

/* Flechas fuera en mobile */
@media (max-width: 900px){
  .slider .arrow{ display: none !important; }
}

/* Dots más tocables en móvil */
@media (max-width: 900px){
  .slider-controls{ gap: 8px; bottom: 12px; }
  .dot{ width: 12px; height: 12px; }
}

.caption .inner{
  text-shadow: 0 6px 16px rgba(0,0,0,.7);
}

/* Slider 100% ancho. En móvil usamos relación 16:9 y en desktop tu alto actual */
.slider{ position:relative; width:100%; }
.slide{ position:relative; width:100%; }

/* MOBILE: alto fluido por relación de aspecto */
@media (max-width:900px){
  .slide::before{
    content:""; display:block; padding-top:56.25%; /* 16:9 */
  }
  .slide img.bg{
    position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;
  }
  /* el resto de elementos siguen posicionados sobre la imagen */
  .caption{ inset:auto 0 10%; }
}

/* DESKTOP: conserva tu lógica (vh) */
@media (min-width:901px){
  .slide{ min-height:420px; height:60vh; max-height:700px; }
  .slide img.bg{
    position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;
  }
}

/* Mejora gestos táctiles: permite scroll vertical y gesto horizontal */
@media (max-width:900px){
  .slider, .slide{ touch-action: pan-y; }
}

/* === Slider móvil: más horizontal (panorámico) y sin flechas === */
@media (max-width:900px){
  /* Anula alturas que lo hacen demasiado alto */
  .slide{
    height:auto !important;
    min-height:0 !important;
    max-height:none !important;
    position:relative;
  }

  /* Espaciador para fijar relación de aspecto panorámica ( 21:9) */
  .slide::before{
    content:"";
    display:block;
    padding-top:65%; /* 45%  20:9. Prueba 42.85% (21:9) o 50% (2:1) a tu gusto */
  }

  /* La imagen sigue cubriendo el área completa */
  .slide img.bg{
    position:absolute; inset:0;
    width:100%; height:100%;
    object-fit:cover;
    display:block;
  }

  /* Ajusta el texto un poco más arriba */
  .caption{ inset:auto 0 8%; }

  /* Oculta flechas en móvil */
  .slider .arrow{ display:none !important; }
}

/* === Checkbox de privacidad === */
.privacy-check {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  font-size: .9rem;
  color: var(--muted);
}

.privacy-check input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--accent); /* color moderno soportado en navegadores */
  cursor: pointer;
}

.privacy-check label {
  cursor: pointer;
  line-height: 1.3;
}

/* KPI cards: 1 col por defecto */
.kpis{
  display:grid;
  grid-template-columns: 1fr;
  gap:16px;
}

/* >= 420px (iPhone 16 Pro Max vertical incluido)  3 columnas */
@media (min-width: 420px){
  .kpis{
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap:16px; /* ajusta si quieres más/menos aire */
  }
}

/* Opcional: que todas tengan la misma altura visual */
.kpi{
  display:flex;
  flex-direction:column;
  justify-content:center;
}