/* ============================================================
   FORMULARIO PAISSANA — HOJA DE ESTILOS
   Paleta de marca:
   #020659 (azul primario) · #010440 (azul profundo)
   #012340 (azul petróleo) · #032F40 (azul verdoso) · #FFFFFF
   ============================================================ */

:root {
  --azul-primario: #020659;
  --azul-profundo: #010440;
  --azul-petroleo: #012340;
  --azul-verdoso:  #032F40;
  --blanco:        #FFFFFF;

  /* Tintes derivados de la paleta (transparencias sobre blanco) */
  --tinte-suave:   rgba(1, 35, 64, 0.04);
  --tinte-medio:   rgba(1, 35, 64, 0.08);
  --borde:         rgba(1, 35, 64, 0.22);
  --borde-suave:   rgba(1, 35, 64, 0.12);
  --texto:         #012340;
  --texto-suave:   rgba(1, 35, 64, 0.68);

  --radio: 10px;
  --sombra: 0 2px 10px rgba(1, 4, 64, 0.08);
}

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

html { scroll-behavior: smooth; }

body {
  font-family: "Segoe UI", Roboto, Arial, sans-serif;
  background: var(--blanco);
  color: var(--texto);
  line-height: 1.55;
  font-size: 16px;
}

/* ===================== BARRA DE PROGRESO ===================== */
.indicador-progreso {
  position: fixed; top: 0; left: 0; width: 100%; height: 4px;
  background: var(--tinte-medio); z-index: 3000;
}
.barra-progreso {
  height: 100%; width: 0;
  background: linear-gradient(90deg, var(--azul-primario), var(--azul-verdoso));
  transition: width .15s ease-out;
}

/* ===================== CONTENEDOR Y ENCABEZADO ===================== */
.container { max-width: 880px; margin: 0 auto; padding: 28px 20px 80px; }

.header {
  background: var(--blanco);
  border: 1px solid var(--borde-suave);
  border-top: 6px solid var(--azul-primario);
  border-radius: var(--radio);
  box-shadow: var(--sombra);
  padding: 28px 32px 26px;
  text-align: center;
}
.header .logo-marca {
  max-width: 380px; width: 80%; height: auto;
  display: block; margin: 0 auto 18px;
}
.header h1 {
  color: var(--azul-profundo);
  font-size: 1.55rem;
  letter-spacing: .2px;
  margin-bottom: 8px;
}
.header .subtitle {
  color: var(--texto-suave);
  font-size: .95rem;
  max-width: 640px;
  margin: 0 auto;
}

/* ===================== NAVEGADOR DE SECCIONES ===================== */
.navegador-secciones {
  position: sticky; top: 10px; z-index: 1500;
  background: var(--azul-profundo);
  border-radius: var(--radio);
  box-shadow: var(--sombra);
  margin: 18px 0 26px;
  padding: 8px 10px;
}
.navegador-secciones ul {
  list-style: none;
  display: flex; flex-wrap: wrap; gap: 6px; justify-content: center;
}
.navegador-secciones a {
  display: inline-block;
  color: var(--blanco);
  text-decoration: none;
  font-size: .78rem;
  font-weight: 600;
  padding: 5px 11px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.25);
  transition: background .2s, color .2s;
}
.navegador-secciones a:hover,
.navegador-secciones a:focus-visible {
  background: var(--blanco);
  color: var(--azul-profundo);
  outline: none;
}

/* ===================== SECCIONES ===================== */
.section {
  background: var(--blanco);
  border: 1px solid var(--borde-suave);
  border-radius: var(--radio);
  box-shadow: var(--sombra);
  padding: 26px 30px 30px;
  margin-bottom: 26px;
}
.section legend {
  background: var(--azul-petroleo);
  color: var(--blanco);
  font-weight: 700;
  font-size: .98rem;
  letter-spacing: .3px;
  padding: 9px 18px;
  border-radius: 8px;
  margin-bottom: 6px;
}
.section-desc {
  color: var(--texto-suave);
  font-size: .9rem;
  margin: 6px 2px 18px;
}

