.empresas-page{
  display:none;
  position:relative;
  width:100%;
  min-height:100vh;
  background:#ffffff;
  box-sizing:border-box;
  padding:0 0 60px;
  overflow:visible;
}

.empresas-page.show{
  display:block;
}

:root{

  --empresa-text-dark:#071a44;
--empresa-text-blue:#0072ff;
  --empresa-card-top-desktop:0px;
  --empresa-card-left-desktop:0px;

  --empresa-card-width-mobile:100%;
  --empresa-card-height-mobile:auto;
  --empresa-card-padding-mobile:22px;
  --empresa-card-padding-desktop:24px;
  --empresa-icon-size-mobile:100px;
  --empresa-text-size-mobile:17px;
  --empresas-category-title-top-desktop:-100px;
  --empresas-category-title-left-desktop:0px;
  --empresas-category-title-size-desktop:clamp(22px, 3vw, 34px);

  --empresas-category-title-top-mobile:-150px;
  --empresas-category-title-left-mobile:0px;
  --empresas-category-title-size-mobile:clamp(20px, 6vw, 28px);

  --empresas-cards-group-top-desktop:-50px;
--empresas-cards-group-left-desktop:0px;

--empresa-card-width-desktop:100%;
--empresa-card-max-width-desktop:240px;
--empresa-card-height-desktop:240px;

--empresa-icon-size-desktop:176px;
--empresa-text-size-desktop:18px;
}

.empresas-banner.home-hero{
  margin-bottom:clamp(70px, 10vw, 120px);
}

.empresas-body{
  width:calc(100% - 12vw);
  margin:0 auto;
  padding:clamp(35px, 5vw, 70px) 0;
}

@media (min-width:769px){

  .empresas-banner .home-hero-content{
    width:var(--home-hero-content-width);
  }

  .empresas-banner .home-hero-title{
    position:relative;
    font-size:var(--home-hero-title-size-desktop);
    line-height:var(--home-title-line-height);
  }

  .empresas-banner .home-hero-content p{
    position:relative;
    top:var(--home-subtitle-top-desktop);
    left:var(--home-subtitle-left-desktop);
    max-width:var(--home-subtitle-width-desktop);
    font-size:var(--home-subtitle-size-desktop);
    line-height:var(--home-subtitle-line-height);
  }
}

.empresas-category-title{
  position:relative;

  margin:0 0 clamp(32px, 4vw, 48px);

  top:var(--empresas-category-title-top-desktop, 0px);
  left:var(--empresas-category-title-left-desktop, 0px);

  text-align:center;

  color:#071a44;
  font-size:var(--empresas-category-title-size-desktop, clamp(22px, 3vw, 34px));
  line-height:1.1;
  font-weight:900;
  text-transform:uppercase;
}

.empresas-categories{
  display:grid;
  grid-template-columns:repeat(4, minmax(180px, 1fr));
  gap:clamp(18px, 3vw, 45px);
  align-items:stretch;
  justify-items:center;

  position:relative;
  top:var(--empresas-cards-group-top-desktop, 0px);
  left:var(--empresas-cards-group-left-desktop, 0px);
}

.empresa-category{
  position:relative;
  top:var(--empresa-card-top-desktop);
  left:var(--empresa-card-left-desktop);

width:var(--empresa-card-width-desktop);
max-width:var(--empresa-card-max-width-desktop);
min-height:var(--empresa-card-height-desktop);
  padding:var(--empresa-card-padding-desktop);
  box-sizing:border-box;

  background:#ffffff;
  border:1px solid rgba(0,114,255,.14);
  border-radius:16px;
  box-shadow:0 14px 35px rgba(15,23,42,.08);

  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  cursor:pointer;
}

.empresa-category-circle{
  width:var(--empresa-icon-size-desktop);
  height:var(--empresa-icon-size-desktop);
  margin:0 auto clamp(14px, 2vw, 22px);
  border-radius:50%;
  background:#eef3fb;

  display:flex;
  align-items:center;
  justify-content:center;
}

.empresa-category-icon{
  width:60%;
  height:60%;
  object-fit:contain;
}

.empresa-category p{
  position:relative;
  top:var(--empresa-text-top-desktop, 0px);
  left:var(--empresa-text-left-desktop, 0px);

  margin:0;
  color:#0072ff;
  font-size:var(--empresa-text-size-desktop);
  line-height:1.05;
  font-weight:900;
  text-transform:uppercase;
}

@media (max-width:768px){

  .empresas-category-title{
  top:var(--empresas-category-title-top-mobile, 0px);
  left:var(--empresas-category-title-left-mobile, 0px);
  font-size:var(--empresas-category-title-size-mobile, clamp(20px, 6vw, 28px));
}

  .empresas-body{
  width:calc(100% - 48px);
  padding:40px 0 70px;
}

.empresas-banner.home-hero{
  overflow:visible;
  height:auto;
  min-height:var(--home-hero-height-mobile);
  padding-bottom:clamp(120px, 30vw, 190px);
}

.empresas-banner .home-hero-content{
  width:100%;
}

.empresas-banner .home-hero-title{
  top:var(--home-title-mobile-top);
  left:var(--home-title-mobile-left);
  width:var(--home-title-mobile-width);
  font-size:var(--home-title-mobile-size);
}

.empresas-banner .home-hero-content p{
  top:var(--home-subtitle-top-mobile);
  left:var(--home-subtitle-left-mobile);
  max-width:var(--home-subtitle-width-mobile);
  font-size:var(--home-subtitle-size-mobile);
}

  .empresas-categories{
    grid-template-columns:1fr;
    gap:28px;
  }

.empresa-category{
  top:var(--empresa-card-top-mobile, 0px);
  left:var(--empresa-card-left-mobile, 0px);

  width:var(--empresa-card-width-mobile);
  min-height:var(--empresa-card-height-mobile);
  padding:var(--empresa-card-padding-mobile);
}

.empresa-category-circle{
  width:var(--empresa-icon-size-mobile);
  height:var(--empresa-icon-size-mobile);
}

.empresa-category p{
  top:var(--empresa-text-top-mobile, 0px);
  left:var(--empresa-text-left-mobile, 0px);
  font-size:var(--empresa-text-size-mobile);
}

}

