.js .loading::before {
	content: '';
	position: fixed;
	z-index: 100000;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--color-bg);
}

.js .loading::after {
	content: '';
	position: fixed;
	z-index: 100000;
	top: 50%;
	left: 50%;
	width: 60px;
	height: 60px;
	margin: -30px 0 0 -30px;
	pointer-events: none;
	border-radius: 50%;
	opacity: 0.4;
	background: var(--color-link);
	animation: loaderAnim 0.7s linear infinite alternate forwards;
}

@keyframes loaderAnim {
	to {
		opacity: 1;
		transform: scale3d(0.5,0.5,1);
	}
}


a {
	text-decoration: none;
	color: var(--color-link);
	outline: none;
}

a:hover,
a:focus {
	color: var(--color-link-hover);
}

button:focus,
a:focus {
	outline: none;
}

.hidden {
	position: absolute;
	overflow: hidden;
	width: 0;
	height: 0;
	pointer-events: none;
}

.message {
	position: relative;
	z-index: 100;
	display: none;
	padding: 1em;
	text-align: center;
	color: var(--color-bg);
	background: var(--color-text);
}

/* Icons */
.icon {
	display: block;
	width: 2.5em;
    height: 2.5em;
	margin: 0 auto;
	fill: #fff;
}

main {
	position: relative;
	width: 100%;
}

.content {
	text-align: center;
}

/* Header */
.codrops-header {
	position: relative;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: center;
	justify-items: center;
	color: var(--color-header);
	padding: 1rem 0;
}

.codrops-header__title {
	font-size: 1rem;
	line-height: 1;
	font-weight: normal;
	margin: 0 1rem;
}

.info {
	display: block;
	max-width: 260px;
	margin: 0 1rem;
	font-weight: bold;
}

.github {
	display: block;
	grid-area: github;
	justify-self: start;
}

/* Top Navigation Style */
.codrops-links {
	position: relative;
	display: flex;
	justify-content: center;
	text-align: center;
	white-space: nowrap;
	font-size: 0.85rem;
}

.codrops-icon {
	display: inline-block;
	padding: 0.25em;
}

.page-header__title {
	font-size: 1rem;
	margin: 0;
}

.page-header__title-inner {
	position: relative;
	line-height: 1.25;
	margin: 0 0.5rem 0 0;
	padding: 0 1rem 0 0;
}

.page-header__title-inner::after {
	content: '';
	right: 0;
	width: 3px;
	height: 1.25rem;
	background: currentColor;
	position: absolute;
}

.page-header__title-sub {
	position: relative;
}

.social {
	display: none;
}

.social__item {
	display: block;
	font-size: 0.75rem;
	margin: 0 0.25rem;
}

.slideshow {
	position: relative;
	width: 100%;
	margin-top: 1rem;
}

.slideshow::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.4);
	z-index: 1000;
	opacity: 0;
	transition: opacity 0.4s;
}

.slideshow--details::after {
	opacity: 1;
}

.slide {
	width: 100%;
	height: 50vh;
	top: 0;
	left: 0;
	position: absolute;
	overflow-x: hidden;
	pointer-events: none;
	opacity: 0;
}

.slide--current {
	opacity: 1;
	z-index: 999;
	pointer-events: auto;
	position: relative;
}

.slide__wrap {
	width: 100%;
	height: 50vh;
	overflow: hidden;
	position: relative;
}

.slide__bg,
.slide__img {
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background-color: white;
	background-size: cover;
	background-position: 50% 50%;
	position: absolute;
	pointer-events: none;
}

.slide__bg {
	filter: grayscale(1) brightness(0.7);
}

.slide__title-wrap {
	padding: 2rem 1rem 0;
	text-align: center;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.slide__title {
	margin: 0;
    font-family: 'Plus Jakarta Sans';
    font-size: 6rem !important;
	line-height: 0.9;
	white-space: pre;
}

.slide__title span {
	display: inline-block;
}

.slide__subtitle {
	font-size: 1.15rem;
	font-weight: normal;
    font-family: Roboto;
    max-width: 100% !important;
    margin-top: 40px !important;
}

.boxnav {
	position: absolute;
	bottom: 0;
	left: 0;
	display: flex;
	z-index: 1000;
	width: 100%;
}

.boxnav__item {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color-nav-bg);
	border: 0;
	height: 4rem;
	flex: 1;
}

.boxnav__item--prev:hover,
.boxnav__item--next:hover {
	color: var(--color-nav-hover);
}

