/* ============================
   Estructura Base para Sticky Footer
============================ */
html, body {
  height: 100%;
  margin: 0;
  padding: 0;
}
body {
  display: flex;
  flex-direction: column;
}
/* El main se expandirá para empujar el footer hacia abajo */
.site-main {
  flex: 1;
}
/* ============================
   Ajustes Globales
============================ */
    body {
      /*  font-family: Arial, sans-serif;*/
      /*  font-family: 'Open Sans', Arial, sans-serif;*/
      /*  font-family: 'Poppins', Arial, sans-serif;*/
      font-family: 'Roboto', Helvetica, sans-serif;
      line-height: 1.6;
      background: #f0f8ff; /* azul clarito */
      text-align: center;
    }
    h1, h2, h3 {
      font-weight: 600; /* Semi-Bold para encabezados */
      color: #333;
      margin: 1em 0;
      text-align: center;
    }
    p, label, input, select, button {
      font-weight: 400; /* Regular para texto normal */
      font-size: 1em;
    }
/* ============================
   Encabezado (Header)
============================ */
/* --- CON DEGRADADO, BORDES Y SOMBRAS --- */
.site-header {
  width: 100%;
  background-color: rgb(242, 129, 53);
  color: #fff;
  padding: 15px 0;
  text-align: center;
  position: fixed;
  top: 0;
  z-index: 1000;
  border-radius: 5px;
  box-shadow: 0 4px 4px rgba(0,0,0,0.1);
  /* Quitar o cambiar overflow para que el dropdown no se recorte */
  overflow: visible;
}
.site-header:before {
  content: "";
  display: block;
  position: absolute;
  top: 10px;
  bottom: 10px;
  left: 10px;
  right: 10px;
  background: linear-gradient(
      to right,
      rgba(255, 140, 80, 0.8),
      rgba(242, 129, 53, 1),
      rgba(255, 140, 80, 0.8)
  );
  z-index: -1;
  border-style: outset;
  border-width: 2px;
  border-radius: 5px;
  border-color: rgba(255, 220, 150, 0.5);
  box-shadow: 5px 8px 20px 5px rgba(0, 0, 0, 0.3);
}
/*En lugar de .header-container y .title-box, usamos .brand-line, .brand y .brand-logo para mantener “MiniDMS by” y el logo en la misma línea */
.brand-line {
  display: flex;
  justify-content: center; /* Centra horizontalmente */
  align-items: center;
  gap: 10px;
  margin-bottom: 5px; /* Separación con la info de usuario */
}
.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  /* Fondo blanco y texto azul */
  background: #fff;
  color: #337ab7;
  padding: 0 15px;
  border-radius: 8px; /* Esquinas redondeadas */
}
.brand h1 {
  margin: 0;
  font-size: 22px;
}
.brand h1 small {
  font-size: 14px;
  margin-left: 5px;
}
.brand-logo {
  height: 50px;
  width: auto;
}
/* Info de usuario debajo (opcional) */
.user-info {
  margin: 0;
  font-weight: bold;
  text-align: center;
  /* Algo de espacio abajo para separarlo del menú */
  margin-bottom: 8px;
}

/* Ajustamos color de enlaces para “Iniciar sesión” / “Cerrar sesión” */
.user-info a {
  color: #ffe84f; /* Un amarillo que contraste bien, por ejemplo */
  text-decoration: none;
  font-weight: bold;
}
.user-info a:hover {
  text-decoration: underline;
}
/* ============================
   Main y Navegación
============================ */
.site-main {
  width: 80%;
  margin: 20px auto;
  text-align: center;
  margin-top: 200px; /* Ajusta este valor según la altura real del header */
  margin-bottom: 50px;
}

