@charset "UTF-8";
@import url(main.css);
a.dropdown-item.text-color-fourth { color: white !important; }

a.dropdown-item:hover { background-color: #b9995b !important; }

a.nav-link.fs-6.dropdown-toggle.px-0.text-color-secondary.text-center { font-family: 'Trajan Pro'; font-size: 0.8rem !important; }

div.row.justify-content-center.justify-content-lg-around.text-center.text-lg-start > div:nth-child(3) > div:nth-child(2) { display: none !important; }

/*========================= CUSTOM BLOC SEO ================*/
.card.card-cover.h-100.overflow-hidden.rounded-4.shadow-lg { background-color: black; border-radius: 0px !important; border: none; }

/*============================ CUSTOM NAV BAR ===============================*/
.spacer { display: none; }

a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone { background-color: transparent; color: white !important; border-radius: 0px !important; border: 1px solid #b9995b; padding: 12px 30px !important; font-family: 'Trajan Pro'; text-transform: uppercase; font-size: 0.80rem; }

a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone:hover { transform: none; }

.fs-6.animated-border-button.obftrucs { font-family: 'Trajan Pro'; }

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

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

.logo_nav { height: 8vh !important; }

nav#navigation-bar-show { position: fixed; top: 0; left: 0; width: 100%; z-index: 999; background: transparent; border-bottom: 1px solid transparent; transition: background 0.35s ease, border-color 0.35s ease, box-shadow 0.35s ease, backdrop-filter 0.35s ease; }

/* Effet quand la page est scrollée */
nav#navigation-bar-show.is-scrolled { background: rgba(0, 0, 0, 0.86); backdrop-filter: blur(14px); border-bottom: 1px solid rgba(185, 153, 91, 0.28); box-shadow: 0 14px 34px rgba(0, 0, 0, 0.35); }

/* Logo un peu plus vivant au scroll */
nav#navigation-bar-show img { transition: transform 0.35s ease, opacity 0.35s ease; }

nav#navigation-bar-show.is-scrolled img { transform: scale(0.92); }

/* 📱 Responsive : navbar TOUJOURS visible */
@media (max-width: 991px) { .navbar { background-color: rgba(0, 0, 0, 0.4) !important; backdrop-filter: blur(14px); } }

/* Responsive */
@media (max-width: 768px) { nav#navigation-bar-show.is-scrolled { background: rgba(0, 0, 0, 0.94); } nav#navigation-bar-show a::after { display: none; } }

.fs-6.animated-border-button.obftrucs.nav-current { color: #b9995b; }

/*=============================== CUSTOM COOKIES ===============================*/
div#termsfeed-com---nb { border-radius: 0px; margin: 10px; }

/*============================================================================================================ HERO D'ACCUEIL ======================================================================================================================*/
:root { --tbg-black: #000000; --tbg-white: #ffffff; --tbg-gold: #b9995b; --tbg-red: #a73d2d; }

.tbg-hero-minimal { position: relative; min-height: 100vh; padding: 120px 7%; background-image: url("https://firebasestorage.googleapis.com/v0/b/refpro-app-ca244.appspot.com/o/customers%2FVYbxGNzRX9cQeXFEKURpBajZ3kd2%2Fimages%2F03d1e05d-b99f-41fd-b927-0690f310059b_ln8i.webp?alt=media&token=89b5936a-2ea9-47bb-85e1-9e719d901368"); background-size: cover; background-position: center; background-repeat: no-repeat; color: var(--tbg-white); display: flex; align-items: center; justify-content: center; text-align: center; overflow: hidden; }

.tbg-hero-minimal::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(0, 0, 0, 0.56), rgba(0, 0, 0, 0.68)); z-index: 1; }

.tbg-hero-minimal::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at center, rgba(185, 153, 91, 0.12), transparent 34%); z-index: 2; pointer-events: none; }

.tbg-hero-minimal__content { position: relative; z-index: 3; max-width: 1500px; }

.tbg-hero-minimal h1 { margin: 0; }

.tbg-hero-minimal__kicker { display: block; margin: 0 0 18px; font-family: "Minion Pro", serif; font-size: clamp(1rem, 1.3vw, 1.25rem); font-style: italic; font-weight: 400; line-height: 1.4; letter-spacing: 0; text-transform: none; color: rgba(255, 255, 255, 0.82); }

.tbg-hero-minimal__title { display: block; font-family: "Trajan Pro", serif; font-size: clamp(2.4rem, 6vw, 5.8rem); font-weight: 400; line-height: 1.05; letter-spacing: 0.04em; text-transform: uppercase; color: var(--tbg-white); }

.tbg-hero-minimal__subtitle { margin: 22px 0 0; font-family: "Trajan Pro", serif; font-size: clamp(0.78rem, 1vw, 0.95rem); letter-spacing: 0.16em; text-transform: uppercase; color: var(--tbg-gold); }

.tbg-hero-minimal__btn { display: inline-flex; align-items: center; justify-content: center; margin-top: 34px; padding: 14px 28px; border: 1px solid var(--tbg-gold); background: transparent; color: var(--tbg-white); font-family: "Trajan Pro", serif; font-size: 0.75rem; letter-spacing: 0.13em; text-transform: uppercase; text-decoration: none; transition: all 0.35s ease !important; }

a.grow.button_header.text-color-fourth.mx-3.mx-lg-2.p-2.rounded-pill.text-decoration-none.button-header-telephone:hover, .tbg-hero-minimal__btn:hover { background: var(--tbg-red); border-color: var(--tbg-red); color: var(--tbg-white); transform: translateY -3px; }

.tbg-scroll-indicator { position: absolute; left: 50%; bottom: 34px; z-index: 5; width: 34px; height: 46px; transform: translateX(-50%); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 0; text-decoration: none; }

.tbg-scroll-indicator span { display: block; width: 18px; height: 18px; border-right: 1px solid #b9995b; border-bottom: 1px solid #b9995b; transform: rotate(45deg); animation: tbg-scroll-arrow 1.6s infinite; }

.tbg-scroll-indicator span:nth-child(2) { margin-top: -6px; animation-delay: 0.25s; }

@keyframes tbg-scroll-arrow { 0% { opacity: 0;
    transform: rotate(45deg) translate(-6px, -6px); }
  45% { opacity: 1; }
  100% { opacity: 0;
    transform: rotate(45deg) translate(6px, 6px); } }

.tbg-scroll-indicator:hover span { border-color: #a73d2d; }

@media (max-width: 768px) { .tbg-scroll-indicator { bottom: 24px; } .tbg-scroll-indicator span { width: 15px; height: 15px; } }

/* Responsive */
@media (max-width: 768px) { .tbg-hero-minimal { min-height: 100vh; padding: 100px 6%; } .tbg-hero-minimal h1 { letter-spacing: 0.05em; } .tbg-hero-minimal__subtitle { line-height: 1.8; } }

@media (max-width: 480px) { .tbg-hero-minimal { min-height: 100vh; padding: 90px 5%; } .tbg-hero-minimal__btn { width: 100%; max-width: 280px; } }

/*========================================================================================================== PRESENTATION PAGE D'ACCUEIL ========================================================================================================*/
:root { --tbg-black: #000000; --tbg-white: #ffffff; --tbg-gold: #b9995b; --tbg-red: #a73d2d; }

.tbg-presentation { position: relative; padding: 120px 7%; background: var(--tbg-black); color: var(--tbg-white); overflow: hidden; }

.tbg-presentation::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 20% 20%, rgba(185, 153, 91, 0.07), transparent 28%), radial-gradient(circle at 85% 80%, rgba(167, 61, 45, 0.06), transparent 24%); pointer-events: none; }

.tbg-presentation__inner { position: relative; z-index: 1; max-width: 1450px; margin: 0 auto; display: grid; grid-template-columns: 1fr 0.85fr; gap: 90px; align-items: center; }

/* Galerie carrée */
.tbg-presentation__gallery { position: relative; width: 100%; aspect-ratio: 1 / 1; max-width: 680px; display: grid; grid-template-columns: 1.08fr 0.92fr; grid-template-rows: 0.92fr 1.08fr; gap: 28px; }

.tbg-presentation__img { position: relative; overflow: hidden; border: 1px solid rgba(185, 153, 91, 0.55); background: #111; }

.tbg-presentation__img::before { content: ""; position: absolute; inset: 14px; border: 1px solid rgba(185, 153, 91, 0.28); z-index: 2; pointer-events: none; }

.tbg-presentation__img img { width: 100%; height: 100%; display: block; object-fit: cover; filter: brightness(0.72) contrast(1.08) saturate(0.92); transition: transform 0.7s ease, filter 0.7s ease; }

/* Asymétrie légère */
.tbg-presentation__img--one { transform: translateY(-18px); }

.tbg-presentation__img--two { transform: translateY(16px); }

.tbg-presentation__img--three { transform: translateY(-4px); }

.tbg-presentation__img--four { transform: translateY(26px); }

.tbg-presentation__content { max-width: 750px; }

.tbg-presentation__kicker { margin: 0 0 20px; font-family: "Minion Pro", serif; font-size: 1.08rem; font-style: italic; color: var(--tbg-gold); }

.tbg-presentation h2 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2rem, 3.6vw, 4rem); font-weight: 400; line-height: 1.12; letter-spacing: 0.07em; text-transform: uppercase; color: var(--tbg-white); }

.tbg-presentation h2 span { display: block; color: var(--tbg-gold); }

.tbg-presentation__line { width: 86px; height: 1px; margin: 30px 0; background: var(--tbg-gold); }

.tbg-presentation p { margin: 0 0 18px; font-family: "Minion Pro", serif; font-size: 1.1rem; line-height: 1.78; color: rgba(255, 255, 255, 0.82); }

.tbg-presentation__btn { display: inline-flex; align-items: center; justify-content: center; margin-top: 34px; padding: 14px 28px; border: 1px solid var(--tbg-gold); background: transparent; color: var(--tbg-white); font-family: "Trajan Pro", serif; font-size: 0.75rem; letter-spacing: 0.13em; text-transform: uppercase; text-decoration: none; transition: all 0.35s ease; }

.tbg-presentation__btn:hover { background: var(--tbg-red); border-color: var(--tbg-red); color: var(--tbg-white); transform: translateY(-3px); }

@media (max-width: 1100px) { .tbg-presentation__inner { grid-template-columns: 1fr; gap: 70px; } .tbg-presentation__gallery { margin: 0 auto; } .tbg-presentation__content { max-width: 820px; } }

@media (max-width: 768px) { .tbg-presentation { padding: 80px 6%; } .tbg-presentation__gallery { max-width: 100%; gap: 18px; } .tbg-presentation__img--one, .tbg-presentation__img--two, .tbg-presentation__img--three, .tbg-presentation__img--four { transform: none; } .tbg-presentation h2 { letter-spacing: 0.045em; } }

@media (max-width: 560px) { .tbg-presentation { padding: 65px 5%; } .tbg-presentation__inner { gap: 45px; } .tbg-presentation__gallery { grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 10px; } .tbg-presentation__img::before { inset: 8px; } .tbg-presentation p { font-size: 1.02rem; line-height: 1.7; } .tbg-presentation__btn { width: 100%; text-align: center; } }

/*========================================================================================================== Présentation David =============================================================================================================*/
.pres_david { text-align: center !important; }

/*========================================================================================================== LES PRESTATIONS ACCUEIL =============================================================================================================*/
.tbg-services { padding: 120px 7%; background: #000000; color: #ffffff; }

.tbg-services__inner { max-width: 1450px; margin: 0 auto; }

.tbg-services__heading { max-width: 1300px; margin: 0 auto 70px; text-align: center; }

.tbg-services__kicker { margin-bottom: 20px; font-family: "Minion Pro", serif; font-size: 1.1rem; font-style: italic; color: #b9995b; }

.tbg-services h2 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2rem, 4vw, 4.4rem); font-weight: 400; line-height: 1.12; letter-spacing: 0.07em; text-transform: uppercase; color: #ffffff; }

.tbg-services h2 span { display: block; color: #b9995b; }

.tbg-services__heading p { max-width: 720px; margin: 26px auto 20px; font-family: "Minion Pro", serif; font-size: 1.12rem; line-height: 1.75; color: rgba(255, 255, 255, 0.82); }

.tbg-services__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 22px; }

.tbg-service { position: relative; display: block; min-height: 520px; overflow: hidden; border: 1px solid rgba(185, 153, 91, 0.45); background: #111111; color: inherit; text-decoration: none; cursor: pointer; }

.tbg-service:focus-visible { outline: 2px solid #b9995b; outline-offset: 6px; }

.tbg-service::before { content: ""; position: absolute; inset: 14px; border: 1px solid rgba(185, 153, 91, 0.25); z-index: 3; pointer-events: none; }

.tbg-service img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(0.78) contrast(1.05); transition: transform 0.8s ease, filter 0.8s ease; }

.tbg-service::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0, 0, 0, 0.68) 0%, rgba(0, 0, 0, 0.28) 45%, rgba(0, 0, 0, 0.05) 100%); z-index: 1; }

