@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&family=Raleway:ital,wght@0,100..900;1,100..900&display=swap');
:root{
  --primaryBlue:#004AAD;
  --primaryYellow:#FEB814;
  --white:#FFFFFF;
  --secondaryBlue:#163D64;
  --darkBlue:rgba(22, 61, 100, 1);
  --primaryBlue10:#004AAD1A;
  --primaryGradient:linear-gradient(90deg, #2F65E5 0%, #8B4FEA 100%);
  --primaryPurple:#5C5BE8;
  --darkGray:#373737;
  --primaryGreen:#24A479;
  --primaryRed:#DC4F4F;
  --lightBlue:#0B8DD4;
  --lightGray:#E0E0E0;
  --black:#000000;
  --gray:#A1A1A1;
  --white-30:#FFFFFF4D;
  --background:#F6F9FF;
  --poppins:"Poppins", sans-serif;
  --raleway:"Raleway", sans-serif;
  --small:#808080;
  --gray600:#5F6C72;
  --graySecondary:#EFEFEF;
  --grayText:#878787;
}

.bg-primary{
  background: var(--primaryBlue) !important;
}
.title-bold{
  font-size: 16px;
  font-weight: 500;
  line-height: 20px;
  margin-bottom: 0;
}
html {
  font-size: 14px;
}
@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

body{
  font-family: var(--poppins);
}
.navbar{
  padding: 0;
  padding-inline: 60px;
  padding-right: 7rem;
  box-shadow: 0px 0px 19.3px 0px rgba(0, 74, 173, 0.5);

}

.logo-navbar{
  width: 94px;
}

.nav-link{
  font-weight: 500;
  font-size: 16px;
  color: var(--primaryBlue) !important;
}

.btn{
  border-radius: 35px;
  padding: 13px 29px;
  font-size: 14px;
  font-weight: 600;
  transition: 0.5s all ease-in-out;
}

.btn-primary{
  background: var(--primaryBlue);
  color: var(--white);
  border: none;
}
.btn-primary:hover{
  background: var(--secondaryBlue);
}
.btn-secondary{
  background: var(--white);
  border: 1px solid var(--primaryBlue);
  color: var(--primaryBlue);
}

.btn-secondary:hover{
  background: var(--background);
  color: var(--secondaryBlue);
}

body{
  background: var(--background);
}

.navbar-transparent{
  background: transparent;
  box-shadow: none;
}

.navbar-transparent .nav-link{
  color: var(--white) !important;
}

.banner-main {
  position: relative;
  padding-top: 0px;
  background: var(--primaryGradient);
}

.banner-main::before {
  content: "";
  position: absolute;
  inset: 0;
  top: -130px; 
  background: var(--primaryGradient);
  z-index: -1;
}

.welcome-text{
  font-weight: 700;
  font-size: 52px;
  color: var(--white);
}

.logo-xl{
  width: 130px;
}
.banner-img{
  width: 100%;
  position: relative;
  z-index: 2;
}
.sectores{
  position: relative;
  margin-bottom: 3rem;
}

.sectores::after{
  content: '';
  width: 100%;
  height: 52px;
  position: absolute;
  background: var(--background);
  top: -52px;
  left: 0;
  z-index: 1;
}


.container-cards{
  padding-inline: 3rem;
}


.title-section{
  font-size: 64px;
  font-weight: 700;
  color: var(--primaryBlue);
  text-transform: uppercase;
}
.card-home{
  width: 80%;
  background: var(--primaryBlue10);
  border-radius: 10px;
  border: 1px solid var(--primaryBlue);
  text-align: center;  
  display: flex;
  align-items: center;
  padding-block: 1rem;
  margin-bottom: 3rem;
}

.card-home-title{
  font-size: 18px;
  font-weight: 700;
  color: var(--primaryBlue);
  text-decoration: none;
  margin-bottom: 0;
  position: relative;
}

.card-home-title::after{
  content: '>';
  color: var(--primaryBlue);
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translate(0, -50%);
}

a{
  text-decoration: none;
}

.container-cards{
  display: flex;
  justify-content: space-between;
}

.proceso{
  background: var(--primaryPurple);
  padding-block: 3rem;  
}

.step{
  text-align: center;
  color: var(--white);
}

.step i{
  font-size: 30px;
  position: relative;

}

.step i::after{
  content: '';
  width: 90px;
  height: 90px;
  background: var(--white-30);
  position: absolute;
  top: -50%;
  left: 50%;
  transform: translate(-50%, 0%) rotateZ(45deg);
  transform:rotateY('90deg');
  border-radius: 25px;
}

.title-step{
  margin-top: 4rem;
}

.step{
  position: relative;
}

.step::after{
  content: '';
  width: 70%;
  height: 50%;
  border-radius: 50%;
  border: 2px dotted var(--white);
  border-bottom: none;
  border-left: none;
  border-right: none;
  position: absolute;
  top: 0%;
  right: -55%;
}

.step::before{
  content: '▼';
  color: var(--white);
  position: absolute;
  top: 10%;
  right: -55%;
  transform: rotateZ(292deg);
}
.step.step-final::after, .step.step-final::before{
  display: none;
}

.subtitle-section{
  font-size: 32px;
  font-weight: 600;
  margin-bottom: 2rem;
}

.title-step{
  font-size: 18px;
  font-weight: 500;

}

.subtitle-step{
  font-size: 14px;
  font-weight: 400;
  line-height: 28px;
  font-family: var(--raleway);
  
}
.ubicaciones{
  padding-block: 3rem;
}

.container-cards .col-md-3{
  display: flex;
  justify-content: center;
}

.welcome-sm{
  font-size: 18px;
  color: var(--white);
  font-weight: 400;
  margin-bottom: 2rem;
}
.input-filters{
  margin-bottom: 2rem;
}

.input-filters input{
  border-radius: 25px;
}

.input-filters input:focus{
  box-shadow: none;
}

.rol-input{
  background-image: url('../svg/buscar.svg');   /* tu icono */
  background-repeat: no-repeat;
  background-position: 10px center;
  background-size: 18px;
}


.estado-input{
  background-image: url('../svg/ubicacion.svg');   /* tu icono */
  background-repeat: no-repeat;
  background-position: 10px center;
  background-size: 18px;

}

.rol-input, .estado-input{
  padding-block: 1rem;
  padding-left: 2rem;
}

.img-btn{
  width: 20px;
  margin-right: 5px;
}

.btn-terciary{
  border: 1px solid var(--primaryPurple);
  color: var(--primaryPurple);
}

.card{
  border: 1px solid var(--lightGray);
  border-radius: 15px;
  padding: 1.5rem 1rem;
}

.title-auth{
  font-size: 36px;
  font-weight: 600;
  margin-bottom: 1rem;
}

.text-auth{
  font-size: 16px;
  font-weight: 400;
  line-height: 30px;
}

.text-auth b{
  font-size: 18px;
  font-weight: 600;
}

.form-control, .form-select{
  border-radius: 20px;
}

label{
  margin-bottom: 0.5rem;
  font-size: 16px;
  font-weight: 700;
}
.label-thin{
  font-weight: 400;
}
small{
  font-size: 10px;
  color: var(--small);
}


.hr-signup{
  position: relative;
  margin-bottom: 0;
  margin-top: 1rem;
}
.signup-hr{
  position: absolute;
  top: 4px;
  right: 50%;
  background: var(--background);
  padding-inline: 1rem;
  transform: translate(50%,0%);
  font-size: 16px;
  margin-bottom: 0;
}

.title-recover{
  font-size: 20px;
  font-weight: 600;
}
.text-recover{
  font-size: 14px;
  color: var(--small);
}
.link-recover{
  color: var(--gray600);
  font-size: 14px;
}
.card-shadow{
  border: 1px solid rgba(228, 231, 233, 1);
  box-shadow: 0px 8px 40px 0px rgba(0, 0, 0, 0.12);
  margin-top: 3rem;
}

.card.card-sm{
  padding: 0;
  margin-top: 1rem;
}

.flex{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.flex-end{
  display: flex;
  justify-content: end;
}

.icon-job{
  display: flex;
  gap: 5px;
}
.etiqueta{
  font-size: 13px;
  padding: 3px 12px;
  border-radius: 20px;
  background: var(--graySecondary);
  width: fit-content;
  color: var(--grayText);
  margin-bottom: 5px;
}

.title-job{
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 0;
}

.title-empresa{
  font-size: 16px;
}

.icon-job{
  font-size: 13px;
  color: var(--darkBlue);
}

.postulado{
  background: var(--primaryBlue);
  color: var(--white);
}

.subtitle-icon{
  margin-bottom: 5px;
}
.favorite{
  color: var(--primaryYellow);
  font-size: 20px;
}

.btn-secondary.dropdown-toggle{
  font-size: 13px;
  padding: 7px 20px;
  font-weight: 400;
}

.btn-secondary.dropdown-toggle:focus{
  background: var(--white);
  color: var(--primaryBlue);
}

.btn-disabled{
  padding: 7px 20px;
  font-size: 13px;
  background: var(--lightGray);
  color: var(--gray);
}

.img-job{
  width: 100%;
  object-fit: cover;
  border-radius: 10px;
}

.grid{
  display: grid;
  align-items: center;
  align-content: space-between;
}

.flex-gap{
  display: flex;
  gap: 1.5rem;
}

.icon-job-group .subtitle-job, .subtitle-job{
  font-size: 13px;
  color: var(--gray);
  text-align: justify;
  margin-bottom: 0;
}

.subtitle{
  font-size: 18px;
  font-weight: 700;
  line-height: 30px;
  margin-top: 2rem;
}

.text{
  font-size: 16px;
  font-weight: 400;
  line-height: 30px;
}

.job-description{
  padding-inline: 3rem;
}

.title-busqueda{
  position: relative;
  font-size: 12px;
  font-weight: 500;
}

.title-busqueda::after{
  content: '';
  position: absolute;
  height: 3px;
  width:168px;
  background: var(--primaryGradient);
  bottom: -10px;
  left: 0;
}

a.dropdown-item{
  font-size: 13px;
  color: var(--primaryBlue);
}
a.dropdown-item p{
  margin-bottom: 0;
}
.dropdown-menu{
  border: 1px solid var(--primaryBlue);
  border-radius: 10px;
  padding: 5px 10px;
}

.dropdown-item:focus, .dropdown-item:hover{
  background: var(--primaryBlue10);
  color: var(--primaryBlue);
  border-radius: 15px;
}

.requiered, .optional{
  position: relative;
}

.requiered::after{
  content: '*';
  color: var(--primaryRed);
  font-size: 18px;
}

.optional::after{
  content: '(Opcional)';
  color: var(--gray);
  font-size: 12px;
  font-weight: 400;
  margin-left: 5px;
}

textarea{
  resize: none;
}

.accordion-button{
  font-size: 18px;
  font-weight: 600;
  color: var(--primaryBlue);
  padding: 1.5rem 2rem;
  border-radius: 15px !important;
}
.accordion-item{
  border-radius: 15px !important;
  margin-bottom: 1rem;
}
.accordion-item:first-of-type .accordion-butto{
  border-radius: 15px !important;
}
.accordion-item:last-of-type .accordion-button{
  border-radius: 15px !important;
  border-top: 1px solid rgba(0,0,0,.125);
}

.accordion-button:not(.collapsed){
  background: var(--white);
  color: var(--primaryBlue);
  box-shadow: none;
}

.accordion-button:focus{
  box-shadow: none;
}
.form-check-input[type=checkbox]{
  border-radius: 50%;
}


.btn-more{
  padding: 1px 5px;
  border: 2px solid var(--darkBlue);
  color: var(--darkBlue);
  font-size: 16px;

}

.text-primary{
  color: var(--primaryBlue) !important;
}

.title-back{
  position: relative;
}
.back{
  position: absolute;
  top: 20%;
  left: 0;
  margin-bottom: 0;
  font-size: 16px;
  color: var(--primaryBlue);
}

.text-dark{
  color: var(--darkBlue) !important;
}

.title-metrica{
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 0rem;
  margin-top: 1rem;
}

.title-profile{
  font-size: 18px;
  font-weight: 600;
  color: var(--primaryBlue);
}
.text-gray{
  color: var(--gray);
}

.text-sm{
  font-size: 13px;
  line-height: 20px;
}
.text-secondary{
  color: var(--lightBlue) !important;
}

.nav-tabs{
  border-bottom: 0;
  justify-content: center;
}
.nav-tabs .nav-link{
  border: none;
  margin-bottom: 1rem;
}
.nav-tabs .nav-item .nav-link{
  color: var(--black) !important;
  font-size: 13px;
  font-weight: 400;
  position: relative;
}
.nav-tabs .nav-item .nav-link::after{
    content: '';
  position: absolute;
  height: 3px;
  width: 80%;
  background: var(--gray);
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 0%);
}
.nav-tabs .nav-item .nav-link.active{
  background: transparent;
  border: none;
}

.nav-tabs .nav-item .nav-link.active::after{
  content: '';
  position: absolute;
  height: 3px;
  width: 80%;
  background: var(--primaryGradient);
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 0%);
}

