@charset "UTF-8";
@import url(main.css);
.spacer { display: none; }

@media (max-width: 991px) { .gl-intro { clip-path: none !important; } }

/*------------Bloc actu------------------------------*/
#news-posts-bloc { margin-top: 150px !important; margin-bottom: 150px !important; }

/*-----------------------------------------------------------Ajustements SEO----------------------------------------------*/
div:has(> .first-activity-div) { padding: 100px 0; }

.first-activity-div h2, .second-activity-div h2, .third-activity-div h2 { font-size: 1.6rem; }

#navbarSupportedContent > ul > li.dropdown.px-4 > div > a:nth-child(1) { font-size: 0.8em !important; }

#navbarSupportedContent > ul > li.dropdown.px-4 > div > ul a { transition: all 0.5s ease; }

#navbarSupportedContent > ul > li.dropdown.px-4 > div > ul a:hover { background-color: !important; }

.first-banner-seo-page .background-image-div-opacity, .bandeau { background-image: url("https://firebasestorage.googleapis.com/v0/b/refpro-app-ca244.appspot.com/o/customers%2FTMXtRmK1Z2MsWvcpWczjJCjphMV2%2Fimages%2FDEVANT_JOUR_wely.webp?alt=media&token=62068137-23b8-41cd-a414-b252f3b22f99") !important; background-size: cover; background-position: center; }

#bandeau-title-seo .titles { font-weight: 300 !important; }

#photo-text-seo-page h2.titles, #seo-text-images h2.titles { font-weight: 300 !important; }

/*-------------------------------------------------------Barre de navigation----------------------------------------------------*/
.animated-border-button:after { background-color: white; }

.animated-border-button.fs-6 { font-size: 1.2rem !important; }

.animated-border-button.fs-6 a { text-decoration: none; }

.navbar-brand { width: 10vw !important; height: 10vh !important; }

.logo_nav { height: 10vh !important; }

/*--------------------------------------------------Réseaux-sociaux---------------------------------------------------*/
.gl-socials { position: relative; padding: 100px 24px; overflow: hidden; background: linear-gradient(180deg, #24282d 0%, #333438 100%); color: #fff; isolation: isolate; }

.gl-socials__bg, .gl-socials__overlay, .gl-socials__grid-bg { position: absolute; inset: 0; }

.gl-socials__bg { z-index: 0; background: linear-gradient(135deg, rgba(255, 255, 255, 0.02), transparent 40%); }

.gl-socials__overlay { z-index: 0; background: radial-gradient(circle at 15% 20%, rgba(225, 4, 3, 0.2), transparent 28%), radial-gradient(circle at 85% 80%, rgba(141, 0, 0, 0.22), transparent 30%), linear-gradient(110deg, rgba(36, 40, 45, 0.88) 0%, rgba(36, 40, 45, 0.62) 42%, rgba(36, 40, 45, 0.78) 100%); }

.gl-socials__grid-bg { z-index: 0; background-image: linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px); background-size: 60px 60px; mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent 95%); pointer-events: none; }

.gl-socials__inner { position: relative; z-index: 1; max-width: 1400px; margin: 0 auto; }

.gl-socials__heading { max-width: 860px; margin-bottom: 40px; }

.gl-socials__eyebrow { display: inline-flex; align-items: center; min-height: 40px; padding: 0 16px; margin-bottom: 18px; border-radius: 999px; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.14); backdrop-filter: blur(10px); letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255, 255, 255, 0.78); font-family: 'Audiowide'; }

.gl-socials h2, .gl-socials h3, .gl-socials p { margin: 0; }

.gl-socials__heading h2 { line-height: 1.08; }

.gl-socials__heading p { margin-top: 16px; line-height: 1.7; color: rgba(255, 255, 255, 0.82); max-width: 700px; }

/* grille centrée */
.gl-socials__grid { display: grid; grid-template-columns: repeat(2, max-content); justify-content: center; align-items: start; gap: 28px; }

/* carte qui s'adapte au contenu */
.gl-social-card { position: relative; width: fit-content; max-width: 100%; padding: 32px; border-radius: 30px; background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.04) 100%); border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: 0 20px 60px rgba(0, 0, 0, 0.22); backdrop-filter: blur(12px); overflow: hidden; text-align: center; }

.gl-social-card::before { content: ""; position: absolute; inset: 16px; border: 1px solid rgba(255, 255, 255, 0.08); border-radius: 22px; pointer-events: none; z-index: 1; }

.gl-social-card::after { content: ""; position: absolute; width: 320px; height: 320px; top: -120px; right: -90px; border-radius: 50%; background: radial-gradient(circle, rgba(225, 4, 3, 0.32) 0%, rgba(225, 4, 3, 0.16) 34%, rgba(225, 4, 3, 0) 72%); filter: blur(24px); pointer-events: none; z-index: 0; animation: glSocialHaloFloat 6s ease-in-out infinite, glSocialHaloPulse 4.2s ease-in-out infinite; }

.gl-social-card:nth-child(2)::after { top: auto; right: auto; left: -90px; bottom: -120px; background: radial-gradient(circle, rgba(255, 255, 255, 0.16) 0%, rgba(225, 4, 3, 0.18) 38%, rgba(225, 4, 3, 0) 72%); animation-delay: 0.8s, 1.4s; }

.gl-social-card__head { position: relative; z-index: 2; display: grid; grid-template-columns: 74px minmax(0, 1fr); gap: 18px; align-items: start; margin-bottom: 24px; text-align: left; }

.gl-social-card__icon { width: 74px; height: 74px; display: grid; place-items: center; border-radius: 22px; background: linear-gradient(135deg, rgba(225, 4, 3, 0.2) 0%, rgba(255, 255, 255, 0.08) 100%); border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); }

.gl-social-card__icon i { color: #fff; line-height: 1; font-size: 2.3rem; }

.gl-social-card__head p { margin-top: 10px; line-height: 1.65; color: rgba(255, 255, 255, 0.8); }

/* wrapper qui suit la vraie largeur de l'iframe */
.gl-social-card__embed { position: relative; z-index: 2; display: inline-block; width: auto; max-width: 100%; border-radius: 22px; overflow: hidden; background: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255, 255, 255, 0.08); box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02); line-height: 0; }

