/* Couchet premium overrides - stable outside Elementor generated files */

html,
body{
  max-width: 100%;
  overflow-x: hidden !important;
}

.site,
.site-main,
.elementor,
.elementor-widget-wrap{
  max-width: 100%;
}

/* Services */
.sc-services{
  padding: clamp(2.2rem, 4vw, 3.2rem) 0;
  border-top: 1px solid rgba(11,22,36,.10);
  border-bottom: 1px solid rgba(11,22,36,.10);
  background:
    radial-gradient(900px 420px at 8% 10%, rgba(134,210,29,.14), transparent 60%),
    radial-gradient(820px 390px at 92% 25%, rgba(31,140,255,.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.58), rgba(255,255,255,.38));
}
.sc-sectionHead{ margin-bottom: 1.35rem; max-width: 760px; }
.sc-sectionHead .sc-h2{ margin-bottom: .5rem; font-weight: 950; }
.sc-sectionHead .sc-h2::after{
  content: "";
  display: block;
  width: 78px;
  height: 3px;
  margin-top: .5rem;
  border-radius: 4px;
  background: linear-gradient(90deg, #86d21d, #1f8cff);
}
.sc-cards{ gap: 1rem; }
.sc-card{
  padding: 1.15rem 1.1rem;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(252,254,255,.90));
  border: 1px solid rgba(11,22,36,.12);
  box-shadow: 0 20px 42px rgba(16,24,40,.11), 0 6px 18px rgba(16,24,40,.06);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
  position: relative;
  overflow: hidden;
}
.sc-card::before{
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 90px;
  background: linear-gradient(180deg, rgba(31,140,255,.08), transparent 70%);
  pointer-events: none;
}
.sc-card::after{
  content: "";
  position: absolute;
  left: 1rem;
  right: 1rem;
  top: 0;
  height: 3px;
  border-radius: 0 0 6px 6px;
  background: linear-gradient(90deg, rgba(134,210,29,.95), rgba(31,140,255,.75));
  transform: scaleX(.25);
  transform-origin: left;
  transition: transform .22s ease;
}
.sc-card:hover{
  transform: translateY(-4px);
  border-color: rgba(11,22,36,.16);
  box-shadow: 0 26px 52px rgba(16,24,40,.14), 0 10px 24px rgba(16,24,40,.09);
}
.sc-card:hover::after{ transform: scaleX(1); }
.sc-card--accent{
  border-color: rgba(134,210,29,.36);
  background:
    radial-gradient(600px 260px at 20% 20%, rgba(134,210,29,.18), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.98), rgba(248,252,242,.94));
}
.sc-list{
  margin: .72rem 0 0 0;
  padding-left: 0;
  list-style: none;
  display: grid;
  gap: .4rem;
}
.sc-list li{ position: relative; padding-left: 1.15rem; margin: 0; }
.sc-list li::before{
  content: "";
  position: absolute;
  left: 0;
  top: .52em;
  width: .42rem;
  height: .42rem;
  border-radius: 50%;
  background: linear-gradient(135deg, #86d21d, #1f8cff);
  box-shadow: 0 0 0 3px rgba(134,210,29,.14);
}
.sc-ctaBand{
  margin-top: 1.35rem;
  padding: 1.05rem 1.15rem;
  border: 1px solid rgba(11,22,36,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(247,251,255,.92));
  box-shadow: 0 18px 40px rgba(16,24,40,.10), 0 6px 14px rgba(16,24,40,.06);
  position: relative;
  overflow: hidden;
}
.sc-ctaBand::before{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(255,255,255,.75);
  pointer-events: none;
}
.sc-ctaBand__text{ font-size: 1.02rem; }

/* About */
.sc-about{
  position: relative;
  background:
    radial-gradient(820px 380px at 8% 10%, rgba(31,140,255,.08), transparent 60%),
    radial-gradient(820px 380px at 92% 90%, rgba(134,210,29,.10), transparent 60%);
}
.sc-about .sc-copy{
  border-radius: 26px;
  padding: 1.15rem 1.2rem;
  border: 1px solid rgba(11,22,36,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.94), rgba(248,252,255,.88));
  box-shadow: 0 18px 40px rgba(16,24,40,.10), 0 6px 16px rgba(16,24,40,.06);
}
.sc-about .sc-h2{ margin-bottom: .6rem; font-weight: 950; }
.sc-about .sc-h2::after{
  content: "";
  display: block;
  width: 78px;
  height: 3px;
  margin-top: .5rem;
  border-radius: 4px;
  background: linear-gradient(90deg, #1f8cff, #86d21d);
}
.sc-about .sc-badge{
  padding: .46rem .74rem;
  border-radius: 12px;
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(245,249,255,.90));
  border: 1px solid rgba(11,22,36,.12);
  box-shadow: 0 8px 18px rgba(16,24,40,.07);
}
.sc-about .sc-note--soft{
  border-radius: 16px;
  padding: 1rem 1.05rem;
  border: 1px solid rgba(11,22,36,.13);
  background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(247,251,255,.93));
  box-shadow: 0 16px 34px rgba(16,24,40,.10), 0 5px 12px rgba(16,24,40,.06);
  position: relative;
  display: grid;
  gap: .55rem;
}
.sc-about .sc-note--soft::before{
  content: "";
  position: absolute;
  left: 1rem;
  right: 1rem;
  top: 0;
  height: 3px;
  border-radius: 0 0 6px 6px;
  background: linear-gradient(90deg, #86d21d, #1f8cff);
}
.sc-about .sc-note--soft::after{
  content: "Interventions locales (Bourgogne) et toute la France";
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  padding: .34rem .62rem;
  border-radius: 999px;
  border: 1px solid rgba(31,140,255,.22);
  background: rgba(31,140,255,.08);
  font-size: .82rem;
  font-weight: 700;
}

/* Cave and trust */
.sc-cave{
  background:
    radial-gradient(840px 360px at 12% 8%, rgba(31,140,255,.08), transparent 62%),
    radial-gradient(840px 360px at 88% 92%, rgba(134,210,29,.10), transparent 62%);
}
.sc-cave .sc-copy{
  border-radius: 26px;
  padding: 1.1rem 1.15rem;
  border: 1px solid rgba(11,22,36,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,252,255,.90));
  box-shadow: 0 20px 44px rgba(16,24,40,.10), 0 6px 16px rgba(16,24,40,.06);
}
.sc-cave .sc-h2{ margin-bottom: .6rem; font-weight: 950; }
.sc-cave .sc-h2::after{
  content: "";
  display: block;
  width: 82px;
  height: 3px;
  margin-top: .52rem;
  border-radius: 4px;
  background: linear-gradient(90deg, #1f8cff, #86d21d);
}
.sc-point{
  border-radius: 14px;
  padding: .9rem 1rem;
  border: 1px solid rgba(11,22,36,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.97), rgba(248,252,255,.92));
  box-shadow: 0 14px 28px rgba(16,24,40,.09), 0 4px 12px rgba(16,24,40,.05);
  position: relative;
}
.sc-point::before{
  content: "";
  position: absolute;
  left: 0;
  top: .72rem;
  bottom: .72rem;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: linear-gradient(180deg, #86d21d, #1f8cff);
}

.sc-trust{
  padding: clamp(2.2rem, 4vw, 3.2rem) 0;
  background:
    radial-gradient(820px 350px at 8% 10%, rgba(31,140,255,.07), transparent 62%),
    radial-gradient(780px 330px at 92% 90%, rgba(134,210,29,.10), transparent 62%);
}
.sc-trust__copy{
  border-radius: 26px;
  padding: 1.1rem 1.15rem;
  border: 1px solid rgba(11,22,36,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.95), rgba(248,252,255,.90));
  box-shadow: 0 18px 40px rgba(16,24,40,.10), 0 6px 16px rgba(16,24,40,.06);
}
.sc-trust .sc-h2::after{
  content: "";
  display: block;
  width: 82px;
  height: 3px;
  margin-top: .52rem;
  border-radius: 4px;
  background: linear-gradient(90deg, #1f8cff, #86d21d);
}
.sc-trust__badge{
  border-radius: 26px;
  border: 1px solid rgba(11,22,36,.12);
  background:
    radial-gradient(560px 320px at 18% 22%, rgba(134,210,29,.16), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(247,251,255,.92));
  box-shadow: 0 24px 52px rgba(16,24,40,.12), 0 8px 20px rgba(16,24,40,.07);
  overflow: hidden;
  position: relative;
}
.sc-trust__badge::before{
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 3px;
  background: linear-gradient(90deg, #86d21d, #1f8cff);
}

/* Header desktop + burger premium */
.sc-nav--desktop{
  flex-wrap: nowrap;
}
.sc-nav--desktop .sc-nav__link,
.sc-nav--desktop .sc-nav__link--summary{
  white-space: nowrap !important;
}
.sc-nav--desktop .sc-nav__link{
  position: relative;
  border-radius: 6px;
  background: transparent !important;
  border-color: transparent !important;
  transition: color .18s ease, transform .18s ease;
}
.sc-nav--desktop .sc-nav__link::before{
  content: "";
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 6px;
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, #86d21d, #1f8cff);
  transform: scaleX(0);
  transform-origin: left;
  opacity: .9;
  transition: transform .2s ease, opacity .2s ease;
}
.sc-nav--desktop .sc-nav__link:hover,
.sc-nav--desktop .sc-nav__link:focus-visible{
  background: transparent !important;
  border-color: transparent !important;
  transform: translateY(-1px);
  text-decoration: none;
}
.sc-nav--desktop .sc-nav__link:hover::before,
.sc-nav--desktop .sc-nav__link:focus-visible::before,
.sc-nav--desktop .sc-nav__details:hover > .sc-nav__link--summary::before,
.sc-nav--desktop .sc-nav__details:focus-within > .sc-nav__link--summary::before{
  transform: scaleX(1);
}
@media (min-width: 1025px){
  .sc-nav--desktop{
    gap: .15rem;
  }
  .sc-nav--desktop .sc-nav__link{
    padding: .62rem .72rem;
    font-size: .93rem;
  }
}

.sc-burger{
  border: 1px solid rgba(11,22,36,.14);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(246,250,255,.90));
  box-shadow: 0 12px 28px rgba(16,24,40,.10), 0 2px 8px rgba(16,24,40,.06);
  backdrop-filter: blur(8px);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
}
.sc-burger:hover{
  transform: translateY(-1px);
  border-color: rgba(31,140,255,.38);
  box-shadow: 0 16px 34px rgba(16,24,40,.14), 0 4px 10px rgba(16,24,40,.08);
}
.sc-burger span{
  width: 20px;
  height: 2px;
  border-radius: 2px;
  background: rgba(11,22,36,.84);
  transition: transform .22s ease, opacity .2s ease, background .2s ease;
}
.sc-navToggle:checked + .sc-burger{
  border-color: rgba(31,140,255,.42);
  background: linear-gradient(180deg, rgba(236,245,255,.98), rgba(224,239,255,.92));
  box-shadow: 0 18px 36px rgba(31,140,255,.20), 0 4px 12px rgba(16,24,40,.10);
}
.sc-navToggle:checked + .sc-burger span:nth-child(1){
  transform: translateY(7px) rotate(45deg);
}
.sc-navToggle:checked + .sc-burger span:nth-child(2){
  opacity: 0;
}
.sc-navToggle:checked + .sc-burger span:nth-child(3){
  transform: translateY(-7px) rotate(-45deg);
}

.sc-drawer__panel{
  left: 0 !important;
  right: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  height: 100vh !important;
  background: #ffffff !important;
  opacity: 1 !important;
  border-left: 0 !important;
  box-shadow: 0 24px 54px rgba(16,24,40,.24), 0 8px 18px rgba(16,24,40,.14) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  isolation: isolate;
}
.sc-drawer__overlay{
  display: none !important;
}

.sc-navToggle:checked ~ .sc-drawer .sc-drawer__panel{
  background: #ffffff !important;
  opacity: 1 !important;
  z-index: 2 !important;
  transform: translateX(0) !important;
}
.sc-drawer{
  z-index: 2147483000 !important;
  background: #ffffff !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.sc-navToggle:checked ~ .sc-drawer{
  display: block !important;
}
.sc-drawer__top,
.sc-nav--mobile .sc-nav__mLink,
.sc-nav--mobile .sc-nav__mSub,
.sc-nav--mobile .sc-nav__mSubLink,
.sc-drawer__cta,
.sc-drawer__hint{
  background-color: #ffffff !important;
  opacity: 1 !important;
}
.sc-drawer__cta{
  margin-top: .85rem !important;
}
.sc-nav--mobile .sc-nav__mSub{
  border: 1px solid rgba(11,22,36,.10) !important;
}

.sc-nav__dropdown{
  background: #ffffff !important;
  opacity: 1 !important;
  border: 1px solid rgba(11,22,36,.14) !important;
  box-shadow: 0 22px 48px rgba(16,24,40,.16), 0 8px 18px rgba(16,24,40,.10) !important;
  backdrop-filter: none !important;
}

/* Maintenance page */
.sc-maint{
  color: #0b1624;
  background:
    radial-gradient(900px 460px at 12% -8%, rgba(134,210,29,.16), transparent 58%),
    radial-gradient(860px 420px at 92% 0%, rgba(31,140,255,.10), transparent 60%),
    linear-gradient(180deg, #f6f8fb, #eef3f9);
}
.sc-maint .sc-wrap{
  width: min(1180px, 92vw);
  margin-inline: auto;
}
.sc-maint__hero{
  padding: clamp(2.2rem, 4vw, 4rem) 0 1.2rem;
  border-bottom: 1px solid rgba(11,22,36,.10);
}
.sc-maint .sc-kicker{
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  color: rgba(11,22,36,.68);
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .8rem;
  margin: 0 0 .75rem 0;
}
.sc-maint .sc-h1{
  font-size: clamp(1.8rem, 2vw + 1rem, 3rem);
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin: 0 0 .85rem 0;
  font-weight: 950;
}
.sc-maint .sc-lead{
  margin: 0;
  max-width: 900px;
  color: rgba(11,22,36,.84);
  line-height: 1.65;
  font-size: 1.05rem;
}
.sc-maint__chips{
  margin-top: 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}
.sc-maint__chip{
  display: inline-flex;
  align-items: center;
  padding: .44rem .72rem;
  border-radius: 999px;
  border: 1px solid rgba(11,22,36,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(245,249,255,.90));
  box-shadow: 0 8px 18px rgba(16,24,40,.06);
  font-weight: 800;
  font-size: .86rem;
  color: rgba(11,22,36,.82);
}
.sc-maint__body{
  padding: clamp(1.4rem, 3vw, 2.4rem) 0 clamp(2rem, 4vw, 3.2rem);
}
.sc-maint__grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 1rem;
}
.sc-maint__card{
  border-radius: 18px;
  padding: 1.05rem 1.05rem;
  border: 1px solid rgba(11,22,36,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,252,255,.90));
  box-shadow: 0 16px 34px rgba(16,24,40,.09), 0 5px 14px rgba(16,24,40,.05);
  position: relative;
  overflow: hidden;
}
.sc-maint__card::before{
  content: "";
  position: absolute;
  left: 1rem;
  right: 1rem;
  top: 0;
  height: 3px;
  border-radius: 0 0 6px 6px;
  background: linear-gradient(90deg, #86d21d, #1f8cff);
}
.sc-maint__cardTitle{
  margin: 0 0 .48rem 0;
  font-size: 1.08rem;
  letter-spacing: -0.01em;
  font-weight: 950;
}
.sc-maint .sc-text{
  margin: 0;
  color: rgba(11,22,36,.75);
  line-height: 1.66;
}
.sc-maint__band{
  margin-top: 1.1rem;
  border-radius: 18px;
  padding: 1rem 1.05rem;
  border: 1px solid rgba(11,22,36,.12);
  background:
    radial-gradient(580px 260px at 20% 20%, rgba(134,210,29,.16), transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.97), rgba(247,251,255,.92));
  box-shadow: 0 18px 40px rgba(16,24,40,.10), 0 6px 16px rgba(16,24,40,.06);
  color: rgba(11,22,36,.82);
  line-height: 1.6;
}
.sc-maint__band strong{
  margin-right: .35rem;
}
@media (max-width: 980px){
  .sc-maint__grid{
    grid-template-columns: 1fr;
  }
}
