.elementor-383 .elementor-element.elementor-element-36549ce{--display:flex;--min-height:120vh;--margin-top:-20%;--margin-bottom:0%;--margin-left:0%;--margin-right:0%;--padding-top:7%;--padding-bottom:0%;--padding-left:0%;--padding-right:0%;}.elementor-383 .elementor-element.elementor-element-913b2ac{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-383 .elementor-element.elementor-element-a9a9b2c{--display:flex;}.elementor-383 .elementor-element.elementor-element-7991f11{margin:4% 0% calc(var(--kit-widget-spacing, 0px) + 0%) 0%;}@media(min-width:768px){.elementor-383 .elementor-element.elementor-element-a9a9b2c{--content-width:1112px;}}@media(max-width:767px){.elementor-383 .elementor-element.elementor-element-36549ce{--margin-top:-50%;--margin-bottom:0%;--margin-left:0%;--margin-right:0%;--padding-top:15%;--padding-bottom:0%;--padding-left:0%;--padding-right:0%;}.elementor-383 .elementor-element.elementor-element-a9a9b2c{--margin-top:-44%;--margin-bottom:0%;--margin-left:0%;--margin-right:0%;--padding-top:0%;--padding-bottom:0%;--padding-left:0%;--padding-right:0%;}}/* Start custom CSS for html, class: .elementor-element-067e9e6 *//* ============================================================
   HERO
============================================================ */

#hero {
  --ink: #0A0A0A;
  --gold: #E5C361;
  --gold2: #F2D47E;
  --gold3: #C9A84C;
  --white: #FAFAF8;
  --beige: #E8D8BC;
  --beige2: rgba(232,216,188,0.55);
  --muted: rgba(232,216,188,0.38);

  --f-display: 'Cormorant Garamond', serif;
  --f-head: 'Outfit', sans-serif;
  --f-body: 'Inter', sans-serif;

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);

  position: relative;
  min-height: 130vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  padding: 0 1.5rem;
  background: var(--ink);
}

/* Background */
.hero-bg{
  position:absolute;
  inset:0;

  background:
    linear-gradient(
      to bottom,
      rgba(0,0,0,.58),
      rgba(0,0,0,.62)
    ),
    radial-gradient(
      circle at center,
      rgba(229,195,97,.10) 0%,
      transparent 60%
    ),
    url("https://lesbainsdestains.fr/wp-content/uploads/2026/05/bg-section.webp");

  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}
/* Ornament */

.hero-ornament {
  position: absolute;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  border: 1px solid rgba(229,195,97,0.06);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  animation: orbSpin 30s linear infinite;
}

