:root{
  --bg:#0b1020;
  --card:#11162a;
  --muted:#a8b0c3;
  --text:#e9eefb;
  --brand:#5b7cff;
  --brand-2:#00d4ff;
  --success:#16c79a;
  --radius:16px;
  --shadow:0 10px 30px rgba(0,0,0,.25);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:linear-gradient(180deg,#0b1020 0%,#0a0f1d 100%);color:var(--text);}

.container{max-width:1100px;margin:0 auto;padding:0 20px}
.mt-32{margin-top:32px}.mt-48{margin-top:48px}

.site-header{position:sticky;top:0;backdrop-filter:saturate(1.8) blur(10px);background:rgba(11,16,32,.7);z-index:50;border-bottom:1px solid rgba(255,255,255,.06)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.logo{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-weight:700}
.logo img{height: 90px;px}

nav a{color:var(--muted);text-decoration:none;margin:0 10px;padding:8px 10px;border-radius:10px}
nav a.active, nav a:hover{color:var(--text);background:rgba(255,255,255,.06)}
.btn{background:linear-gradient(90deg,var(--brand),var(--brand-2));border:none;color:#fff;padding:10px 18px;border-radius:12px;cursor:pointer;font-weight:700;box-shadow:var(--shadow);text-decoration:none;display:inline-block}
.btn:hover{opacity:.95}
.btn-outline{background:transparent;border:1px solid rgba(255,255,255,.2)}
.btn-ghost{background:transparent}

.hero{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:center;min-height:60vh}
.hero h1{font-size:44px;line-height:1.1;margin:0 0 10px}
.hero p{color:var(--muted);font-size:18px}
.cta-group{display:flex;gap:12px;margin-top:16px}
.hero-card{background:linear-gradient(160deg,#0f1630,#0a1226);padding:24px;border-radius:var(--radius);box-shadow:var(--shadow)}
.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.kpi{background:rgba(255,255,255,.04);padding:18px;border-radius:14px;text-align:center}
.kpi span{font-size:28px;font-weight:800;display:block}
.kpi small{color:var(--muted)}

.features{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:40px auto}
.card{background:var(--card);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.05)}
.card h3{margin:8px 0 6px}
.card i{font-size:22px;opacity:.9}
.link{color:#cfe2ff;text-decoration:none}
.link:hover{text-decoration:underline}

.banner {
  background: linear-gradient(90deg, rgba(91,124,255,.15), rgba(0,212,255,.12));
  padding: 40px 20px;
  border-radius: 16px;
  text-align: center;        /* centra el texto */
  margin: 50px auto 30px;
  border: 1px solid rgba(255,255,255,.06);
  max-width: 900px;          /* limita ancho para mejor lectura */
}

.banner h2 {
  margin: 0 0 12px;
  font-size: 32px;
  font-weight: 700;
}

.banner p {
  margin: 0;
  font-size: 18px;
  color: var(--muted);
}



.page h1{margin-top:12px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

.list{margin:0;padding-left:18px;color:var(--muted)}
.testimonials{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:16px}
.testimonial{display:flex;gap:12px;align-items:center;background:rgba(255,255,255,.04);padding:14px;border-radius:14px;border:1px solid rgba(255,255,255,.06)}
.testimonial img{width:56px;height:56px;border-radius:50%;object-fit:cover}
.quote{margin:0 0 4px}
.author{margin:0;color:var(--muted);font-size:14px}

.form-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.form-grid label{display:block;font-weight:600;margin-bottom:6px}
.form-grid input,.form-grid select{width:100%;padding:10px;border-radius:10px;border:1px solid rgba(255,255,255,.15);background:#0c1328;color:var(--text)}
.form-actions{grid-column:1/-1;display:flex;align-items:center;gap:14px}
.quote{font-weight:600}
.map-wrap{margin-top:16px;overflow:hidden;border-radius:16px;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow)}

.form-two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
form label{display:block;margin:8px 0 6px}
form input{width:100%;padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:#0c1328;color:var(--text)}
.form-msg{color:var(--muted);margin-top:8px;min-height:22px}

.table-wrap{overflow:auto;border-radius:14px;border:1px solid rgba(255,255,255,.08)}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
.table thead th{background:rgba(255,255,255,.05);text-align:left}

.download{display:flex;gap:14px;align-items:center;text-decoration:none;color:var(--text)}
.download i{font-size:26px}

.site-footer{margin-top:48px;border-top:1px solid rgba(255,255,255,.06);background:rgba(11,16,32,.7)}
.footer-grid{display:flex;justify-content:space-between;gap:20px;padding:20px 0}
.social a{font-size:20px;color:#cfe2ff;margin-right:12px}
.copy{text-align:center;color:var(--muted);padding:10px 0;border-top:1px solid rgba(255,255,255,.06);margin:0}

@media (max-width:980px){
  .hero{grid-template-columns:1fr}
  .features{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:1fr 1fr}
  .form-grid{grid-template-columns:1fr 1fr}
  .form-two-col{grid-template-columns:1fr}
}
@media (max-width:640px){
  .features{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  nav a{margin:0 4px}
}

/* === Layout base para sticky footer === */
html, body { height: 100%; }
body { min-height: 100svh; display: flex; flex-direction: column; }
main { flex: 1 0 auto; }
.site-footer { margin-top: auto; }

/* === Nav: mejor alineación del botón Login === */
.nav { display:flex; align-items:center; justify-content:space-between; height:64px }
.nav .nav-links { display:flex; gap:8px; align-items:center; }
.nav .nav-actions { margin-left:auto; display:flex; align-items:center; gap:10px; }
.nav .nav-actions .btn { white-space:nowrap; }

/* Pequeños ajustes de footer consistente */
.site-footer .container { padding-top: 8px; padding-bottom: 8px; }
.footer-grid { align-items:flex-start; flex-wrap:wrap; }
.footer-grid h4 { margin: 0 0 6px; }
.footer-grid p, .footer-grid a { color: var(--muted); }
.copy { padding: 12px 0; }

/* === Carrusel === */
.carousel { position:relative; overflow:hidden; border-radius:16px; border:1px solid rgba(255,255,255,.08); box-shadow:var(--shadow); background:#0c1328; }
.carousel .slides { display:flex; transition: transform .5s ease; }
.carousel .slide { min-width:100%; aspect-ratio: 16/9; display:grid; place-items:center; }
.carousel .slide img { width:100%; height:100%; object-fit:cover; display:block; }
.carousel .control { position:absolute; top:50%; transform:translateY(-50%); border:none; background:rgba(0,0,0,.35); color:#fff; padding:10px 12px; border-radius:12px; cursor:pointer; }
.carousel .prev { left:10px; }
.carousel .next { right:10px; }
.carousel .dots { position:absolute; bottom:10px; left:50%; transform:translateX(-50%); display:flex; gap:8px; }
.carousel .dot { width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.4); border:none; cursor:pointer; }
.carousel .dot.active { background:#fff; }

/* === Galería visual === */
.gallery {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 16px;
}
/* Galería más grande */
.gallery-card {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: var(--shadow);
  border: 1px solid rgba(255,255,255,.08);
  background: #0c1328;
  isolation: isolate;
  height: 320px;               /* antes más bajo, ahora más grande */
}

.gallery-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}

.gallery-card:hover img {
  transform: scale(1.08);
}

.gallery-card .info {
  position: absolute;
  inset: auto 0 0 0;
  padding: 20px;               /* más espacio para el texto */
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(5,8,18,.85) 45%, rgba(5,8,18,.95) 100%);
  color: var(--text);
}

.gallery-card h3 {
  margin: 0 0 6px;
  font-size: 20px;             /* más grande */
  font-weight: 700;
}

.gallery-card p {
  margin: 0;
  font-size: 16px;             /* más grande */
  line-height: 1.4;
  color: var(--muted);
}


.badges {
  position: absolute; top: 10px; left: 10px; display: flex; gap: 6px; z-index: 2;
}
.badge {
  background: rgba(0,0,0,.45);
  border: 1px solid rgba(255,255,255,.15);
  color: #fff; font-size: 12px; padding: 4px 8px; border-radius: 999px;
}

@media (max-width: 980px) {
  .gallery { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .gallery { grid-template-columns: 1fr; }
}



/* Hero con imagen de fondo */
.hero {
  position: relative;
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 28px;
  align-items: center;
  min-height: 70vh;
  border-radius: 18px;
  overflow: hidden;
  padding: 40px;
  color: #fff;
  background: url("../img/generated-m6LJaOW2bKFKw6rb.webp") center/cover no-repeat; /* tu imagen */
}

.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(11, 16, 32, 0.7); /* capa oscura para legibilidad */
  z-index: 0;
}

.hero-text, .hero-card {
  position: relative;
  z-index: 1; /* sobre la capa oscura */
}

/* Bloque vertical de highlights */
/* Bloque vertical de highlights más compacto */
.highlights {
  display: grid;
  gap: 20px;
  margin: 40px auto;
  max-width: 1100px;     /* no ocupar todo el ancho en pantallas grandes */
}

.highlight-card {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--shadow);
  height: 220px;         /* más bajo que antes */
  display: flex;
  align-items: flex-end;
}

.highlight-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
}

.highlight-card:hover img {
  transform: scale(1.05);
}

.highlight-card .overlay {
  position: relative;
  z-index: 1;
  background: linear-gradient(180deg, rgba(0,0,0,0.05) 0%, rgba(0,0,0,.75) 100%);
  color: #fff;
  padding: 18px 22px;
}

.highlight-card h2 {
  margin: 0 0 6px;
  font-size: 22px;       /* más pequeño */
  font-weight: 700;
}

.highlight-card p {
  margin: 0;
  font-size: 15px;
  color: #dbe2f5;
}


.social a {
  font-size: 20px;
  color: #cfe2ff;
  margin-right: 12px;
}

/* Bloque de texto centrado debajo de la galería */
.blockchain-intro {
  text-align: center;
  margin: 40px auto;
  max-width: 800px;
}

.blockchain-intro h2 {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 12px;
}

.blockchain-intro p {
  font-size: 18px;
  color: var(--muted);
  line-height: 1.5;
  margin: 0;
}

/* Bloque de texto centrado para Blockchain intro */
.bc-intro {
  text-align: center;
  margin: 50px auto;
  max-width: 900px;
  padding: 0 20px;
}

.bc-intro h2 {
  font-size: 26px;
  font-weight: 700;
  margin-bottom: 16px;
  line-height: 1.3;
}

.bc-intro p {
  font-size: 17px;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}

/* Imagen de fondo desde HTML */
.financial-services-bg {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
}

.financial-services-bg .fs-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.financial-services-content {
  position: relative;
  z-index: 1;
  padding: 60px 40px;
  text-align: center;
  color: #fff;
  background: rgba(0,0,0,0.5); /* capa oscura encima de la imagen */
}

.financial-services-content h1 {
  font-size: 34px;
  margin-bottom: 10px;
}

.financial-services-content p {
  font-size: 18px;
  color: #d0d8f7;
  margin-bottom: 40px;
}

.financial-services-content .card {
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(6px);
  color: #fff;
  border-radius: 16px;
  padding: 20px;
  box-shadow: var(--shadow);
}

/* ===== Sección de testimonios ===== */
.testimonials-section {
  text-align: center;
  margin: 60px auto;
  max-width: 1100px;
}

.testimonials-section h2 {
  font-size: 32px;
  font-weight: 700;
  margin-bottom: 40px;
  text-align: center;
}

/* Contenedor: 3 columnas una al lado de otra */
.testimonials {
  display: flex;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap; /* se ajusta en pantallas pequeñas */
}

/* Cada tarjeta del mismo tamaño */
.testimonial {
  flex: 1 1 300px; /* todas crecen igual, mínimo 300px */
  max-width: 320px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  padding: 24px;
  text-align: center;
  box-shadow: var(--shadow);
  transition: transform 0.3s ease;
}

.testimonial:hover {
  transform: translateY(-5px);
}

/* Imagen */
.testimonial img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 50%;
  margin-bottom: 16px;
  border: 2px solid #fff;
}

/* Texto */
.testimonial .quote {
  font-size: 16px;
  font-style: italic;
  margin-bottom: 10px;
  color: #dbe2f5;
}

.testimonial .author {
  font-size: 15px;
  font-weight: 600;
  color: #fff;
}

/* ===== HEADER PEGADO A LOS BORDES ===== */
/* ===== HEADER ===== */
.site-header {
  position: sticky;
  top: 0;
  width: 100%;
  background: rgba(11, 16, 32, 0.9);
  border-bottom: 1px solid rgba(255,255,255,.06);
  backdrop-filter: saturate(1.8) blur(10px);
  z-index: 50;
}

.nav {
  display: flex;
  align-items: center;
  width: 100%;
  height: 90px;
  padding: 0 40px; /* espacio lateral, puedes bajarlo a 20px si quieres aún más pegado */
}

/* LOGO - pegado izquierda */
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--text);
  text-decoration: none;
}

.logo img {
  height: 90px;
  width: auto;
  display: block;
}

.logo span {
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
}

/* CONTENEDOR DEL MENÚ Y LOGIN - pegado a la derecha */
.nav-right {
  display: flex;
  align-items: center;
  margin-left: auto; /* empuja TODO hacia el borde derecho */
  gap: 24px;
}

/* Links del menú */
.nav-links {
  display: flex;
  align-items: center;
  gap: 24px;
}

.nav-links a {
  color: var(--muted);
  text-decoration: none;
  padding: 8px 10px;
  border-radius: 10px;
  transition: all 0.3s ease;
}

.nav-links a:hover,
.nav-links a.active {
  color: var(--text);
  background: rgba(255,255,255,0.06);
}

/* Botón Login */
.nav-actions {
  display: flex;
  align-items: center;
}

.nav-actions .btn {
  padding: 10px 18px;
  border-radius: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.btn-outline {
  background: transparent;
  border: 1px solid rgba(255,255,255,.2);
  color: #fff;
  text-decoration: none;
}



/* ====== Responsive Header / Mobile ====== */
.menu-toggle{
  display:none;
  background:transparent;
  border:0;
  padding:8px;
  cursor:pointer;
}
.menu-toggle span{
  display:block;
  width:24px;
  height:2px;
  background:#fff;
  margin:5px 0;
  transition:transform .3s ease, opacity .3s ease;
}

/* Estado abierto (animación X) */
.nav.open .menu-toggle span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav.open .menu-toggle span:nth-child(2){ opacity:0; }
.nav.open .menu-toggle span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 768px){
  /* Header compacto */
  .nav{
    padding: 0 16px;
    height: 64px;
  }
  .logo img{ height: 54px; }
  .logo span{ font-size: 1.1rem; }

  /* Mostrar hamburguesa, ocultar menú por defecto */
  .menu-toggle{ display:block; margin-left:auto; }
  .nav-links, .nav-actions{
    display:none;
  }

  /* Menú desplegable */
  .nav.open .nav-links,
  .nav.open .nav-actions{
    display:flex;
  }

  .nav.open{
    align-items:flex-start;
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .nav.open .nav-links{
    flex-direction:column;
    gap:10px;
    position:absolute;
    top:-1px;           /* debajo del header */
    right:0;
    left:0;
    background:rgba(11,16,32,.97);
    border-top:1px solid rgba(255,255,255,.06);
    padding:14px 16px;
  }

  .nav.open .nav-actions{
    position:absolute;
    top:auto;
    right:16px;
    left:16px;
    margin-left:0;
    margin-top: calc(14px + 44px * 0); /* queda debajo de links */
    padding-bottom:12px;
  }

  /* Mejoras de tacto */
  .nav-links a{
    padding:12px 10px;
    border-radius:10px;
  }

  /* Hero y secciones más compactas en móvil */
  .hero{
    grid-template-columns: 1fr;
    padding: 20px;
    min-height: 56vh;
  }
  .hero h1{ font-size: 30px; }
  .hero p { font-size: 16px; }
  .hero-card{ margin-top: 8px; }

  .features{ grid-template-columns: 1fr 1fr; }
  .grid-3{ grid-template-columns: 1fr; }
  .highlights{ gap:14px; margin:28px auto; }
  .highlight-card{ height:180px; }

  .gallery{ grid-template-columns: 1fr; }
  .gallery-card{ height:260px; }

  .testimonials{ gap:16px; }
  .testimonial{ flex:1 1 100%; max-width: 100%; }
}

/* Muy pequeñas (≤ 380px) */
@media (max-width: 380px){
  .logo img{ height: 46px; }
  .logo span{ display:none; } /* oculta texto marca si aprieta demasiado */
}


/* ======= HEADER BASE ======= */
.site-header {
  position: sticky;
  top: 0;
  width: 100%;
  background: rgba(11, 16, 32, 0.95);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  z-index: 1000;
  backdrop-filter: saturate(1.8) blur(10px);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 40px;
  height: 90px;
  width: 100%;
}

/* Logo pegado izquierda */
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--text);
}

.logo img {
  height: 90px;
  width: auto;
}

.logo span {
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
}

/* Menú y login derecha */
.nav-right {
  display: flex;
  align-items: center;
  margin-left: auto;
  gap: 24px;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 24px;
}

.nav-links a {
  color: var(--muted);
  text-decoration: none;
  padding: 8px 10px;
  border-radius: 10px;
  transition: 0.3s;
}

.nav-links a:hover,
.nav-links a.active {
  color: var(--text);
  background: rgba(255, 255, 255, 0.06);
}

.nav-actions .btn {
  padding: 10px 18px;
  border-radius: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.btn-outline {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: #fff;
}

/* ======= BOTÓN MENÚ HAMBURGUESA ======= */
.menu-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  cursor: pointer;
  background: transparent;
  border: none;
  padding: 8px;
  z-index: 2000;
}

.menu-toggle span {
  width: 26px;
  height: 3px;
  background: #fff;
  margin: 4px 0;
  border-radius: 3px;
  transition: all 0.3s ease;
}

/* ======= ESTADO ABIERTO ======= */
.nav.open .menu-toggle span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.nav.open .menu-toggle span:nth-child(2) {
  opacity: 0;
}
.nav.open .menu-toggle span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ======= RESPONSIVE ======= */
@media (max-width: 768px) {
  .nav {
    padding: 0 20px;
    height: 70px;
  }

  .logo img {
    height: 60px;
  }

  .logo span {
    font-size: 1.2rem;
  }

  /* Mostrar hamburguesa */
  .menu-toggle {
    display: flex;
    margin-left: auto;
  }

  /* Ocultar menú por defecto */
  .nav-right {
    display: none;
  }

  /* Mostrar cuando está abierto */
  .nav.open .nav-right {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 70px;
    right: 0;
    left: 0;
    background: rgba(11, 16, 32, 0.98);
    padding: 20px;
    gap: 20px;
    border-top: 1px solid rgba(255, 255, 255, 0.06);
  }

  .nav.open .nav-links {
    flex-direction: column;
    gap: 16px;
  }

  .nav.open .nav-links a {
    font-size: 18px;
    text-align: center;
    width: 100%;
  }

  .nav.open .nav-actions {
    justify-content: center;
    width: 100%;
  }
}


/* ===== Footer Moderno ===== */
.site-footer {
  background: rgba(11, 16, 32, 0.95);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  padding: 50px 20px 20px;
  color: var(--text);
  margin-top: 80px;
}

.footer-inner {
  max-width: 1200px;          /* 👈 evita que toque los bordes */
  margin: 0 auto;
}

.footer-grid {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 40px;
}

.footer-contact h4,
.footer-social h4 {
  font-size: 20px;
  margin-bottom: 12px;
  color: #fff;
}

.footer-contact p {
  margin: 6px 0;
  font-size: 16px;
  color: var(--muted);
}

.footer-contact a {
  color: var(--brand-2);
  text-decoration: none;
}

.footer-contact a:hover {
  text-decoration: underline;
}

/* Redes sociales */
.footer-social .social-links {
  display: flex;
  gap: 16px;
}

.footer-social a {
  font-size: 28px;
  color: #cfe2ff;
  transition: color 0.3s ease, transform 0.2s ease;
}

.footer-social a:hover {
  color: var(--brand-2);
  transform: translateY(-2px);
}

/* Copyright */
.copy {
  text-align: center;
  color: var(--muted);
  font-size: 14px;
  margin-top: 40px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  padding-top: 20px;
}

/* ===== Responsive ===== */
@media (max-width: 768px) {
  .footer-grid {
    flex-direction: column;
    text-align: center;
    gap: 24px;
  }

  .footer-social .social-links {
    justify-content: center;
  }
}


/* ===== Auth (Login/Register) ===== */
.auth-wrap{
  display:flex;
  justify-content:center;
  align-items:flex-start;
  padding: 40px 20px;
}
.auth-card{
  width:100%;
  max-width:520px;
  margin: 0 auto;
}
.auth-card h1{ margin-top:0; margin-bottom:12px; }

.auth-card form label{
  display:block;
  margin:10px 0 6px;
  font-weight:600;
}
.auth-card form input{
  width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background:#0c1328;
  color:var(--text);
}
.auth-card .btn{ margin-top:12px; width:100%; }

.auth-switch{
  margin-top:14px;
  color:var(--muted);
  text-align:center;
}
.auth-switch a{
  color:var(--brand-2);
  text-decoration:none;
  font-weight:700;
}
.auth-switch a:hover{ text-decoration:underline; }

.hidden{ display:none !important; }

@media (max-width:640px){
  .auth-wrap{ padding: 24px 16px; }
}


/* ===== HEADER BASE ===== */
.site-header {
  position: sticky;
  top: 0;
  z-index: 2000;               /* por encima del contenido */
  background: rgba(11,16,32,.95);
  border-bottom: 1px solid rgba(255,255,255,.06);
  backdrop-filter: saturate(1.8) blur(10px);
}
.site-header .nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px; height: 72px; width: 100%;
  position: relative;          /* base para posicionar el dropdown si se usa absolute */
}

/* Logo izquierda */
.site-header .logo { display:flex; align-items:center; gap:10px; color:#fff; text-decoration:none; }
.site-header .logo img { height: 60px; width:auto; }
.site-header .logo span { font-weight:800; }

/* Menú derecha (desktop) */
.site-header .nav-right { display:flex; align-items:center; gap:20px; margin-left:auto; }
.site-header .nav-links { display:flex; gap:18px; }
.site-header .nav-links a { color: var(--muted); text-decoration:none; padding:8px 10px; border-radius:10px; }
.site-header .nav-links a:hover, .site-header .nav-links a.active { color:#fff; background: rgba(255,255,255,.06); }
.site-header .nav-actions .btn { padding:10px 16px; border-radius:12px; white-space:nowrap; }
.btn-outline { background:transparent; border:1px solid rgba(255,255,255,.2); color:#fff; }

/* Botón hamburguesa */
.menu-toggle { display:none; flex-direction:column; gap:4px; background:transparent; border:0; cursor:pointer; }
.menu-toggle span { width:26px; height:3px; background:#fff; border-radius:3px; transition:all .3s ease; }

/* Estado abierto (X) */
.site-header .nav.open .menu-toggle span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.site-header .nav.open .menu-toggle span:nth-child(2){ opacity:0; }
.site-header .nav.open .menu-toggle span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* ===== MÓVIL ===== */
@media (max-width: 768px){

  .menu-toggle { display:flex; margin-left:auto; }
  .site-header .nav-right { display:none; }

  /* Dropdown desplegable */
  .site-header .nav.open .nav-right{
    display:flex;
    flex-direction:column;
    gap:18px;
    position: fixed;      /* fijo: no se corta ni queda detrás */
    top: 72px;            /* debajo del header */
    left: 0; right: 0;
    background: rgba(11,16,32,.98);
    padding: 18px 20px 24px;
    border-top: 1px solid rgba(255,255,255,.06);
    z-index: 2100;        /* por encima del header */

  }
  .site-header .nav.open .nav-links{flex-direction:column;gap:12px;padding-top: 70px;}
  .site-header .nav.open .nav-links a{ padding:12px; text-align:center; width:100%; }
  .site-header .nav.open .nav-actions {
     justify-content:center;
     padding: 0px 0px;
     padding-right: 34px;
    }


  #loginBtn, #logoutBtn {
    background: #0b1020;
    box-shadow: unset;
  }

}


.nav-mobile {
    padding-top: 0px;
}



/* ESTILOS DE LA TABLA DE USUARIOS*/
/* CONTENEDOR */
.users-table-wrapper {

  margin: 60px auto;
  padding: 24px;
  background: linear-gradient(180deg, #0b1220, #070c18);
  border-radius: 12px;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4);
}

/* TABLA */
.users-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Inter', sans-serif;
  color: #e5e7eb;
}

/* CABECERA */
.users-table thead th {
  text-align: left;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #9ca3af;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

/* FILAS */
.users-table tbody tr {
  transition: background 0.2s ease;
}

.users-table tbody tr:hover {
  background: rgba(255, 255, 255, 0.03);
}

/* CELDAS */
.users-table td {
  padding: 16px;
  font-size: 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

/* LABEL ESTADO */
.status-label {
  display: inline-block;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 600;
  border-radius: 999px;
  letter-spacing: 0.03em;
}

/* ACTIVO */
.status-active {
  color: #22c55e;
  background: rgba(34, 197, 94, 0.15);
}

/* INACTIVO */
.status-inactive {
  color: #ef4444;
  background: rgba(239, 68, 68, 0.15);
}

.details-link {
  color: #38bdf8; /* azul elegante */
  font-weight: 500;
  text-decoration: none;
  transition: color 0.2s ease;
}

.details-link:hover {
  color: #7dd3fc;
  text-decoration: underline;
}


/* ESTULOS DETALLE DE UN USUARIO*/

.user-form-wrapper {
  max-width: 520px;
  margin: 80px auto;
  padding: 32px;
  background: linear-gradient(180deg, #0b1220, #070c18);
  border-radius: 14px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45);
  font-family: 'Inter', sans-serif;
  color: #e5e7eb;
}

.user-form-wrapper h2 {
  margin-bottom: 24px;
  font-size: 20px;
  font-weight: 600;
}

.form-group {
  display: flex;
  flex-direction: column;
  margin-bottom: 18px;
}

.form-group-checkbox label {
  font-size: 13px;
  color: #9ca3af;
  margin-bottom: 6px;
}

.form-group label {
  font-size: 13px;
  color: #9ca3af;
  margin-bottom: 6px;
}

.form-group input[type="text"],
.form-group input[type="email"] {
  padding: 10px 12px;
  background: #020617;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  color: #e5e7eb;
  font-size: 14px;
}

.form-group input:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.checkbox-group {
  margin-top: 6px;
}

.checkbox-group input {
  margin-right: 8px;
}

.form-actions {
  display: flex;
  justify-content: space-between;
  margin-top: 30px;
}

.btn {
  padding: 10px 18px;
  font-size: 14px;
  border-radius: 8px;
  border: none;
  cursor: pointer;
}

.btn-primary {
  background: #2563eb;
  color: #fff;
}

.btn-primary:hover {
  background: #1d4ed8;
}

.btn-danger {
  background: #7f1d1d;
  color: #fecaca;
}

.btn-danger:hover {
  background: #991b1b;
}


/* MODAL CONFIRMACIÓN*/

.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.modal {
  background: linear-gradient(180deg, #0b1220, #070c18);
  padding: 24px;
  border-radius: 12px;
  width: 360px;
  color: #e5e7eb;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6);
}

.modal h3 {
  margin-bottom: 10px;
  font-size: 18px;
}

.modal p {
  font-size: 14px;
  color: #9ca3af;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 24px;
}

.hidden {
  display: none;
}

.files-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.files-list li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  margin-bottom: 6px;
  background: rgba(255,255,255,0.05);
  border-radius: 6px;
  font-size: 14px;
}
#admin_section {
  margin-top: 15px;
  margin-bottom: 15px;
}

.files-list li span {
  opacity: 0.85;
}

.files-list li small {
  opacity: 0.6;
  font-size: 12px;
}


.file-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.file-delete {
  color: #ef4444;
  cursor: pointer;
  font-weight: bold;
  font-size: 16px;
  transition: transform 0.1s ease, opacity 0.1s ease;
}

.file-delete:hover {
  transform: scale(1.2);
  opacity: 0.8;
}


.file-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

.file-download {
  text-decoration: none;
  color: #2c7be5;
  font-size: 16px;
  cursor: pointer;
}

.file-download:hover {
  color: #1a5fd0;
}

.file-delete {
  color: #ef4444;
  cursor: pointer;
  font-size: 16px;
}

a.download:hover {
  border: 1px solid #e5e7eb;
}






