
:root {
    --fa-font-family: "FontAwesome";
    --gstm-box-shadow-color: rgba(34, 54, 84, 0.24);
    --bs-link-color-rgb:#212529;
    --lightbox: rgb(0 0 0 / 0.75);
    --carousel-text: #fff;
    --golf-green-dark: #1B4332;   /* vert forêt profond */
    --golf-green: #2D6A4F;        /* vert terrain */
    --golf-green-light: #74C69D;  /* vert gazon clair */
    --golf-sand: #DAD7CD;         /* bunker */
    --gstm-form-control-shadow: 0 0 0 3px #99b9e5;
     --gstm-error-color:#D02536;
    --gstm-important-color: #ed6b41;
    --gstm-succes-color:#4F813D;
    --gstm-input-succes-color:#1F7F37;
     --gstm-color-blue-regular: #1472bf;
     --gstm-color-blue-dark: #223654;
  --gstm-color-grey-pale: #f1f1f2;
  --gstm-color-grey-light: #c5cad2;
  --gstm-color-grey-regular: #808A9D;
  --gstm-color-grey-medium: #6b778a;
  --gstm-color-grey-dark: #4e5662;
}

body {
	font-family: 'Open Sans', sans-serif; font-size:1rem
}
.font-roboto {
	font-family: 'Roboto', sans-serif!important;
}
.font-open-sans {
	font-family: "Open Sans", sans-serif!important;
}
.font-size-0 { font-size:0!important}
.font-size-85 { font-size:85%!important}
.font-size-100 { font-size:1rem!important}
.font-size-125 { font-size:125%!important}
.font-size-150 { font-size:150%!important}
.font-size-175 { font-size:175%!important}
.font-size-200 { font-size:200%!important}

body:not(.page) header .accueil,
body.page header .membres {
    display: none;
}

header .nav-link {
    color: white!important;
}
header .navbar-toggler {
    color:white;
    background-color: rgba(8, 99, 47, 0.7);
    border-color: white;
}
a.btn-gstm-membre {
    border: 1px solid #fff;
    border-radius: 5px;
    color: #fff;
    padding: 0.5rem;
    background-color: rgba(0, 102, 49);
    text-decoration: none;
    display: inline-block;
    text-align: center;
}
header a.btn, header a.btn-gstm-membre{
    margin-left: .5rem;
}
.btn-reservation {
    display: block;
    border: 2px solid #fff;
    padding: 0.75rem;
    border-radius: 0.5rem;
    background-color: rgba(8, 99, 47, 0.5);
    text-align: center;
}
section.home-main-img{
    --gstm-text-shadow: -2px 3px 4px rgba(0, 0, 0, 1);
    position: relative;
    background-color: #006631;
    background-image: url(images/home-trou-11-automne.jpg);
    background-position: top center;
    background-size: cover;
    color: #fff !important;
}
section.home-main-img a{
    color: #fff !important;
}
.logo{
   position: relative;
   top: -4rem; 
}
.home-slogan {
    font-family: 'Roboto';
    line-height:1.10;
    color:#fff; 
    text-shadow: var(--gstm-text-shadow); 
    margin:0 auto;
    padding: 1rem 1rem 0;
    text-align: center;
    font-size:1.75rem;
    font-weight:300; 
}

section.home-main-img h1, 
section.home-main-img p, 
section.home-main-img h2, section.home-main-img .btn-reservation {
    text-shadow: var(--gstm-text-shadow);
 }
section.home-main-img h1{
    border-bottom: 1px solid #fff;
    display: block;
}
section.home-main-img span.avec-ligne-cotes{
    text-transform: uppercase;
    font-weight: 300;
    font-size: 1.5rem;
    text-shadow: var(--gstm-text-shadow); 
}