.boxnav__item:focus {
	outline: none;
}

.boxnav__label {
	padding: 0 0.5rem;
	font-size: 1.15rem;
	position: relative;
    color: #fff;
}

.boxnav__label--total::before {
	content: '';
	position: absolute;
	right: 100%;
	top: 0;
	width: 2px;
	height: 1.45rem;
	background: #fff;
	transform: rotate(22.5deg);
}

.icon--caret-rot {
	transform: rotate(180deg);
}

.category {
	font-weight: normal;
}

.details-wrap {
	position: relative;
	pointer-events: none;
	width: 100%;
	z-index: 10000;
}

.details {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	display: grid;
	grid-auto-rows: 80px;
	overflow: hidden;
}

.details-wrap--open .details--current {
	pointer-events: auto;
}

.details__item {
	overflow: hidden;
}

.details__item--addtocart {
	grid-row: 4;
}

.details__inner {
	width: 100%;
	height: 100%;
}

.details__inner {
	display: flex;
	align-items: center;
	justify-content: space-around;
	transform: translate3d(100%,0,0);
}

.details__item-img {
	display: none;
}

.details__inner--sizes {
	background: #d4d4d4;
}

.details__size {
	position: relative;
	cursor: pointer;
}

.details__size--selected::before {
	content: '';
	position: absolute;
	width: 2rem;
	height: 2rem;
	top: 50%;
	left: 50%;
	margin: -1rem 0 0 -1rem;
	border: 2px solid #333;
	border-radius: 50%;
}

.details__inner--price {
	background: #d42d2d;
	color: #fff;
	font-size: 1.25rem;
}

.details__inner--colors {
	background: #fff;
}

.details__color {
	width: 1.5rem;
	height: 1.5rem;
	overflow: hidden;
	color: transparent;
	border-radius: 50%;
	align-self: center;
    justify-self: center;
    cursor: pointer;
}

.details__color--white {
	border: 1px solid #ddd;
}

.details__color--red {
	background: red;
}

.details__color--black {
	background: black;
}

.details__color--blue {
	background: blue;
}

.details__color--beige {
	background: beige;
}

.details__color--sky {
	background: lightblue;
}

.details__inner--grid {
	display: grid;
	padding: 1rem;
	grid-template-columns: repeat(6,1fr);
}

.action {
	border: 0;
	padding: 0;
	flex: 1;
	align-self: stretch;
	background: none;
}

.action--addtocart {
	background: var(--color-cart-bg);
	color: var(--color-cart);
}

.action--close {
	background: var(--color-close-bg);
	color: var(--color-close);
	text-transform: lowercase;
}

.action--details {
	position: absolute;
	z-index: 3000;
	top: 100%;
	font-weight: bold;
	font-size: 1.15rem;
	width: 100%;
	background: #000;
	padding: 1rem;
	color: #fff;
}

