/* Estilos exclusivos de las vistas de descargas: login con clave y panel de archivos.
   Contiene: .descargas-section, .descargas-container/-wrapper, .descargas-form, .descargas-table, .alert.
   Variables clave: --color-secondary, --color-error-*, --color-warning-*, --color-table-*, --sombra.
   Dependencia: shared-components.css (variables, navbar, botones y decoraciones — debe cargarse antes). */

.descargas-section {
  padding: 48px 0;
  position: relative;
  overflow: hidden;
}

.descargas-container {
  max-width: 520px;
  position: relative;
  z-index: 1;
  background: var(--color-white);
  border-radius: 15px;
  box-shadow: var(--sombra);
  padding: 36px 32px;
}

.descargas-container-wrapper {
  position: relative;
  z-index: 1;
  background: var(--color-white);
  border-radius: 15px;
  box-shadow: var(--sombra);
  padding: 36px 32px;
}

.descargas-form label {
  display: block;
  margin-bottom: 6px;
  font-weight: 600;
}

.descargas-form input[type="password"] {
  display: block;
  width: 100%;
  padding: 10px;
  margin: 8px 0 16px;
  border: 1px solid var(--color-input-border);
  border-radius: 6px;
  font-size: 1rem;
}

.alert {
  padding: 12px;
  margin: 16px 0;
  border-radius: 6px;
}

.alert-error {
  background: var(--color-error-bg);
  color: var(--color-error-text);
  border: 1px solid var(--color-error-border);
}

.alert-warning {
  background: var(--color-warning-bg);
  color: var(--color-warning-text);
  border: 1px solid var(--color-warning-border);
}

/* Panel de descargas — tabla */
.descargas-table-wrapper {
  overflow-x: auto;
  margin: 20px 0;
  border-radius: 12px;
}

.descargas-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-white);
}

.descargas-table thead tr {
  background: var(--color-table-header);
}

.descargas-table th,
.descargas-table td {
  text-align: left;
  padding: 10px;
  border: 1px solid var(--color-table-border);
}

.descargas-table tbody tr:hover {
  background-color: var(--color-secondary);
}

.descargas-form button,
.descargas-form input[type="submit"] {
  margin-top: 8px;
}

/* Responsive — tablet y mobile */
@media (max-width: 1024px) {

  .descargas-container,
  .descargas-container-wrapper {
    max-width: calc(100% - 40px);
    padding: 28px 24px;
  }
}

@media (max-width: 768px) {
  .descargas-form input[type="password"] {
    padding: 12px;
    font-size: 16px;
  }

  .descargas-table {
    font-size: 0.9rem;
  }

  .descargas-table th,
  .descargas-table td {
    padding: 8px;
  }

  .descargas-container,
  .descargas-container-wrapper {
    padding: 24px 18px;
    border-radius: 12px;
  }

}