/* ==========================================================================
   1. VARIABLES & POLICES
   ========================================================================== */
@font-face {font-family: "SatoB"; src: url("../fonts/SatoB.woff2") format("woff2"); font-weight: 400; font-display: swap;}
@font-face {font-family: "ChillR"; src: url("../fonts/ChillR.woff2") format("woff2"); font-weight: 400; font-display: swap;}
@font-face {font-family: "ChillSB"; src: url("../fonts/ChillSB.woff2") format("woff2"); font-weight: 400; font-display: swap;}
@font-face {font-family: "ChillB"; src: url("../fonts/ChillB.woff2") format("woff2"); font-weight: 400; font-display: swap;}

:root {
  --bs-primary: #192551;
  --bs-secondary: #3CC9BE;
  --bs-body-color: #475073;
  --bs-light: #E9EAEE;
  --bs-gutter-x: 3rem;
  --bs-gutter-y: 3rem;
  --bs-white: #fff;
}

/* ==========================================================================
   2. REINIT & STRUCTURE (GRID)
   ========================================================================== */
html { height: 100%; box-sizing: border-box; }
*, ::after, ::before { box-sizing: inherit; }
body { font-family: 'ChillR', sans-serif; margin: 0; color: var(--bs-body-color); line-height: 1.5; }

.container, .container-fluid { width: 100%; /*padding: 0 2rem;*/margin: auto; }
.container { max-width: 1320px; }

.row { display: flex; flex-wrap: wrap; margin-top: calc(-1 * var(--bs-gutter-y)); margin-right: calc(-.5 * var(--bs-gutter-x)); margin-left: calc(-.5 * var(--bs-gutter-x)); }
.row > * { flex-shrink: 0; width: 100%; max-width: 100%; padding-right: calc(var(--bs-gutter-x) * .5); padding-left: calc(var(--bs-gutter-x) * .5); margin-top: var(--bs-gutter-y); }

.col-4 { width: 33.333333%; }
.col-6 { width: 50%; }
.col-11 { width: 91.666667%; }
.col-12 { width: 100%; }
@media (min-width: 768px) { .col-md-6 { width: 50%; } }
@media (min-width: 1200px) { .col-xl-10 { width: 83.33%; } }

.g-4, .gx-4 {--bs-gutter-x: 1.5rem;}
.g-4, .gy-4 {--bs-gutter-y: 1.5rem;}

/* ==========================================================================
   3. COULEURS, OPACITÉ & BORDURES
   ========================================================================== */
.bg-primary { background-color: var(--bs-primary) !important; }
.bg-secondary { background-color: var(--bs-secondary) !important; }
.bg-light { background-color: var(--bs-light) !important; }
.bg-white { background-color: var(--bs-white) !important; }
.bg-opacity-10 { --bs-bg-opacity: 0.1; background-color: rgba(255, 255, 255, var(--bs-bg-opacity)) !important; }