@media screen and (min-width: 53em) {
	body {
		padding: 0;
	}
	.content {
		position: relative;
		display: flex;
		justify-content: center;
		align-items: center;
		margin: 0 auto;
		min-height: 100vh;
		text-align: left;
	}
	.content--fixed {
		position: fixed;
		z-index: 10000;
		top: 0;
		left: 0;
		display: grid;
		align-content: space-between;
		width: 100%;
		max-width: none;
		min-height: 0;
		height: 100vh;
		padding: 1.5rem 4rem 2rem;
		pointer-events: none;
		align-items: start;
		grid-template-columns: 50% 50%;
		grid-template-rows: auto auto auto;
		grid-template-areas: 'pageheader codropsheader'
							'... ...'
							'tagline category';
	}
	.codrops-header {
		grid-area: codropsheader;
		padding: 0;
		justify-content: flex-end;
	}
	.codrops-links {
		margin: 0 0 1rem;
	}
	.page-header {
		grid-area: pageheader;
		align-self: start;
		justify-self: start;
		position: relative;
		display: flex;
		padding: 1.25rem 1.5rem 1.25rem 0;
		pointer-events: none;
	}
	.page-header::before {
		content: '';
		background: #000;
		width: calc(100% + 4rem);
		height: 100%;
		position: absolute;
		left: -4rem;
		top: 0;
		transform: translate3d(-100%,0,0) translate3d(2rem,0,0);
		transition: transform 0.3s;
		pointer-events: auto;
	}
	.page-header:hover::before {
		transform: translate3d(0,0,0); 
	}
	.page-header::after {
		content: '';
		width: 17rem;
		height: 100%;
		position: absolute;
		left: -2rem;
		top: 0;
		pointer-events: auto;
	}
	.page-header__title {
		transition: color 0.3s;
	}
	.page-header:hover .page-header__title {
		color: #fff;
	}
	.social {
		display: flex;
		list-style: none;
		margin: 0 0 0 3rem;
		padding: 0;
		position: relative;
		opacity: 0;
		pointer-events: none;
		transition: opacity 0.3s;
	}
	.social__item-link {
		color: #fff;
	}
	.icon--social {
		opacity: 0;
		transform: translate3d(0,150%,0);
		transition: opacity 0.2s linear, transform 0.8s cubic-bezier(0.2,1,0.3,1);
		transition-delay: 0.05s;
	}
	.icon--instagram {
		transition-delay: 0.1s;
	}
	.icon--facebook {
		transition-delay: 0.15s;
	}
	.page-header:hover .social {
		opacity: 1;
		pointer-events: auto;
	}
	.page-header:hover .social__item-link .icon {
		opacity: 1;
		transform: translate3d(0,0,0);
	}
	.content--fixed a {
		pointer-events: auto;
	}
	.codrops-links {
		margin-top: 1rem;
	}
	.tagline {
		margin: 0;
		grid-area: tagline;
		-webkit-writing-mode: vertical-rl;
		writing-mode: vertical-rl;
		transform: rotate(180deg);
	}
	.category {
		margin: 0;
		grid-area: category;
		justify-self: end;
		align-self: end;
	}
	.slideshow {
		overflow: hidden;
		margin: 0;
		height: calc(100vh - 75px);
	}
	.slide {
		height: calc(100vh - 75px);
	}
	.slide__title-wrap {
		text-align: center;
        top: 50%;
        display: inline-block;
        height: auto;
        transform: translateY(-50%);
		padding: 0;
	}
	.slide__title {
		font-size: 4.5vw;
	}
	.slide__subtitle {
		margin: 1rem 0 0 0.2rem;
		max-width: 300px;
	}
	.slide__wrap {
		height: 100%;
		position: absolute;
	}
	.slide__bg,
	.slide__img {
		background-position: 50% 0%;
	}
	.boxnav {
		top: 50%;
        right: auto;
        bottom: auto;
		transform: translateY(-50%);
        width: 100%;
        justify-content: space-between;
	}
	.boxnav__item {
		width: 7vw;
        height: 6vw;
        flex: none;
	}
	.details-wrap {
		position: absolute;
		top: 0;
		right: 0;
		pointer-events: none;
	}
	.details {
		width: auto;
		grid-template-columns: 8rem 14rem 150px;
		grid-template-rows: 125px 125px 7rem 3.5rem;
	}
	.details__item-img {
		display: block;
		grid-area: 1 / 3 / 3 / 4;
		max-width: 100%;
	}
	.details__item-sizes {
		grid-area: 1 / 2 / 2 / 3;
	}
	.details__item-price {
		grid-area: 1 / 1 / 2 / 2;
	}
	.details__item-colors {
		grid-area: 2 / 2 / 3 / 3;
	}
	.details__item--addtocart {
		grid-area: 3 / 3 / 4 / 4;
	}
	.details__item--close {
		grid-area: 4 / 3 / 5 / 4;
	}
	.details__inner--grid {
		grid-template-columns: repeat(3,1.5rem);
	}
	.action--details {
		top: calc(6rem + 10vh);
		right: 4rem;
		left: auto;
		background: none;
		color: inherit;
		width: auto;
		padding: 0;
	}
	.action--details:hover {
		color: var(--color-details-hover);
	}
}

.product-card {
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12); /* more spread and stronger opacity */
  overflow: hidden;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  height: 100%;
  display: flex;
  flex-direction: column;
}

.product-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}

.product-card a {
  text-decoration: none;
  color: inherit;
  display: block;
  height: 100%;
  padding: 20px;
}

.product-card .photo img {
  width: 180px;
  height: auto;
  border-radius: 8px;
  object-fit: cover;
}

.product-card .titre {
  font-size: 20px;
  font-weight: 700;
  margin: 15px 0 10px;
  color: #025590;
}

.product-card .texte p {
  font-size: 14px;
  color: #444;
  margin-bottom: 1rem;
}

.product-card .slider_new_link {
  display: inline-flex;
  align-items: center;
  font-weight: 600;
  color: #025590;
  transition: color 0.3s ease;
}