/* ===================== CAMPOS ===================== */
.form-group { margin-bottom: 22px; }
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}
@media (max-width: 640px) {
  .form-row { grid-template-columns: 1fr; }
}

.form-label {
  display: block;
  font-weight: 600;
  color: var(--azul-profundo);
  margin-bottom: 8px;
  font-size: .95rem;
}
.req { color: var(--azul-primario); font-weight: 800; }

.help-text {
  font-size: .82rem;
  color: var(--texto-suave);
  margin-top: 6px;
}

.form-input, .form-select, .form-textarea {
  width: 100%;
  padding: 10px 13px;
  border: 1.5px solid var(--borde);
  border-radius: 8px;
  font-size: .95rem;
  font-family: inherit;
  color: var(--texto);
  background: var(--blanco);
  transition: border-color .2s, box-shadow .2s;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  outline: none;
  border-color: var(--azul-primario);
  box-shadow: 0 0 0 3px rgba(2, 6, 89, 0.12);
}
.form-input[readonly] { background: var(--tinte-suave); }
.form-textarea { resize: vertical; min-height: 80px; }

/* Radios y checkboxes */
.radio-group, .check-group {
  display: flex; flex-direction: column; gap: 8px;
}
.radio-option, .check-option {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 9px 13px;
  border: 1.5px solid var(--borde-suave);
  border-radius: 8px;
  cursor: pointer;
  font-size: .93rem;
  transition: background .15s, border-color .15s;
  background: var(--blanco);
}
.radio-option:hover, .check-option:hover { background: var(--tinte-suave); }
.radio-option input, .check-option input {
  margin-top: 3px;
  accent-color: var(--azul-primario);
  flex-shrink: 0;
}
.opcion-desc { display: block; font-weight: 400; color: var(--texto-suave); font-size: .85rem; }

.grupo-subtitulo {
  font-size: .82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--azul-verdoso);
  margin: 10px 0 4px;
}

/* Adjuntos */
.file-group {
  background: var(--tinte-suave);
  border: 1.5px dashed var(--borde);
  border-radius: 8px;
  padding: 14px 16px;
  margin-bottom: 12px;
}
.file-label {
  display: block;
  font-weight: 600;
  font-size: .88rem;
  color: var(--azul-petroleo);
  margin-bottom: 8px;
}
.form-file { font-size: .85rem; color: var(--texto); max-width: 100%; }

/* Condicionales */
.conditional-section {
  display: none;
  margin-top: 14px;
  padding: 16px 18px;
  background: var(--tinte-suave);
  border-left: 4px solid var(--azul-primario);
  border-radius: 0 8px 8px 0;
}

/* Mensajes de validación */
.error-message {
  color: #8a1f1f;
  font-size: .82rem;
  margin-top: 5px;
  font-weight: 600;
}
.input-error { border-color: #8a1f1f !important; }

/* ===================== BOTONES ===================== */
.btn-primary, .btn-secondary, .btn-ghost {
  font-family: inherit;
  font-weight: 700;
  font-size: .95rem;
  border-radius: 8px;
  padding: 12px 26px;
  cursor: pointer;
  transition: background .2s, color .2s, transform .1s;
  border: 2px solid transparent;
}
.btn-primary {
  background: var(--azul-primario);
  color: var(--blanco);
}
.btn-primary:hover { background: var(--azul-profundo); }
.btn-secondary {
  background: var(--blanco);
  color: var(--azul-primario);
  border-color: var(--azul-primario);
}
.btn-secondary:hover { background: var(--azul-primario); color: var(--blanco); }
.btn-ghost {
  background: transparent;
  color: var(--azul-verdoso);
  border-color: var(--borde);
  font-weight: 600;
  padding: 9px 18px;
}
.btn-ghost:hover { background: var(--tinte-medio); }
.btn-primary:active, .btn-secondary:active, .btn-ghost:active { transform: scale(.98); }

.acciones-finales {
  display: flex; flex-wrap: wrap; gap: 14px; justify-content: center;
  margin-top: 10px;
}

/* ============================================================
   BLOQUE DE PRODUCTOS Y SERVICIOS (PREGUNTAS 33–47)
   ============================================================ */
.editor-oferta {
  border: 2px solid var(--azul-petroleo);
  border-radius: var(--radio);
  padding: 22px 24px;
  margin-top: 6px;
  background: var(--blanco);
}
.editor-oferta-titulo {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; flex-wrap: wrap;
  margin-bottom: 18px;
}
.editor-oferta-titulo h3 {
  color: var(--azul-petroleo);
  font-size: 1.02rem;
}
.badge-tipo {
  display: inline-block;
  background: var(--azul-verdoso);
  color: var(--blanco);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .5px;
  padding: 4px 12px;
  border-radius: 999px;
  text-transform: uppercase;
}
.bloque-rama { display: none; }
.bloque-rama.activo { display: block; }

.acciones-oferta {
  display: flex; flex-wrap: wrap; gap: 12px;
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--borde-suave);
}

