/* Variables de diseño */
:root {
  --color-primario: #2c3e50;
  --color-secundario: #3498db;
  --color-acento: #27ae60;
  --color-fondo: #ecf0f1;
  --color-texto: #2c3e50;
  --color-border: #bdc3c7;
  --color-exito: #27ae60;
  --color-error: #e74c3c;
  --padding-base: 16px;
  --padding-grande: 24px;
  --border-radius: 8px;
  --sombra: 0 2px 8px rgba(0, 0, 0, 0.1);
  --transicion: all 0.3s ease;
}

/* Estilos generales */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html,
body {
  height: 100%;
}

body {
  font-family: "Segoe UI", Tahoma, Geneva, Verdana, sans-serif;
  background-color: var(--color-fondo);
  color: var(--color-texto);
  line-height: 1.6;
}

.contenedor {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--padding-grande);
}

/* Encabezado */
.encabezado {
  background: linear-gradient(135deg, var(--color-primario) 0%, var(--color-secundario) 100%);
  color: white;
  padding: var(--padding-grande);
  border-radius: var(--border-radius);
  margin-bottom: var(--padding-grande);
  box-shadow: var(--sombra);
  text-align: center;
}

.encabezado h1 {
  font-size: 2.5em;
  margin-bottom: 8px;
}

.encabezado p {
  font-size: 1.1em;
  opacity: 0.9;
}

/* Sección de búsqueda */
.seccion-busqueda {
  background: white;
  padding: var(--padding-grande);
  border-radius: var(--border-radius);
  margin-bottom: var(--padding-grande);
  box-shadow: var(--sombra);
}

.formulario-busqueda {
  display: flex;
  gap: 12px;
}

.grupo-busqueda {
  display: flex;
  gap: 8px;
  width: 100%;
}

.input-busqueda {
  flex: 1;
  padding: var(--padding-base);
  border: 2px solid var(--color-border);
  border-radius: var(--border-radius);
  font-size: 1em;
  transition: var(--transicion);
}

.input-busqueda:focus {
  outline: none;
  border-color: var(--color-secundario);
  box-shadow: 0 0 8px rgba(52, 152, 219, 0.3);
}

.btn-buscar,
.btn-limpiar {
  padding: var(--padding-base) var(--padding-grande);
  border: none;
  border-radius: var(--border-radius);
  font-size: 1em;
  cursor: pointer;
  transition: var(--transicion);
  font-weight: 600;
}

.btn-buscar {
  background-color: var(--color-secundario);
  color: white;
}

.btn-buscar:hover {
  background-color: #2980b9;
  box-shadow: var(--sombra);
}

.btn-limpiar {
  background-color: #95a5a6;
  color: white;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}

.btn-limpiar:hover {
  background-color: #7f8c8d;
}

/* Indicador de posición */
.indicador-posicion {
  text-align: center;
  padding: var(--padding-base);
  background-color: #f8f9fa;
  border-radius: var(--border-radius);
  margin-bottom: var(--padding-grande);
  border-left: 4px solid var(--color-secundario);
}

.indicador-posicion p {
  font-size: 1.1em;
  color: var(--color-texto);
}

.indicador-posicion strong {
  color: var(--color-secundario);
}

/* Contenido principal */
.contenido-principal {
  margin-bottom: var(--padding-grande);
}

.tarjeta-factura {
  background: white;
  border-radius: var(--border-radius);
  box-shadow: var(--sombra);
  overflow: hidden;
}

.seccion-encabezado-factura {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--padding-grande);
  background-color: #f8f9fa;
  border-bottom: 2px solid var(--color-border);
}

.seccion-encabezado-factura h2 {
  font-size: 1.8em;
  color: var(--color-primario);
  margin-bottom: 4px;
}

.subtitulo {
  color: #7f8c8d;
  font-size: 0.95em;
}

.total-factura {
  text-align: right;
}

.etiqueta-total {
  color: #95a5a6;
  font-size: 0.9em;
  margin-bottom: 4px;
}