.hero-ornament::before {
  content: '';
  position: absolute;
  width: 500px;
  height: 500px;
  border-radius: 50%;
  border: 1px solid rgba(229,195,97,0.04);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.hero-ornament::after {
  content: '';
  position: absolute;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  border: 1px solid rgba(229,195,97,0.07);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* Star */

.hero-star {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 180px;
  height: 180px;
  opacity: 0.04;
}

.hero-star svg {
  width: 100%;
  height: 100%;
}

/* Content */

.hero-content {
  position: relative;
  z-index: 2;
  max-width: 1000px;
}

.hero-eyebrow {
  font-family: "Great Vibes", cursive;
  font-size: 1.5rem;
  font-style: italic;
  font-weight: 400;
  color: var(--gold);
  letter-spacing: 0.08em;
  margin-bottom: 1.5rem;
}

.hero-h1 {
  font-family: "Sora", sans-serif;
    font-size: clamp(1.4rem, 5vw, 5.5rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.02;
  color: var(--white);
  margin-bottom: 1rem;
}

.gold-word {
  font-family: "Sora", sans-serif;
   font-size: clamp(1.4rem, 5vw, 5.5rem);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  line-height: 1.02;
  color: #E5C361;
  margin-bottom: 1rem;
}

.hero-sub {
  font-family: var(--f-body);
  font-size: clamp(0.88rem, 1.5vw, 1.05rem);
  font-weight: 300;
  color: var(--beige2);
  max-width: 600px;
  line-height: 1.8;
  margin: 1.8rem auto 3rem;
}

/* Buttons */

/* ============================================================
   HERO BUTTONS — PREMIUM STYLE
============================================================ */

.hero-cta-group{
  display:flex;
  gap:1rem;
  justify-content:center;
  flex-wrap:wrap;
}

/* Base */
.btn-gold,
.btn-ghost{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;

  padding:14px 30px;
  border-radius:999px;

  font-family:var(--f-head);
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.18em;
  text-transform:uppercase;
  text-decoration:none;

  overflow:hidden;
  transition:all .4s ease;

  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}

/* ============================================================
   GOLD BUTTON
============================================================ */

.btn-gold{
  color:#0A0A0A;

  background:linear-gradient(
    135deg,
    #F1D98A 0%,
    #E5C361 45%,
    #B8923A 100%
  );

  border:1px solid rgba(229,195,97,.6);

  box-shadow:
    0 8px 24px -8px rgba(229,195,97,.5),
    inset 0 1px 0 rgba(255,255,255,.35);
}

/* Hover */
.btn-gold:hover{
  transform:translateY(-2px);
  filter:brightness(1.06);
}

/* Shine effect */
.btn-gold::before{
  content:"";
  position:absolute;
  top:0;
  left:-120%;
  width:60%;
  height:100%;

  background:linear-gradient(
    110deg,
    transparent 0%,
    rgba(255,255,255,.55) 50%,
    transparent 100%
  );

  transition:left .8s ease;
  pointer-events:none;
}

.btn-gold:hover::before{
  left:130%;
}

/* Fix text layer */
.btn-gold *{
  position:relative;
  z-index:2;
}

.btn-gold,
.btn-gold:visited,
.btn-gold:hover,
.btn-gold:focus,
.btn-gold:active{
  color:#0A0A0A !important;
  text-decoration:none;
}

/* ============================================================
   GHOST BUTTON
============================================================ */

.btn-ghost{
  color:#E5C361;
  background:transparent;
  border:1px solid rgba(229,195,97,.45);
}

.btn-ghost:hover{
  color:#0A0A0A;
  background:#E5C361;
  border-color:#E5C361;

  transform:translateY(-2px);

  box-shadow:
    0 10px 28px -8px rgba(229,195,97,.55);
}

/* ============================================================
   MOBILE
============================================================ */

@media (max-width:600px){

  .hero-cta-group{
    flex-direction:column;
    width:100%;
  }

  .hero-cta-group a{
    width:100%;
  }

  .btn-gold,
  .btn-ghost{
    padding:13px 24px;
    font-size:11px;
  }
}

/* Scroll */

.hero-scroll {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
}

.hero-scroll-text {
  font-family: var(--f-head);
  font-size: 0.58rem;
  letter-spacing: 0.35em;
  text-transform: uppercase;
  color: var(--muted);
}

.hero-scroll-track {
  width: 1px;
  height: 56px;
  background: rgba(229,195,97,0.15);
  position: relative;
  overflow: hidden;
}

.hero-scroll-thumb {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 40%;
  background: linear-gradient(to bottom, var(--gold), transparent);
  animation: scrollDrop 2s ease-in-out infinite;
}

/* Particles */

.particles-hero {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
}

.particle {
  position: absolute;
  width: 2px;
  height: 2px;
  background: var(--gold);
  border-radius: 50%;
  opacity: 0;
  animation: floatParticle linear infinite;
}

/* Animations */

@keyframes orbSpin {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

@keyframes scrollDrop {
  0% { top: -40%; }
  100% { top: 130%; }
}

@keyframes floatParticle {
  0% {
    transform: translateY(110vh) scale(0);
    opacity: 0;
  }

  10% {
    opacity: 0.6;
    transform: translateY(90vh) scale(1);
  }

  90% {
    opacity: 0.2;
  }

  100% {
    transform: translateY(-10vh) scale(0.5);
    opacity: 0;
  }
}

/* Responsive */

@media (max-width: 768px) {
  .hero-h1 {
    font-size: clamp(2.5rem, 12vw, 4rem);
  }

  .hero-ornament {
    width: 500px;
    height: 500px;
  }

  .hero-cta-group {
    flex-direction: column;
    align-items: center;
  }
}
@media (max-width: 768px) {
  .hero-h1 {
    font-size: clamp(2.5rem, 12vw, 4rem);
  }

  .hero-ornament {
    width: 500px;
    height: 500px;
  }

  .hero-cta-group {
    flex-direction: column;
    align-items: center;
  }
}
@media (max-width: 480px){
      #hero{
    min-height:80vh;
    padding:0 1.2rem;
  }


  #hero{
    padding:0 1rem;
  }

  .hero-ornament{
    width:300px;
    height:300px;
  }

  .hero-ornament::before{
    width:200px;
    height:200px;
  }

  .hero-ornament::after{
    width:120px;
    height:120px;
  }

  .hero-star{
    width:75px;
    height:75px;
  }

  .hero-eyebrow{
    font-size:.9rem;
  }

  .hero-h1,
  .gold-word{
    font-size:clamp(1.9rem, 10vw, 2.8rem);
  }

  .hero-sub{
    font-size:.76rem;
    line-height:1.65;
  }

  .btn-gold,
  .btn-ghost{
    padding:12px 16px;
    font-size:.58rem;
  }

  .hero-scroll-track{
    height:34px;
  }
}

.hero-content > *{
  opacity:0;
  transform:translateY(24px);
  animation:fadeUp 1s var(--ease-out) forwards;
}

/* Stagger */
.hero-eyebrow{animation-delay:.15s;}
.hero-h1{animation-delay:.35s;}
.hero-sub{animation-delay:.55s;}
.hero-cta-group{animation-delay:.75s;}

/* Scroll */
.hero-scroll{
  opacity:0;
  transform:translateY(16px);
  animation:fadeUp 1s var(--ease-out) forwards;
  animation-delay:1s;
}

/* Keyframes */
@keyframes fadeUp{
  from{
    opacity:0;
    transform:translateY(24px);
  }

  to{
    opacity:1;
    transform:translateY(0);
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-7991f11 */.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4px;
  min-height:640px;
}

/* LEFT — map panel */
.map-panel{
  position:relative;
  overflow:hidden;
  background:#111111;
}

.map-frame{
  width:100%;
  height:100%;
  min-height:500px;
  position:relative;
}

.map-frame iframe{
  width:100%;
  height:100%;
  border:none;

  transition:filter .6s ease;
}

.map-frame:hover iframe{
  filter:grayscale(60%) contrast(1.05) brightness(.65) sepia(10%);
}

/* Map overlay with address card */
.map-card{
  position:absolute;
  bottom:2rem;
  left:2rem;
  right:2rem;

  background:rgba(10,10,10,.88);

  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);

  border:1px solid rgba(229,195,97,.15);

  padding:1.6rem 2rem;

  display:flex;
  align-items:center;
  gap:1.4rem;
}

.map-pin{
  width:42px;
  height:42px;

  border-radius:50%;
  border:1px solid rgba(229,195,97,.25);

  display:flex;
  align-items:center;
  justify-content:center;

  color:#E5C361;
  font-size:1.1rem;
  flex-shrink:0;
}

.map-addr-label{
  font-family:'Outfit',sans-serif;
  font-size:.58rem;
  letter-spacing:.28em;
  text-transform:uppercase;

  color:rgba(229,195,97,.7);

  margin-bottom:.25rem;
  font-weight:600;
}

.map-addr-val{
  font-family:'Outfit',sans-serif;
  font-size:.9rem;
  font-weight:600;

  color:#FFFFFF;

  letter-spacing:.02em;
  line-height:1.3;
}

.map-addr-city{
  font-size:.78rem;
  color:rgba(255,255,255,.55);

  margin-top:.15rem;
}

.map-cta-link{
  margin-left:auto;

  font-family:'Outfit',sans-serif;
  font-size:.62rem;
  font-weight:700;
  letter-spacing:.16em;
  text-transform:uppercase;

  color:#E5C361;
  text-decoration:none;

  border:1px solid rgba(229,195,97,.2);

  padding:.55rem 1.1rem;

  transition:all .3s ease;

  white-space:nowrap;
  flex-shrink:0;
}

.map-cta-link:hover{
  background:rgba(229,195,97,.07);
  border-color:#E5C361;
  color: white;
}

/* RIGHT — info panel */
.info-panel{
  background:#141414;

  padding:3.5rem;

  display:flex;
  flex-direction:column;
  gap:0;

  border:1px solid rgba(229,195,97,.05);
}

/* ── CONTACT ITEMS ── */
.cinfo-list{
  display:flex;
  flex-direction:column;
  gap:0;

  margin-bottom:3rem;
}

.cinfo-item{
  display:flex;
  align-items:flex-start;
  gap:1.4rem;

  padding:1.6rem 0;

  border-bottom:1px solid rgba(255,255,255,.04);

  transition:background .3s ease;

  position:relative;
}

.cinfo-item:first-child{
  padding-top:0;
}

.cinfo-item:last-child{
  border-bottom:none;
}

.cinfo-icon{
  width:44px;
  height:44px;

  border:1px solid rgba(229,195,97,.15);
  border-radius:50%;

  display:flex;
  align-items:center;
  justify-content:center;

  flex-shrink:0;

  font-size:1rem;
  color:#E5C361;

  transition:all .4s ease;

  background:rgba(229,195,97,.03);
}

.cinfo-item:hover .cinfo-icon{
  border-color:rgba(229,195,97,.4);

  background:rgba(229,195,97,.07);

  box-shadow:0 0 20px rgba(229,195,97,.08);
}

.cinfo-label{
  font-family:'Outfit',sans-serif;
  font-size:.58rem;
  letter-spacing:.28em;
  text-transform:uppercase;

  color:rgba(229,195,97,.7);

  font-weight:600;

  margin-bottom:.3rem;
}

.cinfo-val{
  font-size:.96rem;
  color:#FFFFFF;

  font-weight:400;
  line-height:1.4;
}

.cinfo-val a{
  color:#FFFFFF;
  text-decoration:none;

  transition:color .3s ease;
}

.cinfo-val a:hover{
  color:#E5C361;
}

.cinfo-val-sub{
  font-size:.78rem;
  color:rgba(255,255,255,.55);

  margin-top:.2rem;
}

/* ── SOCIAL STRIP ── */
.social-strip{
  display:flex;
  gap:1px;
}

.social-btn{
  flex:1;

  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;

  gap:.5rem;

  padding:1.4rem 1rem;

  background:#111111;

  border:1px solid rgba(229,195,97,.06);

  text-decoration:none;

  transition:all .4s ease;

  position:relative;
  overflow:hidden;
}

.social-btn::before{
  content:'';

  position:absolute;
  inset:0;

  background:linear-gradient(
    135deg,
    rgba(229,195,97,.07) 0%,
    transparent 60%
  );

  opacity:0;

  transition:opacity .4s ease;
}

.social-btn:hover{
  border-color:rgba(229,195,97,.18);
  transform:translateY(-2px);
}

.social-btn:hover::before{
  opacity:1;
}

.social-icon{
  font-size:1.3rem;
  transition:transform .3s ease;
}

.social-btn:hover .social-icon{
  transform:scale(1.15);
}

.social-name{
  font-family:'Outfit',sans-serif;
  font-size:.58rem;
  font-weight:700;

  letter-spacing:.18em;
  text-transform:uppercase;

  color:rgba(255,255,255,.55);

  transition:color .3s ease;
}

.social-handle{
  font-family:'Outfit',sans-serif;
  font-size:.65rem;
  font-weight:500;

  color:rgba(255,255,255,.42);

  transition:color .3s ease;
}

.social-btn:hover .social-name,
.social-btn:hover .social-handle{
  color:#E5C361;
}
.sec-h2{
  font-family:"Sora", sans-serif;
  text-transform:uppercase;

  background:linear-gradient(
    135deg,
    #F0D27A,
    #E5C361 50%,
    #A8842F
  );

  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.social-icon,
.cinfo-icon i,
.map-pin i{
  color:#E5C361;
}
@media(max-width:900px){
  nav{padding:1.2rem 1.5rem}nav.solid{padding:.9rem 1.5rem}
  .nlinks,.ncta{display:none}.hbg{display:flex}
  .contact-grid{grid-template-columns:1fr}
  .info-panel{padding:2.5rem 1.8rem}
  .map-frame{min-height:380px}
  .sched-layout{grid-template-columns:1fr}
  footer{flex-direction:column;text-align:center;padding:2rem 1.5rem}
  .f-nav{justify-content:center}
  .sticky-bar{display:block}
  body{padding-bottom:72px}
}
@media(max-width:600px){
  .hh1{font-size:clamp(2.4rem,12vw,3.8rem)}
  .map-card{flex-direction:column;gap:1rem;text-align:center}
  .map-cta-link{margin-left:0}
  .sched-header{padding:1.5rem}
  .sched-row{padding:.85rem 1.5rem}
  .cta-watermark{font-size:12rem}
  .cta-btns{flex-direction:column;align-items:center}
  .btn-g,.btn-o{width:100%;max-width:300px;text-align:center}
  .social-strip{flex-wrap:wrap}
  .social-btn{flex:1 1 calc(50% - 1px);min-width:120px}
}
/* ============================================================
   CONTACT SECTION — SOFT FADE UP
============================================================ */

/* ============================================================
   CONTACT SECTION — SLOW FADE UP
============================================================ */

/* ============================================================
   CONTACT SECTION — WORKING FADE UP
============================================================ */

/* IMPORTANT:
   remove any opacity:0 already applied elsewhere
*/

.map-panel,
.info-panel,
.cinfo-item,
.social-btn{
  animation:fadeUpSoft 1.4s cubic-bezier(0.16, 1, 0.3, 1) both;
}

/* Stagger */
.map-panel{animation-delay:.1s;}
.info-panel{animation-delay:.3s;}

.cinfo-item:nth-child(1){animation-delay:.5s;}
.cinfo-item:nth-child(2){animation-delay:.7s;}
.cinfo-item:nth-child(3){animation-delay:.9s;}
.cinfo-item:nth-child(4){animation-delay:1.1s;}

.social-btn:nth-child(1){animation-delay:1.3s;}
.social-btn:nth-child(2){animation-delay:1.45s;}
.social-btn:nth-child(3){animation-delay:1.6s;}
.social-btn:nth-child(4){animation-delay:1.75s;}

/* Keyframes */
@keyframes fadeUpSoft{
  from{
    opacity:0;
    transform:translateY(40px);
  }

  to{
    opacity:1;
    transform:translateY(0);
  }
}/* End custom CSS */