.tbg-service__content { position: relative; z-index: 2; min-height: 520px; padding: 34px; display: flex; flex-direction: column; justify-content: flex-end; transform: translateY(78px); transition: transform 0.45s ease; }

.tbg-service__content span { margin-bottom: 14px; font-family: "Trajan Pro", serif; font-size: 0.75rem; letter-spacing: 0.16em; color: #b9995b; }

.tbg-service h3 { margin: 0; font-family: "Trajan Pro", serif; font-size: 1.45rem; font-weight: 400; letter-spacing: 0.08em; text-transform: uppercase; color: #ffffff; }

.tbg-service p { max-width: 95%; margin: 18px 0 0; font-family: "Minion Pro", serif; font-size: 1.02rem; line-height: 1.65; color: rgba(255, 255, 255, 0.84); opacity: 0; transform: translateY(18px); transition: opacity 0.45s ease, transform 0.45s ease; }

.tbg-service:hover img { transform: scale(1.06); filter: brightness(0.72) contrast(1.1); }

.tbg-service:hover .tbg-service__content { transform: translateY(0); }

.tbg-service:hover p { opacity: 1; transform: translateY(0); }

@media (max-width: 1100px) { .tbg-services { padding: 90px 6%; } .tbg-services__grid { grid-template-columns: repeat(2, 1fr); } .tbg-service, .tbg-service__content { min-height: 430px; } .tbg-service__content { transform: translateY(0); } .tbg-service p { opacity: 1; transform: none; } }

@media (max-width: 650px) { .tbg-services { padding: 75px 5%; } .tbg-services__heading { margin-bottom: 45px; } .tbg-services h2 { letter-spacing: 0.045em; } .tbg-services__heading p { font-size: 1.02rem; line-height: 1.65; } .tbg-services__grid { grid-template-columns: 1fr; gap: 18px; } .tbg-service, .tbg-service__content { min-height: 360px; } .tbg-service__content { padding: 28px; } .tbg-service h3 { font-size: 1.25rem; } }

/*========================================================================================================= BLOC PHOTOS + CITATION ==============================================================================================================*/
.tbg-quote { position: relative; padding: 180px 7%; overflow: hidden; }

.tbg-quote__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; z-index: 0; }

.tbg-quote::before { content: ""; position: absolute; inset: 0; background: linear-gradient(rgba(0, 0, 0, 0.38), rgba(0, 0, 0, 0.48)); z-index: 1; }

.tbg-quote::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at center, rgba(185, 153, 91, 0.18), transparent 48%); z-index: 2; pointer-events: none; }