.monto-total {
  font-size: 2em;
  font-weight: bold;
  color: var(--color-acento);
}

/* Grid de información */
.grid-informacion {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--padding-grande);
  padding: var(--padding-grande);
}

.columna {
  background-color: #f8f9fa;
  padding: var(--padding-base);
  border-radius: var(--border-radius);
  border-left: 4px solid var(--color-secundario);
}

.columna h3 {
  color: var(--color-primario);
  margin-bottom: 12px;
  font-size: 1.2em;
}

.campo-info {
  margin-bottom: 12px;
}

.campo-info label {
  display: block;
  font-size: 0.85em;
  color: #7f8c8d;
  margin-bottom: 4px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.campo-info span {
  display: block;
  font-size: 1em;
  color: var(--color-texto);
  word-break: break-word;
  padding: 6px;
  background-color: white;
  border-radius: 4px;
}

/* Sección PDF */
.seccion-pdf {
  padding: var(--padding-grande);
  background-color: #f8f9fa;
  border-top: 2px solid var(--color-border);
  text-align: center;
}

.btn-pdf {
  display: inline-block;
  padding: 12px 24px;
  background-color: var(--color-acento);
  color: white;
  text-decoration: none;
  border-radius: var(--border-radius);
  font-weight: 600;
  transition: var(--transicion);
  font-size: 1em;
}

.btn-pdf:hover {
  background-color: #229954;
  box-shadow: var(--sombra);
  transform: translateY(-2px);
}

/* Sin resultados */
.sin-resultados {
  text-align: center;
  padding: 60px var(--padding-grande);
  background: white;
  border-radius: var(--border-radius);
  color: #95a5a6;
  font-size: 1.2em;
  box-shadow: var(--sombra);
}

/* Navegación */
.navegacion {
  display: flex;
  gap: 8px;
  justify-content: center;
  flex-wrap: wrap;
  padding: var(--padding-grande);
  background: white;
  border-radius: var(--border-radius);
  box-shadow: var(--sombra);
}

.btn-nav {
  padding: 12px 20px;
  border: 2px solid var(--color-secundario);
  background-color: white;
  color: var(--color-secundario);
  text-decoration: none;
  border-radius: var(--border-radius);
  font-weight: 600;
  cursor: pointer;
  transition: var(--transicion);
  font-size: 1em;
}

.btn-nav:hover {
  background-color: var(--color-secundario);
  color: white;
  box-shadow: var(--sombra);
  transform: translateY(-2px);
}

.btn-primero,
.btn-ultimo {
  border-color: var(--color-primario);
  color: var(--color-primario);
}

.btn-primero:hover,
.btn-ultimo:hover {
  background-color: var(--color-primario);
  color: white;
}

/* Responsive */
@media (max-width: 768px) {
  .contenedor {
    padding: 12px;
  }

  .encabezado {
    padding: 16px;
  }

  .encabezado h1 {
    font-size: 1.8em;
  }

  .encabezado p {
    font-size: 0.95em;
  }

  .grupo-busqueda {
    flex-direction: column;
  }

  .input-busqueda,
  .btn-buscar,
  .btn-limpiar {
    width: 100%;
  }

  .seccion-encabezado-factura {
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }

  .total-factura {
    margin-top: 12px;
    text-align: left;
  }

  .grid-informacion {
    grid-template-columns: 1fr;
  }

  .monto-total {
    font-size: 1.5em;
  }

  .navegacion {
    flex-direction: column;
  }

  .btn-nav {
    width: 100%;
    text-align: center;
  }
}

@media (max-width: 480px) {
  .contenedor {
    padding: 8px;
  }

  .encabezado h1 {
    font-size: 1.5em;
  }

  .encabezado {
    margin-bottom: 12px;
  }

  .campo-info label {
    font-size: 0.75em;
  }

  .campo-info span {
    font-size: 0.9em;
  }
}