main:not(.home) .home-reservations {
    display: none;
}
.avec-ligne-cotes{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.avec-ligne-cotes span{
    width: 100%;
    display: block;
    text-align: center;
    text-wrap: nowrap;
    padding: 0 0.5rem;
}
.avec-ligne-cotes::before,
.avec-ligne-cotes::after{
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background-color: white;
}

.offcanvas-body .nav-link {
    --bs-navbar-color: rgba(255, 255, 255, 0.55);
    --bs-nav-link-color: white;
}
.offcanvas-body .nav-link {
    border-bottom: 1px solid var(--bs-navbar-color)
}
.offcanvas-body a.btn, .offcanvas-body a.btn-gstm-membre{
    margin-top: .75rem;
    display: block;
    width: 70%;
}
.offcanvas-body a.btn {
    margin-top: 1.5rem;
}

section{
    padding: 1.5rem 0;
    box-shadow:  0 0.5rem 0.5rem rgb(33 37 41 / 16%);
    position: relative;
    z-index: 2;
}

/*section:not(.home-main-img) {
    border-top:2px solid rgba(8, 99, 47, 1)
}*/

:is(h1,h2,h3,h4,h5,h6) {
    font-family: 'Roboto';
}

:is(h1,h2,h3,h4) > .small, 
:is(h1,h2,h3,h4) > small {
    font-size: 70%;
}

section h1,
footer h1{
    font-size: 2rem;
    text-transform: uppercase;
    font-weight: 300;
    /*letter-spacing: 5px;*/
     display: inline-block;
}

h2 {
    color: var(--golf-green-dark);
}
h3 {
    color: var(--golf-green);
    font-size: 1.75rem
}
footer h1::after,
section h1:after {
    content: "";
    display: block;
    margin: 0;
    width:100%;
    padding-top: 0.4rem;
    border-bottom: 1px solid rgba(8, 99, 47, 1);
}

section.home-main-img h1::after{
    content: none;
    font-size: 1.5rem;
    padding-bottom: 0.5rem;
}
section:not(.home-main-img) h1{
    padding-bottom: .5rem;
    margin-bottom: 2rem
}

.row > [class^="col"] > .card{
    height: 100%;
    box-shadow: 0 0 7px 0px rgb(33 37 41 / 16%);
    border-radius: initial;
}

.btn-gstm{
    display: inline-flex;
    padding: 1rem;
    align-items: center;
    margin: 0.75rem 0;
    border-radius: 0.5rem;
    text-align: center;
    text-decoration: none;
    font-size: 1.25rem;
    text-transform: uppercase;
    font-weight: 500;
    line-height: 1;
    transition: border .2s, transform .2s ease-in-out, color .2s ease-in-out, background-color .2s ease-in-out;
    font-family: 'Roboto', sans-serif;
    max-width: 400px;
}
.btn-gstm-principal {
    color: white;
    background-color: rgba(8, 99, 47, 0.8);
    border: 2px solid rgba(8, 99, 47, 1);
}

.btn-gstm-secondaire {
    color: white;
    background-color: transparent;
    border: 2px solid white;
}

.btn-gstm-principal:not([disabled]):hover,
.btn-gstm-principal:focus {
    background-color: rgba(8, 99, 47, 1);
    border-color: #333;
}

.btn-gstm i{
    margin-right: 0.5rem;
}

.home-tarification .col-12 {
    margin-bottom: 0.5rem;
}

.home-promotions,
.home-nouvelles  { 
    background-color:#1b2075;
    color:#fff;
}
.home-promotions h1:after{
    border-bottom-color: white;
}

.home-promotions .row > [class^="col"]{
    margin-bottom: 0.5rem ;
}
.home-promotions .row > [class^="col"] > .card {  
    color:#fff;
    border-color:#fff; 
    text-align:center;
    background: linear-gradient(to bottom, #3b679e 0%,#2b88d9 50%,#7db9e8 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
}

body.page .home-promotions .btn-gstm-secondaire {
    display: none;
}

.home-promotions div[class*='col'] div p { 
    font-size:1.5rem; 
    line-height: 1.2;
}
.home-promotions div[class*='col'] div p strong {
    display:block;
    font-size:2rem; 
    font-weight:800;
}
.home-promotions .row > [class^="col"] > .card a {
    color: #1b2075;
}
.home-promotions a:not(.btn-gstm-secondaire ) { 
    color:#badef9; 
}

.nous-joindre {
    position: relative;
    padding: 0;
    z-index: 1;
    background-color: #d3f8e2;
}
.nous-joindre iframe {
   height: 100%;
   width: 100%;
   min-height:260px;
}
.nous-joindre .cont-details {
    background: #fff;
    padding: 1rem 2rem;
 }

.nous-joindre .cont-details i,
.nous-joindre .cont-details a{
    color:rgba(8, 99, 47, 1);
    text-decoration: none;
}
.nous-joindre .cont-details a:hover,
.nous-joindre .cont-details a:focus {
    text-decoration: underline;
}

.btn-gstm-secondaire.text-dark{
    color: #333;
    background-color: transparent;
    border: 2px solid #333;
}

.parcours{
    position: relative;
     min-height: 460px;
    padding: 1.5rem 0;
}
.parcours::before {
        content: "";
        position: absolute;
        inset: 0;

        background: url("images/putting.jpeg") 30% center no-repeat;
        opacity: 0.85;
        z-index: -1;
        }

.parcours,{
    --gstm-text-shadow: -2px 3px 4px rgba(0, 0, 0, 1);
    position: relative;
    background-color:  rgba(8, 99, 47, 1);
}
.parcours h1,{
    color: white;
    text-shadow: var(--gstm-text-shadow);
}
.autres-services .row .card {
    border-radius: .25rem
}

.autres-services .row .card h2{
    font-size: 1.25rem;
    font-weight: 600;
    text-transform: uppercase;
}
.autres-services h3{
    text-transform: uppercase;
    font-weight: 300;
     font-size: 1.25rem;
}

@keyframes zoomin {
  0% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.05);
  }
  100% {
    transform: scale(1);
  }
}