.gl-social-card__embed iframe { display: block; border: 0 !important; border-radius: 22px !important; background: #fff; max-width: 100%; }

/* on laisse la largeur native */
#facebookIframe { width: 500px; height: 500px; }

#instagram-embed-1 { width: 540px; height: 500px !important; }

/* animations de halo */
@keyframes glSocialHaloFloat { 0% { transform: translate3d(0, 0, 0) scale(1); }
  25% { transform: translate3d(-12px, 10px, 0) scale(1.04); }
  50% { transform: translate3d(8px, 18px, 0) scale(1.12); }
  75% { transform: translate3d(14px, -8px, 0) scale(1.05); }
  100% { transform: translate3d(0, 0, 0) scale(1); } }

@keyframes glSocialHaloPulse { 0% { opacity: 0.5;
    filter: blur(20px); }
  50% { opacity: 1;
    filter: blur(30px); }
  100% { opacity: 0.5;
    filter: blur(20px); } }

@media (max-width: 1200px) { .gl-socials__grid { grid-template-columns: 1fr; justify-items: center; } }

@media (max-width: 767px) { .gl-socials { padding: 64px 18px; } .gl-social-card { width: 100%; max-width: 100%; padding: 22px 18px; border-radius: 22px; } .gl-social-card::before { inset: 10px; border-radius: 14px; } .gl-social-card::after { width: 190px; height: 190px; top: -60px; right: -40px; } .gl-social-card:nth-child(2)::after { left: -40px; bottom: -60px; } .gl-social-card__head { grid-template-columns: 1fr; gap: 14px; } .gl-social-card__icon { width: 62px; height: 62px; border-radius: 18px; } .gl-social-card__embed { display: block; width: 100%; } .gl-social-card__embed, .gl-social-card__embed iframe { border-radius: 16px !important; } #facebookIframe, #instagram-embed-1 { width: 100% !important; height: 420px !important; } }

@media (prefers-reduced-motion: reduce) { .gl-social-card::after { animation: none; } }

/*-------------------------------------------------------Séparation diagonale-----------------------------------------------*/
.gl-baseline { position: relative; overflow: hidden; color: #fff; isolation: isolate; clip-path: polygon(0 15%, 100% 0, 100% 85%, 0 100%); margin: 60px 0; }

.gl-baseline.secondaires { clip-path: polygon(0 0, 100% 0, 100% 85%, 0 100%); margin-top: 0; }

.gl-baseline__bg, .gl-baseline__overlay, .gl-baseline__grid { position: absolute; inset: 0; }

.gl-baseline__bg { z-index: 0; background-size: cover; background-position: center; background-attachment: fixed; }

.gl-baseline__overlay { z-index: 1; background: radial-gradient(circle at 15% 20%, rgba(225, 4, 3, 0.2), transparent 28%), radial-gradient(circle at 85% 80%, rgba(141, 0, 0, 0.22), transparent 30%), linear-gradient(110deg, rgba(36, 40, 45, 0.88) 0%, rgba(36, 40, 45, 0.62) 42%, rgba(36, 40, 45, 0.78) 100%); }

.gl-baseline__grid { z-index: 2; background-image: linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px); background-size: 60px 60px; mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent 90%); pointer-events: none; }

.gl-baseline__inner { position: relative; z-index: 3; max-width: 1400px; margin: 0 auto; padding: 160px 24px; }

.gl-baseline__content { max-width: 820px; }

.gl-baseline__eyebrow { display: inline-flex; align-items: center; min-height: 40px; padding: 0 16px; margin-bottom: 20px; border-radius: 999px; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.14); backdrop-filter: blur(10px); letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255, 255, 255, 0.78); font-family: 'Audiowide'; }

.gl-baseline h2, .gl-baseline p { margin: 0; }

.gl-baseline h2 { line-height: 1.08; max-width: 760px; }

.gl-baseline p { margin-top: 18px; line-height: 1.6; max-width: 680px; color: rgba(255, 255, 255, 0.84); }

.gl-baseline__address { display: inline-flex; align-items: center; gap: 12px; min-height: 56px; padding: 0 20px; margin-top: 28px; border-radius: 18px; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.14); backdrop-filter: blur(10px); box-shadow: 0 14px 35px rgba(0, 0, 0, 0.18); }