.form-switch .form-check-input[type=checkbox]{
  border-radius: 15px;
  width: 6rem;
  height: 2rem;
}
.form-switch .form-check-input:focus{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='16' viewBox='0 0 30 16'%3E%3Crect x='1' y='1' width='28' height='14' rx='7' fill='rgba(0,0,0,0.25)'/%3E%3Ctext x='50%25' y='50%25' font-size='8' fill='%23ffffff' font-family='Arial' dominant-baseline='middle' text-anchor='middle'%3ENo%3C/text%3E%3C/svg%3E");
  
}
.form-switch .form-check-input{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='16' viewBox='0 0 30 16'%3E%3Crect x='1' y='1' width='28' height='14' rx='7' fill='rgba(0,0,0,0.25)'/%3E%3Ctext x='50%25' y='50%25' font-size='8' fill='%23ffffff' font-family='Arial' dominant-baseline='middle' text-anchor='middle'%3ENo%3C/text%3E%3C/svg%3E");

}
.form-switch .form-check-input:checked{
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='16' viewBox='0 0 30 16'%3E%3Crect x='1' y='1' width='28' height='14' rx='7' fill='%23ffffff'/%3E%3Ctext x='50%25' y='50%25' font-size='8' fill='%23004AAD' font-family='Arial' dominant-baseline='middle' text-anchor='middle'%3ES%C3%AD%3C/text%3E%3C/svg%3E");
  background-color: var(--primaryBlue);
}