.tbg-quote__content { position: relative; z-index: 3; max-width: 1100px; margin: 0 auto; text-align: center; }

.tbg-quote__content p { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(1.15rem, 1.8vw, 2.2rem); line-height: 1.55; letter-spacing: 0.05em; text-transform: uppercase; color: rgba(255, 255, 255, 0.82); }

.tbg-quote__content p::before, .tbg-quote__content p::after { content: ""; display: block; width: 90px; height: 1px; margin: 28px auto; background: #b9995b; }

@media (max-width: 768px) { .tbg-quote { padding: 120px 6%; } .tbg-quote__content p { line-height: 1.6; letter-spacing: 0.04em; } .tbg-quote__content p::before, .tbg-quote__content p::after { width: 60px; margin: 22px auto; } }

@media (max-width: 520px) { .tbg-quote { padding: 90px 5%; } }

/*========================================================================================================== GALERIE D'IMAGES ACCUEIL ==========================================================================================================*/
.tbg-gallery { padding: 120px 4%; background: #000000; color: #ffffff; overflow: hidden; }

.tbg-gallery__grid { display: grid; grid-template-columns: repeat(6, 1fr); grid-auto-rows: 120px; gap: 18px; }

.tbg-gallery__item { width: 100%; height: 100%; object-fit: cover; display: block; filter: brightness(0.78) contrast(1.08) saturate(0.9); transition: transform 0.6s ease, filter 0.6s ease; }

.tbg-gallery__item { grid-column: span 1; grid-row: span 2; }

.tbg-gallery__item.tall { grid-row: span 4; }

.tbg-gallery__item.wide { grid-column: span 2; grid-row: span 2; }

.tbg-gallery__item.large { grid-column: span 2; grid-row: span 4; }

@media (max-width: 1000px) { .tbg-gallery__grid { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 110px; } }

@media (max-width: 700px) { .tbg-gallery { padding: 80px 5%; } .tbg-gallery__grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 120px; gap: 12px; } .tbg-gallery__item, .tbg-gallery__item.wide, .tbg-gallery__item.large { grid-column: span 1; grid-row: span 2; } .tbg-gallery__item.tall { grid-row: span 3; } }

/*============================================================================================================ LA CARTE ========================================================================================================================*/
.tbg-card-preview { padding: 120px 7%; background: #000000; color: #ffffff; }

.tbg-card-preview__inner { max-width: 1250px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; align-items: stretch; gap: 70px; }

.tbg-card-preview__content { max-width: 700px; align-self: center; }

.tbg-card-preview__kicker { margin: 0 0 18px; font-family: "Minion Pro", serif; font-size: 1.08rem; font-style: italic; color: #b9995b; }

.tbg-card-preview h2 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2rem, 3.6vw, 4rem); font-weight: 400; line-height: 1.12; letter-spacing: 0.07em; text-transform: uppercase; }

.tbg-card-preview h2 span { display: block; color: #b9995b; }

.tbg-card-preview__content p { margin: 28px 0 20px; font-family: "Minion Pro", serif; font-size: 1.1rem; line-height: 1.75; color: rgba(255, 255, 255, 0.82); }

.tbg-card-preview__btn { display: inline-flex; align-items: center; justify-content: center; margin-top: 34px; padding: 14px 28px; border: 1px solid #b9995b; background: transparent; color: #ffffff; font-family: "Trajan Pro", serif; font-size: 0.75rem; letter-spacing: 0.13em; text-transform: uppercase; text-decoration: none; transition: all 0.35s ease; }

.tbg-card-preview__btn:hover { background: #a73d2d; border-color: #a73d2d; color: #ffffff; transform: translateY(-3px); }

.tbg-card-preview__media { position: relative; overflow: hidden; height: 100%; min-height: unset; border: 1px solid rgba(185, 153, 91, 0.45); }

.tbg-card-preview__media::before { content: ""; position: absolute; inset: 16px; border: 1px solid rgba(185, 153, 91, 0.25); z-index: 2; pointer-events: none; }

.tbg-card-preview__media img { width: 100%; height: 100%; min-height: unset; display: block; object-fit: cover; filter: brightness(0.78) contrast(1.08); transition: transform 0.7s ease, filter 0.7s ease; }

@media (max-width: 900px) { .tbg-card-preview { padding: 80px 6%; } .tbg-card-preview__inner { grid-template-columns: 1fr; gap: 45px; } .tbg-card-preview__content { max-width: 100%; text-align: center; } .tbg-card-preview__media, .tbg-card-preview__media img { min-height: 360px; } }

@media (max-width: 520px) { .tbg-card-preview { padding: 65px 5%; } .tbg-card-preview__content p { font-size: 1.02rem; line-height: 1.65; } .tbg-card-preview__btn { width: 100%; } .tbg-card-preview__media, .tbg-card-preview__media img { min-height: 280px; } }

/*=========================================================================================================== ZONE D'INTERVENTION ===============================================================================================================*/
.tbg-zone-band { width: 100%; padding: 70px 6%; background: #000000; color: #ffffff; display: grid; grid-template-columns: 36% 64%; align-items: center; gap: 48px; box-sizing: border-box; }

.tbg-zone-band__kicker { margin: 0 0 16px; font-family: "Minion Pro", serif; font-size: 1.25rem; font-style: italic; color: #b9995b; }

.tbg-zone-band h2 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2rem, 3vw, 3.2rem); font-weight: 400; line-height: 1.08; letter-spacing: 0.03em; text-transform: uppercase; color: #ffffff; }

.tbg-zone-band h2 span { display: block; }

.tbg-zone-band__line { width: 48px; height: 1px; margin: 30px 0 24px; background: #b9995b; }

.tbg-zone-band p { max-width: 520px; margin: 0 0 20px; font-family: "Minion Pro", serif; font-size: 1.1rem; line-height: 1.65; color: rgba(255, 255, 255, 0.82); }

.tbg-zone-band__map { min-height: 430px; border: 1px solid rgba(185, 153, 91, 0.45); overflow: visible; display: flex; align-items: center; justify-content: center; border-radius: 150px; }

.tbg-zone-band__map img { width: 100%; height: auto; max-height: 430px; object-fit: contain; display: block; }

@media (max-width: 1000px) { .tbg-zone-band { grid-template-columns: 1fr; padding: 75px 6%; gap: 42px; } .tbg-zone-band h2 { font-size: clamp(2.3rem, 8vw, 3.6rem); } .tbg-zone-band__map { height: 360px; } }

@media (max-width: 520px) { .tbg-zone-band { padding: 60px 5%; } .tbg-zone-band__map { height: 300px; } }

@media (max-width: 393px) { .tbg-zone-band { padding: 55px 5%; grid-template-columns: 1fr; gap: 34px; } .tbg-zone-band__kicker { font-size: 1.05rem; margin-bottom: 12px; } .tbg-zone-band h2 { font-size: 2rem; line-height: 1.12; letter-spacing: 0.025em; } .tbg-zone-band__line { width: 42px; margin: 22px 0 20px; } .tbg-zone-band p { font-size: 1rem; line-height: 1.6; } .tbg-zone-band__btn { width: 100%; justify-content: center; margin-top: 24px; padding: 13px 18px; font-size: 0.68rem; } .tbg-zone-band__map { height: 280px; } .tbg-zone-band__map iframe { height: 100%; } }

/*================================================================================================================== BOUTON FIXE ===============================================================================================================*/
/* Bouton fixe */
.tbg-fixed-card-btn { position: fixed; right: 28px; bottom: 28px; z-index: 999; padding: 15px 24px; border: 1px solid #A73D2D; background: #A73D2D; color: #ffffff; font-family: "Trajan Pro", serif; font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; cursor: pointer; transition: all 0.3s ease; }

.tbg-fixed-card-btn:hover { background: #b9995b; border-color: #b9995b; color: #000000; transform: translateY(-3px); }

/* Modal */
.tbg-card-modal { position: fixed; inset: 0; z-index: 1000; display: none; background: rgba(0, 0, 0, 0.92); }

.tbg-card-modal.is-open { display: block; }

.tbg-card-modal__overlay { position: absolute; inset: 0; }

/* Galerie des cartes */
.tbg-card-modal__box--gallery { position: absolute; top: 5vh; left: 50%; width: 720px; height: 90vh; transform: translateX(-50%); padding: 0; background: transparent; border: none; overflow-y: auto; scrollbar-width: thin; scrollbar-color: #b9995b #000000; }

.tbg-card-modal__box--gallery img { width: 100%; height: auto; display: block; margin-bottom: 22px; }

.tbg-card-modal__box--gallery img:last-child { margin-bottom: 0; }

/* Croix */
.tbg-card-modal__close { position: fixed; top: 24px; right: 28px; z-index: 1002; width: 42px; height: 42px; border: 1px solid rgba(185, 153, 91, 0.55); background: rgba(0, 0, 0, 0.65); color: #ffffff; font-size: 1.7rem; line-height: 1; cursor: pointer; transition: all 0.3s ease; }

.tbg-card-modal__close:hover { background: #A73D2D; border-color: #A73D2D; }

/* Responsive */
@media (max-width: 520px) { .tbg-fixed-card-btn { right: 16px; bottom: 16px; padding: 13px 18px; font-size: 0.65rem; } .tbg-card-modal__box--gallery { top: 7vh; width: 94vw; height: 90vh; } .tbg-card-modal__close { top: 14px; right: 14px; width: 38px; height: 38px; font-size: 1.5rem; } }

/*==================================================================================================== EN TETE - PAGE SECONDAIRE ===============================================================================================================*/
.tbg-page-head { position: relative; min-height: 420px; padding: 90px 7%; background: #000000; color: #ffffff; overflow: hidden; display: flex; align-items: center; }

.tbg-page-head__bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(0.68) contrast(1.04); z-index: 1; }

.tbg-page-head__overlay { position: absolute; inset: 0; z-index: 2; background: linear-gradient(90deg, rgba(0, 0, 0, 0.46) 0%, rgba(0, 0, 0, 0.32) 45%, rgba(0, 0, 0, 0.18) 100%); }

.tbg-page-head__inner { position: relative; z-index: 3; width: 100%; max-width: 1250px; margin: 0 auto; display: grid; grid-template-columns: 0.8fr 1px 1.2fr; align-items: center; gap: 48px; }

.tbg-page-head__brand { display: flex; justify-content: center; max-width: 700px; }

.tbg-page-head__brand img { max-width: 260px; width: 100%; height: auto; display: block; }

.tbg-page-head__line { width: 1px; height: 185px; background: #b9995b; }

.tbg-page-head__content p:first-child { margin: 0 0 14px; font-family: "Minion Pro", serif; font-size: 1.1rem; font-style: italic; color: rgba(255, 255, 255, 0.82); }

.tbg-page-head h1 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2.2rem, 4vw, 4.2rem); font-weight: 400; line-height: 1.08; letter-spacing: 0.06em; text-transform: uppercase; color: #ffffff; }

.tbg-page-head h1 span { display: block; color: #B9995B; }

.tbg-page-head__sep { width: 58px; height: 1px; margin: 24px 0 20px; background: #b9995b; }

.tbg-page-head__text { max-width: 560px; margin: 0; font-family: "Minion Pro", serif; font-size: 1.08rem; line-height: 1.65; color: rgba(255, 255, 255, 0.84); }

@media (max-width: 850px) { .tbg-page-head { min-height: auto; padding: 100px 6%; } .tbg-page-head__inner { grid-template-columns: 1fr; gap: 28px; text-align: center; } .tbg-page-head__line { width: 70px; height: 1px; margin: 0 auto; } .tbg-page-head__brand img { max-width: 210px; } .tbg-page-head__sep { margin: 22px auto 18px; } .tbg-page-head__text { margin: 0 auto; } }

@media (max-width: 480px) { .tbg-page-head { padding: 100px 5%; } .tbg-page-head__brand img { max-width: 180px; } .tbg-page-head h1 { font-size: 2rem; letter-spacing: 0.04em; } .tbg-page-head__text { font-size: 1rem; } }

/*=========================================================================================================== LE CONCEPT ======================================================================================================================*/
.tbg-concept-block { padding: 120px 7%; background: #000000; color: #ffffff; overflow: hidden; }

.tbg-concept-block__inner { max-width: 1350px; margin: 0 auto; display: grid; grid-template-columns: 0.95fr 1.05fr; gap: 80px; align-items: center; }

.tbg-concept-block__content { max-width: 620px; }

.tbg-concept-block__kicker { margin: 0 0 18px; font-family: "Minion Pro", serif; font-size: 1.1rem; font-style: italic; color: #b9995b; }

.tbg-concept-block h2 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2rem, 3.7vw, 4rem); font-weight: 400; line-height: 1.12; letter-spacing: 0.06em; text-transform: uppercase; color: #ffffff; }

.tbg-concept-block h2 span { display: block; color: #b9995b; }

.tbg-concept-block__line { width: 70px; height: 1px; margin: 30px 0 26px; background: #b9995b; }

.tbg-concept-block p { margin: 0 0 18px; font-family: "Minion Pro", serif; font-size: 1.08rem; line-height: 1.75; color: rgba(255, 255, 255, 0.82); }

.tbg-concept-block__media { position: relative; min-height: 520px; overflow: hidden; border: 1px solid rgba(185, 153, 91, 0.45); }

.tbg-concept-block__media::before { content: ""; position: absolute; inset: 16px; border: 1px solid rgba(185, 153, 91, 0.25); z-index: 2; pointer-events: none; }

.tbg-concept-block__media img { width: 100%; height: 100%; min-height: 520px; display: block; object-fit: cover; filter: brightness(0.78) contrast(1.08); transition: transform 0.7s ease, filter 0.7s ease; }

@media (max-width: 900px) { .tbg-concept-block { padding: 80px 6%; } .tbg-concept-block__inner { grid-template-columns: 1fr; gap: 45px; } .tbg-concept-block__content { max-width: 100%; } .tbg-concept-block__media, .tbg-concept-block__media img { min-height: 380px; } }

@media (max-width: 520px) { .tbg-concept-block { padding: 65px 5%; } .tbg-concept-block h2 { letter-spacing: 0.04em; } .tbg-concept-block p { font-size: 1.02rem; line-height: 1.65; } .tbg-concept-block__media, .tbg-concept-block__media img { min-height: 280px; } .tbg-concept-block__media::before { inset: 10px; } }

/*======================================================================================================= PRODUITS LOCAUX & CIRCUIT COURT =====================================================================================================*/
.tbg-local-products { padding: 120px 7%; background: #000000; color: #ffffff; overflow: hidden; }

.tbg-local-products__inner { max-width: 1350px; margin: 0 auto; display: grid; grid-template-columns: 1fr 0.9fr 1fr; gap: 48px; align-items: center; }

.tbg-local-products__side { text-align: left; }

.tbg-local-products__kicker { margin: 0 0 16px; font-family: "Minion Pro", serif; font-size: 1.1rem; font-style: italic; color: rgba(255, 255, 255, 0.82); }

.tbg-local-products h2 { margin: 0 0 26px; font-family: "Trajan Pro", serif; font-size: clamp(1.7rem, 2.6vw, 3rem); font-weight: 400; line-height: 1.15; letter-spacing: 0.06em; text-transform: uppercase; color: #ffffff; }

.tbg-local-products h2 span { color: #b9995b; }

.tbg-local-products__side p:not(.tbg-local-products__kicker) { margin: 0 0 18px; font-family: "Minion Pro", serif; font-size: 1.08rem; line-height: 1.75; color: rgba(255, 255, 255, 0.82); }

.tbg-local-products__image { position: relative; min-height: 460px; overflow: hidden; border: 1px solid rgba(185, 153, 91, 0.45); }

.tbg-local-products__image::before { content: ""; position: absolute; inset: 14px; border: 1px solid rgba(185, 153, 91, 0.25); z-index: 2; pointer-events: none; }

.tbg-local-products__image img { width: 100%; height: 100%; min-height: 460px; display: block; object-fit: cover; filter: brightness(0.78) contrast(1.08); }

.tbg-local-products__btn { display: inline-flex; margin-top: 20px; padding: 14px 28px; border: 1px solid #b9995b; color: #ffffff; font-family: "Trajan Pro", serif; font-size: 0.72rem; letter-spacing: 0.13em; text-transform: uppercase; text-decoration: none; transition: all 0.35s ease; }

.tbg-local-products__btn:hover { background: #a73d2d; border-color: #a73d2d; }

@media (max-width: 950px) { .tbg-local-products { padding: 80px 6%; } .tbg-local-products__inner { grid-template-columns: 1fr; gap: 42px; } .tbg-local-products__image { order: -1; } .tbg-local-products__image, .tbg-local-products__image img { min-height: 360px; } }

@media (max-width: 520px) { .tbg-local-products { padding: 65px 5%; } .tbg-local-products__image, .tbg-local-products__image img { min-height: 280px; } .tbg-local-products h2 { font-size: 1.7rem; } .tbg-local-products__side p:not(.tbg-local-products__kicker) { font-size: 1.02rem; line-height: 1.65; } .tbg-local-products__btn { width: 100%; justify-content: center; } }

/*========================================================================================================= COMMENT CA SE PASSE ? =============================================================================================================*/
.tbg-process { padding: 120px 7%; background: #000000; color: #ffffff; overflow: hidden; }

.tbg-process__inner { max-width: 1350px; margin: 0 auto; }

.tbg-process__heading { max-width: 1300px; margin: 0 auto 70px; text-align: center; }

.tbg-process__kicker { margin: 0 0 20px; font-family: "Minion Pro", serif; font-size: 1.1rem; font-style: italic; color: #b9995b; }

.tbg-process h2 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2rem, 3.8vw, 4rem); font-weight: 400; line-height: 1.12; letter-spacing: 0.06em; text-transform: uppercase; }

.tbg-process h2 span { display: block; color: #b9995b; }

.tbg-process__heading p { margin: 26px auto 20px; max-width: 720px; font-family: "Minion Pro", serif; font-size: 1.08rem; line-height: 1.75; color: rgba(255, 255, 255, 0.82); }

.tbg-process__steps { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(185, 153, 91, 0.45); border-bottom: 1px solid rgba(185, 153, 91, 0.45); }

.tbg-process__step { position: relative; padding: 42px 28px; border-right: 1px solid rgba(185, 153, 91, 0.28); }

.tbg-process__step:last-child { border-right: none; }

.tbg-process__step span { display: inline-block; margin-bottom: 28px; font-family: "Trajan Pro", serif; font-size: 0.8rem; letter-spacing: 0.16em; color: #b9995b; }

.tbg-process__step h3 { margin: 0 0 16px; font-family: "Trajan Pro", serif; font-size: 1.25rem; font-weight: 400; letter-spacing: 0.07em; text-transform: uppercase; }

.tbg-process__step p { margin: 0; font-family: "Minion Pro", serif; font-size: 1.02rem; line-height: 1.65; color: rgba(255, 255, 255, 0.78); }

.tbg-process__step::after { content: ""; position: absolute; left: 28px; top: 78px; width: 34px; height: 1px; background: #a73d2d; }

.tbg-process__cta-simple { margin-top: 55px; text-align: center; }

.tbg-process__btn { display: inline-flex; justify-content: center; align-items: center; margin-top: 32px; padding: 14px 28px; border: 1px solid #b9995b; color: #ffffff; font-family: "Trajan Pro", serif; font-size: 0.72rem; letter-spacing: 0.13em; text-transform: uppercase; text-decoration: none; transition: all 0.35s ease; }

.tbg-process__btn:hover { background: #a73d2d; border-color: #a73d2d; }

@media (max-width: 1050px) { .tbg-process__steps { grid-template-columns: repeat(2, 1fr); } .tbg-process__step:nth-child(2) { border-right: none; } .tbg-process__step:nth-child(1), .tbg-process__step:nth-child(2) { border-bottom: 1px solid rgba(185, 153, 91, 0.28); } }

@media (max-width: 650px) { .tbg-process { padding: 70px 5%; } .tbg-process__heading { margin-bottom: 45px; } .tbg-process__steps { grid-template-columns: 1fr; } .tbg-process__step { border-right: none; border-bottom: 1px solid rgba(185, 153, 91, 0.28); padding: 34px 24px; } .tbg-process__step:last-child { border-bottom: none; } .tbg-process__cta { margin-top: 45px; padding: 42px 24px; } .tbg-process__btn { width: 100%; } }

/*================================================================================================================= TYPES D'EVENEMENTS ========================================================================================================*/
.tbg-events-types { padding: 120px 7%; background: #000000; color: #ffffff; }

.tbg-events-types__inner { max-width: 1350px; margin: 0 auto; }

.tbg-events-types__heading { max-width: 1200px; margin: 0 auto 65px; text-align: center; }

.tbg-events-types__kicker { margin: 0 0 18px; font-family: "Minion Pro", serif; font-size: 1.1rem; font-style: italic; color: rgba(255, 255, 255, 0.82); }

.tbg-events-types h2 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2rem, 3.8vw, 4rem); font-weight: 400; line-height: 1.12; letter-spacing: 0.06em; text-transform: uppercase; }

.tbg-events-types h2 span { display: block; color: #b9995b; }

.tbg-events-types__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }

.tbg-event-card { position: relative; min-height: 420px; overflow: hidden; border: 1px solid rgba(185, 153, 91, 0.42); background: #111111; }

.tbg-event-card::before { content: ""; position: absolute; inset: 14px; border: 1px solid rgba(185, 153, 91, 0.24); z-index: 3; pointer-events: none; }

.tbg-event-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: brightness(0.55) contrast(1.1); transition: transform 0.8s ease, filter 0.8s ease; }

.tbg-event-card::after { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, rgba(0, 0, 0, 0.58) 0%, rgba(0, 0, 0, 0.28) 48%, rgba(0, 0, 0, 0.06) 100%); }

.tbg-event-card__content { position: relative; z-index: 2; min-height: 420px; padding: 30px; display: flex; flex-direction: column; justify-content: flex-end; }

.tbg-event-card__content span { margin-bottom: 16px; font-family: "Trajan Pro", serif; font-size: 0.76rem; letter-spacing: 0.16em; color: #b9995b; }

.tbg-event-card h3 { min-height: 10px; margin: 0 0 16px; font-family: "Trajan Pro", serif; font-size: 1.35rem; font-weight: 400; line-height: 1.25; letter-spacing: 0.07em; text-transform: uppercase; display: flex; align-items: flex-start; }

.tbg-event-card p { min-height: 76px; margin: 0; font-family: "Minion Pro", serif; font-size: 1.04rem; line-height: 1.65; color: rgba(255, 255, 255, 0.82); }

@media (max-width: 950px) { .tbg-events-types { padding: 80px 6%; } .tbg-events-types__grid { grid-template-columns: 1fr; gap: 20px; } .tbg-event-card, .tbg-event-card__content { min-height: 360px; } }

/* ---------------------------------------------------------- */
/* GALLERY FULL WIDTH */
/* ---------------------------------------------------------- */
.gallery { display: grid; grid-template-columns: repeat(4, 1fr); width: 100%; }

.gallery-item { position: relative; width: 100%; aspect-ratio: 1 / 1; overflow: hidden; }

.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease, filter 0.6s ease; }

.gallery-item::after { content: ""; position: absolute; inset: 0; background: rgba(0, 0, 0, 0.28); z-index: 1; pointer-events: none; transition: background 0.35s ease; }

/* ---------------------------------------------------------- */
/* RESPONSIVE */
/* ---------------------------------------------------------- */
@media (max-width: 992px) { .gallery { grid-template-columns: repeat(2, 1fr); } }

@media (max-width: 480px) { .close-btn { top: 20px; right: 20px; font-size: 32px; } }

@media (max-width: 520px) { .tbg-events-types { padding: 65px 5%; } .tbg-events-types__heading { margin-bottom: 42px; } .tbg-event-card__content { padding: 28px; } .tbg-event-card h3 { font-size: 1.15rem; } }

/*======================================================================================================= PRESENTATION DE LA PRESTATION ========================================================================================================*/
.tbg-presta-three { padding: 120px 7%; background: #000000; color: #ffffff; overflow: hidden; }

.tbg-presta-three__inner { max-width: 1450px; margin: 0 auto; display: grid; grid-template-columns: 0.9fr 0.9fr 1.15fr; gap: 55px; align-items: center; }

.tbg-presta-three__kicker { margin: 0 0 18px; font-family: "Minion Pro", serif; font-size: 1.08rem; font-style: italic; color: rgba(255, 255, 255, 0.82); }

.tbg-presta-three h2 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2rem, 3.4vw, 3.8rem); font-weight: 400; line-height: 1.12; letter-spacing: 0.06em; text-transform: uppercase; }

.tbg-presta-three h2 span { display: block; color: #b9995b; }

.tbg-presta-three__content p:not(.tbg-presta-three__kicker) { margin: 24px 0 0; font-family: "Minion Pro", serif; font-size: 1.08rem; line-height: 1.75; color: rgba(255, 255, 255, 0.82); }

.tbg-presta-three__image { position: relative; min-height: 520px; overflow: hidden; border: 1px solid rgba(185, 153, 91, 0.45); }

.tbg-presta-three__image::before { content: ""; position: absolute; inset: 14px; border: 1px solid rgba(185, 153, 91, 0.25); z-index: 2; pointer-events: none; }

.tbg-presta-three__image img { width: 100%; height: 100%; min-height: 520px; display: block; object-fit: cover; filter: brightness(0.78) contrast(1.08); }

.tbg-presta-three__advantages { display: grid; gap: 34px; border-left: 1px solid rgba(185, 153, 91, 0.45); padding-left: 42px; }

.tbg-presta-three__advantages div { position: relative; }

.tbg-presta-three__advantages span { display: block; margin-bottom: 10px; font-family: "Trajan Pro", serif; font-size: 0.72rem; letter-spacing: 0.16em; color: #a73d2d; }

.tbg-presta-three__advantages p { margin: 0; font-family: "Trajan Pro", serif; font-size: 1.02rem; line-height: 1.55; letter-spacing: 0.06em; text-transform: uppercase; color: #ffffff; }

@media (max-width: 1050px) { .tbg-presta-three { padding: 85px 6%; } .tbg-presta-three__inner { grid-template-columns: 1fr; gap: 45px; } .tbg-presta-three__advantages { border-left: none; border-top: 1px solid rgba(185, 153, 91, 0.45); padding-left: 0; padding-top: 30px; grid-template-columns: repeat(2, 1fr); } .tbg-presta-three__image, .tbg-presta-three__image img { min-height: 380px; } }

@media (max-width: 560px) { .tbg-presta-three { padding: 65px 5%; } .tbg-presta-three__inner { gap: 36px; } .tbg-presta-three h2 { font-size: 2rem; letter-spacing: 0.04em; } .tbg-presta-three__image, .tbg-presta-three__image img { min-height: 300px; } .tbg-presta-three__advantages { grid-template-columns: 1fr; gap: 22px; } .tbg-presta-three__content p:not(.tbg-presta-three__kicker) { font-size: 1.02rem; line-height: 1.65; } }

/*======================================================================================================= INFORMATIONS PRATIQUES + CTA ==========================================================================================================*/
.tbg-practical-info { padding: 120px 7%; background: #000000; color: #ffffff; }

.tbg-practical-info__inner { max-width: 1350px; margin: 0 auto; }

.tbg-practical-info__heading { max-width: 820px; margin: 0 auto 65px; text-align: center; }

.tbg-practical-info__kicker { margin: 0 0 18px; font-family: "Minion Pro", serif; font-size: 1.1rem; font-style: italic; color: #b9995b; }

.tbg-practical-info h2 { margin: 0; font-family: "Trajan Pro", serif; font-size: clamp(2rem, 3.8vw, 4rem); font-weight: 400; line-height: 1.12; letter-spacing: 0.06em; text-transform: uppercase; }

.tbg-practical-info h2 span { display: block; color: #b9995b; }

.tbg-practical-info__heading > p { max-width: 680px; margin: 26px auto 20px; font-family: "Minion Pro", serif; font-size: 1.08rem; line-height: 1.75; color: rgba(255, 255, 255, 0.82); }

.tbg-practical-info__grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid rgba(185, 153, 91, 0.45); border-bottom: 1px solid rgba(185, 153, 91, 0.45); }

.tbg-practical-info__item { padding: 40px 28px; border-right: 1px solid rgba(185, 153, 91, 0.28); }

.tbg-practical-info__item:last-child { border-right: none; }

.tbg-practical-info__item span { display: inline-block; margin-bottom: 22px; font-family: "Trajan Pro", serif; font-size: 0.76rem; letter-spacing: 0.16em; color: #a73d2d; }

.tbg-practical-info__item h3 { margin: 0 0 16px; min-height: 48px; font-family: "Trajan Pro", serif; font-size: 1.05rem; font-weight: 400; line-height: 1.35; letter-spacing: 0.07em; text-transform: uppercase; }

.tbg-practical-info__item p { margin: 0; font-family: "Minion Pro", serif; font-size: 1.02rem; line-height: 1.65; color: rgba(255, 255, 255, 0.78); }

.tbg-practical-info__cta { margin-top: 55px; text-align: center; }

.tbg-practical-info__btn { display: inline-flex; justify-content: center; align-items: center; padding: 14px 28px; border: 1px solid #b9995b; color: #ffffff; font-family: "Trajan Pro", serif; font-size: 0.72rem; letter-spacing: 0.13em; text-transform: uppercase; text-decoration: none; transition: all 0.35s ease; }

.tbg-practical-info__btn:hover { background: #a73d2d; border-color: #a73d2d; }

@media (max-width: 1050px) { .tbg-practical-info { padding: 85px 6%; } .tbg-practical-info__grid { grid-template-columns: repeat(2, 1fr); } .tbg-practical-info__item:nth-child(2) { border-right: none; } .tbg-practical-info__item:nth-child(1), .tbg-practical-info__item:nth-child(2) { border-bottom: 1px solid rgba(185, 153, 91, 0.28); } }

@media (max-width: 560px) { .tbg-practical-info { padding: 65px 5%; } .tbg-practical-info__heading { margin-bottom: 42px; } .tbg-practical-info__grid { grid-template-columns: 1fr; } .tbg-practical-info__item { padding: 32px 0; border-right: none; border-bottom: 1px solid rgba(185, 153, 91, 0.28); } .tbg-practical-info__item:last-child { border-bottom: none; } .tbg-practical-info__item h3 { min-height: unset; } .tbg-practical-info__btn { width: 100%; } }

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