.product-card .slider_new_link:hover {
  color: #003e66;
}

.product-card .slider_new_link .icon-fleche_droite {
  margin-left: 6px;
  font-size: 16px;
  transition: transform 0.3s ease;
}

.product-card .slider_new_link:hover .icon-fleche_droite {
  transform: translateX(4px);
}

.about-section {
  background-color: #f9f9f9;
}

.about-text .section-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: #025590;
  margin-bottom: 20px;
}

.about-text .section-description {
  font-size: 1.1rem;
  color: #333;
  line-height: 1.7;
  text-align: justify;
}
.about-image{
	text-align: center;
}
.about-image img {
  transition: transform 0.4s ease, box-shadow 0.4s ease;
  border-radius: 15px !important;
  max-height: 400px;
}

.about-image img:hover {
  transform: scale(1.03);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
}

.contact-cta {
  background: url('/images/alfa-trusted-since-1998.jpg') center center / cover no-repeat;
  padding: 80px 0;
}

.contact-cta .cta-title {
  font-size: 48px;
  font-weight: 700;
  margin-bottom: 20px;
  font-family: 'Plus Jakarta Sans', sans-serif;
}

.contact-cta .cta-subtitle {
  font-size: 24px;
  font-weight: 400;
  color: #dcdcdc;
  font-family: 'Plus Jakarta Sans', sans-serif;
}

.contact-cta .cta-btn {
  font-size: 18px;
  font-weight: 600;
  padding: 12px 32px;
  border: 2px solid #fff;
  transition: all 0.3s ease;
}

.contact-cta .cta-btn:hover {
  background-color: #fff;
  color: #005b96;
  border: 2px solid #005b96;
}

.technology_slide .slick-slide {
  position: relative;
    display: flex !important;
    height: 450px;
    flex-direction: column;
    justify-content: flex-end;
    width: 35.875rem;
    clip-path: polygon(11.5rem 0%, 100% 0, calc(100% - 11.5rem) 100%, 0% 100%);
    margin: 0 -4.5rem;
    padding-bottom: 1rem;
    padding-inline: 5.75rem 9.75rem;
}

.technology_slide .slick-slide::before {
    content: "";
    position: absolute;
    inset: 0;
    background-blend-mode: multiply;
    background-image: linear-gradient(to top, #183672 15%, rgba(16, 50, 121, 0.3) 50%, rgba(16, 50, 121, 0.3));
    z-index: -1;
}
.technology--num {
    line-height: 1.4;
	margin-left: 20px;
}
.technology_slide img {
    position: absolute;
    inset: 0;
    z-index: -2;
}
.img-cover {
    object-fit: contain;max-width: 300px;margin: 0 auto;
	height: 100%;
}
.slide-title{
	color: #fff;
	font-family: 'Plus Jakarta Sans';
	font-size: 18px;
	margin-left: 20px;
	font-weight: 700;
}
.slide-content{
	color: #fff;
	font-family: 'Roboto';
	margin-left: 20px;
}
@media print, screen and (min-width: 48em) {
    .inner:has(.technology--btn) {
        display: flex;
        align-items: center;
        padding-bottom: 2rem;
    }
}
.icon{
	fill: #222;
}
.technology--num{
	color: #fff;
	font-family: 'Plus Jakarta Sans';
	font-size: 28px;
    letter-spacing: normal;
    font-weight: bold;
}
.verticals-bg{
	background: url('/images/bg-verticals.webp');
	background-repeat: contain;
}
.slick-scrollbar{
	margin: 0 auto;
}
.slick-scrollbar input[type=range] {
    -webkit-appearance: none;
    appearance: none;
    outline: none;
    background-color: rgba(0, 0, 0, 0);
    cursor: grab;
   	width: 50vw;
    height: 0.5rem;
    border-radius: 9999px;
}
.inner-lg {
    max-width: 100rem;
	text-align: center;
}
.inner:has(.technology--btn) {
    padding-top: 4rem;
}
.inner {
    width: 90%;
    max-width: 84rem;
    margin-left: auto;
    margin-right: auto;
}
button.slick-next{
	padding: 0;
    border-radius: 50%;
    position: initial;
    width: 50px;
    height: 50px;
    background-color: #c40303;
}
.carousel-control.left{
	position: absolute !important;
    top: -115px !important;
    right: 150px !important;
}
.carousel-control.right{
	position: absolute !important;
    top: -115px !important;
    right: 75px !important;
}
 