.nav-pills{
  justify-content: center;
  gap: 2rem;
}
.nav-pills .nav-item .nav-link{
  background: var(--white);
  color: var(--primaryBlue);
  border-radius: 35px;
  border: 1px solid var(--primaryBlue);
  font-size: 14px;
}

.nav-pills .nav-item .nav-link.active{
  background: var(--primaryBlue);
  color: var(--white) !important;
}

.btn-dropdown{
  background: transparent;
  padding: 0;
  margin: 0;
}

.nav-item.dropdown{
  display: flex;
  align-items: center;
}

.file-uploader {
  border: 1px dashed #ccc;
  border-radius: 20px;
  padding: 10px 15px;
  text-align: center;
  cursor: pointer;
  transition: .2s;
  position: relative;
}

.file-uploader input {
  display: none;
}

.file-uploader.dragover {
  border-color: var(--primaryBlue);
  background: #f4f8ff;
}

.file-uploader label {
  font-size: 12px;
  font-weight: 400;
  color: var(--small);
}

.file-uploader .link {
  color: var(--lightBlue);
  font-weight: 400;
}

.file-uploader .file-name {
  margin-top: 0;
  font-size: 12px;
  color: #333;
  font-weight: 500;
  margin-bottom: 0;
}

.file-uploader small{
  margin-bottom: 0;
}