.gallery-grid {
    justify-content: center;
}
.gallery-grid .col-auto {
    max-width: 292px;
}
 
.gallery-item {
  display: block;
  max-width: 260px;
  text-align: center;
}

.gallery-item img {
  box-shadow: 0 1rem 1rem rgba(0, 0, 0, 0.15);
  transition: box-shadow 0.2s;
}

.gallery-item:hover img {
  box-shadow: 0 1rem 1rem rgba(0, 0, 0, 0.35);
}

.lightbox-modal .modal-content {
  background-color: var(--lightbox);
}

.lightbox-modal .btn-close {
  position: absolute;
  top: 1.25rem;
  right: 1.25rem;
  font-size: 1.25rem;
  z-index: 10;
  filter: invert(1) grayscale(100);
}

.lightbox-modal .modal-body {
  display: flex;
  align-items: center;
  padding: 0;
}

.lightbox-modal .lightbox-content {
  width: 100%;
}

.lightbox-modal .carousel-indicators {
  margin-bottom: 0;
}

.lightbox-modal .carousel-indicators [data-bs-target] {
  background-color: var(--carousel-text) !important;
}

.lightbox-modal .carousel-inner {
  width: 75%;
}

.lightbox-modal .carousel-inner img {
  animation: zoomin 10s linear infinite;
}

.lightbox-modal .carousel-item .carousel-caption {
  right: 0;
  bottom: 0;
  left: 0;
  padding-bottom: 2rem;
  background-color: var(--lightbox);
  color: var(--carousel-text) !important;
}

.lightbox-modal .carousel-control-prev,
.lightbox-modal .carousel-control-next {
  width: auto;
}

.lightbox-modal .carousel-control-prev {
  left: 1.25rem;
}

.lightbox-modal .carousel-control-next {
  right: 1.25rem;
}

@media (min-width: 1400px) {
  .lightbox-modal .carousel-inner {
    max-width: 60%;
  }
}

[data-bs-theme=dark] .lightbox-modal {
  --bs-carousel-control-icon-filter: none;
}

.btn-fullscreen-enlarge,
.btn-fullscreen-exit {
  position: absolute;
  top: 1.25rem;
  right: 3.5rem;
  z-index: 10;
  border: 0;
  background: transparent;
  opacity: .6;
  font-size: 1.25rem;
}

.bi {
  display: inline-block;
  width: 1em;
  height: 1em;
  vertical-align: -0.035em;
  fill: currentcolor;
}

.accordion-header button {
    font-size: 1.5rem;
    font-weight: 600;
    color: #223654;
    background-color: #fff;
}
.accordion-content {
    border: 1px solid rgba(255, 255, 255, 0);
    border-top: 1px solid #223654;
}
.accordion-content:last-of-type {
    border: 1px solid rgba(255, 255, 255, 0);
    border-top: 1px solid #223654;
    border-bottom: 1px solid #223654;
}

footer h1::after, section:not(.contenu-page) h1:after {
   border-bottom-color: white; 
}
section.contenu-page h1:after {
   border-bottom-color: #212529; 
}

/* ------------- Accordion ---------------------- */
.gstm-accordion > .gstm-btn-group {
    margin: 0;
	flex-direction: row!important
}
.gstm-accordion > .gstm-btn-group button {
    padding: .25rem !important;
    color: var(--qc-color-text-primary);
    font-size: .875rem;
    min-height: 42px;
	width: auto!important;
	min-width: 0
}
.gstm-accordion > .gstm-btn-group button span {
    padding-right: .25rem
}
.gstm-accordion > .gstm-btn-group button i {
    font-size: 1rem !important;
    padding-left: 0 !important;
    transition: transform .5s;
}
.gstm-accordion .gstm-accordion-content > .gstm-accordion-header {
    margin: 0 !important;
    padding: 0 !important
}
.gstm-accordion .gstm-accordion-content {
    margin-top: 1rem;
    border: 1px solid rgba(255, 255, 255, 0)
}
.gstm-accordion > .gstm-btn-group + .gstm-accordion-content {
    margin-top: .25rem;
}
.gstm-accordion .gstm-accordion-content:has(button[aria-expanded="true"]),
.gstm-accordion .gstm-accordion-content:hover {
    border-color: var(--gstm-color-grey-light)
}
.gstm-accordion-header button {
    display: flex;
    align-items: center;
    position: relative;
    background-color: var(--gstm-color-grey-pale);
    padding: 1rem;
    width: 100%;
    text-align: left;
    text-decoration: none;
    color: var(--gstm-color-text-primary);
    font-size: 1.3125rem;
    font-weight: 400;
    line-height: 1.2;
    border: none
}
.gstm-accordion-header button::after {
    flex-shrink: 0;
    width: var(--bs-accordion-btn-icon-width);
    height: var(--bs-accordion-btn-icon-width);
    margin-left: auto;
    content: "";
    background-image: var(--bs-accordion-btn-icon);
    background-repeat: no-repeat;
    background-size: var(--bs-accordion-btn-icon-width);
    transition: var(--bs-accordion-btn-icon-transition);
}

