
/* NOMBRE DE LIGNES A AFFICHER */
.main-cta{
  --cta-height : 10rem;
  --height-p-cta : 5;
  --height-p-cta-hover :6;
}

.main-cta {
  display: flex;
  flex-direction: row;
  gap: var(--gap);
  font-size: var(--small-font);
}
.main-cta a {
  display: flex;
  flex-direction: column;
  gap: var(--gap);
  padding: var(--gap);
  border-radius: var(--radius);
  width: 100%;
  cursor: pointer;
  position: relative;
  box-shadow: 6px 6px 9px rgba(0, 0, 0, 0);
  transition: box-shadow 250ms ease-in-out, opacity 250ms ease-in-out;
}
.main-cta a > div{
  transition: opacity 250ms ease-in-out;
  opacity: 1;
}

.main-cta-entry-meta {
  width: 100%;
  justify-content: space-between;
  flex-direction: row-reverse;
  margin-bottom: auto;
  padding-bottom: var(--cta-height);
  font-size: var(--small-font);
  align-items: flex-start;
}
.main-cta-entry-meta span {
  margin: 0;
  display: inline-flex;
  border-radius: var(--radius);
  padding: calc(var(--gap) / 3) calc(var(--gap) / 2);
  color: var(--white);
  align-items: center;
  border: 1px solid #ffffff50;
}
.main-cta-icon{
  position: relative;
  height: 52px;
  width: 52px;
}
.main-cta-icon > svg,
.main-cta-icon > img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.main-cta-octogone,
.main-cta-octogone > svg {
  width: 100%;
  height: 100%;
  transform: rotate(0deg);
  overflow: visible;
  transition: transform 250ms cubic-bezier(0.42, 0, 0, 1.03);
}

.main-cta-octogone > svg > path {
  fill: transparent !important;
  stroke-width: 3px;
  stroke: #fff;
}
.main-cta a svg *{
  fill: var(--white);
}
.main-cta-content {
  gap: calc(var(--gap) / 2 );
  position: absolute;
  width: 100%;
  left: 0;
  bottom: 0;
  padding: var(--gap);
}
.main-cta a h2{
  font-size: var(--medium-font);
  margin: 0;
}
.main-cta a .main-cta-content p {
  margin: 0;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  max-height: calc(1rem * var(--height-p-cta));
  height: 100%;
  position: relative;
  transition: max-height 250ms ease-in-out, height 250ms ease-in-out, -webkit-line-clamp 250ms ease-in-out 250ms;
}

.main-cta a .main-cta-content p > span {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translate(0%, 0%);
  width: 3rem;
  height: 1rem;
  pointer-events: none;
  color: var(--white);
  opacity: 1;
  transition: opacity 300ms ease-in-out;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
  opacity: 1;
  transition: opacity 250ms ease-in-out, transform 250ms ease-in-out;
  display: none;
}

.main-cta a .main-cta-content span.material-icon svg {
  transform: translate(0px, 0px);
  transition: transform 250ms ease-in-out;
}



/* TYPE ACTIVITIES */
.type-activities.main-cta {
  flex-wrap: wrap;
  color: var(--black);
  position: relative;
  left: 50%;
  transform: translate(-50%, 0);
  margin-top: calc(var(--header-height-fixed) / -1.5);
  width: 100vw;
  max-width: none;
  padding: 0 var(--container-space-vw);
  background-image: linear-gradient(0deg, var(--white) 0%, var(--white) 80%, transparent 80%, transparent);
  padding-bottom: var(--gap);
  z-index: 1;
}
.type-activities.main-cta a,
.type-recrutement.main-cta a {
  flex-direction: row;
  flex: calc(50% - var(--gap));
  background-color: var(--white);
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: 0px 19px 40px -20px rgba(30, 69, 98, 0.15);
  border: 1px solid var(--blue-border);
  min-height: clamp(140px, 20vh, 160px);
}
.type-activities .main-cta-entry-meta {
  padding-bottom: 0;
  margin-bottom: 0;
  width: clamp(100px, 25%, 135px);
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
.type-activities .main-cta-content {
  gap: calc(var(--gap) / 2);
  position: relative;
  width: 100%;
  left: unset;
  bottom: unset;
  padding: 0;
  padding-left: clamp(100px, 25%, 135px);
}
.type-activities.main-cta a .main-cta-content p {
  max-height: none;
  height: auto;
  padding-left: var(--gap);
}
.type-activities .main-cta-content > span,
.type-activities.main-cta a h2 {
  margin-top: auto!important;
  padding-left: var(--gap);
}
.type-activities .main-cta-icon {
  position: relative;
  height: 100%;
  width: 100%;
}
.type-activities .main-cta-octogone {
  transform: rotate(0deg);
  width: 100%;
  height: 100%;
}
.type-activities .main-cta-octogone > svg {
  z-index: 0;
  top: 0;
  left: 0;
  height: auto;
  width: 100%;
  transform: translate(var(--gap), -20%);
  opacity: 1;
}
.type-activities .main-cta-octogone > svg * {
  fill: var(--secondary)!important;
}
.type-activities .main-cta-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  transform: translate(0%, 0%) scale(1);
  -webkit-mask-image: url(../../../assets/img/shapes/mask-activities.svg);
  mask-image: url(../../../assets/img/shapes/mask-activities.svg);
  mask-size: cover;
  mask-repeat: no-repeat;
  mask-position: top right;
}



.type-activities .main-cta-content > span, .type-recrutement .main-cta-content > span {
  color: var(--primary-light);
  flex-wrap: wrap;
  gap: var(--gap);
  font-weight: 700;
}
.type-activities .main-cta-content > span{
  white-space: nowrap;
  flex-wrap: nowrap;
}
.type-activities.main-cta a .main-cta-content > span svg * {
  fill: var(--primary-light);
}