.gl-baseline__address i { color: #e10403; line-height: 1; }

.gl-baseline__address span { color: #fff; line-height: 1.4; }

@media (max-width: 991px) { .gl-baseline { clip-path: polygon(0 6%, 100% 0, 100% 94%, 0 100%); } .gl-baseline__inner { padding: 130px 32px; } }

@media (max-width: 767px) { .gl-baseline { clip-path: polygon(0 4%, 100% 0, 100% 96%, 0 100%); } .gl-baseline__inner { padding: 110px 18px; } .gl-baseline__address { width: 100%; padding: 14px 16px; min-height: 0; align-items: flex-start; } }

/*-----------------------------------------------------------------INTRO-------------------------------------------------------------------*/
.gl-intro { position: relative; padding: 60px 24px 150px 24px; background: radial-gradient(circle at top left, rgba(225, 4, 3, 0.08), transparent 24%), linear-gradient(180deg, #24282d 0%, #333438 100%); color: #fff; overflow: hidden; clip-path: polygon(0 0, 100% 0, 100% 85%, 0 100%); }

.gl-intro iframe { width: 100%; border-radius: 24px; max-height: 300px !important; margin: 50px auto !important; filter: grayscale(0.7) invert(1); }

.gl-intro__inner { max-width: 1400px; margin: 0 auto; position: relative; }

.gl-intro__inner::after { content: ""; position: absolute; inset: 0; z-index: 0; background-image: linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px); background-size: 60px 60px; pointer-events: none; }

.gl-intro__top { display: grid; grid-template-columns: minmax(0, 1fr) minmax(320px, 520px); gap: 80px; align-items: center; }

.gl-intro__text { min-width: 0; }

.gl-intro__heading { max-width: 840px; }

.gl-intro__eyebrow { display: inline-flex; align-items: center; min-height: 38px; padding: 0 14px; margin-bottom: 18px; border-radius: 999px; background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.1); letter-spacing: 0.08em; text-transform: uppercase; color: rgba(255, 255, 255, 0.72); font-family: 'Audiowide'; }

.gl-intro h2, .gl-intro h3, .gl-intro p { margin: 0; }

.gl-intro h2 { line-height: 1.08; color: #fff; }

.gl-intro h3 { margin-top: 14px; line-height: 1.3; color: rgba(255, 255, 255, 0.76); font-weight: 500; }

.gl-intro__content { max-width: 920px; margin-top: 28px; }

.gl-intro__content p { line-height: 1.75; color: rgba(255, 255, 255, 0.88); }

.gl-intro__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-top: 36px; z-index: 5; max-width: 1200px; }

.gl-intro__card { position: relative; padding: 24px 22px; border-radius: 24px; background: radial-gradient(circle at top left, rgba(225, 4, 3, 0.08), transparent 24%), linear-gradient(180deg, #24282d 0%, #333438 100%); border: 1px solid rgba(255, 255, 255, 0.08); box-shadow: 0 16px 40px rgba(0, 0, 0, 0.18); transition: transform 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease; text-decoration: none !important; }

.gl-intro__card:hover { transform: translateY(-4px); border-color: rgba(225, 4, 3, 0.35); box-shadow: 0 22px 50px rgba(0, 0, 0, 0.24); }

.gl-intro__card--highlight { background: linear-gradient(135deg, #6b1f1f 0%, #852828 100%); border-color: rgba(225, 4, 3, 0.26); height: fit-content; }

.gl-intro__icon { width: 58px; height: 58px; display: inline-grid; place-items: center; margin-bottom: 18px; border-radius: 18px; background: linear-gradient(135deg, rgba(225, 4, 3, 0.18) 0%, rgba(255, 255, 255, 0.08) 100%); border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); }

.gl-intro__icon i { color: #fff; line-height: 1; font-size: 1.8rem; }

.gl-intro__card p { line-height: 1.6; color: rgba(255, 255, 255, 0.9); }

.gl-intro__media { position: relative; min-height: 620px; border-radius: 30px; overflow: hidden; background: #24282d; box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28); }

.gl-intro__slider, .gl-intro__slide, .gl-intro__media-overlay, .gl-intro__media-frame { position: absolute; inset: 0; }

.gl-intro__slider { z-index: 1; }

.gl-intro__slide { opacity: 0; transform: scale(1.08); transition: opacity 1s ease, transform 5.5s ease; background-size: cover; background-position: center; background-repeat: no-repeat; will-change: opacity, transform; }

.gl-intro__slide.is-active { opacity: 1; transform: scale(1); }

.gl-intro__media-overlay { z-index: 2; background: linear-gradient(180deg, rgba(36, 40, 45, 0.08) 0%, rgba(36, 40, 45, 0.36) 100%), radial-gradient(circle at top left, rgba(225, 4, 3, 0.14), transparent 30%); pointer-events: none; }

.gl-intro__media-frame { z-index: 3; pointer-events: none; }

.gl-intro__media-frame::before { content: ""; position: absolute; inset: 16px; border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03); border-radius: 24px; }

.gl-intro__media-corner { position: absolute; width: 76px; height: 76px; }

.gl-intro__media-corner::before, .gl-intro__media-corner::after { content: ""; position: absolute; background: linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12), 0 10px 25px rgba(0, 0, 0, 0.18); }

.gl-intro__media-corner--tl { top: 16px; left: 16px; }

.gl-intro__media-corner--tl::before { top: 0; left: 0; width: 76px; height: 4px; border-radius: 24px 24px 24px 6px; }

.gl-intro__media-corner--tl::after { top: 0; left: 0; width: 4px; height: 76px; border-radius: 24px 6px 24px 24px; }

.gl-intro__media-corner--tr { top: 16px; right: 16px; }

.gl-intro__media-corner--tr::before { top: 0; right: 0; width: 76px; height: 4px; border-radius: 24px 24px 6px 24px; }

.gl-intro__media-corner--tr::after { top: 0; right: 0; width: 4px; height: 76px; border-radius: 6px 24px 24px 24px; }

.gl-intro__media-corner--bl { bottom: 16px; left: 16px; }

.gl-intro__media-corner--bl::before { bottom: 0; left: 0; width: 76px; height: 4px; border-radius: 24px 6px 24px 24px; }

.gl-intro__media-corner--bl::after { bottom: 0; left: 0; width: 4px; height: 76px; border-radius: 24px 24px 24px 6px; }

.gl-intro__media-corner--br { bottom: 16px; right: 16px; }

.gl-intro__media-corner--br::before { bottom: 0; right: 0; width: 76px; height: 4px; border-radius: 6px 24px 24px 24px; }

.gl-intro__media-corner--br::after { bottom: 0; right: 0; width: 4px; height: 76px; border-radius: 24px 24px 6px 24px; }

.gl-intro__nav { position: absolute; bottom: 24px; z-index: 4; width: 52px; height: 52px; border: 0; border-radius: 16px; display: grid; place-items: center; cursor: pointer; color: #fff; background: rgba(255, 255, 255, 0.1); border: 1px solid rgba(255, 255, 255, 0.14); backdrop-filter: blur(10px); box-shadow: 0 12px 30px rgba(0, 0, 0, 0.2); transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease; }

.gl-intro__nav:hover { transform: translateY(-2px); background: rgba(255, 255, 255, 0.16); border-color: rgba(255, 255, 255, 0.26); }

.gl-intro__nav svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.gl-intro__nav--prev { right: 84px; }

.gl-intro__nav--next { right: 24px; }

@media (max-width: 991px) { .gl-intro { padding: 90px 32px; } .gl-intro__top { grid-template-columns: 1fr; gap: 30px; } .gl-intro__media { min-height: 460px; order: -1; } }

@media (max-width: 767px) { .gl-intro { padding: 72px 18px; } .gl-intro__grid { grid-template-columns: 1fr; gap: 14px; margin-top: 28px; } .gl-intro__card { padding: 22px 18px; border-radius: 20px; } .gl-intro__media { min-height: 340px; border-radius: 22px; } .gl-intro__media-frame::before { inset: 10px; border-radius: 16px; } .gl-intro__media-corner { width: 54px; height: 54px; } .gl-intro__media-corner--tl, .gl-intro__media-corner--tr { top: 10px; } .gl-intro__media-corner--bl, .gl-intro__media-corner--br { bottom: 10px; } .gl-intro__media-corner--tl, .gl-intro__media-corner--bl { left: 10px; } .gl-intro__media-corner--tr, .gl-intro__media-corner--br { right: 10px; } .gl-intro__media-corner--tl::before, .gl-intro__media-corner--tr::before, .gl-intro__media-corner--bl::before, .gl-intro__media-corner--br::before { width: 54px; } .gl-intro__media-corner--tl::after, .gl-intro__media-corner--tr::after, .gl-intro__media-corner--bl::after, .gl-intro__media-corner--br::after { height: 54px; } .gl-intro__nav { width: 46px; height: 46px; bottom: 16px; border-radius: 14px; } .gl-intro__nav--prev { right: 68px; } .gl-intro__nav--next { right: 16px; } }

@media (prefers-reduced-motion: reduce) { .gl-intro__slide, .gl-intro__card, .gl-intro__nav { transition: none; } }

/*---------------------------------------------------------Bannières secondaires-----------------------------------------------*/
.gl-subhero { position: relative; min-height: 420px; overflow: hidden; background: #24282d; color: #fff; isolation: isolate; }

.gl-subhero__bg, .gl-subhero__overlay, .gl-subhero__grid, .gl-subhero__frame { position: absolute; inset: 0; }

.gl-subhero__bg { z-index: 0; background: linear-gradient(135deg, rgba(255, 255, 255, 0.03), transparent 40%), linear-gradient(180deg, #24282d 0%, #333438 100%); transform: scale(1.03); }

.gl-subhero__overlay { z-index: 1; background: radial-gradient(circle at 15% 20%, rgba(225, 4, 3, 0.2), transparent 28%), radial-gradient(circle at 85% 80%, rgba(141, 0, 0, 0.22), transparent 30%), linear-gradient(110deg, rgba(36, 40, 45, 0.88) 0%, rgba(36, 40, 45, 0.62) 42%, rgba(36, 40, 45, 0.78) 100%); }

.gl-subhero__grid { z-index: 2; background-image: linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px); background-size: 60px 60px; mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent 90%); pointer-events: none; }

.gl-subhero__frame { z-index: 4; pointer-events: none; }

.gl-subhero__frame::before { content: ""; position: absolute; inset: 18px; border: 1px solid rgba(255, 255, 255, 0.08); box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03); }

.gl-subhero__corner { position: absolute; width: 88px; height: 88px; }

.gl-subhero__corner::before, .gl-subhero__corner::after { content: ""; position: absolute; background: linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12), 0 10px 25px rgba(0, 0, 0, 0.18); }

.gl-subhero__corner::before { width: 88px; height: 4px; }

.gl-subhero__corner::after { width: 4px; height: 88px; }

.gl-subhero__corner--tl { top: 18px; left: 18px; }

.gl-subhero__corner--tl::before, .gl-subhero__corner--tl::after { top: 0; left: 0; }

.gl-subhero__corner--tr { top: 18px; right: 18px; }

.gl-subhero__corner--tr::before, .gl-subhero__corner--tr::after { top: 0; right: 0; }

.gl-subhero__corner--bl { bottom: 18px; left: 18px; }

.gl-subhero__corner--bl::before, .gl-subhero__corner--bl::after { bottom: 0; left: 0; }

.gl-subhero__corner--br { right: 18px; bottom: 18px; }

.gl-subhero__corner--br::before, .gl-subhero__corner--br::after { right: 0; bottom: 0; }

.gl-subhero__inner { position: relative; z-index: 3; max-width: 1400px; min-height: 420px; margin: 0 auto; padding: 80px 48px; display: grid; grid-template-columns: 240px 34px minmax(0, 1fr); align-items: center; gap: 28px; }

.gl-subhero__logo-wrap { display: flex; align-items: center; justify-content: center; }

.gl-subhero__logo { width: 100%; max-width: 180px; height: auto; display: block; filter: drop-shadow(0 14px 30px rgba(0, 0, 0, 0.2)); }

.gl-subhero__divider { position: relative; width: 1px; height: 160px; margin: 0 auto; background: linear-gradient(180deg, rgba(245, 247, 250, 0.1) 0%, rgba(255, 255, 255, 0.95) 50%, rgba(155, 163, 173, 0.18) 100%); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.04), 0 0 18px rgba(255, 255, 255, 0.12); }

.gl-subhero__divider::before { content: ""; position: absolute; top: -10px; left: 50%; width: 8px; height: 8px; border-radius: 999px; transform: translateX(-50%); background: linear-gradient(135deg, #f5f7fa 0%, #9ba3ad 100%); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12); }

.gl-subhero__divider::after { content: ""; position: absolute; bottom: -10px; left: 50%; width: 8px; height: 8px; border-radius: 999px; transform: translateX(-50%); background: linear-gradient(135deg, #f5f7fa 0%, #9ba3ad 100%); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12); }

.gl-subhero__content h1, .gl-subhero__content h2 { margin: 0; }

.gl-subhero__content h1 { line-height: 1.08; }

.gl-subhero__content h2 { margin-top: 16px; line-height: 1.35; color: rgba(255, 255, 255, 0.8); font-weight: 500; max-width: 620px; }

@media (max-width: 991px) { .gl-subhero__inner { min-height: 0; padding: 70px 32px; grid-template-columns: 1fr; gap: 24px; text-align: center; } .gl-subhero__divider { width: 140px; height: 1px; background: linear-gradient(90deg, rgba(245, 247, 250, 0.1) 0%, rgba(255, 255, 255, 0.95) 50%, rgba(155, 163, 173, 0.18) 100%); } .gl-subhero__divider::before { top: 50%; left: -10px; transform: translateY(-50%); } .gl-subhero__divider::after { bottom: auto; top: 50%; left: auto; right: -18px; transform: translateY(-50%); } .gl-subhero__content h1, .gl-subhero__content h2 { max-width: none; } .gl-subhero__frame::before { inset: 14px; } .gl-subhero__corner--tl, .gl-subhero__corner--tr { top: 14px; } .gl-subhero__corner--bl, .gl-subhero__corner--br { bottom: 14px; } .gl-subhero__corner--tl, .gl-subhero__corner--bl { left: 14px; } .gl-subhero__corner--tr, .gl-subhero__corner--br { right: 14px; } }

@media (max-width: 767px) { .gl-subhero { min-height: 0; } .gl-subhero__inner { padding: 58px 18px; } .gl-subhero__logo { max-width: 140px; } .gl-subhero__divider { width: 100px; } .gl-subhero__frame::before { inset: 10px; } .gl-subhero__corner { width: 58px; height: 58px; } .gl-subhero__corner::before { width: 58px; } .gl-subhero__corner::after { height: 58px; } .gl-subhero__corner--tl, .gl-subhero__corner--tr { top: 10px; } .gl-subhero__corner--bl, .gl-subhero__corner--br { bottom: 10px; } .gl-subhero__corner--tl, .gl-subhero__corner--bl { left: 10px; } .gl-subhero__corner--tr, .gl-subhero__corner--br { right: 10px; } }

/*----------------------------------------------------Avis Google------------------------------------------------------------------------*/
.googleReviews-div { position: relative; padding: 110px 24px; overflow: hidden; color: #fff; isolation: isolate; }

.googleReviews-div::before { content: ""; position: absolute; inset: 0; z-index: 0; background: radial-gradient(circle at 15% 20%, rgba(225, 4, 3, 0.2), transparent 28%), radial-gradient(circle at 85% 80%, rgba(141, 0, 0, 0.22), transparent 30%), linear-gradient(110deg, rgba(36, 40, 45, 0.88) 0%, rgba(36, 40, 45, 0.62) 42%, rgba(36, 40, 45, 0.78) 100%); }

.googleReviews-div::after { content: ""; position: absolute; inset: 0; z-index: 0; background-image: linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px); background-size: 60px 60px; pointer-events: none; }

.googleReviews-div > * { position: relative; z-index: 1; }

.googleReviews-div .container { max-width: 1400px; }

.googleReviews-div .container.m-4 { margin-left: auto !important; margin-right: auto !important; }

/* Cartes générales */
.googleReviews-div .card { position: relative; overflow: hidden; border: 1px solid rgba(255, 255, 255, 0.1) !important; border-radius: 28px !important; background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.04) 100%) !important; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.22) !important; backdrop-filter: blur(12px); color: #fff; }

/* Cadre intérieur subtil */
.googleReviews-div .card::before { content: ""; position: absolute; inset: 16px; border: 1px solid rgba(255, 255, 255, 0.08); border-radius: 22px; pointer-events: none; z-index: 1; }

/* Coins métalliques : paire 1 */
.googleReviews-div .card::after { content: ""; position: absolute; inset: 0; pointer-events: none; z-index: 2; background: linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) top 16px left 16px/72px 4px no-repeat, linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) top 16px left 16px/4px 72px no-repeat, linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) bottom 16px right 16px/72px 4px no-repeat, linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) bottom 16px right 16px/4px 72px no-repeat; filter: drop-shadow(0 8px 18px rgba(0, 0, 0, 0.18)); }

/* Coins métalliques : paire 2 sur un enfant existant */
.googleReviews-div .card .card-body, .googleReviews-div .container > .card > div { position: relative; }

/* En-tête principal */
.googleReviews-div .container > .card { margin-bottom: 36px; }

.googleReviews-div .avatar-google-place { border: 1px solid rgba(255, 255, 255, 0.18); background: rgba(255, 255, 255, 0.08); padding: 6px; box-shadow: 0 10px 25px rgba(0, 0, 0, 0.18); }

.googleReviews-div h3 { color: #fff; margin-bottom: 8px; }

.googleReviews-div #place-rating, .googleReviews-div .card-text, .googleReviews-div .lead, .googleReviews-div .text-muted, .googleReviews-div small { color: rgba(255, 255, 255, 0.82) !important; }

.googleReviews-div .star { color: #e10403 !important; }

/* Bouton Google */
.googleReviews-div #maps-url { display: inline-flex; align-items: center; justify-content: center; min-height: 56px; padding: 0 22px; border-radius: 18px; text-decoration: none; color: #fff !important; background: linear-gradient(135deg, #e10403 0%, #8d0000 100%); border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: 0 14px 35px rgba(225, 4, 3, 0.28); transition: transform 0.3s ease, box-shadow 0.3s ease; }

.googleReviews-div #maps-url:hover { transform: translateY(-3px); box-shadow: 0 18px 42px rgba(225, 4, 3, 0.34); }

/* Slider avis */
.googleReviews-div #google-reviews-widget .owl-stage-outer { overflow: hidden; }

.googleReviews-div #google-reviews-widget .card { min-height: 100%; }

.googleReviews-div #google-reviews-widget .card .my-2 { padding: 26px 24px 10px; }

.googleReviews-div #google-reviews-widget .card-body { padding: 0 24px 26px; }

.googleReviews-div .avatar-google-reviews { width: 52px !important; height: 52px !important; object-fit: contain; border-radius: 50%; background: rgba(255, 255, 255, 0.1); padding: 6px; border: 1px solid rgba(255, 255, 255, 0.14); }

.googleReviews-div #google-reviews-widget .card .mx-2 > div:first-child { color: #fff; }

.googleReviews-div #google-reviews-widget .card-text { margin-top: 14px; line-height: 1.65; }

/* Navigation owl */
.googleReviews-div .owl-nav { display: flex !important; justify-content: flex-end; gap: 12px; margin-top: 18px; padding-right: 24px; }

.googleReviews-div .owl-nav button { width: 52px; height: 52px; border: 0 !important; border-radius: 16px !important; display: grid; place-items: center; background: rgba(255, 255, 255, 0.1) !important; color: #fff !important; border: 1px solid rgba(255, 255, 255, 0.14) !important; backdrop-filter: blur(10px); box-shadow: 0 12px 30px rgba(0, 0, 0, 0.2); transition: transform 0.3s ease, background 0.3s ease; }

.googleReviews-div .owl-nav button:hover { transform: translateY(-2px); background: rgba(255, 255, 255, 0.16) !important; }

.googleReviews-div .owl-nav button span { font-size: 28px; line-height: 1; }

.googleReviews-div .owl-dots { margin-top: 18px; text-align: center; }

.googleReviews-div .owl-dots .owl-dot span { width: 10px; height: 10px; margin: 5px; border-radius: 999px; background: rgba(255, 255, 255, 0.22); display: block; }

.googleReviews-div .owl-dots .owl-dot.active span { background: #e10403; }

/* Responsive */
@media (max-width: 991px) { .googleReviews-div { padding: 90px 32px; } }

@media (max-width: 767px) { .googleReviews-div { padding: 72px 18px; } .googleReviews-div .card { border-radius: 22px !important; } .googleReviews-div .card::before { inset: 10px; border-radius: 16px; } .googleReviews-div .card::after { background: linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) top 10px left 10px / 52px 4px no-repeat, linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) top 10px left 10px / 4px 52px no-repeat, linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) bottom 10px right 10px / 52px 4px no-repeat, linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) bottom 10px right 10px / 4px 52px no-repeat; } .googleReviews-div .card .card-body::before, .googleReviews-div .container > .card > div::before { background: linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) top 10px right 10px / 52px 4px no-repeat, linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) top 10px right 10px / 4px 52px no-repeat, linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) bottom 10px left 10px / 52px 4px no-repeat, linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%) bottom 10px left 10px / 4px 52px no-repeat; } .googleReviews-div .owl-nav { justify-content: center; padding-right: 0; } }