.empresa-detalle{
  margin-top: 1rem;
}

.img-job{
  max-width:80px;
  max-height: 80px;
  object-fit: cover;

}

.badge-destacado{
  margin-block: 1rem;
}

/* ==========================================================
   Corporate redesign 2026
   ========================================================== */
:root {
  --primaryBlue: #0f2a43;
  --secondaryBlue: #164b63;
  --darkBlue: #0a1828;
  --primaryYellow: #d5a84f;
  --primaryPurple: #16a3b8;
  --primaryGradient: linear-gradient(135deg, #0a1828 0%, #123b5a 48%, #0f766e 100%);
  --primaryBlue10: rgba(15, 42, 67, 0.08);
  --background: #eef3f7;
  --white: #ffffff;
  --lightGray: #d8e2ea;
  --gray: #718198;
  --gray600: #46586d;
  --graySecondary: #edf2f6;
  --grayText: #5b6b7f;
  --primaryGreen: #0f9f7a;
  --primaryRed: #b42339;
  --lightBlue: #0ea5b7;
  --surface: rgba(255, 255, 255, 0.88);
  --surfaceStrong: #ffffff;
  --borderSoft: rgba(15, 42, 67, 0.12);
  --shadowSoft: 0 18px 50px rgba(10, 24, 40, 0.10);
  --shadowCard: 0 14px 36px rgba(10, 24, 40, 0.12);
  --shadowHover: 0 22px 60px rgba(10, 24, 40, 0.18);
}

html {
  background: #eef3f7;
}

body {
  min-height: 100vh;
  color: var(--darkBlue);
  background:
    radial-gradient(circle at top left, rgba(14, 165, 183, 0.18), transparent 34rem),
    linear-gradient(180deg, #f8fbfd 0%, #eef3f7 42%, #e8eef4 100%) !important;
  letter-spacing: -0.01em;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(15, 42, 67, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(15, 42, 67, 0.035) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.65), transparent 65%);
  z-index: -1;
}

.navbar {
  min-height: 78px;
  padding: 0.75rem clamp(1rem, 5vw, 4.5rem) !important;
  background: rgba(255, 255, 255, 0.86) !important;
  border-bottom: 1px solid rgba(15, 42, 67, 0.08);
  box-shadow: 0 12px 36px rgba(10, 24, 40, 0.08) !important;
  backdrop-filter: blur(18px);
}

.navbar-transparent {
  background: rgba(10, 24, 40, 0.22) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: none !important;
}

.navbar .nav-link {
  color: var(--primaryBlue) !important;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.02em;
  padding-inline: 0.9rem !important;
}

.navbar-transparent .nav-link {
  color: rgba(255, 255, 255, 0.92) !important;
}

.navbar .nav-link:hover,
.navbar .nav-link:focus {
  color: var(--lightBlue) !important;
}

.logo-navbar {
  width: 106px;
  filter: drop-shadow(0 8px 18px rgba(10, 24, 40, 0.12));
}

.btn {
  border-radius: 999px !important;
  font-weight: 800 !important;
  letter-spacing: -0.015em;
  box-shadow: none;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease !important;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn-primary {
  color: #fff !important;
  border: 0 !important;
  background: linear-gradient(135deg, #0f766e 0%, #0e7490 46%, #0f2a43 100%) !important;
  box-shadow: 0 14px 26px rgba(14, 116, 144, 0.28) !important;
}

.btn-primary:hover,
.btn-primary:focus {
  background: linear-gradient(135deg, #0d9488 0%, #0891b2 48%, #123b5a 100%) !important;
  box-shadow: 0 18px 34px rgba(14, 116, 144, 0.36) !important;
}

.btn-secondary,
.btn-outline-secondary {
  color: var(--primaryBlue) !important;
  border: 1px solid rgba(15, 42, 67, 0.18) !important;
  background: rgba(255, 255, 255, 0.74) !important;
  box-shadow: 0 10px 24px rgba(10, 24, 40, 0.08) !important;
}

.btn-secondary:hover,
.btn-outline-secondary:hover {
  color: #fff !important;
  border-color: transparent !important;
  background: var(--primaryBlue) !important;
}

.card,
.dropdown-menu,
.modal-content {
  border: 1px solid var(--borderSoft) !important;
  border-radius: 28px !important;
  background: var(--surfaceStrong) !important;
  box-shadow: var(--shadowCard) !important;
}

.form-control,
.form-select {
  min-height: 52px;
  color: var(--darkBlue);
  border: 1px solid rgba(15, 42, 67, 0.14) !important;
  border-radius: 18px !important;
  background-color: rgba(255, 255, 255, 0.92) !important;
}

.form-control:focus,
.form-select:focus {
  border-color: rgba(14, 165, 183, 0.75) !important;
  box-shadow: 0 0 0 0.22rem rgba(14, 165, 183, 0.14) !important;
}

.banner-main {
  overflow: hidden;
  padding: 5rem 0 0;
  background:
    radial-gradient(circle at 78% 18%, rgba(213, 168, 79, 0.26), transparent 18rem),
    radial-gradient(circle at 20% 18%, rgba(14, 165, 183, 0.24), transparent 22rem),
    linear-gradient(135deg, #071521 0%, #0f2a43 45%, #0f766e 100%) !important;
}

.banner-main::before {
  background: transparent !important;
}

.welcome-text {
  max-width: 980px;
  margin: 0 auto;
  color: #fff !important;
  font-size: clamp(3rem, 7vw, 6.6rem) !important;
  line-height: 0.95;
  letter-spacing: -0.07em;
  text-shadow: 0 24px 60px rgba(0, 0, 0, 0.22);
}

.welcome-sm {
  color: rgba(255, 255, 255, 0.78) !important;
  font-size: 17px;
}

.banner-main .input-filters,
.busqueda .input-filters {
  overflow: hidden;
  padding: 0.45rem;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 26px 70px rgba(4, 14, 24, 0.22);
  backdrop-filter: blur(16px);
}

.busqueda .input-filters {
  border-color: rgba(15, 42, 67, 0.10);
  box-shadow: var(--shadowSoft);
}

.input-filters .form-control {
  min-height: 58px;
  border: 0 !important;
  border-radius: 20px !important;
  background-color: transparent !important;
}

.input-filters .btn {
  min-width: 132px;
  min-height: 58px;
}

.title-section {
  color: var(--primaryBlue) !important;
  font-size: clamp(2.4rem, 5vw, 5.2rem) !important;
  line-height: 0.95;
  letter-spacing: -0.07em;
  text-transform: none !important;
}

.sectores,
.ubicaciones {
  padding-block: 5rem;
}

.sectores::after {
  display: none;
}

.carousel-wrapper {
  overflow: visible !important;
}

.carousel-container {
  gap: 1rem !important;
  padding: 0.75rem 0.25rem 1.6rem !important;
}

.card-home {
  min-height: 112px;
  width: 100% !important;
  border: 1px solid rgba(15, 42, 67, 0.10) !important;
  border-radius: 26px !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 250, 252, 0.92)) !important;
  box-shadow: var(--shadowSoft);
}

.card-home:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadowHover) !important;
}

.card-home-title {
  color: var(--primaryBlue) !important;
  font-size: 16px;
  letter-spacing: -0.02em;
}

.card-home-title::after {
  color: var(--lightBlue) !important;
}

.carousel-btn {
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.4) !important;
  background: var(--primaryBlue) !important;
  box-shadow: var(--shadowCard);
}

