
    /* ===========================
       HERO RECLUTAMIENTO
    =========================== */
    .lb-hero-reclutamiento {
      position: relative;
      min-height: 100vh;
      display: flex;
      align-items: center;
      background-image:
        linear-gradient(
          to right,
          rgba(5, 4, 59, 0.92) 0%,
          rgba(23, 18, 170, 0.78) 55%,
          rgba(23, 18, 170, 0.35) 100%
        ),
        url('../img//hero-bg.jpg');
      background-size: cover;
      background-position: center;
      background-attachment: fixed;
    }

    @media (max-width: 768px) {
      .lb-hero-reclutamiento { background-attachment: scroll; }
    }

    .hero-recl-inner {
      width: 90%;
      max-width: 1140px;
      margin: 0 auto;
      padding: 80px 0 60px;
    }

    .hero-recl-inner h1 {
      font-size: clamp(1.6rem, 3.5vw, 2.6rem);
      font-weight: 800;
      color: #fff;
      margin-bottom: 14px;
      line-height: 1.2;
    }

    .hero-recl-inner p {
      font-size: 1rem;
      color: rgba(255,255,255,0.80);
      max-width: 560px;
    }

    /* ===========================
       SECCIÓN PRINCIPAL TIMELINE
    =========================== */
    .recl-section {
      padding: 90px 0 110px;
      background: var(--gray-50);
    }

    .recl-section .container {
      position: relative;
    }

    /* Título de sección */
    .recl-title {
      text-align: center;
      margin-bottom: 72px;
    }

    .recl-title h2 {
      font-size: 2rem;
      font-weight: 800;
      color: var(--primary-dark);
      display: inline-block;
      position: relative;
    }

    .recl-title h2::after {
      content: '';
      display: block;
      width: 40px;
      height: 3px;
      background: var(--accent);
      margin: 12px auto 0;
      border-radius: 2px;
    }

    .recl-title p {
      margin-top: 16px;
      color: var(--text-muted);
      font-size: 0.97rem;
      max-width: 540px;
      margin-left: auto;
      margin-right: auto;
    }

    /* ===========================
       LÍNEA DE TIEMPO VERTICAL
    =========================== */
    .timeline {
      position: relative;
      max-width: 860px;
      margin: 0 auto;
    }

    /* La línea central */
    .timeline::before {
      content: '';
      position: absolute;
      left: 38px;
      top: 0;
      bottom: 0;
      width: 3px;
      background: linear-gradient(to bottom, var(--accent), var(--primary-dark));
      border-radius: 2px;
      opacity: 0.25;
    }

    /* Cada item de la timeline */
    .tl-item {
      display: flex;
      gap: 32px;
      margin-bottom: 48px;
      position: relative;
    }

    .tl-item:last-child {
      margin-bottom: 0;
    }

    /* Número / ícono lateral */
    .tl-num {
      flex-shrink: 0;
      width: 78px;
      display: flex;
      flex-direction: column;
      align-items: center;
      gap: 6px;
      position: relative;
      z-index: 1;
    }

    .tl-badge {
      width: 56px;
      height: 56px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1rem;
      font-weight: 800;
      letter-spacing: -0.02em;
      color: #fff;
      flex-shrink: 0;
      box-shadow: 0 4px 16px rgba(23,18,170,0.22);
      transition: transform 0.25s ease, box-shadow 0.25s ease;
    }

    .tl-item:hover .tl-badge {
      transform: scale(1.08);
      box-shadow: 0 8px 24px rgba(23,18,170,0.32);
    }

    /* Colores de badges por sección */
    .tl-badge-01 { background: var(--primary); }
    .tl-badge-02 { background: #2563EB; }
    .tl-badge-03 { background: #7C3AED; }
    .tl-badge-04 { background: #DC2626; }
    .tl-badge-05 { background: #D97706; }
    .tl-badge-06 { background: #059669; }
    .tl-badge-07 { background: #0891B2; }
    .tl-badge-alerta-normal   { background: #16a34a; }
    .tl-badge-alerta-atencion { background: #d97706; }
    .tl-badge-alerta-critico  { background: #dc2626; }

    /* Tarjeta del contenido */
    .tl-card {
      flex: 1;
      background: var(--light);
      border: 1px solid var(--gray-100);
      border-radius: var(--radius-lg);
      padding: 28px 30px 26px;
      box-shadow: var(--shadow-sm);
      transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
    }

    .tl-card:hover {
      transform: translateY(-3px);
      box-shadow: var(--shadow-md);
      border-color: rgba(76, 68, 255, 0.18);
    }

    .tl-card-header {
      display: flex;
      align-items: center;
      justify-content: space-between;
      margin-bottom: 18px;
      flex-wrap: wrap;
      gap: 10px;
    }

    .tl-card-title {
      font-size: 0.75rem;
      font-weight: 800;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--accent);
    }

    .tl-card h3 {
      font-size: 1.08rem;
      font-weight: 700;
      color: var(--primary-dark);
      margin: 0 0 14px;
    }

    /* ===========================
       BADGES DE ESTADO
    =========================== */
    .badge-estado {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 5px 12px;
      border-radius: 50px;
      font-size: 0.75rem;
      font-weight: 700;
      letter-spacing: 0.04em;
    }

    .badge-estado::before {
      content: '';
      width: 7px;
      height: 7px;
      border-radius: 50%;
      display: inline-block;
    }

    .badge-abierta    { background: #dcfce7; color: #15803d; }
    .badge-abierta::before { background: #22c55e; }
    .badge-en-proceso { background: #dbeafe; color: #1d4ed8; }
    .badge-en-proceso::before { background: #3b82f6; }
    .badge-finalistas { background: #fef9c3; color: #a16207; }
    .badge-finalistas::before { background: #eab308; }
    .badge-cerrada    { background: #fee2e2; color: #b91c1c; }
    .badge-cerrada::before { background: #ef4444; }

    /* ===========================
       MÉTRICAS NUMÉRICAS
    =========================== */
    .metric-row {
      display: flex;
      align-items: baseline;
      gap: 8px;
      margin-bottom: 6px;
    }

    .metric-val {
      font-size: 2.2rem;
      font-weight: 800;
      color: var(--primary-dark);
      line-height: 1;
    }

    .metric-label {
      font-size: 0.85rem;
      color: var(--text-muted);
      font-weight: 600;
    }

    .metric-note {
      font-size: 0.82rem;
      color: var(--text-muted);
      margin-top: 4px;
    }

    .metric-warn {
      color: #d97706;
      font-weight: 700;
    }

    .metric-ok {
      color: #16a34a;
      font-weight: 700;
    }

    /* ===========================
       PROGRESS BARS
    =========================== */
    .progress-list {
      display: flex;
      flex-direction: column;
      gap: 12px;
    }

    .progress-item {
      display: grid;
      grid-template-columns: 140px 1fr 42px;
      align-items: center;
      gap: 12px;
    }

    .progress-name {
      font-size: 0.82rem;
      font-weight: 600;
      color: var(--text);
    }

    .progress-track {
      background: var(--gray-100);
      border-radius: 99px;
      height: 8px;
      overflow: hidden;
    }

    .progress-fill {
      height: 100%;
      border-radius: 99px;
      background: linear-gradient(to right, var(--accent), var(--primary-mid));
      transition: width 1.2s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .progress-count {
      font-size: 0.85rem;
      font-weight: 700;
      color: var(--primary-dark);
      text-align: right;
    }

    /* ===========================
       BARRAS DE RECHAZO
    =========================== */
    .rechazo-list {
      display: flex;
      flex-direction: column;
      gap: 12px;
    }

    .rechazo-item {
      display: flex;
      flex-direction: column;
      gap: 5px;
    }

    .rechazo-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
    }

    .rechazo-name {
      font-size: 0.83rem;
      font-weight: 600;
      color: var(--text);
    }

    .rechazo-pct {
      font-size: 0.83rem;
      font-weight: 700;
      color: var(--primary-dark);
    }

    .rechazo-track {
      background: var(--gray-100);
      border-radius: 99px;
      height: 7px;
      overflow: hidden;
    }

    .rechazo-fill {
      height: 100%;
      border-radius: 99px;
    }

    .rechazo-fill.r1 { background: #dc2626; }
    .rechazo-fill.r2 { background: #d97706; }
    .rechazo-fill.r3 { background: #7c3aed; }
    .rechazo-fill.r4 { background: #6b7280; }

    /* ===========================
       COMPARATIVA SALARIAL
    =========================== */
    .salary-compare {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 16px;
      margin-bottom: 16px;
    }

    .salary-box {
      border-radius: var(--radius-md);
      padding: 18px 16px;
      text-align: center;
    }

    .salary-box.cliente {
      background: rgba(23, 18, 170, 0.07);
      border: 1.5px solid rgba(23, 18, 170, 0.14);
    }

    .salary-box.mercado {
      background: rgba(220, 38, 38, 0.06);
      border: 1.5px solid rgba(220, 38, 38, 0.18);
    }

    .salary-box-label {
      font-size: 0.72rem;
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      margin-bottom: 6px;
    }

    .salary-box.cliente .salary-box-label { color: var(--accent); }
    .salary-box.mercado .salary-box-label { color: #dc2626; }

    .salary-amount {
      font-size: 1.7rem;
      font-weight: 800;
      line-height: 1;
    }

    .salary-box.cliente .salary-amount { color: var(--primary-dark); }
    .salary-box.mercado .salary-amount { color: #dc2626; }

    .salary-diff {
      background: #fef3c7;
      border: 1px solid #fcd34d;
      border-radius: var(--radius-sm);
      padding: 9px 14px;
      display: flex;
      align-items: center;
      gap: 8px;
      font-size: 0.85rem;
      font-weight: 600;
      color: #92400e;
    }

    /* ===========================
       VELOCIDAD / INDICADOR
    =========================== */
    .speed-indicator {
      display: flex;
      align-items: center;
      gap: 20px;
      margin-bottom: 14px;
    }

    .speed-circle {
      width: 80px;
      height: 80px;
      border-radius: 50%;
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      border: 3px solid;
      flex-shrink: 0;
    }

    .speed-circle.warn {
      border-color: #f59e0b;
      background: #fffbeb;
    }

    .speed-circle.ok {
      border-color: #22c55e;
      background: #f0fdf4;
    }

    .speed-days {
      font-size: 1.5rem;
      font-weight: 800;
      line-height: 1;
    }

    .speed-circle.warn .speed-days { color: #d97706; }
    .speed-circle.ok .speed-days   { color: #16a34a; }

    .speed-unit {
      font-size: 0.68rem;
      font-weight: 600;
      color: var(--text-muted);
      text-transform: uppercase;
    }

    .speed-text h4 {
      font-size: 0.95rem;
      font-weight: 700;
      color: var(--primary-dark);
      margin-bottom: 5px;
    }

    .speed-text p {
      font-size: 0.83rem;
      color: var(--text-muted);
      line-height: 1.6;
    }

    /* ===========================
       CALIDAD DE PERFILES — donut simple
    =========================== */
    .quality-wrap {
      display: flex;
      align-items: center;
      gap: 28px;
    }

    .donut-wrap {
      position: relative;
      width: 90px;
      height: 90px;
      flex-shrink: 0;
    }

    .donut-wrap svg {
      width: 90px;
      height: 90px;
    }

    .donut-label {
      position: absolute;
      inset: 0;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 1.1rem;
      font-weight: 800;
      color: var(--primary-dark);
    }

    .quality-text h4 {
      font-size: 0.95rem;
      font-weight: 700;
      color: var(--primary-dark);
      margin-bottom: 5px;
    }

    .quality-text p {
      font-size: 0.83rem;
      color: var(--text-muted);
      line-height: 1.6;
    }

    /* ===========================
       ALERTA GENERAL
    =========================== */
    .alerta-card {
      border-radius: var(--radius-md);
      padding: 22px 24px;
      display: flex;
      align-items: flex-start;
      gap: 18px;
      border-width: 2px;
      border-style: solid;
    }

    .alerta-card.normal {
      background: #f0fdf4;
      border-color: #86efac;
    }

    .alerta-card.atencion {
      background: #fffbeb;
      border-color: #fcd34d;
    }

    .alerta-card.critico {
      background: #fef2f2;
      border-color: #fca5a5;
    }

    .alerta-icon {
      font-size: 2rem;
      line-height: 1;
      flex-shrink: 0;
    }

    .alerta-body h4 {
      font-size: 1rem;
      font-weight: 800;
      margin-bottom: 6px;
    }

    .alerta-card.normal h4    { color: #15803d; }
    .alerta-card.atencion h4  { color: #92400e; }
    .alerta-card.critico h4   { color: #b91c1c; }

    .alerta-body p {
      font-size: 0.85rem;
      line-height: 1.65;
      color: var(--text-muted);
    }

    .alerta-items {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
      margin-top: 12px;
    }

    .alerta-tag {
      padding: 4px 11px;
      border-radius: 50px;
      font-size: 0.75rem;
      font-weight: 700;
    }

    .alerta-card.normal   .alerta-tag { background: #dcfce7; color: #15803d; }
    .alerta-card.atencion .alerta-tag { background: #fef3c7; color: #92400e; }
    .alerta-card.critico  .alerta-tag { background: #fee2e2; color: #b91c1c; }

    /* ===========================
       NOTA EXTRA EN CARD
    =========================== */
    .tl-note {
      margin-top: 14px;
      padding: 10px 14px;
      background: var(--gray-50);
      border-left: 3px solid var(--accent);
      border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
      font-size: 0.8rem;
      color: var(--text-muted);
      line-height: 1.6;
    }

    .tl-note strong {
      color: var(--primary-dark);
    }

    /* ===========================
       RESPONSIVO
    =========================== */
    @media (max-width: 600px) {
      .timeline::before { left: 26px; }

      .tl-item { gap: 16px; }

      .tl-num { width: 52px; }

      .tl-badge {
        width: 44px;
        height: 44px;
        font-size: 0.85rem;
      }

      .tl-card { padding: 20px 18px; }

      .salary-compare { grid-template-columns: 1fr; }

      .progress-item { grid-template-columns: 110px 1fr 36px; }

      .quality-wrap { flex-direction: column; align-items: flex-start; gap: 16px; }
    }

    /* =============================
       SECCIÓN INSIGHT / QR
    ============================= */
    .sel-insight {
      padding: 96px 0;
      background: var(--primary-dark);
      position: relative;
      overflow: hidden;
    }

    /* Patrón de fondo decorativo */
    .sel-insight::before {
      content: '';
      position: absolute;
      top: 0; left: 0; right: 0; bottom: 0;
      background-image:
        radial-gradient(circle at 20% 50%, rgba(76,68,255,0.18) 0%, transparent 50%),
        radial-gradient(circle at 80% 20%, rgba(76,68,255,0.12) 0%, transparent 40%);
      pointer-events: none;
    }

    .sel-insight-grid {
      display: grid;
      grid-template-columns: 1fr 420px;
      gap: 72px;
      align-items: center;
      position: relative;
      z-index: 1;
    }

    .sel-insight-text .eyebrow {
      display: inline-block;
      font-size: 0.72rem;
      font-weight: 800;
      letter-spacing: 0.15em;
      text-transform: uppercase;
      color: var(--accent);
      margin-bottom: 16px;
    }

    .sel-insight-text h2 {
      font-size: clamp(1.5rem, 2.8vw, 2.1rem);
      font-weight: 800;
      color: #fff;
      line-height: 1.22;
      margin-bottom: 20px;
    }

    .sel-insight-text p {
      font-size: 0.97rem;
      color: rgba(255,255,255,0.72);
      line-height: 1.85;
      margin-bottom: 14px;
    }

    /* Pills de beneficios */
    .insight-pills {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      margin-top: 28px;
    }

    .insight-pill {
      display: inline-flex;
      align-items: center;
      gap: 6px;
      padding: 7px 14px;
      background: rgba(255,255,255,0.08);
      border: 1px solid rgba(255,255,255,0.15);
      border-radius: 50px;
      font-size: 0.78rem;
      font-weight: 600;
      color: rgba(255,255,255,0.85);
    }

    /* Tarjeta QR */
    .sel-qr-card {
      background: #fff;
      border-radius: var(--radius-lg);
      padding: 40px 36px;
      text-align: center;
      box-shadow: 0 24px 60px rgba(0,0,0,0.35);
    }

    .sel-qr-card .qr-eyebrow {
      font-size: 0.7rem;
      font-weight: 800;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--text-muted);
      margin-bottom: 20px;
    }

   

    

    

    @media (max-width: 900px) {
      .sel-insight-grid { grid-template-columns: 1fr; gap: 48px; }
      .sel-qr-card { max-width: 420px; }
    }