
:root{--fg:#0f172a;--muted:#475569;--bg:#ffffff;--accent:#0ea5e9;--ring:#bae6fd}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;color:var(--fg);background:#f8fafc}
img{max-width:100%;height:auto;display:block}
header{position:sticky;top:0;background:#fff;border-bottom:1px solid #e2e8f0;z-index:50;backdrop-filter:saturate(1.3) blur(6px)}
.container{max-width:1100px;margin:0 auto;padding:0 16px}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav a{color:#0f172a;text-decoration:none;margin:0 10px;font-weight:600}
.btn{display:inline-block;padding:12px 18px;border-radius:12px;text-decoration:none;font-weight:700}
.btn-primary{background:var(--accent);color:#fff}
.btn-outline{border:2px solid var(--accent);color:#0ea5e9;background:#fff}
.section{padding:56px 0}
.section h2{margin:0 0 18px;font-size:28px}
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:18px;box-shadow:0 6px 20px rgba(2,8,23,.04)}
.card .thumb{aspect-ratio:16/9;border-radius:12px;overflow:hidden;margin:-2px -2px 10px -2px;border:1px solid #e2e8f0}
.band{background:linear-gradient(180deg,#ffffff 0,#f1f5f9 100%);border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0}
.footer{background:#0f172a;color:#cbd5e1;padding:36px 0;margin-top:40px}

/* mejora footer*/
.site-footer{background:#060b2b;color:#e5edff;margin-top:56px}
.footer-top-border{height:3px;background:linear-gradient(90deg,#1e90ff,rgba(30,144,255,.2))}
.footer-grid{display:grid;grid-template-columns:1.1fr 1.4fr 1fr;gap:40px;padding:48px 0}
.footer-title{font-size:16px;letter-spacing:.03em;text-transform:uppercase;color:#c7d7ff;margin:0 0 14px}
.footer-links{list-style:none;padding:0;margin:0;display:grid;gap:10px}
.footer-links a{color:#d9e4ff;text-decoration:none}
.footer-links a:hover{color:#8ecaff}

.footer-muted{color:#9ab0ff;font-size:14px}
.office,.contact-line{display:flex;gap:12px;align-items:flex-start;margin:14px 0}
.footer-icon{flex:0 0 auto;width:20px;height:20px;color:#2aa0ff}
.footer-icon svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
address{font-style:normal;color:#e5edff;line-height:1.35}

.footer-brand img{display:block;filter:brightness(1.2)}
.footer-claim{color:#c7d7ff;margin:12px 0 18px}

.footer-social{display:flex;gap:12px}
.footer-social a{display:inline-flex;width:36px;height:36px;border-radius:10px;background:#0b1045;align-items:center;justify-content:center;color:#cfe2ff;border:1px solid rgba(255,255,255,.08)}
.footer-social a:hover{background:#132069;color:#fff;border-color:#2aa0ff}
.footer-social svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2}

.footer-bottom{border-top:1px solid rgba(255,255,255,.08);background:#050922}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;padding:16px 0;color:#9ab0ff}
.footer-bottom small{opacity:.9}
/* fin mejora footer*/


/* Responsive */
@media (max-width: 960px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
}
@media (max-width: 640px){
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom-inner{flex-direction:column;gap:8px;text-align:center}
}


.clients-swiper img{filter:grayscale(100%);opacity:.85;max-height:60px}
@media (max-width:1000px){.grid-3{grid-template-columns:1fr}.grid-2{grid-template-columns:1fr}}

/* --- UI tweaks per feedback --- */
.section h2{text-align:center}


/* --- Cards: forzar misma cota de inicio del texto --- */

/* La tarjeta puede seguir en grid o flex; aquí no tocamos eso */
.card .thumb{
  aspect-ratio: 3 / 2;     /* misma altura visual en todas */
  overflow: hidden;        /* recorta desbordes */
  border-radius: 12px;     /* opcional, si ya lo usas */
}

/* Elimina el hueco por baseline y rellena por completo la miniatura */
.card .thumb picture,
.card .thumb img{
  display: block;          /* <- quita el gap bajo la imagen */
  width: 100%;
  height: 100%;
  object-fit: cover;       /* cubre sin deformar */
}

/* Normaliza el margen superior del título para todas las cards */
.card h3{
  margin-top: 14px;        /* ajusta a tu ritmo visual */
  margin-bottom: 10px;
}

/* Badge / claim underline style */
.claim-underline{
  display:inline;
  background-image: linear-gradient(#0ea5e9,#0ea5e9);
  background-repeat:no-repeat;
  background-size: 100% 4px;
  background-position: 0 95%;
  padding-bottom: 2px;
}

/* Badge / claim underline style */
.claim-underline-h2{
  display:center;
  background-image: linear-gradient(#0ea5e9,#0ea5e9);
  background-repeat:no-repeat;
  background-size: 100% 4px;
  background-position: 0 95%;
  padding-bottom: 2px;
}
/* HERO overlay with background slider behind text */
.hero-overlay{position:relative; min-height: 520px; border-bottom:1px solid #e2e8f0}
.hero-overlay .bg-slider{position:absolute; inset:0; z-index:0}
.hero-overlay .bg-slider .swiper-slide picture,
.hero-overlay .bg-slider .swiper-slide img{width:100%; height:100%; object-fit:cover}
.hero-overlay .inner{position:relative; z-index:1; height:100%; display:flex; align-items:center}
.hero-box{max-width:880px;background:rgba(15,23,42,.55);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:52px; margin: 50px;box-shadow:0 10px 30px rgba(2,8,23,.35)}
.hero-box h1{margin:0 0 8px; font-size:40px; line-height:1.05}
.hero-box .kicker{display:inline-block;color:#e0f2fe;margin-bottom:6px}
.hero-actions{display:flex;gap:12px;margin-top:12px}
.hero-actions .btn-outline{border-color:#fff;color:var(--accent)}
.hero-actions .btn-outline:hover{background:rgba(255,255,255,.1)}
/* Features band spacing smaller */
.features-band .features{gap:18px}
@media (max-width:900px){
  .hero-overlay{min-height: 460px}
  .hero-box{max-width:100%;}
}

/* === Grids auto-fit === */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.section h1,.section h2{text-align:center}
.section .container{max-width:1200px;margin:0 auto}


/* === Clients slider === */
.clients-swiper .swiper-slide{width:auto;display:flex;align-items:center;justify-content:center;padding:6px 12px}
.clients-swiper img{height:90px;width:auto;opacity:.9;filter:grayscale(100%);transition:all .2s}
.clients-swiper img:hover{opacity:1;filter:none}



/* Formulario de contacto */
.form input,
.form textarea {
  width:100%;
  padding:12px;
  border:1px solid #cbd5e1;
  border-radius:8px;
  font-size:16px;
  margin-bottom:12px;
}
.form input:focus,
.form textarea:focus {
  outline:none;
  border-color:#0ea5e9;
  box-shadow:0 0 0 2px rgba(14,165,233,.2);
}
.form button {
  margin-top:8px;
}


/* estilos minimos paginas legales */
:root{--ink:#0b1045;--muted:#546a8f}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial,sans-serif;color:#0e1525;line-height:1.55}
.container{max-width:980px;margin:0 auto;padding:0 20px}
.legal-hero{background:#f5f8ff;border-bottom:1px solid #e8eefc;padding:40px 0}
.legal-hero h1{margin:0 0 6px;color:var(--ink)}
.legal-hero p{margin:0;color:var(--muted)}
.legal-content{padding:28px 0 60px}
.legal-content h2{margin-top:28px;color:var(--ink)}
.legal-content ul{padding-left:18px}
.legal-content a{color:#0a84ff}


/* centrar botones */
.section-header {
  display: flex;
  flex-direction: column; /* título arriba, botón debajo */
  align-items: center;    /* centra en horizontal */
  gap: 12px;              /* espacio entre título y botón */
  text-align: center;
  margin: 0 0 18px;
}


/* LOGO Base */
.header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;}
.brand img{height:44px;width:auto;object-fit:contain;}
.main-nav{display:flex;gap:18px;align-items:center;}   /* visible en escritorio */
.nav-toggle{display:none;background:none;border:0;padding:8px;margin-left:auto;cursor:pointer;}
.nav-toggle .bar{display:block;width:22px;height:2px;background:#091133;margin:4px 0;border-radius:1px}


/* Menú escritorio: tipografía y estados */
.main-nav a{
  font-weight: 600;          /* seminegrita */
  text-decoration: none;     /* sin subrayado */
  color: #0a0f1a;            /* ajusta si usas otro color */
  padding: 4px 6px; 
  line-height: 2;
}
.main-nav a:hover,
.main-nav a:focus{
  text-decoration: none;
  opacity: .8;               /* feedback sin subrayado */
}
.main-nav .btn{              /* tu botón Contacto */
  font-weight: 600;
  text-decoration: none;
}


/* --- móvil --- */
@media (max-width: 767px){
  .nav-toggle{
    display:block;
    position:relative;
    z-index:1100;        /* por encima de banners/fondos */
  }
  .main-nav{
    position:fixed; inset:60px 0 auto 0;
    background:#fff; box-shadow:0 12px 30px rgba(0,0,0,.08);
    display:none;        /* oculto por defecto en móvil */
    flex-direction:column; gap:12px; padding:14px;
    z-index:1000;
  }
  .main-nav.is-open{ display:flex; }
}

/* Evitar reglas globales que rompen móvil */
#mainnav{ display: initial; }          /* neutraliza posibles display:none heredados */
@media (max-width: 767px){ #mainnav{ display:none; } }  /* en móvil sí se oculta por defecto */

/* Asegura que el header no bloquea clics */
.header{ position:relative; z-index:100; }
body.no-scroll{ overflow:hidden; }