/* CONTROL INDIVIDUAL ESCRITORIO */
@media (min-width:769px){
  .empresa-category-1{
    --empresa-card-top-desktop:0px;
    --empresa-card-left-desktop:0px;
  }

  .empresa-category-2{
    --empresa-card-top-desktop:0px;
    --empresa-card-left-desktop:0px;
  }

  .empresa-category-3{
    --empresa-card-top-desktop:0px;
    --empresa-card-left-desktop:0px;
  }

  .empresa-category-4{
    --empresa-card-top-desktop:0px;
    --empresa-card-left-desktop:0px;
  }
}

/* CONTROL INDIVIDUAL MÓVIL */
@media (max-width:768px){
  .empresa-category-1{
    --empresa-card-top-mobile:0px;
    --empresa-card-left-mobile:0px;
  }

  .empresa-category-2{
    --empresa-card-top-mobile:0px;
    --empresa-card-left-mobile:0px;
  }

  .empresa-category-3{
    --empresa-card-top-mobile:0px;
    --empresa-card-left-mobile:0px;
  }

  .empresa-category-4{
    --empresa-card-top-mobile:0px;
    --empresa-card-left-mobile:0px;
  }
}

/* ANIMACIÓN HOVER CARDS EMPRESAS */

.empresa-category{
  transition:
    transform .35s ease,
    box-shadow .35s ease,
    border-color .35s ease;
  will-change:transform;
}

@media (hover:hover) and (pointer:fine){
  .empresa-category:hover{
    transform:translateY(-10px) scale(1.06);
    box-shadow:0 24px 50px rgba(0,114,255,.22);
    border-color:rgba(0,114,255,.35);
    z-index:5;
  }
}

/* MODAL CATEGORÍA ALIMENTOS */

:root{
  --category-modal-width-desktop:min(92%, 920px);
  --category-modal-padding-desktop:50px;
  --category-modal-logo-width-desktop:220px;

  --category-modal-width-mobile:calc(100% - 32px);
  --category-modal-padding-mobile:28px 20px;
  --category-modal-logo-width-mobile:180px;
}

.category-modal{
  position:fixed;
  inset:0;
  display:none;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.55);
  z-index:9999;
  padding:24px;
  box-sizing:border-box;
}

.category-modal.show{
  display:flex;
}

.category-modal-content{
  position:relative;
  width:var(--category-modal-width-desktop);
  padding:var(--category-modal-padding-desktop);
  background:#ffffff;
  border-radius:24px;
  box-shadow:0 30px 80px rgba(0,0,0,.25);
  text-align:center;
  box-sizing:border-box;
}

.category-modal-close{
  position:absolute;
  top:18px;
  right:24px;
  border:none;
  background:transparent;
  font-size:34px;
  font-weight:900;
  cursor:pointer;
  color:#071a44;
}

.category-modal-title{
  margin:0;
  color:#071a44;
  font-size:clamp(28px, 4vw, 46px);
  font-weight:900;
  text-transform:uppercase;
}

.category-modal-title-blue{
  color:#0072ff;
  display:inline-block;
}

.category-modal-subtitle{
  margin:10px 0 35px;
  color:#4b5563;
  font-size:18px;
}

.category-companies-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(230px, 1fr));
  gap:28px;
  justify-items:center;
}

.category-company-card{
  width:100%;
  max-width:300px;
  min-height:260px;
  padding:28px;
  border:1px solid rgba(0,114,255,.16);
  border-radius:18px;
  box-shadow:0 18px 40px rgba(15,23,42,.10);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  transition:transform .35s ease, box-shadow .35s ease;
}

.category-company-card:hover{
  transform:translateY(-8px) scale(1.04);
  box-shadow:0 25px 55px rgba(0,114,255,.20);
}

.category-company-logo{
  width:var(--category-modal-logo-width-desktop);
  max-width:100%;
  height:auto;
  object-fit:contain;
  margin-bottom:18px;
}

.category-company-card h3{
  margin:0 0 10px;
  color:#0072ff;
  font-size:22px;
  font-weight:900;
  text-transform:uppercase;
}

.category-company-card p{
  margin:0;
  color:#071a44;
  font-size:15px;
  line-height:1.4;
}

@media (max-width:768px){
  .category-modal{
    padding:16px;
  }

  .category-modal-content{
    width:var(--category-modal-width-mobile);
    padding:var(--category-modal-padding-mobile);
    max-height:88vh;
    overflow-y:auto;
  }

  .category-modal-title{
    font-size:26px;
  }

  .category-modal-subtitle{
    font-size:15px;
    margin-bottom:24px;
  }

  .category-company-logo{
    width:var(--category-modal-logo-width-mobile);
  }

  .category-company-card{
    min-height:auto;
    padding:24px 18px;
  }
}