@charset "UTF-8";
@import url(main.css);
h1.display-4.fw-bold.bandeauTitre.titles.text-color-seventh { color: black !important; }

.img-fluid { max-width: 80% !important; }

img.fondDegradeLogo { max-width: 20rem; }

.carousel-inner-homepage .carousel-item-homepage > img { animation: none !important; -webkit-animation: none !important; -o-animation: none !important; }

.logo-footer > .logo_nav { height: 15vh !important; }

a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone { border-radius: 0px !important; color: #fff !important; }

.animated-border-button:after { background-color: #f08417; }

#contour.mx-auto.col-lg-11.px-4.py-4.mb-5.mt-5.text-color-primary.rounded-3.shadow-lg.bg-primaryColor.position-relative { margin: 0 !important; width: 100%; }

div#contour { box-shadow: none !important; }

.row.flex-lg-row-reverse.align-items-center.g-5.py-2.px-4.mt-5.position-relative.z-1 { flex-direction: row !important; }

.d-flex.align-items-center.justify-content-center.px-4.py-5.text-center.cta_banner.bg-sixthColor.position-relative { padding-top: 7rem !important; padding-bottom: 7rem !important; }

a.button_homepageDoubleScreen.ctaLinks-button.text-color-fourth.p-3.fs-6.fw-bold.m-2 { border-radius: 0px !important; }

div#fullHeight { height: 85vh; }

a#phone-analytics-tag-video-bloc { border-radius: 0px !important; padding: 15px 60px !important; }

/* 🟢 Force le texte à gauche dans tout le bloc du slider */
.bloc-slider-homepage.text-center { text-align: left !important; }

/* 🟢 Supprime le centrage automatique du logo */
.sliderLogoContainer.mx-auto { margin: 0 !important; }

.sliderLogoContainer { width: 305px !important; }

/* 🟢 Force les titres à gauche aussi */
.titleText.text-white.text-center.fs-2.mb-4.mt-lg-5.titles { text-align: left !important; }

/* 🟢 Bonus : si Bootstrap réapplique .text-center, tu peux écraser globalement */
.bloc-slider-homepage .text-center, .titleText.text-center { text-align: left !important; }

/*-------------------------------------------------------------------------INTRO-----------------------------------------------------------------------------*/
.alpi-about, .alpi-about * { box-sizing: border-box; }

.alpi-about { width: 100%; padding: 70px 50px; background: #f8f8f8; overflow: hidden; }

.alpi-about__wrap { width: 100%; max-width: 1480px; margin: 0 auto; display: grid; grid-template-columns: 1.08fr 0.92fr; align-items: center; gap: 82px; }

.alpi-about__image { width: 100%; height: 575px; overflow: hidden; background: #e8e8e8; }

.alpi-about__image img { width: 100%; height: 100%; display: block; object-fit: cover; }

.alpi-about__content { max-width: 620px; }

.alpi-about__label { display: inline-block; margin-bottom: 24px; color: #f08417; font-size: 14px; font-weight: 800; line-height: 1; letter-spacing: 4px; text-transform: uppercase; }

.alpi-about__title { margin: 0 0 26px; color: #000; font-size: clamp(38px, 4.2vw, 68px); font-weight: 900; line-height: 1.12; letter-spacing: -1.8px; }

.alpi-about__text { margin: 0; color: #4f5664; font-size: 21px; font-weight: 400; line-height: 1.65; }

.alpi-about__text + .alpi-about__text { margin-top: 18px; }

@media (max-width: 1180px) { .alpi-about { padding: 60px 50px; } .alpi-about__wrap { grid-template-columns: 1fr 1fr; gap: 48px; } .alpi-about__image { height: 500px; } .alpi-about__text { font-size: 18px; } }

@media (max-width: 900px) { .alpi-about { padding: 48px 50px; } .alpi-about__wrap { grid-template-columns: 1fr; gap: 36px; } .alpi-about__image { height: 420px; } .alpi-about__content { max-width: 100%; } .alpi-about__label { margin-bottom: 18px; font-size: 12px; letter-spacing: 3px; } .alpi-about__title { margin-bottom: 20px; font-size: clamp(34px, 9vw, 48px); } }

@media (max-width: 560px) { .alpi-about { padding: 38px 22px; } .alpi-about__image { height: 330px; } .alpi-about__title { font-size: 34px; line-height: 1.15; letter-spacing: -1px; } .alpi-about__text { font-size: 16px; line-height: 1.65; } }

/*-------------------------------------------------------------------------SERVICES-----------------------------------------------------------------------------*/
.services-section, .services-section * { box-sizing: border-box; }

.services-section { position: relative; width: 100%; padding: 70px 50px 95px; background: #f8f8f8; overflow: hidden; }

.services-section::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(rgba(20, 25, 35, 0.09) 1.5px, transparent 1.5px); background-size: 26px 26px; opacity: 0.55; pointer-events: none; }

.services-section__wrap { position: relative; z-index: 1; width: 100%; max-width: 1520px; margin: 0 auto; }

.services-section__top { max-width: 900px; margin-bottom: 72px; }

.services-section__label { position: relative; display: inline-block; margin-bottom: 22px; padding-left: 15px; color: #ff6728; font-size: 18px; font-weight: 800; line-height: 1; text-transform: uppercase; }

.services-section__label::before { content: ""; position: absolute; left: 0; top: 1px; width: 3px; height: 18px; background: #ff6728; }

.services-section__title { margin: 0; color: #20242c; font-size: clamp(44px, 5vw, 78px); font-weight: 900; line-height: 1.02; letter-spacing: -3px; }

.services-section__grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 54px 30px; margin-top: 2rem; }

.service-card { position: relative; display: block; min-height: 485px; color: inherit; text-decoration: none; outline: none; cursor: pointer; }

.service-card__image { position: relative; width: 100%; height: 320px; overflow: hidden; background: #dddddd; }

.service-card__image::after { content: ""; position: absolute; inset: 0; background: rgba(5, 14, 32, 0); transition: background 0.35s ease; }

.service-card__image img { width: 100%; height: 100%; display: block; object-fit: cover; transition: transform 0.5s ease, filter 0.5s ease; }

.service-card__content { position: relative; width: calc(100% - 20px); min-height: 255px; margin: -40px 30px 0; padding: 48px 42px 42px; background: #ffffff; box-shadow: 0 8px 28px rgba(15, 23, 42, 0.04); transform: translateY(0); transition: transform 0.35s ease, box-shadow 0.35s ease, background 0.35s ease; }

.service-card__icon { position: absolute; left: 0; top: -98px; width: 98px; height: 98px; display: flex; align-items: center; justify-content: center; background: #ff6728; transition: transform 0.35s ease, background 0.35s ease; }

.service-card__icon svg { width: 48px; height: 48px; fill: none; stroke: #ffffff; stroke-width: 2.4; stroke-linecap: round; stroke-linejoin: round; }

.service-card__number { display: block; margin-bottom: 18px; color: #ff6728; font-size: 22px; font-weight: 900; line-height: 1; transition: color 0.35s ease; }

.service-card h3 { margin: 0 0 18px; color: #111827; font-size: clamp(24px, 2vw, 29px); font-weight: 900; line-height: 1.15; letter-spacing: -0.6px; transition: color 0.35s ease; }

.service-card p { max-width: 310px; margin: 0; color: #252a33; font-size: 20px; font-weight: 400; line-height: 1.6; transition: color 0.35s ease; }

.service-card__link { position: relative; display: inline-flex; align-items: center; gap: 10px; margin-top: 26px; color: #ff6728; font-size: 15px; font-weight: 900; line-height: 1; text-transform: uppercase; letter-spacing: 0.4px; transition: color 0.35s ease, transform 0.35s ease; }

.service-card__link::after { content: "→"; font-size: 19px; line-height: 1; transition: transform 0.35s ease; }

.service-card:hover .service-card__image img, .service-card:focus-visible .service-card__image img { transform: scale(1.08); filter: brightness(0.82); }

.service-card:hover .service-card__image::after, .service-card:focus-visible .service-card__image::after { background: rgba(5, 14, 32, 0.25); }

.service-card:hover .service-card__content, .service-card:focus-visible .service-card__content { transform: translateY(-12px); background: #20242c; box-shadow: 0 26px 60px rgba(15, 23, 42, 0.18); }

.service-card:hover .service-card__icon, .service-card:focus-visible .service-card__icon { transform: translateY(-8px); background: #ff6728; }

.service-card:hover .service-card__number, .service-card:focus-visible .service-card__number, .service-card:hover .service-card__link, .service-card:focus-visible .service-card__link { color: #ff6728; }

.service-card:hover h3, .service-card:focus-visible h3, .service-card:hover p, .service-card:focus-visible p { color: #ffffff; }

.service-card:hover .service-card__link::after, .service-card:focus-visible .service-card__link::after { transform: translateX(8px); }

.service-card:focus-visible { outline: 3px solid #ff6728; outline-offset: 8px; }

@media (min-width: 1500px) { .services-section__grid { gap: 60px 34px; } .service-card__image { height: 340px; } .service-card__content { padding: 20px 20px 20px; } }

@media (max-width: 1280px) { .services-section { padding: 64px 50px 86px; } .services-section__top { margin-bottom: 58px; } .services-section__grid { gap: 48px 26px; } .service-card__content { width: calc(100% - 50px); margin: -38px 25px 0; padding: 46px 32px 38px; } .service-card p { font-size: 18px; } }

@media (max-width: 1100px) { .services-section { padding: 60px 50px 80px; } .services-section__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 46px 30px; } .service-card { min-height: auto; } .service-card__image { height: 300px; } .service-card__content { min-height: 235px; } }

@media (max-width: 900px) { .services-section { padding: 54px 50px 72px; } .services-section__top { margin-bottom: 44px; } .services-section__title { max-width: 720px; letter-spacing: -2px; } .services-section__grid { gap: 42px 24px; } .service-card__image { height: 280px; } .service-card__content { padding: 44px 30px 34px; } .service-card h3 { font-size: 24px; } .service-card p { font-size: 17px; } }

@media (max-width: 760px) { .services-section { padding: 48px 28px 64px; } .services-section::before { background-size: 22px 22px; opacity: 0.4; } .services-section__top { margin-bottom: 38px; } .services-section__label { margin-bottom: 16px; font-size: 15px; } .services-section__title { font-size: clamp(38px, 11vw, 52px); line-height: 1.08; letter-spacing: -1.6px; } .services-section__grid { grid-template-columns: 1fr; gap: 38px; } .service-card__image { height: 290px; } .service-card__content { width: calc(100% - 32px); min-height: auto; margin: -34px 16px 0; padding: 42px 28px 32px; } .service-card__icon { top: -78px; width: 78px; height: 78px; } .service-card__icon svg { width: 39px; height: 39px; } .service-card h3 { font-size: 24px; } .service-card p { max-width: 100%; font-size: 17px; line-height: 1.55; } .service-card__link { margin-top: 22px; font-size: 13px; } .service-card:hover .service-card__content, .service-card:focus-visible .service-card__content { transform: translateY(-7px); } }

@media (max-width: 520px) { .services-section { padding: 42px 22px 58px; } .services-section__title { font-size: 38px; } .service-card__image { height: 250px; } .service-card__content { width: calc(100% - 24px); margin: -30px 12px 0; padding: 40px 24px 30px; } .service-card__number { font-size: 19px; margin-bottom: 14px; } .service-card h3 { margin-bottom: 14px; font-size: 22px; } .service-card p { font-size: 16px; } }

@media (max-width: 390px) { .services-section { padding: 40px 18px 54px; } .services-section__title { font-size: 34px; } .service-card__image { height: 225px; } .service-card__content { width: calc(100% - 18px); margin: -28px 9px 0; padding: 38px 20px 28px; } .service-card__icon { top: -70px; width: 70px; height: 70px; } .service-card__icon svg { width: 34px; height: 34px; } }

/*-------------------------------------------------------------------------VALEURS-----------------------------------------------------------------------------*/
.plus-alpi { width: 100%; padding: 80px 20px; background-color: #f8f8f8; box-sizing: border-box; overflow: hidden; }

.plus-alpi *, .plus-alpi *::before, .plus-alpi *::after { box-sizing: inherit; margin: 0; padding: 0; }

.plus-alpi .plus-alpi__container { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px 34px; }

.plus-alpi .plus-alpi__block { position: relative; display: flex; flex-direction: column; min-height: 190px; padding: 4px 0 0 22px; border-left: 2px solid rgba(240, 132, 23, 0.22); }

.plus-alpi .plus-alpi__block::before { content: ""; position: absolute; left: -2px; top: 0; width: 2px; height: 54px; background: linear-gradient(180deg, #f08417, #ffad45); }

.plus-alpi .plus-alpi__header { display: flex; flex-direction: column; gap: 16px; }

.plus-alpi .plus-alpi__number { color: #f08417; font-size: clamp(42px, 4.6vw, 58px); font-weight: 900; line-height: 0.95; letter-spacing: -2px; }

.plus-alpi .plus-alpi__title { max-width: 330px; color: #15263c; font-size: 20px; font-weight: 800; line-height: 1.35; text-transform: uppercase; letter-spacing: 0.5px; }

.plus-alpi .plus-alpi__text { max-width: 330px; margin-top: 18px; color: #4f5664; font-size: 17px; font-weight: 400; line-height: 1.65; }

@media (max-width: 992px) { .plus-alpi { padding: 70px 20px; } .plus-alpi .plus-alpi__container { grid-template-columns: repeat(2, 1fr); gap: 42px; } .plus-alpi .plus-alpi__block { min-height: 175px; } }

@media (max-width: 640px) { .plus-alpi { padding: 55px 20px; } .plus-alpi .plus-alpi__container { grid-template-columns: 1fr; gap: 38px; } .plus-alpi .plus-alpi__block { min-height: auto; padding-left: 18px; } .plus-alpi .plus-alpi__number { font-size: 44px; letter-spacing: -1.4px; } .plus-alpi .plus-alpi__title { font-size: 17px; } .plus-alpi .plus-alpi__text { margin-top: 14px; font-size: 16px; line-height: 1.6; } }

/*-------------------------------------------------------------------------ACCUEIL PAGE -----------------------------------------------------------------------------*/
/* ============================== HEADER TOITURE PAGE ============================== */
.toiture-page, .toiture-page * { box-sizing: border-box; }

.toiture-page { position: relative; width: 100%; height: 55vh; min-height: 400px; overflow: hidden; background-color: #000000; }

.toiture-page__bg { position: absolute; inset: 0; background-size: cover; background-position: center; background-repeat: no-repeat; z-index: 0; }

.toiture-page__overlay { position: absolute; inset: 0; background: linear-gradient(120deg, rgba(0, 0, 0, 0.22) 0%, rgba(0, 0, 0, 0.62) 55%, rgba(0, 0, 0, 0.78) 100%); z-index: 1; }

.toiture-page__container { position: relative; z-index: 2; max-width: 1200px; height: 100%; margin: 0 auto; padding: 0 50px; display: grid; grid-template-columns: 1fr 2fr; align-items: center; gap: 60px; }

.toiture-page__logo { display: flex; align-items: center; justify-content: flex-start; }

.toiture-page__logo img { max-width: 310px; width: 100%; height: auto; display: block; }

.toiture-page__text-wrapper { display: flex; align-items: stretch; gap: 60px; }

.toiture-page__line { width: 4px; background-color: #f08417; border-radius: 2px; flex-shrink: 0; }

.toiture-page__text h1 { margin: 0 0 1.5rem; color: #ffffff; font-size: 42px; font-weight: 700; line-height: 1.15; letter-spacing: 1px; text-transform: uppercase; }

.toiture-page__text p { max-width: 540px; margin: 0; color: #f2f2f2; font-size: clamp(15px, 2vw, 18px); line-height: 1.6; }

/* ============================== RESPONSIVE ============================== */
@media (max-width: 900px) { .toiture-page { height: auto; min-height: 520px; } .toiture-page__container { grid-template-columns: 1fr; gap: 30px; padding: 70px 35px; justify-items: center; text-align: center; } .toiture-page__logo { justify-content: center; } .toiture-page__logo img { max-width: 220px; } .toiture-page__text-wrapper { flex-direction: column; align-items: center; gap: 20px; } .toiture-page__line { width: 60px; height: 4px; } .toiture-page__text h1 { font-size: clamp(32px, 7vw, 42px); } .toiture-page__text p { max-width: 620px; } }

@media (max-width: 600px) { .toiture-page { min-height: auto; } .toiture-page__container { padding: 70px 22px; } .toiture-page__logo img { max-width: 175px; } .toiture-page__text h1 { font-size: 30px; line-height: 1.2; } .toiture-page__text p { font-size: 15px; } }

/*-------------------------------------------------------------------------INTRO PAGE-----------------------------------------------------------------------------*/
.toiture-layout, .toiture-layout * { box-sizing: border-box; }

.toiture-layout { position: relative; width: 100%; overflow: hidden; }

.toiture-layout__wrap { width: 100%; max-width: 1600px; margin: 0 auto; min-height: 820px; display: grid; grid-template-columns: 42% 58%; align-items: center; }

.toiture-layout__content { padding: 90px 60px 90px 80px; }

.toiture-layout__label { display: inline-block; margin-bottom: 28px; color: #f08417; font-size: 18px; font-weight: 600; line-height: 1; letter-spacing: 5px; text-transform: uppercase; }

.toiture-layout__title { max-width: 520px; margin: 0 0 40px; color: #1d232c; font-size: clamp(48px, 4.6vw, 74px); font-weight: 700; line-height: 1.12; letter-spacing: -0.8px; }

.toiture-layout__text { max-width: 560px; margin: 0 0 42px; color: #6b727d; font-size: 19px; font-weight: 400; line-height: 2; }

.toiture-layout__btn { display: inline-flex; align-items: center; justify-content: center; min-width: 246px; min-height: 74px; padding: 18px 34px; background: #f57c00; color: #ffffff; font-size: 20px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; text-decoration: none; transition: transform 0.25s ease, background 0.25s ease; }

.toiture-layout__btn:hover { background: #de6f00; transform: translateY(-2px); }

.toiture-layout__visual { position: relative; min-height: 820px; display: flex; align-items: center; justify-content: center; padding: 70px 70px 70px 40px; overflow: hidden; }

.toiture-layout__visual::before { content: ""; position: absolute; inset: 0; background-image: repeating-linear-gradient(135deg, rgba(0, 0, 0, 0.035) 0, rgba(0, 0, 0, 0.035) 2px, transparent 2px, transparent 11px); opacity: 0.7; pointer-events: none; }

.toiture-layout__image-box { position: relative; z-index: 1; width: 100%; max-width: 760px; height: 610px; background: #f8f8f8; box-shadow: 0 24px 55px rgba(0, 0, 0, 0.06); overflow: hidden; }

.toiture-layout__image-box img { width: 100%; height: 100%; display: block; object-fit: cover; object-position: center; }

/* Responsive */
@media (max-width: 1250px) { .toiture-layout__wrap { min-height: 720px; grid-template-columns: 45% 55%; } .toiture-layout__content { padding: 80px 45px 80px 55px; } .toiture-layout__visual { min-height: 720px; padding: 55px 50px 55px 30px; } .toiture-layout__image-box { height: 540px; } .toiture-layout__text { font-size: 17px; line-height: 1.9; } }

@media (max-width: 980px) { .toiture-layout { background: #f5f5f5; } .toiture-layout__wrap { min-height: auto; grid-template-columns: 1fr; } .toiture-layout__content { padding: 65px 35px 30px; } .toiture-layout__title { max-width: 100%; font-size: clamp(40px, 7vw, 56px); } .toiture-layout__text { max-width: 100%; } .toiture-layout__visual { min-height: auto; padding: 20px 35px 65px; } .toiture-layout__image-box { max-width: 100%; height: 500px; } }

@media (max-width: 640px) { .toiture-layout__content { padding: 50px 22px 24px; } .toiture-layout__label { margin-bottom: 20px; font-size: 14px; letter-spacing: 4px; } .toiture-layout__title { margin-bottom: 26px; font-size: 38px; line-height: 1.12; } .toiture-layout__text { margin-bottom: 30px; font-size: 16px; line-height: 1.85; } .toiture-layout__btn { min-width: 200px; min-height: 62px; font-size: 17px; } .toiture-layout__visual { padding: 15px 22px 50px; } .toiture-layout__image-box { height: 360px; } }

/*-------------------------------------------------------------------------SERVICES PAGE-----------------------------------------------------------------------------*/
.alpi-roof-services, .alpi-roof-services * { box-sizing: border-box; }

.alpi-roof-services { width: 100%; padding: 80px 50px 95px; background: #f8f8f8; overflow: hidden; }

.alpi-roof-services__wrap { width: 100%; max-width: 1520px; margin: 0 auto; }

.alpi-roof-services__head { margin-bottom: 34px; padding-bottom: 32px; border-bottom: 1px solid rgba(20, 25, 35, 0.14); }

.alpi-roof-services__label { display: block; margin-bottom: 16px; color: #f08417; font-size: 15px; font-weight: 700; line-height: 1; letter-spacing: 5px; text-transform: uppercase; }

.alpi-roof-services__title { max-width: 760px; margin: 0; color: #1c2520; font-size: clamp(46px, 5.2vw, 78px); font-weight: 400; line-height: 1.05; letter-spacing: -1px; }

.alpi-roof-services__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 34px; }

.alpi-roof-services__card { display: flex; flex-direction: column; min-height: 620px; background: #fffaf0; border-radius: 4px; overflow: hidden; box-shadow: 0 16px 45px rgba(15, 23, 42, 0.08); }

.alpi-roof-services__image { width: 100%; height: 315px; overflow: hidden; background: #dcdcdc; }

.alpi-roof-services__image img { width: 100%; height: 100%; display: block; object-fit: cover; }

.alpi-roof-services__content { flex: 1; padding: 34px 36px 40px; background: #fff; }

.alpi-roof-services__content h3 { margin: 0 0 22px; color: #1b1b1b; font-size: clamp(27px, 2.5vw, 38px); font-weight: 400; line-height: 1.08; letter-spacing: -0.8px; }

.alpi-roof-services__content p { margin: 0; color: #1f2522; font-size: 17px; font-weight: 400; line-height: 1.65; }

/* Responsive tablette */
@media (max-width: 1150px) { .alpi-roof-services { padding: 70px 50px 80px; } .alpi-roof-services__grid { grid-template-columns: repeat(2, 1fr); } .alpi-roof-services__card { min-height: auto; } }

/* Responsive mobile */
@media (max-width: 760px) { .alpi-roof-services { padding: 55px 28px 65px; } .alpi-roof-services__head { margin-bottom: 28px; padding-bottom: 26px; } .alpi-roof-services__label { font-size: 13px; letter-spacing: 4px; } .alpi-roof-services__title { font-size: clamp(38px, 10vw, 54px); } .alpi-roof-services__grid { grid-template-columns: 1fr; gap: 28px; } .alpi-roof-services__image { height: 285px; } .alpi-roof-services__content { padding: 30px 28px 34px; } .alpi-roof-services__content h3 { font-size: 31px; } .alpi-roof-services__content p { font-size: 16px; } }

@media (max-width: 460px) { .alpi-roof-services { padding: 45px 18px 55px; } .alpi-roof-services__image { height: 240px; } .alpi-roof-services__content { padding: 28px 22px 32px; } .alpi-roof-services__content h3 { font-size: 28px; } }

/*-------------------------------------------------------------------------PRESTA PAGE-----------------------------------------------------------------------------*/
.alpi-featured, .alpi-featured * { box-sizing: border-box; }

.alpi-featured { width: 100%; padding: 70px 50px 85px; background: #f4efe5; overflow: hidden; }

.alpi-featured__wrap { width: 100%; max-width: 1380px; margin: 0 auto; }

.alpi-featured__head { margin-bottom: 45px; text-align: center; }

.alpi-featured__head h2 { margin: 0; color: #3b342c; font-size: clamp(34px, 3.8vw, 56px); font-weight: 400; line-height: 1; letter-spacing: 7px; text-transform: uppercase; }

.alpi-featured__head span { display: block; width: 64px; height: 5px; margin: 16px auto 0; border-radius: 999px; background: #f08417; }

.alpi-featured__head span::after { content: ""; display: block; width: 50px; height: 5px; margin: 7px auto 0; border-radius: 999px; background: #f08417; }

.alpi-featured__grid { display: grid; grid-template-columns: 2fr 1.25fr; gap: 34px; align-items: stretch; }

.alpi-featured__cards-left { display: grid; grid-template-columns: repeat(2, 1fr); gap: 26px; }

.alpi-featured__card { overflow: hidden; background: #ffffff; box-shadow: 0 14px 38px rgba(30, 24, 18, 0.1); }

.alpi-featured__image { width: 100%; height: 230px; overflow: hidden; background: #ddd; }

.alpi-featured__image img { width: 100%; height: 100%; display: block; object-fit: cover; }

.alpi-featured__content { padding: 30px 32px 34px; background: #ffffff; }

.alpi-featured__content h3 { margin: 0 0 16px; color: #2f2922; font-size: 23px; font-weight: 800; line-height: 1.25; }

.alpi-featured__content p { margin: 0; color: #4d4842; font-size: 16px; line-height: 1.6; }

.alpi-featured__side { display: grid; grid-template-columns: 1fr; gap: 22px; }

.alpi-featured__side-card { position: relative; min-height: 142px; display: grid; grid-template-columns: 92px 1fr 30px; align-items: center; gap: 24px; padding: 24px 24px 24px 0; overflow: hidden; background: #ffffff; box-shadow: 0 14px 38px rgba(30, 24, 18, 0.1); }

.alpi-featured__side-card::before { content: ""; position: absolute; left: 0; top: 0; width: 76px; height: 100%; background: #f08417; clip-path: polygon(0 0, 72% 0, 100% 50%, 72% 100%, 0 100%); }

.alpi-featured__tag { position: relative; z-index: 1; width: 72px; height: 72px; margin-left: 28px; display: flex; align-items: center; justify-content: center; background: #ffbd68; color: #2f2922; }

.alpi-featured__tag svg { width: 38px; height: 38px; fill: none; stroke: currentColor; stroke-width: 2.3; stroke-linecap: round; stroke-linejoin: round; }

.alpi-featured__side-card h3 { position: relative; z-index: 1; margin: 0; color: #2f2922; font-size: 21px; font-weight: 800; line-height: 1.35; }

.alpi-featured__plus { position: relative; z-index: 1; width: 26px; height: 26px; display: inline-flex; align-items: center; justify-content: center; border: 1px solid rgba(47, 41, 34, 0.45); border-radius: 50%; color: #2f2922; font-size: 17px; line-height: 1; }

/* Responsive */
@media (max-width: 980px) { .alpi-featured { padding: 60px 35px 70px; } .alpi-featured__grid { grid-template-columns: 1fr; } .alpi-featured__cards-left { grid-template-columns: repeat(2, 1fr); } .alpi-featured__side-card { min-height: 130px; } }

@media (max-width: 680px) { .alpi-featured { padding: 48px 20px 60px; } .alpi-featured__head h2 { font-size: 32px; letter-spacing: 4px; } .alpi-featured__cards-left { grid-template-columns: 1fr; } .alpi-featured__image { height: 245px; } .alpi-featured__side-card { grid-template-columns: 82px 1fr; min-height: 120px; padding: 22px; } .alpi-featured__side-card::before { width: 64px; } .alpi-featured__tag { width: 64px; height: 64px; margin-left: 12px; } .alpi-featured__tag svg { width: 32px; height: 32px; } .alpi-featured__side-card h3 { font-size: 18px; } .alpi-featured__plus { display: none; } }

@media (max-width: 430px) { .alpi-featured__head h2 { font-size: 27px; letter-spacing: 3px; } .alpi-featured__image { height: 210px; } .alpi-featured__content { padding: 24px; } .alpi-featured__content h3 { font-size: 21px; } .alpi-featured__content p { font-size: 15px; } .alpi-featured__side-card h3 { font-size: 16px; } }

/*-------------------------------------------------------------------------PRESTA-----------------------------------------------------------------------------*/
.presta-plus, .presta-plus * { box-sizing: border-box; }

.presta-plus { width: 100%; padding: 80px 50px 90px; background: #f8f8f8; overflow: hidden; }

.presta-plus__wrap { width: 100%; max-width: 1500px; margin: 0 auto; }

.presta-plus__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 42px; }

.presta-plus__card { display: grid; grid-template-columns: 1fr 1.08fr; min-height: 430px; background: #ffffff; box-shadow: 0 18px 55px rgba(15, 23, 42, 0.06); overflow: hidden; }

.presta-plus__image { width: 100%; min-height: 430px; overflow: hidden; background: #dddddd; }

.presta-plus__image img { width: 100%; height: 100%; display: block; object-fit: cover; }

.presta-plus__content { position: relative; min-height: 430px; padding: 68px 46px 52px; background: #ffffff; overflow: hidden; }

.presta-plus__icon { position: relative; z-index: 2; width: 72px; height: 72px; margin-bottom: 42px; color: #f08417; }

.presta-plus__icon svg { width: 100%; height: 100%; display: block; fill: none; stroke: currentColor; stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; }

.presta-plus__number { position: absolute; z-index: 1; top: 70px; right: 36px; color: transparent; -webkit-text-stroke: 1px rgba(21, 31, 42, 0.08); text-stroke: 1px rgba(21, 31, 42, 0.08); font-size: 180px; font-weight: 900; line-height: 0.8; letter-spacing: -8px; pointer-events: none; }

.presta-plus__name { position: relative; z-index: 2; max-width: 330px; margin: 0 0 26px; color: #07101d; font-size: 30px; font-weight: 900; line-height: 1.15; letter-spacing: -0.7px; }

.presta-plus__text { position: relative; z-index: 2; max-width: 360px; margin: 0; color: #4a5260; font-size: 21px; font-weight: 400; line-height: 1.55; }

@media (max-width: 1300px) { .presta-plus { padding: 70px 50px 80px; } .presta-plus__grid { gap: 34px; } .presta-plus__card { grid-template-columns: 0.95fr 1.05fr; } .presta-plus__content { padding: 60px 38px 46px; } .presta-plus__number { right: 24px; font-size: 150px; } .presta-plus__name { font-size: 27px; } .presta-plus__text { font-size: 19px; } }

@media (max-width: 1100px) { .presta-plus__grid { grid-template-columns: 1fr; max-width: 840px; margin: 0 auto; } .presta-plus__card { grid-template-columns: 1fr 1fr; } }

@media (max-width: 760px) { .presta-plus { padding: 58px 28px 68px; } .presta-plus__card { grid-template-columns: 1fr; min-height: auto; } .presta-plus__image { min-height: auto; height: 330px; } .presta-plus__content { min-height: auto; padding: 44px 34px 42px; } .presta-plus__icon { width: 62px; height: 62px; margin-bottom: 34px; } .presta-plus__number { top: 42px; right: 24px; font-size: 130px; } .presta-plus__name { max-width: 100%; font-size: 26px; } .presta-plus__text { max-width: 100%; font-size: 18px; line-height: 1.55; } }

@media (max-width: 480px) { .presta-plus { padding: 48px 20px 58px; } .presta-plus__image { height: 280px; } .presta-plus__content { padding: 40px 26px 36px; } .presta-plus__icon { width: 56px; height: 56px; margin-bottom: 28px; } .presta-plus__number { top: 38px; right: 18px; font-size: 105px; } .presta-plus__name { margin-bottom: 20px; font-size: 24px; } .presta-plus__text { font-size: 16px; } }

/*# sourceMappingURL=custom.css.map */