.text-white { color: #fff !important; }
.text-primary { color: var(--bs-primary) !important; }
.text-secondary { color: var(--bs-secondary) !important; }
.text-muted { color: #6c757d !important; }
.text-dark { color: #212529 !important; }
.text-pico{color:#97db96 !important;}

.opacity-15 { opacity: 0.15 !important; }
.opacity-50 { opacity: 0.5 !important; }
.opacity-75 { opacity: 0.75 !important; }
.opacity-90 { opacity: 0.9 !important; }

.border { border: 1px solid #dee2e6 !important; }
.border-white { border-color: #fff !important; }
.border-top { border-top: 1px solid #dee2e6 !important; }
.border-opacity-10 {border-color: rgba(255, 255, 255, 0.1) !important; }

/* ==========================================================================
   4. MODALS, BOUTONS & NAVIGATION
   ========================================================================== */
.modal { position: fixed; top: 0; left: 0; z-index: 1055; display: none; width: 100%; height: 100%; overflow: hidden; outline: 0; background: rgba(0,0,0,0.5); }
.modal-dialog { position: relative; width: auto; margin: 0.5rem; pointer-events: none; }
.modal-dialog-centered { display: flex; align-items: center; min-height: calc(100% - 1rem); }
.modal-fullscreen { width: 100vw; max-width: none; height: 100%; margin: 0; }
.modal-content { position: relative; display: flex; flex-direction: column; width: 100%; background-color: #fff; pointer-events: auto; border-radius: 0.5rem; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 1rem; }
.btn-close { box-sizing: content-box; width: 1em; height: 1em; padding: 0.25em; border: 0; opacity: 0.5; cursor: pointer; }

.btn { display: inline-block; font-weight: 400; text-align: center; cursor: pointer; border: 1px solid transparent; padding: 0.375rem 0.75rem; transition: all .15s; text-decoration: none; border-radius: 0.375rem; }
.btn-light { background-color: #f8f9fa; color: var(--bs-primary); }
.btn-primary { background-color: var(--bs-primary); color: #fff; }

.fixed-bottom { position: fixed; right: 0; bottom: 0; left: 0; z-index: 1030; }
.nav-borne-fixed { height:100px;width:100px;position: fixed;top:4rem;right:0;z-index: 5;display: flex;flex-direction: column;text-decoration: none;background-color: #fff;align-items: center;justify-content: center;padding:0rem 1rem;border-top-left-radius:1rem;border-bottom-left-radius:1rem;box-shadow: 0 1rem 3rem rgba(0,0,0,.175) !important;}

/* ==========================================================================
   5. FORMULAIRES
   ========================================================================== */
.form-control { display: block; width: 100%; padding: 0.375rem 0.75rem; font-family: inherit; background-color: #fff; border: 1px solid #ced4da; appearance: none; }
.form-control::placeholder, .custom-select{color:#6c757d;font-family: 'ChillR', sans-serif !important;}
.form-control-lg { min-height: calc(1.5em + 1rem + 2px); padding: 0.5rem 1rem; font-size: 1.25rem; }
.form-check { display: flex; align-items: center; }
.form-check-input { width: 1.25em; height: 1.25em; margin-right: 0.5rem; border: 1px solid rgba(0,0,0,.25); cursor: pointer; }
.btn{font-weight: normal;font-family: 'ChillSB', sans-serif;border-radius: 2rem;padding:0.9rem 1.5rem;}

.btn-secondary {
    background-color: #3CC9BE;
    color:#fff;
}

/* ==========================================================================
   6. UTILITAIRES DE MISE EN PAGE
   ========================================================================== */
#page{overflow: hidden;}
.d-flex { display: flex !important; }
.flex-column { flex-direction: column !important; }
.flex-grow-1 { flex-grow: 1 !important; }
.flex-shrink-0 { flex-shrink: 0 !important; }
.justify-content-start { justify-content: start !important; }
.justify-content-center { justify-content: center !important; }
.justify-content-between { justify-content: space-between !important; }
.align-items-center { align-items: center !important; }
.align-content-start { align-content: flex-start !important; }

.position-relative { position: relative !important; }
.position-absolute { position: absolute !important; }
.top-0 { top: 0 !important; }
.start-0 { left: 0 !important; }
.z-0 { z-index: 0 !important; }
.z-1 { z-index: 1 !important; }
.z-2 { z-index: 2 !important; }
.flex-shrink-0{flex-shrink: 0;}

.w-100 { width: 100% !important; }
.h-100 { height: 100% !important; }
.vh-100, .content-page { min-height: 100vh !important;min-height: 100dvh !important;}
.vh-100-strict { height: 100vh !important;height: 100dvh !important; }
.overflow-auto { overflow: auto !important; }
.overflow-hidden { overflow: hidden !important; }
.object-fit-cover { object-fit: cover !important; }

.text-center { text-align: center !important; }
.text-uppercase { text-transform: uppercase !important; }
.text-decoration-none { text-decoration: none !important; }

.fw-bold, .fw-b, strong, b { font-family: 'ChillB', sans-serif !important; }
.fw-sb { font-family: 'ChillSB', sans-serif !important; }
.fw-r { font-family: 'ChillR', sans-serif !important; }

.fs-3 {font-size: calc(1.3rem + .6vw) !important;}
.display-1 { font-size: calc(1.625rem + 4.5vw); line-height: 1.2 !important; }
.display-2 { font-size: calc(1.575rem + 3.9vw); line-height: 1.2 !important; }
.display-3 {font-size: calc(1.525rem + 3.3vw);line-height: 1.2 !important;}
.display-6 {font-size: calc(1.375rem + 1.5vw);line-height: 1.2 !important;}
.fs-1 { font-size: calc(1.375rem + 1.5vw) !important; }
.fs-2 { font-size: 2rem !important; }
.fs-4 { font-size: 1.5rem !important; }
.fs-5 { font-size: 1.25rem !important; }
.fs-6 { font-size: 1rem !important; }
.fs-7 { font-size: 0.875rem !important; }
.lh-lg { line-height: 2 !important; }
.lh-base { line-height: 1.5 !important; }

.m-0 { margin: 0 !important; }
.mt-0 { margin-top: 0rem !important; }
.mt-2 { margin-top: 0.5rem !important; }
.mt-3 { margin-top: 1rem !important; }
.mt-4 { margin-top: 1.5rem !important; }
.mt-5 { margin-top: 3rem !important; }
.mb-0 { margin-bottom: 0 !important; }
.mb-2 { margin-bottom: 0.5rem !important; }
.mb-4 { margin-bottom: 1.5rem !important; }
.mb-5 { margin-bottom: 3rem !important; }
.ms-4 { margin-left: 1.5rem !important; }
.me-4 { margin-right: 1.5rem !important; }
.mt-auto { margin-top: auto !important; }

.p-0 { padding: 0 !important; }
.p-4 { padding: 1.5rem !important; }
.p-5 { padding: 3rem !important; }
.pt-0 { padding-top: 0rem !important; }
.pt-2 { padding-top: 0.5rem !important; }
.pt-4 { padding-top: 1.5rem !important; }
.pt-5 { padding-top: 3rem !important; }
.pb-4 { padding-bottom: 1.5rem !important; }
.pb-5 { padding-bottom: 3rem !important; }
.py-2 { padding-top: 0.5rem !important; padding-bottom: 0.5rem !important; }
.py-3 { padding-top: 1rem !important; padding-bottom: 1rem !important; }
.py-4 { padding-top: 1.5rem !important; padding-bottom: 1.5rem !important; }
.py-5 { padding-top: 3rem !important; padding-bottom: 3rem !important; }
.px-0 { padding-left: 0 !important; padding-right: 0 !important; }
.px-4 { padding-left: 1.5rem !important; padding-right: 1.5rem !important; }
.px-5 { padding-left: 3rem !important; padding-right: 3rem !important; }

.rounded-pill { border-radius: 50rem !important; }
.rounded-4 { border-radius: 1rem !important; }
.rounded-5 { border-radius: 2rem !important; }
.shadow-sm { box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important; }
.shadow-lg { box-shadow: 0 1rem 3rem rgba(0,0,0,.175) !important; }
.border-0 { border: 0 !important; }
.border-5 { border-width: 5px !important; }
.border-light { border: 1px solid var(--bs-light) !important; }
.border-primary{border-color:var(--bs-secondary) !important;}

/* ==========================================================================
   7. DESIGN BORNE
   ========================================================================== */
   /* SOMMAIRE */
.img-fluid { max-width: 100%; height: auto; }
.logo-borne {width: 50%;height: auto;padding: 2rem 0;max-height: 25vh;}
.main-title {font-family: 'SatoB', sans-serif;font-weight: normal;margin-top:0;text-transform: uppercase;letter-spacing: -0.05rem;-webkit-hyphens: auto;-ms-hyphens: auto;hyphens: auto;word-break: break-word;line-height: 1;}
.tuile-cliquable { height: 410px; border: 5px solid rgba(255,255,255,0.1) !important; border-radius: 2rem; transition: transform 0.3s ease; }
.tuile-cliquable.mini-tuile { height: auto; border: 5px solid rgba(255,255,255,0.1) !important; border-radius: 2rem; transition: transform 0.3s ease; }
.tuile-cliquable:active { transform: scale(0.97); border-color: var(--bs-secondary) !important; }
.btn-retour:active { transform: scale(0.95); }
.card-content{position: relative;z-index: 2;}
.card-content .main-title{margin-top:0;}
.card-ratio-11 { aspect-ratio: 1 / 1; }
.card-overlay-gradient::after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background:linear-gradient(to top,rgba(25,37,81,1) 0%,rgba(25,37,81,0.7) 50%,rgba(25,37,81,0) 100%); z-index: 1; }
.cartouche-borne { font-size: 1rem !important; padding: 0.5rem 1rem !important; letter-spacing: 2px; margin-bottom: 15px !important; display: inline-block; background-color: var(--bs-secondary); color: white; text-transform: uppercase; font-family: 'ChillB', sans-serif !important; }
.tuile-cliquable img{opacity: 0.7;}
.tuile-title { font-size: 2.5rem !important; line-height: 1.25; text-shadow: 2px 2px 4px rgba(0,0,0,0.5); }
.title-jeu{text-shadow: 2px 2px 4px rgba(0,0,0,0.5);}
.tuile-cliquable .p-5{padding:2rem !important;}
.tuile-cliquable.mini-tuile .p-5{padding:2rem !important;}
.tuile-cliquable.mini-tuile .tuile-title {font-size: 1.5rem !important;letter-spacing: 0.05rem;}
/* PICO */
.swiper { width: 100%; height: 500px; }
.swiper-slide { display: flex; align-items: center; justify-content: center; }
.swiper-slide img { width: 100%; height: 100%; object-fit: cover; }
.swiper-pagination{display: flex;align-items: center;justify-content: center;background-color: rgba(75,140,74,0.4);bottom:0 !important;padding:1rem 1rem 4rem 1rem;}
.swiper-pagination-bullet { background: #fff !important; width: 35px !important; height: 35px !important; opacity: 0.75 !important;}
.swiper-pagination-bullet-active { background: #3CC9BE !important; opacity: 1 !important;width:50px !important;height:50px !important;}
.swiper-pico .swiper-pagination-bullet-active { background: #173519 !important;}
.swiper-button-next, .swiper-button-prev { color: #3CC9BE !important; background: rgba(255,255,255,0.8); width: 80px !important; height: 80px !important; border-radius: 50%; shadow: 0 4px 15px rgba(0,0,0,0.3); }
.swiper-button-next:after, .swiper-button-prev:after { font-size: 30px !important; font-weight: bold; }
.swiper-button-next { right: 4rem !important; }
.swiper-button-prev { left: 4rem !important; }
.swiper-button-next:after, .swiper-rtl .swiper-button-prev:after, .swiper-button-prev:after{color: #173519 !important;}

/* FRANCHISE */
.list-unstyled{list-style: none;padding-left:0;margin:0;}
.list-unstyled li{position: relative;display: flex;justify-content: flex-start;align-items: center;line-height: 1.25;margin-bottom: 1rem;}
.list-unstyled.list-negative li:before{display:inline-block;content: "✖";color:#f85151;font-size: 2.5rem;font-family: 'ChillSB', sans-serif !important;margin-right:1rem;}
.list-unstyled.list-positive li:before{content: "✔";color:#3CC9BE;font-size: 2.5rem;font-family: 'ChillSB', sans-serif !important;margin-right:1rem;}
.sticky-footer { position: fixed; bottom: 0; left: 0; width: 100%; z-index: 2; margin-bottom: 0 !important; }
.custom-select {background-color: #fff !important;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233CC9BE' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 2.5rem center;
    background-size: 3rem;
}

.custom-select {
    padding-right: 6rem !important;
}

/* JEU */
.modal-native {display:none;position: fixed; top: 0; left: 0; width: 100%; height: 1px;overflow:hidden; background: rgba(0,0,0,0.85); display: flex; align-items: center; justify-content: center; z-index: 9999; opacity: 0; pointer-events: none; transition: opacity 0.3s ease; }
.modal-native:target {display:flex; opacity: 1; pointer-events: auto;height: 100%;overflow:auto;}
.modal-native-content { background: #ffffff; width: 85%; max-width: 1000px; max-height: 80vh; border-radius: 40px; padding: 50px; position: relative; overflow-y: auto; color: #192551; box-shadow: 0 20px 50px rgba(0,0,0,0.5); }
.btn-close-native { text-decoration: none; font-size: 4rem; color: #192551; line-height: 1; position: absolute; top: 30px; right: 40px; }
.modal-native-body { line-height: 1.5; padding-top: 20px; }
.mobileonly{display: none !important;}

/* RESP */
@media (min-width: 992px) {
    .container, .container-lg, .container-md, .container-sm {
        max-width: 960px;
    }
}

@media (min-width: 1200px) {
    .container, .container-lg, .container-md, .container-sm {
        max-width: 1140px;
    }
}

@media (min-width: 1400px) {
    .container, .container-lg, .container-md, .container-sm {
        max-width: 100%;
    }
}

@media (max-width: 768px) {
    html { font-size: 14px !important; } 

    .py-5 { padding-top: 1.5rem !important; padding-bottom: 1.5rem !important; }
    .pt-5{padding-top: 1.5rem !important; }
    .mt-5{margin-top: 1.5rem !important;}
    .mb-5{margin-bottom: 1.5rem !important;}
    .px-5 { padding-left: 1rem !important; padding-right: 1rem !important; }
    .display-3 { font-size: 2rem !important; }
    .display-6 { font-size: 1.8rem !important; }
    .fs-1 { font-size: 1.4rem !important; }
    .fs-2 { font-size: 1.2rem !important; }
    .fs-3 { font-size: 1.1rem !important; }
    .fs-4 { font-size: 1rem !important; }
    
    input.form-control-lg, select.form-select-lg {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important;
        border-radius: 3rem !important;
    }

    .form-check-input{width:30px !important;height:30px !important;}

    .les-prix .col-4{width:100%;}

    .mobileonly{display: inline-flex !important;}
    .nomobile{display: none;}
    
    .g-5 { --bs-gutter-y: 1.5rem !important; --bs-gutter-x: 1rem !important; }
}
#page{max-width: 2000px;margin:auto;}
#page.frommobile .nav-borne-fixed{display: none !important;}