/*------------------------------------------------------------------Bannière d'accueil-------------------------------------------------------------*/
.gl-hero { position: relative; min-height: 100vh; overflow: hidden; background: #24282d; color: #fff; isolation: isolate; }

.plan-hero { position: absolute; top: 0; left: 0; }

@media (min-width: 1900px) { .plan-hero { height: 370px !important; } }

@media (min-width: 1001px) { .plan-hero { height: 270px; } }

@media (max-width: 1000px) { .plan-hero { height: 200px; } }

.gl-hero__slider, .gl-hero__overlay, .gl-hero__grid, .gl-hero__slide, .gl-hero__frame { position: absolute; inset: 0; }

.gl-hero__slider { z-index: 0; }

.gl-hero__slide { opacity: 0; transform: scale(1.08); transition: opacity 1.2s ease, transform 6.5s ease; background-size: cover; background-position: center; filter: saturate(1.05) contrast(1.02); will-change: opacity, transform; }

.gl-hero__slide.is-active { opacity: 1; transform: scale(1); }

.gl-hero__overlay { z-index: 1; background: radial-gradient(circle at 15% 20%, rgba(225, 4, 3, 0.2), transparent 28%), radial-gradient(circle at 85% 80%, rgba(141, 0, 0, 0.22), transparent 30%), linear-gradient(110deg, rgba(36, 40, 45, 0.88) 0%, rgba(36, 40, 45, 0.62) 42%, rgba(36, 40, 45, 0.78) 100%); }

.gl-hero__grid { z-index: 2; background-image: linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px); background-size: 60px 60px; mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent 90%); pointer-events: none; }