/* Menú principal */
.header-nav {
  text-align: center; /* Centra elementos inline */
  margin-top: 10px;
}
/* Contenedor principal del menú */
.header-nav ul {
  position: relative;
}
/* Estilos para el elemento dropdown */
.header-nav ul li.dropdown {
  position: relative;
}
/* El submenú (dropdown-menu) lo ocultamos inicialmente */
.header-nav ul li.dropdown .dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;    /* Se despliega justo debajo del elemento padre */
  left: 0;
  background: linear-gradient(45deg, #337ab7, #286090);
  border-radius: 4px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
  list-style: none;
  padding: 10px 0;
  margin: 0;
  z-index: 1000;
}
/* Mostrar el submenú al pasar el mouse sobre el elemento dropdown */
.header-nav ul li.dropdown:hover .dropdown-menu {
  display: block;
}
/* Opciones del dropdown */
.header-nav ul li.dropdown .dropdown-menu li {
  margin: 0;
  padding: 0;
}
/* Estilos para los enlaces del dropdown */
.header-nav ul li.dropdown .dropdown-menu li a {
  color: #fff;
  padding: 10px 20px;
  display: block;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.3s;
}
/* Cambio de fondo al pasar el ratón sobre el enlace del dropdown */
.header-nav ul li.dropdown .dropdown-menu li a:hover {
  background: rgba(255, 255, 255, 0.2);
}
/* Por si uso menús superiores e inferiores */
.menu-superior,
.menu-inferior {
  list-style: none;
  margin: 5px auto;
  padding: 0;
  display: flex;
  justify-content: center;
  gap: 20px;
}
.menu-superior li a,
.menu-inferior li a {
  color: #fff;
  text-decoration: none;
  padding: 10px 20px;
  display: inline-block;
  font-weight: bold;
  transition: background 0.3s, transform 0.3s;
  border-radius: 4px;
  white-space: nowrap;
}
.menu-superior li a:hover,
.menu-inferior li a:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: scale(1.05);
}
.menu-superior li a:active,
.menu-inferior li a:active {
  transform: scale(0.95);
}
/* ============================
   Responsividad para móviles
============================ */
@media (max-width: 600px) {
  .brand-line {
    flex-direction: column;
  }
  .brand h1 {
    font-size: 18px;
  }
  .brand-logo {
    height: 40px;
  }
  .site-main {
    width: 90%;
  }
  .form-container {
    width: 90%;
    padding: 10px;
  }
  /* Permitir que los menús se envuelvan en varias filas */
  .menu-superior,
  .menu-inferior {
    flex-wrap: wrap;
    gap: 10px;
  }
}
/* Elimino estilo en li si lo hubiera */
.header-nav li {
  margin: 0;
  padding: 0;
  list-style: none;
}
/* Enlaces del menú */
.header-nav a {
  color: #fff;
  text-decoration: none;
  padding: 10px 20px;
  display: inline-block;
  font-weight: bold;
  transition: background 0.3s, transform 0.3s;
  border-radius: 4px;
}
/* Efecto hover: oscurece un poco y crece */
.header-nav a:hover {
  background: rgba(255, 255, 255, 0.2);
  transform: scale(1.05);
}
/* Efecto al hacer clic: reduce */
.header-nav a:active {
  transform: scale(0.95);
}
/* Evitar que se partan las palabras en dos líneas */
.header-nav ul li a {
  white-space: nowrap;
}
/* ============================
   Tablas
============================ */
/* Contenedor para tabla responsive */
.table-responsive {
  overflow-x: auto;
  margin: 20px auto;
}
/* Estilos para la tabla */
table {
  border-collapse: collapse;
  margin: 0 auto;
  width: 100%;
  max-width: 100%;
  text-align: center;
}
th, td {
  padding: 8px 12px;
  border: 1px solid #ccc;
}
/* Fuerza scroll horizontal en pantallas muy pequeñas */
@media (max-width: 600px) {
  .table-responsive table {
    min-width: 700px;
  }
}
/* ============================
   Botonera y Botones
============================ */
.botonera {
  text-align: center;
  margin: 20px 0;
}
.btn {
  display: inline-block;
  background: #337ab7;
  color: #fff;
  padding: 10px 20px;
  border-radius: 20px;
  border: none;
  text-decoration: none;
  font-weight: bold;
  cursor: pointer;
  margin: 5px 0;
  transition: background 0.2s, transform 0.2s;
}
.btn:hover {
  background: #286090;
  transform: scale(1.02);
}
.btn:active {
  background: #204d74;
  transform: scale(0.98);
}
.btn-danger {
  background: #d9534f;
}