/* RECRUTEMENT */
.main-cta.type-recrutement .offre-detail{
  gap: calc(var(--gap) / 2);
}
.main-cta.type-recrutement a svg * {
  fill: var(--primary-light);
}
.main-cta.type-recrutement a .offre-detail svg,
.main-cta.type-recrutement a .offre-detail img {
  width: 18px;
}
.main-cta.type-recrutement .offre-detail > span{
  border: 1px solid var(--blue-border);
  display: flex;
  align-items: center;
  gap: calc(var(--gap) / 2);
  padding: calc(var(--gap) / 3) calc(var(--gap) / 2);
  border-radius: 3px;
}
.main-cta.type-recrutement .main-cta-entry-meta span{
  background-color: var(--blue-bkg);
  border: 1px solid var(--blue-border);
  color: var(--black);
}
.type-recrutement .main-cta-content {
  gap: calc(var(--gap) / 2);
  position: relative;
  width: 100%;
  left: unset;
  bottom: unset;
  padding: 0;
}
.main-cta.type-recrutement  a .main-cta-entry-meta{
  position: absolute;
  right: var(--gap);
  left: auto;
  top: var(--gap);
  width: fit-content;
  padding-bottom: 0;
}
.main-cta.type-recrutement a h2 {
  font-size: var(--medium-font);
  margin-bottom: auto;
  padding-right: 120px;
}
.main-cta.type-recrutement a .main-cta-content p{
  height: auto;
}
.type-recrutement .main-cta-content > span .offre-detail{
  color: var(--black);
  flex-wrap: wrap;
}
.type-recrutement > a > div{
  z-index: 1;
  position: relative;
}
.type-recrutement > a > svg {
  position: absolute;
  left: 0;
  top: 0;
  transform: translate(-30%, -30%) rotate(0deg);
  z-index: 0;
  opacity: 0.2;
  transition: transform 250ms ease-in-out;
}

.main-cta.type-recrutement .main-cta-entry-meta span:before {
  content: "";
  height: 10px;
  width: 10px;
  min-width: 10px;
  max-width: 10px;
  display: flex;
  background-size: auto 100%;
  background-repeat: no-repeat;
  background-position: center;
  background-image: url(../../../assets/img/shapes/dots-blue.svg);
  object-fit: contain;
  z-index: 4;
  margin-right: 5px;
}
/* HOVER */
@media (min-width: 576px) {
  .main-cta a:hover {
    box-shadow: 6px 6px 9px rgba(0, 0, 0, 0.2);
  }
  .main-cta:hover a:not(:hover){
    opacity: 1;
  }
  .main-cta:hover a:not(:hover) > div{
  opacity: 0.7;
  }
  a:hover .main-cta-octogone > svg{
    transform: rotate(60deg);
  }
  .main-cta a:hover .main-cta-content p {
    transition: max-height 250ms ease-in-out, height 250ms ease-in-out, -webkit-line-clamp 250ms ease-in-out 250ms;
    max-height: calc(1rem * var(--height-p-cta-hover));
  }
  .main-cta a:hover .main-cta-content p > span {
    opacity: 0;
    transform: translate(0%, 100%);
  }
  .main-cta a:hover .main-cta-content span.material-icon svg {
    transform: translate(2px, -2px);
  }
  .type-activities a:hover .main-cta-octogone > svg {
    transform: translate(0, -20%) rotate(0deg);
  }
  .type-recrutement > a:hover > svg {
    transform: translate(-30%, -30%) rotate(45deg);
  }
}
/* RESPONSIVE */
@media (max-width: 1024px) {
  .main-cta{
    --cta-height : 12rem;
    --height-p-cta : 5;
    --height-p-cta-hover :6;
    font-size: var(--small-font);
  }
}
@media (max-width: 1024px) {

}
@media (max-width: 992px) {

}
@media (max-width: 768px) {
  .main-cta{
    --cta-height : 8rem;
    --height-p-cta : 0;
    --height-p-cta-hover : 0;
  }
  .main-cta-entry-meta {
    padding-bottom: 0;
    margin-bottom: 0;
    flex-direction: row-reverse;
  }
  .main-cta-icon {
      position: relative;
      height: 45px;
      width: 45px;
  }
  .main-cta-entry-meta span {
    width: max-content;
  }
  .main-cta-content{
    position: relative;
    padding: 0;
    height: 100%;
    justify-content: space-between;
  }
  .main-cta a .main-cta-content p {
    display: none;
  }
}
@media (max-width: 576px) {
  .main-cta {
    width: 100vw;
    left: 50%;
    position: relative;
    transform: translate(-50%, 0);
    overflow: auto;
    max-width: none !important;
    padding: var(--container-space-vw);
    flex-wrap: nowrap;
  }
  .main-cta a {
    flex: 1 0 calc(100vw - (4 * var(--gap)));
  }
  .main-cta a .main-cta-content p {
    display: flex;
    height: fit-content;
    max-height: fit-content;
  }
  .type-recrutement {
    flex-direction: column;
  }
  .type-activities.main-cta a, .type-recrutement.main-cta a {
    flex-direction: column;
  }
  .main-cta.type-recrutement a .main-cta-entry-meta {
    position: relative;
    right: auto;
    left: auto;
    top: auto;
    width: fit-content;
    padding-bottom: 0;
  }
  .main-cta.type-recrutement a h2 {
    padding-right: 0px;
  }
  .type-activities.main-cta {
    flex-direction: column;
  }
  .type-activities .main-cta-content{
    min-height: clamp(calc(140px - 2*var(--gap)), 20vh, calc(160px - 2*var(--gap)));
  }
  .type-activities.main-cta a h2{
    margin-top: 0!important;
  }
}