.gl-hero__frame { z-index: 4; pointer-events: none; }

.gl-hero__frame::before { content: ""; position: absolute; inset: 18px; border: 1px solid rgba(255, 255, 255, 0.08); box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03); }

.gl-hero__corner { position: absolute; width: 88px; height: 88px; }

.gl-hero__corner::before, .gl-hero__corner::after { content: ""; position: absolute; background: linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12), 0 10px 25px rgba(0, 0, 0, 0.18); }

.gl-hero__corner::before { width: 88px; height: 4px; }

.gl-hero__corner::after { width: 4px; height: 88px; }

.gl-hero__corner--tl { top: 18px; left: 18px; }

.gl-hero__corner--tl::before, .gl-hero__corner--tl::after { top: 0; left: 0; }

.gl-hero__corner--tr { top: 18px; right: 18px; }

.gl-hero__corner--tr::before, .gl-hero__corner--tr::after { top: 0; right: 0; }

.gl-hero__corner--bl { bottom: 18px; left: 18px; }

.gl-hero__corner--bl::before, .gl-hero__corner--bl::after { bottom: 0; left: 0; }

.gl-hero__corner--br { right: 18px; bottom: 18px; }

.gl-hero__corner--br::before, .gl-hero__corner--br::after { right: 0; bottom: 0; }

.gl-hero__content { position: relative; z-index: 3; min-height: 100vh; max-width: 1400px; margin: 0 auto; padding: clamp(120px, 14vh, 180px) 48px 48px; display: flex; flex-direction: column; justify-content: center; align-items: flex-start; }

.gl-hero__eyebrow { display: inline-flex; align-items: center; gap: 10px; padding: 10px 16px; margin-bottom: 22px; border: 1px solid rgba(255, 255, 255, 0.16); border-radius: 999px; background: rgba(255, 255, 255, 0.08); backdrop-filter: blur(12px); box-shadow: 0 10px 35px rgba(0, 0, 0, 0.18); letter-spacing: 0.08em; text-transform: uppercase; }