.btn-danger:hover {
  background: #c9302c;
}
.button-group {
  text-align: center;
}
/* ============================
   Formularios
============================ */
.form-container {
  max-width: 600px;
  margin: 0 auto;
  padding: 15px;
  text-align: left;
}
.form-group {
  margin-bottom: 15px;
}
.form-group label {
  font-weight: bold;
}
.form-group input[type="text"],
.form-group input[type="date"],
.form-group input[type="file"],
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 8px;
  box-sizing: border-box;
  border: 1px solid #ccc;
  border-radius: 4px;
}
.form-group textarea {
  width: 100% !important;
  max-width: 100%;
}
/* Mensajes */
.error {
  color: red;
  font-weight: bold;
}
.exito {
  color: green;
  font-weight: bold;
}
.form-container .form-group input[type="url"] {
  width: 98.5%;
  max-width: 100%;
}
/* ============================
   Responsividad para móviles (Formularios y otros)
============================ */
@media (max-width: 600px) {
  .brand-line {
    flex-direction: column;
  }
  .brand h1 {
    font-size: 18px;
  }
  .brand-logo {
    height: 40px;
  }
  .site-main {
    width: 90%;
  }
  .form-container {
    width: 90%;
    padding: 10px;
  }
  .header-nav ul {
    flex-wrap: wrap;
  }
}
/* ============================
   Footer (independiente)
============================ */
/* --- MODIFICADO PARA LOGRAR DEGRADADO, BORDES Y SOMBRAS --- */
.my-footer {
  width: 100%;
  background-color: rgb(242, 129, 53); /* Nuevo color principal */
  color: #fff;
  text-align: center;
  padding: 10px 0;
  margin-top: 20px;
  position: relative;
  overflow: hidden;
  border-radius: 5px;
}
.my-footer:before {
  content: "";
  position: absolute;
  top: 5px;
  bottom: 5px;
  left: 5px;
  right: 5px;
  background: linear-gradient(
      to right,
      rgba(255, 140, 80, 0.8),
      rgb(242, 129, 53),
      rgba(255, 140, 80, 0.8)
  );
  z-index: -1;
  border-radius: 5px;
  box-shadow: 3px 5px 10px rgba(0,0,0,0.3);
}
.my-footer hr {
  border: 0;
  border-top: 1px solid #fff;
  width: 90%;
  margin: 10px auto;
}
.my-footer a {
  color: #fff;
  text-decoration: none;
  margin: 0 5px;
}
.my-footer a:hover {
  text-decoration: underline;
}
/* ============================
   Login - formulario
============================ */
.login-form {
  max-width: 300px;
  margin: 20px auto;
  padding: 20px;
  text-align: center;
  background: #fff;
  border-radius: 6px;
  box-shadow: 0 0 10px rgba(0,0,0,0.1);
}
.login-form .form-group {
  margin-bottom: 15px;
}
.login-form .form-group label {
  display: block;
  margin-bottom: 5px;
  font-weight: bold;
  text-align: center;
}
.login-form .form-group input {
  width: auto;
  max-width: 200px;
  margin: 0 auto;
  padding: 8px;
  border: 1px solid #ccc;
  border-radius: 4px;
  text-align: center;
}
.login-form .button-group {
  text-align: center;
}
.login-form {
  background: #f8f9fa; /* Gris muy claro */
}
.drop-area {
  border: 2px dashed #337ab7;
  border-radius: 8px;
  padding: 20px;
  text-align: center;
  color: #337ab7;
  cursor: pointer;
  transition: background-color 0.3s, border-color 0.3s;
  margin-bottom: 1rem;
}
/* ============================
   Drag and Drop - descartado
============================ */
/*
.drop-area:hover {
  background-color: #f0f8ff;
  border-color: #286090;
}
.drop-area.dragover {
  background-color: #e0f7fa;
  border-color: #204d74;
}
*/
/* ================================================================
   Alineación izquierda para acordeón 
   ================================================================ */
/* 1) Hago que el .accordion-content sea fila, no columna */
.accordion .accordion-content {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: left !important;
}
/* 2) Margen derecho para la imagen */
.accordion .accordion-content img {
  margin: 0 10px 0 0 !important;
  float: none !important;
}
/* 3) Aseguro que el texto use todo el espacio */
.accordion .accordion-title {
  flex: 1;
  text-align: left !important;
}
/* en modo tabs .tab-btn img(que usan display:block;margin:0 auto) siguen centradas automáticamente. */