.gstm-accordion-header button:not(.collapsed)::after {
    background-image: var(--bs-accordion-btn-active-icon);
    transform: var(--bs-accordion-btn-icon-transform);
}
.gstm-accordion-header button .label {
    padding-right: 1rem;
	display: inline-block
}
.gstm-accordion-header button .label small {
    font-size: 1rem;
    font-weight: normal;
    display: block;
    padding-top: .25rem;
    color: #1c1c1c;
    font-family: var(--gstm-font-family-open-sans)
}
.gstm-accordion .gstm-accordion-content .gstm-accordion-body {
    padding: 1.25rem 1rem
}

.gstm-accordion .gstm-accordion-content .gstm-accordion-body > :is(:last-child){
    margin-bottom: 0
}

.gstm-accordion + p {
    padding-top: 1rem
}

footer {
    border-top: 1px solid rgba(8, 99, 47, 1);
	background: rgb(174,209,233);
	background: -moz-linear-gradient(top, rgba(174,209,233,1) 0%, rgba(197,218,232,1) 20%, rgba(254,255,255,1) 100%);
	background: -webkit-linear-gradient(top, rgba(174,209,233,1) 0%,rgba(197,218,232,1) 20%,rgba(254,255,255,1) 100%);
}
footer > div{
    min-height: 260px;
    padding: 1.5rem 0;
    background-image:url('images/bg-footer.png'); 
    background-repeat: no-repeat;
    background-position:bottom center;
}
footer ul { 
    padding:0;
    margin: 0;
}
footer ul li{ 
    list-style-type:none; 
    font-size:1rem; 
    color: #333;
}
footer ul li a{ 
    color: #333;
}
footer ul li a:hover,
footer ul li a:focus{ 
    font-weight: 600;
}

.feature-icon {
  width: 4rem;
  height: 4rem;
  border-radius: .75rem;
}

.icon-square {
  width: 3rem;
  height: 3rem;
  border-radius: .75rem;
}

.feature-icon-small {
  width: 3rem;
  height: 3rem;
}

@media (max-width: 575.98px) {
    .tee-ball {
        max-width: 100px;
    }
    .btn-reservation img {
        max-width: 200px;
    }
 }
 @media (max-width: 767.98px) {
    .logo{
        max-width: 120px;
    }
     .home-slogan-1{
        display: none;
    }
 }
@media (max-width: 991.98px) {

    footer .container a {
        display: block;
        padding: 0.5rem;
        color: #333;
        margin: 2px 0;
        text-decoration: none;
        font-weight: 500;
        background-color: rgba(255, 255, 255, 0.5);
    }
    footer ul li a:hover,
    footer ul li a:focus{ 
        font-weight: 600;
        background-color: rgba(255, 255, 255, 0.75);
    }
 }
 @media (min-width: 768px) {
    .home-slogan-2{
        font-size:2.25rem;
    }
 }
@media (min-width: 992px) {

    header .nav-link:hover,     
    header .nav-link:focus{
        text-decoration: underline;
    }
    section.home-main-img p {
        font-size: 1.25rem;
    }
    section h1{
        font-size: 2.75rem;
    }
    section.home-main-img h1{
        font-size: 2.5rem;
    }
    section.home-main-img span.avec-ligne-cotes{
        font-size: 2rem;
    }
    .home-slogan-1{
        font-size:2.5rem; 
    }
    .home-slogan-2{
        font-size:3rem;
    }
     .nous-joindre iframe {
        min-height:440px;
    }
    .nous-joindre .cont-details {
        position: absolute;
        max-width: 33%;
        padding: 2rem;;
        font-size: 0.925rem;
        top: 50%;
        left: 70%;
        transform: translate(-30%, -50%);
        -webkit-box-shadow: 0 1px 20px 0 var(--gstm-box-shadow-color);
        box-shadow: 0 1px 20px 0 var(--gstm-box-shadow-color);
    }

    
}