/* Tabla resumen tipo Excel */
.resumen-ofertas { margin-top: 28px; }
.resumen-ofertas h3 {
  color: var(--azul-profundo);
  font-size: 1rem;
  margin-bottom: 10px;
}
.tabla-contenedor {
  overflow-x: auto;
  border: 1px solid var(--borde);
  border-radius: 8px;
}
.tabla-ofertas {
  width: 100%;
  border-collapse: collapse;
  font-size: .87rem;
  min-width: 720px;
  background: var(--blanco);
}
.tabla-ofertas thead th {
  background: var(--azul-profundo);
  color: var(--blanco);
  font-weight: 700;
  text-align: left;
  padding: 10px 12px;
  white-space: nowrap;
  border-right: 1px solid rgba(255,255,255,.15);
}
.tabla-ofertas tbody td {
  padding: 9px 12px;
  border-bottom: 1px solid var(--borde-suave);
  border-right: 1px solid var(--borde-suave);
  vertical-align: top;
}
.tabla-ofertas tbody tr:nth-child(even) { background: var(--tinte-suave); }
.tabla-ofertas tbody tr:hover { background: var(--tinte-medio); }
.tabla-ofertas .celda-num {
  font-weight: 700;
  color: var(--azul-primario);
  text-align: center;
}
.tabla-ofertas .fila-vacia td {
  text-align: center;
  color: var(--texto-suave);
  font-style: italic;
  padding: 18px;
}
.chip-oferta {
  display: inline-block;
  font-size: .73rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 999px;
  color: var(--blanco);
  white-space: nowrap;
}
.chip-producto { background: var(--azul-primario); }
.chip-servicio { background: var(--azul-verdoso); }

.btn-mini {
  background: transparent;
  border: 1.5px solid var(--borde);
  border-radius: 6px;
  color: var(--azul-petroleo);
  font-size: .78rem;
  font-weight: 700;
  padding: 4px 10px;
  cursor: pointer;
  margin-right: 6px;
}
.btn-mini:hover { background: var(--azul-petroleo); color: var(--blanco); }

/* Texto legal de autorizaciones */
.texto-legal {
  background: var(--tinte-suave);
  border: 1px solid var(--borde-suave);
  border-radius: 8px;
  padding: 16px 18px;
  font-size: .85rem;
  color: var(--texto);
  text-align: justify;
  max-height: 220px;
  overflow-y: auto;
  margin-bottom: 12px;
}
.nota-legal {
  font-size: .82rem;
  color: var(--texto-suave);
  font-style: italic;
  margin-bottom: 12px;
}

/* Notificaciones */
@keyframes slideIn {
  from { transform: translateX(40px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}

/* Pie de página */
.footer-form {
  text-align: center;
  color: var(--texto-suave);
  font-size: .8rem;
  margin-top: 30px;
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; animation: none !important; }
}

@media (max-width: 640px) {
  .container { padding: 18px 12px 60px; }
  .section { padding: 20px 16px 24px; }
  .header { padding: 22px 16px; }
  .header h1 { font-size: 1.25rem; }
}