.proceso {
  position: relative;
  overflow: hidden;
  padding-block: 5.5rem !important;
  background:
    radial-gradient(circle at 20% 20%, rgba(14, 165, 183, 0.22), transparent 20rem),
    linear-gradient(135deg, #071521 0%, #102a43 100%) !important;
}

.proceso .title-section,
.proceso .subtitle-section,
.proceso .step {
  color: #fff !important;
}

.step {
  padding: 2rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.step i::after,
.step::after,
.step::before {
  display: none !important;
}

.step i {
  display: inline-grid;
  width: 68px;
  height: 68px;
  place-items: center;
  border-radius: 22px;
  background: linear-gradient(135deg, #0ea5b7, #0f766e);
  box-shadow: 0 18px 36px rgba(14, 165, 183, 0.24);
}

.busqueda {
  padding: 2rem 0 4rem;
}

.busqueda .container {
  max-width: 1180px;
}

.filters-busqueda {
  gap: 0.75rem !important;
  padding: 0.9rem !important;
  border: 1px solid rgba(15, 42, 67, 0.10);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 14px 40px rgba(10, 24, 40, 0.08);
  backdrop-filter: blur(16px);
}

.filters-busqueda .dropdown-toggle,
.filters-busqueda .btn-reset {
  border-radius: 999px !important;
  font-weight: 800 !important;
  padding: 0.78rem 1.05rem !important;
}

.filters-busqueda .dropdown-toggle {
  color: var(--primaryBlue) !important;
  border: 1px solid rgba(15, 42, 67, 0.16) !important;
  background: #fff !important;
}

.filters-busqueda .dropdown-toggle:hover,
.filters-busqueda .dropdown-toggle:focus,
.filters-busqueda .btn-reset {
  color: #fff !important;
  border-color: transparent !important;
  background: linear-gradient(135deg, #0f766e, #0e7490) !important;
}

.title-busqueda {
  color: var(--gray600);
  font-size: 13px !important;
  font-weight: 800 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.title-busqueda::after {
  width: 84px !important;
  height: 4px !important;
  border-radius: 99px;
  background: linear-gradient(90deg, #0ea5b7, #d5a84f) !important;
}

.card.card-sm {
  border-radius: 28px !important;
  margin-top: 1rem;
}

.vacantes-scroll {
  padding-right: 0.5rem;
}

.vac-card {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(15, 42, 67, 0.10) !important;
  background: linear-gradient(145deg, #ffffff 0%, #f7fafc 100%) !important;
  transition: transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.vac-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 6px;
  background: linear-gradient(180deg, #0ea5b7, #0f766e);
}

.vac-card:hover,
.vac-card.expanded {
  transform: translateY(-3px);
  border-color: rgba(14, 165, 183, 0.38) !important;
  box-shadow: var(--shadowHover) !important;
}

.img-job {
  width: 66px !important;
  height: 66px !important;
  padding: 0.8rem;
  border: 1px solid rgba(15, 42, 67, 0.08);
  border-radius: 20px !important;
  background: linear-gradient(145deg, #eef6f8, #ffffff);
  object-fit: contain !important;
}

.title-empresa {
  color: #0f766e !important;
  font-size: 13px !important;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.title-job {
  color: var(--darkBlue);
  font-size: 20px !important;
  line-height: 1.2;
  letter-spacing: -0.03em;
}

.icon-job {
  align-items: center;
  color: var(--gray600) !important;
}

.icon-job i {
  color: #0e7490;
}

.subtitle-icon {
  color: var(--gray600);
  font-weight: 700;
}

.icon-job-group {
  min-width: 110px;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(15, 42, 67, 0.08);
  border-radius: 18px;
  background: rgba(238, 243, 247, 0.65);
}

.icon-job-group .subtitle-job,
.subtitle-job {
  color: var(--gray) !important;
  font-size: 11px !important;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.btn-favorito {
  width: 46px;
  height: 46px;
  padding: 0 !important;
  color: #9aa8b8 !important;
  border: 1px solid rgba(15, 42, 67, 0.08) !important;
  background: #fff !important;
  box-shadow: 0 10px 24px rgba(10, 24, 40, 0.08) !important;
}

.btn-favorito.activo,
.btn-favorito:hover {
  color: #d5a84f !important;
}

.btn-pill {
  min-height: 54px;
  padding-inline: 1.45rem !important;
}

.badge,
.etiqueta,
.badge-destacado {
  border-radius: 999px !important;
}

.dropdown-menu {
  padding: 0.65rem !important;
  border-color: rgba(15, 42, 67, 0.08) !important;
}

.dropdown-item {
  border-radius: 14px !important;
  color: var(--primaryBlue) !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
  color: #fff !important;
  background: linear-gradient(135deg, #0f766e, #0e7490) !important;
}

.nav-tabs .nav-item .nav-link.active::after,
.title-busqueda::after {
  background: linear-gradient(90deg, #0ea5b7, #d5a84f) !important;
}

@media (max-width: 767px) {
  .navbar {
    min-height: auto;
  }

  .welcome-text {
    font-size: clamp(2.6rem, 12vw, 4rem) !important;
  }

  .banner-main .input-filters,
  .busqueda .input-filters {
    display: grid;
    gap: 0.5rem;
    border-radius: 24px;
  }

  .input-filters .btn {
    width: 100%;
  }

  .vac-card .row.align-items-center {
    row-gap: 1rem;
  }

  .vac-card .text-end {
    justify-content: flex-start !important;
  }
}

.hero-eyebrow,
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  width: fit-content;
  margin-bottom: 1rem;
  padding: 0.5rem 0.85rem;
  color: #0f766e;
  border: 1px solid rgba(14, 165, 183, 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 12px 30px rgba(10, 24, 40, 0.08);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.banner-main .hero-eyebrow {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.12);
}

.hero-subtitle {
  max-width: 760px;
  margin: 1.1rem auto 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: clamp(1rem, 2vw, 1.25rem);
  line-height: 1.65;
}

.hero-metrics {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  max-width: 760px;
  margin: 1.5rem auto 0;
  padding: 0.85rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(18px);
}

.hero-metrics div {
  padding: 1rem;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.10);
  text-align: center;
}

.hero-metrics strong {
  display: block;
  color: #fff;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  line-height: 1;
  letter-spacing: -0.06em;
}

.hero-metrics span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 700;
}

.search-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 1.5rem;
  align-items: stretch;
  margin-bottom: 1.4rem;
  padding: clamp(1.5rem, 4vw, 2.3rem);
  border: 1px solid rgba(15, 42, 67, 0.10);
  border-radius: 34px;
  background:
    radial-gradient(circle at 82% 12%, rgba(14, 165, 183, 0.18), transparent 15rem),
    linear-gradient(145deg, #ffffff 0%, #f4f8fb 100%);
  box-shadow: var(--shadowCard);
}

.search-hero h1 {
  max-width: 760px;
  margin: 0;
  color: var(--darkBlue);
  font-size: clamp(2.2rem, 5vw, 4.6rem);
  line-height: 0.98;
  letter-spacing: -0.07em;
  font-weight: 850;
}

.search-hero p {
  max-width: 650px;
  margin: 1rem 0 0;
  color: var(--gray600);
  font-size: 16px;
  line-height: 1.7;
}

.search-hero-card {
  display: grid;
  align-content: center;
  justify-items: start;
  padding: 1.35rem;
  color: #fff;
  border-radius: 28px;
  background: linear-gradient(145deg, #071521, #0f766e);
  box-shadow: 0 18px 40px rgba(15, 118, 110, 0.24);
}

.search-hero-card span,
.search-hero-card small {
  color: rgba(255, 255, 255, 0.72);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.search-hero-card strong {
  color: #fff;
  font-size: 4rem;
  line-height: 1;
  letter-spacing: -0.08em;
}

.search-sidebar-panel {
  position: sticky;
  top: 96px;
  padding: 1rem;
  border: 1px solid rgba(15, 42, 67, 0.10);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 14px 40px rgba(10, 24, 40, 0.08);
  backdrop-filter: blur(16px);
}

.footer-premium {
  position: relative;
  overflow: hidden;
  margin-top: 4rem;
  padding: 4rem 0 3rem;
  color: rgba(255, 255, 255, 0.78);
  background:
    radial-gradient(circle at 80% 10%, rgba(14, 165, 183, 0.24), transparent 18rem),
    linear-gradient(135deg, #071521 0%, #0f2a43 55%, #0f766e 100%);
}

.footer-premium a {
  display: block;
  margin-bottom: 0.7rem;
  color: rgba(255, 255, 255, 0.72);
  font-weight: 650;
}

.footer-premium a:hover {
  color: #fff;
}

.footer-logo {
  width: 112px;
  margin-bottom: 1rem;
  filter: drop-shadow(0 14px 24px rgba(0, 0, 0, 0.22));
}

.footer-copy {
  max-width: 440px;
  color: rgba(255, 255, 255, 0.74);
  line-height: 1.8;
}

.footer-title {
  color: #fff;
  font-size: 13px;
  font-weight: 850;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.footer-small {
  color: rgba(255, 255, 255, 0.70);
  line-height: 1.7;
}

.footer-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.footer-badges span {
  padding: 0.5rem 0.7rem;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.10);
  font-size: 12px;
  font-weight: 750;
}

@media (max-width: 767px) {
  .hero-metrics,
  .search-hero {
    grid-template-columns: 1fr;
  }

  .search-sidebar-panel {
    position: static;
  }
}