.gl-hero h1, .gl-hero h2 { margin: 0; max-width: 900px; text-wrap: balance; }

.gl-hero h1 { line-height: 1.05; font-weight: 700; }

.gl-hero h2 { margin-top: 38px; max-width: 760px; line-height: 1.3; color: rgba(255, 255, 255, 0.8); font-weight: 500; font-size: 1.6rem !important; }

.gl-hero__actions { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 34px; }

.gl-btn { position: relative; display: inline-flex; align-items: center; justify-content: center; min-height: 58px; padding: 0 26px; border-radius: 18px; text-decoration: none; font-weight: 700; letter-spacing: 0.02em; transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease, background 0.35s ease; overflow: hidden; backdrop-filter: blur(10px); }

.gl-btn::before { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, rgba(255, 255, 255, 0.18), transparent 45%, rgba(255, 255, 255, 0.12)); transform: translateX(-100%); transition: transform 0.6s ease; }

.gl-btn:hover::before { transform: translateX(100%); }

.gl-btn:hover { transform: translateY(-3px); }

.gl-btn--primary { color: #fff; background: linear-gradient(135deg, #e10403 0%, #8d0000 100%); box-shadow: 0 14px 35px rgba(225, 4, 3, 0.28); }

.gl-btn--primary:hover { box-shadow: 0 18px 42px rgba(225, 4, 3, 0.34); }

.gl-btn--secondary { color: #fff; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.18); box-shadow: 0 14px 35px rgba(0, 0, 0, 0.16); }

.gl-btn--secondary:hover { border-color: rgba(255, 255, 255, 0.34); background: rgba(255, 255, 255, 0.12); }

.gl-hero__progress { position: absolute; left: 48px; bottom: 34px; z-index: 5; display: flex; gap: 10px; right: 160px; max-width: 260px; }

@media (max-width: 991px) { .gl-hero__progress { left: 32px; right: 150px; max-width: 260px; } }

@media (max-width: 767px) { .gl-hero__progress { left: 18px; right: 100px; } }

.gl-hero__progress span { position: relative; flex: 1; height: 4px; border-radius: 999px; background: rgba(255, 255, 255, 0.18); overflow: hidden; }

.gl-hero__progress span::after { content: ""; position: absolute; inset: 0; width: 0; background: linear-gradient(90deg, #d9dde2 0%, #ffffff 30%, #e10403 100%); }

.gl-hero__progress span.is-active::after { animation: glHeroProgress 6s linear forwards; }

.gl-hero__nav { position: absolute; bottom: 24px; z-index: 5; width: 54px; height: 54px; border: 0; border-radius: 18px; display: grid; place-items: center; cursor: pointer; color: #fff; background: rgba(255, 255, 255, 0.08); border: 1px solid rgba(255, 255, 255, 0.12); backdrop-filter: blur(10px); box-shadow: 0 12px 30px rgba(0, 0, 0, 0.18); transition: transform 0.3s ease, background 0.3s ease, border-color 0.3s ease; }

.gl-hero__nav:hover { transform: translateY(-2px); background: rgba(255, 255, 255, 0.14); border-color: rgba(255, 255, 255, 0.26); }

.gl-hero__nav svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.gl-hero__nav--prev { right: 92px; }

.gl-hero__nav--next { right: 24px; }

@keyframes glHeroProgress { from { width: 0; }
  to { width: 100%; } }

@media (max-width: 991px) { .gl-hero__content { padding-top: 120px; padding-bottom: 120px; padding-left: 32px; padding-right: 32px; } .gl-hero__progress { left: 32px; } .gl-hero__frame::before { inset: 14px; } .gl-hero__corner--tl, .gl-hero__corner--tr { top: 14px; } .gl-hero__corner--bl, .gl-hero__corner--br { bottom: 14px; } .gl-hero__corner--tl, .gl-hero__corner--bl { left: 14px; } .gl-hero__corner--tr, .gl-hero__corner--br { right: 14px; } }

@media (max-width: 767px) { .gl-hero__content { padding: 110px 18px 110px; align-items: stretch; } .gl-hero__actions { flex-direction: column; align-items: stretch; } .gl-btn { width: 100%; } .gl-hero__progress { left: 18px; bottom: 18px; } .gl-hero__nav { bottom: 16px; width: 46px; height: 46px; border-radius: 14px; } .gl-hero__nav--prev { right: 70px; } .gl-hero__nav--next { right: 18px; } .gl-hero__frame::before { inset: 10px; } .gl-hero__corner { width: 58px; height: 58px; } .gl-hero__corner::before { width: 58px; } .gl-hero__corner::after { height: 58px; } .gl-hero__corner--tl, .gl-hero__corner--tr { top: 10px; } .gl-hero__corner--bl, .gl-hero__corner--br { bottom: 10px; } .gl-hero__corner--tl, .gl-hero__corner--bl { left: 10px; } .gl-hero__corner--tr, .gl-hero__corner--br { right: 10px; } }

@media (prefers-reduced-motion: reduce) { .gl-hero__slide, .gl-btn, .gl-btn::before, .gl-hero__nav, .gl-hero__progress span::after { transition: none; animation: none; } }

/*-----------------------------------------------------------------Galerie 3D------------------------------------------------------------*/
.hero-sweetgarden { position: relative; overflow: hidden; display: grid; place-items: center; padding-bottom: 150px; }

/*------CARDS--------------*/
.scene, .a3d { display: grid; }

.scene { position: absolute; inset: 0; width: 100vw; height: 100%; overflow: hidden; perspective: 35em; mask: linear-gradient(90deg, transparent, black 15% 85%, transparent); z-index: 1; opacity: 0.5; }

.a3d { place-self: center; transform-style: preserve-3d; animation: ry 90s linear infinite; }

/* rotation */
@keyframes ry { to { rotate: y 1turn; } }

/* ============================= */
/* CARDS */
/* ============================= */
.hero-sweetgarden .card { grid-area: 1 / 1; /* IMPORTANT */ width: 22vw; /* largeur relative écran */ aspect-ratio: 7 / 8; object-fit: cover; border-radius: 24px !important; backface-visibility: hidden; /* calcul dynamique */ transform: rotateY(calc(var(--i) * (1turn / 9))) translateZ(calc( -1 * (0.5 * 22vw + 0.5em) / tan(0.5 * (1turn / 9)))); box-shadow: 0 25px 60px rgba(0, 0, 0, 0.5); }

/*----------------------------------------------------------Page services-------------------------------------------------------------*/
.gl-services-page { position: relative; padding: 90px 24px; overflow: hidden; background: radial-gradient(circle at top left, rgba(225, 4, 3, 0.08), transparent 24%), linear-gradient(180deg, #24282d 0%, #333438 100%); color: #fff; isolation: isolate; }

.gl-services-page__bg, .gl-services-page__overlay, .gl-services-page__grid { position: absolute; inset: 0; }

.gl-services-page__bg { z-index: 0; background: linear-gradient(135deg, rgba(255, 255, 255, 0.02), transparent 40%); }

.gl-services-page__overlay { z-index: 0; background: radial-gradient(circle at 15% 20%, rgba(225, 4, 3, 0.08), transparent 28%), radial-gradient(circle at 85% 80%, rgba(141, 0, 0, 0.08), transparent 30%); }

.gl-services-page__grid { z-index: 0; background-image: linear-gradient(#ffffff14 1px, transparent 1px), linear-gradient(90deg, #ffffff1f 1px, #00000033 1px); background-size: 60px 60px; mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.45), transparent 95%); pointer-events: none; }

.gl-services-page__inner { position: relative; z-index: 1; max-width: 1400px; margin: 0 auto; display: grid; gap: 28px; }

.gl-service-block { position: relative; padding: 38px 34px; border-radius: 30px; background: linear-gradient(180deg, rgba(255, 255, 255, 0.08) 0%, rgba(255, 255, 255, 0.04) 100%); border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: 0 20px 60px rgba(0, 0, 0, 0.22); backdrop-filter: blur(12px); overflow: hidden; }

.gl-service-block::before { content: ""; position: absolute; inset: 16px; border: 1px solid rgba(255, 255, 255, 0.08); border-radius: 22px; pointer-events: none; }

.gl-service-block__frame { position: absolute; inset: 0; pointer-events: none; }

.gl-service-block__corner { position: absolute; width: 78px; height: 78px; }

.gl-service-block__corner::before, .gl-service-block__corner::after { content: ""; position: absolute; background: linear-gradient(135deg, #f5f7fa 0%, #c8ced6 22%, #8f98a3 48%, #eef2f6 72%, #9ba3ad 100%); box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.12), 0 10px 25px rgba(0, 0, 0, 0.18); }

.gl-service-block__corner::before { width: 78px; height: 4px; }

.gl-service-block__corner::after { width: 4px; height: 78px; }

.gl-service-block__corner--tl { top: 16px; left: 16px; }

.gl-service-block__corner--tl::before, .gl-service-block__corner--tl::after { top: 0; left: 0; }

.gl-service-block__corner--tr { top: 16px; right: 16px; }

.gl-service-block__corner--tr::before, .gl-service-block__corner--tr::after { top: 0; right: 0; }

.gl-service-block__corner--bl { bottom: 16px; left: 16px; }

.gl-service-block__corner--bl::before, .gl-service-block__corner--bl::after { bottom: 0; left: 0; }

.gl-service-block__corner--br { right: 16px; bottom: 16px; }

.gl-service-block__corner--br::before, .gl-service-block__corner--br::after { right: 0; bottom: 0; }

.gl-service-block__head { position: relative; z-index: 1; display: grid; grid-template-columns: 88px minmax(0, 1fr); gap: 22px; align-items: start; margin-bottom: 28px; }

.gl-service-block__icon { width: 88px; height: 88px; display: grid; place-items: center; border-radius: 24px; background: linear-gradient(135deg, rgba(225, 4, 3, 0.2) 0%, rgba(255, 255, 255, 0.08) 100%); border: 1px solid rgba(255, 255, 255, 0.1); box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06); }

.gl-service-block__icon i { line-height: 1; color: #fff; font-size: 2.7rem; }

.gl-service-block h2, .gl-service-block p { margin: 0; }

.gl-service-block h2 { line-height: 1.1; }

.gl-service-block__head p { margin-top: 12px; line-height: 1.7; color: rgba(255, 255, 255, 0.82); max-width: 900px; }

.gl-service-block__body { position: relative; z-index: 1; }

.gl-service-block__list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }

.gl-service-item { display: flex; align-items: center; gap: 14px; min-height: 84px; padding: 20px 18px; border-radius: 20px; background: rgba(255, 255, 255, 0.06); border: 1px solid rgba(255, 255, 255, 0.08); box-shadow: 0 14px 35px rgba(0, 0, 0, 0.12); }

.gl-service-item i { flex: 0 0 auto; color: #e10403; line-height: 1; margin-top: 2px; font-size: 2rem; }

.gl-service-item span { line-height: 1.6; color: rgba(255, 255, 255, 0.94); }

@media (max-width: 991px) { .gl-services-page { padding: 80px 32px; } .gl-service-block { padding: 34px 28px; } .gl-service-block__head { grid-template-columns: 74px minmax(0, 1fr); } .gl-service-block__icon { width: 74px; height: 74px; border-radius: 20px; } .gl-service-block__list { grid-template-columns: 1fr; } }

@media (max-width: 767px) { .gl-services-page { padding: 64px 18px; } .gl-service-block { padding: 26px 18px; border-radius: 22px; } .gl-service-block::before { inset: 10px; border-radius: 14px; } .gl-service-block__head { grid-template-columns: 1fr; gap: 16px; margin-bottom: 22px; } .gl-service-block__icon { width: 64px; height: 64px; border-radius: 18px; } .gl-service-item { min-height: 0; padding: 16px 14px; border-radius: 16px; } .gl-service-block__corner { width: 54px; height: 54px; } .gl-service-block__corner::before { width: 54px; } .gl-service-block__corner::after { height: 54px; } .gl-service-block__corner--tl, .gl-service-block__corner--tr { top: 10px; } .gl-service-block__corner--bl, .gl-service-block__corner--br { bottom: 10px; } .gl-service-block__corner--tl, .gl-service-block__corner--bl { left: 10px; } .gl-service-block__corner--tr, .gl-service-block__corner--br { right: 10px; } }

/*----------------------------------------------------------CONTACT------------------------------------------------------*/
#contact { position: relative; padding: 90px 24px; overflow: hidden; background: radial-gradient(circle at 15% 20%, rgba(225, 4, 3, 0.16), transparent 28%), radial-gradient(circle at 85% 80%, rgba(141, 0, 0, 0.18), transparent 30%), linear-gradient(180deg, #24282d 0%, #333438 100%) !important; color: #fff; isolation: isolate; }

.form-floating > label { color: grey; margin-left: 5px; }

#contact::before { content: ""; position: absolute; inset: 0; z-index: 0; background-image: linear-gradient(rgba(255, 255, 255, 0.12) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.12) 1px, transparent 1px); background-size: 44px 44px; opacity: 1; pointer-events: none; }

#contact > .row { position: relative; z-index: 1; max-width: 1400px; margin: 0 auto !important; justify-content: center; }

#contact .col-lg-6.text-center { display: none; }

#contact .col-md-10.d-flex.justify-content-center.col-lg-6 { width: 100%; max-width: 860px; flex: 0 0 100%; }

#contact #formContact { position: relative; width: 100%; max-width: 760px; margin: 0 auto; padding: 36px 32px !important; border-radius: 30px !important; border: 1px solid rgba(255, 255, 255, 0.1) !important; background: linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(255, 255, 255, 0.88) 100%) !important; box-shadow: 0 24px 70px rgba(0, 0, 0, 0.28) !important; backdrop-filter: blur(10px); overflow: hidden; }

#contact #formContact::before { content: ""; position: absolute; inset: 16px; border: 1px solid rgba(51, 52, 56, 0.08); border-radius: 22px; pointer-events: none; }

#contact #formContact::after { content: ""; position: absolute; width: 280px; height: 280px; top: -90px; right: -80px; border-radius: 50%; background: radial-gradient(circle, rgba(225, 4, 3, 0.16) 0%, rgba(225, 4, 3, 0.08) 36%, rgba(225, 4, 3, 0) 72%); filter: blur(18px); pointer-events: none; animation: glFormHalo 7s ease-in-out infinite; }

#contact #formContact > * { position: relative; z-index: 1; }

#contact .form-control { min-height: 58px; border-radius: 16px !important; border: 1px solid rgba(36, 40, 45, 0.12) !important; background: rgba(255, 255, 255, 0.92) !important; box-shadow: none !important; color: #24282d !important; transition: border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease; }

#contact textarea.form-control { min-height: 170px; resize: vertical; }

#contact .form-control:focus { border-color: rgba(225, 4, 3, 0.45) !important; background: #fff !important; box-shadow: 0 0 0 0.2rem rgba(225, 4, 3, 0.12) !important; }

#contact .input-group .form-control[type="file"] { min-height: 56px; padding: 14px 16px; }

#contact #attachments { border-top-right-radius: 0 !important; border-bottom-right-radius: 0 !important; }

#contact #erase-file { min-width: 56px; border-top-right-radius: 16px !important; border-bottom-right-radius: 16px !important; border: 1px solid rgba(225, 4, 3, 0.24) !important; background: rgba(225, 4, 3, 0.06) !important; color: #e10403 !important; }

#contact #erase-file:hover { background: rgba(225, 4, 3, 0.12) !important; }

#contact .checkbox { padding: 16px 18px; border-radius: 18px; background: rgba(36, 40, 45, 0.04); border: 1px solid rgba(36, 40, 45, 0.08); }

#contact .checkbox label { color: #333438; line-height: 1.65; }

#contact .checkbox a { color: #8d0000; text-decoration: none; }

#contact .checkbox a:hover { color: #e10403; }

#contact button.btn[type="submit"] { min-height: 58px; border-radius: 18px !important; border: 1px solid rgba(255, 255, 255, 0.12) !important; background: linear-gradient(135deg, #e10403 0%, #8d0000 100%) !important; color: #fff !important; box-shadow: 0 14px 35px rgba(225, 4, 3, 0.28); transition: transform 0.3s ease, box-shadow 0.3s ease, opacity 0.3s ease; }

#contact button.btn[type="submit"]:hover { transform: translateY(-3px); box-shadow: 0 18px 42px rgba(225, 4, 3, 0.34); }

#contact button.btn[type="submit"]:active { transform: translateY(0); }

#contact .modal-content { border-radius: 24px !important; border: 1px solid rgba(36, 40, 45, 0.08) !important; box-shadow: 0 20px 60px rgba(0, 0, 0, 0.22); overflow: hidden; }

#contact .modal-header, #contact .modal-footer { border-color: rgba(36, 40, 45, 0.08); }

@keyframes glFormHalo { 0% { transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.7; }
  50% { transform: translate3d(-10px, 12px, 0) scale(1.1);
    opacity: 1; }
  100% { transform: translate3d(0, 0, 0) scale(1);
    opacity: 0.7; } }

@media (max-width: 991px) { #contact { padding: 80px 32px; } #contact #formContact { max-width: 100%; } }

@media (max-width: 767px) { #contact { padding: 64px 18px; } #contact #formContact { padding: 24px 18px !important; border-radius: 22px !important; } #contact #formContact::before { inset: 10px; border-radius: 14px; } #contact #formContact::after { width: 180px; height: 180px; top: -50px; right: -40px; } #contact .checkbox { padding: 14px 14px; border-radius: 16px; } }

@media (prefers-reduced-motion: reduce) { #contact #formContact::after, #contact .form-control, #contact button.btn[type="submit"] { animation: none; transition: none; } }

/*------------------------------------------BOUTONS-------------------------------------------*/
a.button_header, a.button_homepageScreen, a.button_homepageDoubleScreen, a.phone-number-button { position: relative !important; display: inline-flex !important; align-items: center !important; justify-content: center !important; gap: 10px !important; min-height: 56px !important; padding: 0 24px !important; border-radius: 18px !important; border: 1px solid rgba(255, 255, 255, 0.12) !important; background: linear-gradient(135deg, #e10403 0%, #8d0000 100%) !important; color: #ffffff !important; text-decoration: none !important; box-shadow: 0 14px 35px rgba(225, 4, 3, 0.28) !important; backdrop-filter: blur(10px) !important; overflow: hidden !important; transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease, opacity 0.3s ease !important; }

a.button_header::before, a.button_homepageScreen::before, a.button_homepageDoubleScreen::before, a.phone-number-button::before { content: "" !important; position: absolute !important; inset: 0 !important; background: linear-gradient(120deg, rgba(255, 255, 255, 0.2), transparent 45%, rgba(255, 255, 255, 0.1)) !important; transform: translateX(-100%) !important; transition: transform 0.6s ease !important; pointer-events: none !important; }

a.button_header:hover::before, a.button_homepageScreen:hover::before, a.button_homepageDoubleScreen:hover::before, a.phone-number-button:hover::before { transform: translateX(100%) !important; }

a.button_header:hover, a.button_homepageScreen:hover, a.button_homepageDoubleScreen:hover, a.phone-number-button:hover { transform: translateY(-3px) !important; box-shadow: 0 18px 42px rgba(225, 4, 3, 0.34) !important; color: #ffffff !important; text-decoration: none !important; }

a.button_header:focus, a.button_homepageScreen:focus, a.button_homepageDoubleScreen:focus, a.phone-number-button:focus { outline: none !important; color: #ffffff !important; box-shadow: 0 0 0 0.2rem rgba(225, 4, 3, 0.16), 0 18px 42px rgba(225, 4, 3, 0.24) !important; }

a.button_header:active, a.button_homepageScreen:active, a.button_homepageDoubleScreen:active, a.phone-number-button:active { transform: translateY(0) !important; box-shadow: 0 10px 24px rgba(225, 4, 3, 0.24) !important; }

a.button_header i, a.button_homepageScreen i, a.button_homepageDoubleScreen i, a.phone-number-button i, a.button_header svg, a.button_homepageScreen svg, a.button_homepageDoubleScreen svg, a.phone-number-button svg { position: relative !important; z-index: 1 !important; color: currentColor !important; }

a.button_header span, a.button_homepageScreen span, a.button_homepageDoubleScreen span, a.phone-number-button span { position: relative !important; z-index: 1 !important; }

/* Variante plus sobre pour certains contextes */
a.phone-number-button { background: rgba(255, 255, 255, 0.08) !important; border: 1px solid rgba(255, 255, 255, 0.18) !important; box-shadow: 0 14px 35px rgba(0, 0, 0, 0.16) !important; }

a.phone-number-button:hover { background: rgba(255, 255, 255, 0.14) !important; border-color: rgba(255, 255, 255, 0.28) !important; box-shadow: 0 18px 42px rgba(0, 0, 0, 0.22) !important; }

@media (max-width: 767px) { a.button_header, a.button_homepageScreen, a.button_homepageDoubleScreen, a.phone-number-button { min-height: 50px !important; padding: 0 18px !important; border-radius: 16px !important; } }

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